• 0
Mironchik

[закрыто] Ошибка public OnDialogResponse, public OnIncomingPacket

Вопросы

Пишу команду (меню доната - коинов) и крашит сервер

 

[10:12:25] [debug] Server crashed while executing new.amx
[10:12:25] [debug] AMX backtrace:
[10:12:25] [debug] #0 00000014 in public OnDialogResponse (playerid=0, dialogid=271, response=1, listitem=2, inputtext[]=@017b5b8c "3. ") at C:\Users\fanti\OneDrive\Desktop\Мод 6.1\gamemodes\new.pwn:13
[10:12:25] [debug] #1 00bcb0c8 in public OnIncomingPacket () at C:\Users\fanti\OneDrive\Desktop\Мод 6.1\gamemodes\new.pwn:57310

 

Спойлер

public OnDialogResponse(playerid, dialogid, response, listitem, inputtext[])
{
    if(strcmp(inputtext, "#", true) == 0 || strcmp(inputtext, "|", true) == 0 || strcmp(inputtext, "%", true) == 0 || strcmp(inputtext, "@", true) == 0 || strcmp(inputtext, "&", true) == 0)
    {
         SCM(playerid, -1, ".");
    }
    if(strfind(inputtext,"%") != -1)
    {
        return SendClientMessage(playerid, 0xFF6600FF, "В сообщение присутствуют запрещеные символы");
    }
    switch(dialogid)
    {
            case DIALOG_OWNABLE_TRAILER:
        {
            if(response)
            {
                new vehicleid = GetPlayerOwnableTrailerListitem(playerid);
                new index = GetVehicleData(vehicleid, V_ACTION_ID);
                if(vehicleid != INVALID_VEHICLE_ID)
                {
                    switch(listitem + 1)
                    {
                        case 1: // Открыть / закрыть
                        {
                            if(!IsPlayerInAnyVehicle(playerid))
                                return SendClientMessage(playerid, 0xCECECEFF, "Вы должны находиться в транспорте");


                            if(GetPlayerOwnableCars(playerid) == 0)
                                return SendClientMessage(playerid, 0xCECECEFF, "Вы должны находиться в личном транспорте");


                            new Float:pX,Float:pY,Float:pZ;
                            GetPlayerPos(playerid,pX,pY,pZ);
                            new Float:vX,Float:vY,Float:vZ;
                            GetVehiclePos(vehicleid,vX,vY,vZ);
                            if ((floatabs(pX-vX)<12.0)&&(floatabs(pY-vY)<12.0)&&(floatabs(pZ-vZ)<12.0)&& (vehicleid!=GetPlayerVehicleID(playerid)))
                            {
                                if(IsTrailerAttachedToVehicle(GetPlayerVehicleID(playerid)))
                                {
                                    DetachTrailerFromVehicle(GetPlayerVehicleID(playerid));
                                    GetVehiclePos(vehicleid, GetOwnableTrailerData(index, OT_POS_X), GetOwnableTrailerData(index, OT_POS_Y), GetOwnableTrailerData(index, OT_POS_Z));
                                    GetVehicleZAngle(vehicleid, GetOwnableTrailerData(index, OT_ANGLE));

                                    SaveOwnableTrailer(vehicleid);
                                }
                                else
                                {
                                    AttachTrailerToVehicle(vehicleid,GetPlayerVehicleID(playerid));
                                }
                            }
                            else SendClientMessage(playerid, 0x999999FF, "Вы должны находится возле дома на колёсах");
                            SetPVarInt(playerid, "go_list", 1);
                            //callcmd::lock(playerid, "1");
                        }
                        case 2: // Вставить / вытащить ключи
                        {
                            SetPVarInt(playerid, "go_list", 1);
                            if(vehicleid != INVALID_VEHICLE_ID)
                            {
                                new price = 5000;

                                if(GetPlayerGPSInfo(playerid, G_ENABLED) == GPS_STATUS_OFF)
                                {
                                    if(GetPlayerMoneyEx(playerid) >= price)
                                    {
                                        GivePlayerMoneyEx(playerid, -price, "Метка ТС на GPS", true, true);

                                        new Float: x, Float: y, Float: z;
                                        GetVehiclePos(vehicleid, x, y, z);

                                        EnablePlayerGPS(playerid, 55, x, y, z, "Местоположение Вашего транспорта отмечено на GPS");
                                        return 1;
                                    }
                                    else SendClientMessage(playerid, 0x999999FF, "Недостаточно денег");
                                }
                                else SendClientMessage(playerid, 0xCECECEFF, "На Вашем GPS уже отмечено место");
                            }
                        }
                        case 3: // Отметить транспорт на GPS
                        {
                            SetPVarInt(playerid, "go_list", 1);
                            if(DestroyOwnableTrailer(vehicleid))
                            {
                                new fmt_str[128];

                                new car_price = 1400000;
                                new percent = car_price * 20 / 100;
                                new price = car_price - percent;

                                SetPlayerTrailerData(playerid, GetPVarInt(playerid, "listitem_trailer"), INVALID_VEHICLE_ID);
                                AddPlayerData(playerid, P_BANK, +, price);

                                BankLog(playerid, price, "Продажа личного транспорта");

                                format(fmt_str, sizeof fmt_str, "UPDATE accounts SET bank=%d WHERE id=%d LIMIT 1", GetPlayerBankMoney(playerid), GetPlayerAccountID(playerid));
                                mysql_query(mysql, fmt_str, false);

                                SendClientMessage(playerid, 0x3399FFFF, "Вы продали личный дом на колёсах");

                                format(fmt_str, sizeof fmt_str, "Налоговый сбор составляет 30 процентов от его стоимости {FF9900}(%d руб)", percent);
                                SendClientMessage(playerid, 0xFFFFFFFF, fmt_str);

                                format(fmt_str, sizeof fmt_str, "На основной банковский счет переведено {FFFF00}%d руб", price);
                                SendClientMessage(playerid, 0x66CC00FF, fmt_str);

                                format(fmt_str, sizeof fmt_str, "~g~+%d rub", price);
                                GameText(playerid, fmt_str, 4000, 2);
                            }
                        }
                        case 4: // Содержимое багажника
                        {
                            SetVehiclePos(vehicleid, GetOwnableTrailerData(index,OT_POS_X), GetOwnableTrailerData(index,OT_POS_Y), GetOwnableTrailerData(index,OT_POS_Z));
                            SetVehicleZAngle(vehicleid, GetOwnableTrailerData(index, OT_ANGLE));
                        }
                        case 5: // Выгрузить транспорт
                        {
                            if(UnloadPlayerOwnableTrailer(playerid, GetPVarInt(playerid, "listitem_trailer")))
                                SendClientMessage(playerid, 0x66CC33FF, "Ваш трейлер успешно выгружен!");

                            else
                                SendClientMessage(playerid, 0x999999FF, "С момента загрузки данного трейлера еще не прошло 1 минуты");
                        }
                        default:
                            return 1;
                    }
                    //callcmd::car(playerid, "");
                }
            }
        }

 

Спойлер

public OnDialogResponse(playerid, dialogid, response, listitem, inputtext[])
{
    if(strcmp(inputtext, "#", true) == 0 || strcmp(inputtext, "|", true) == 0 || strcmp(inputtext, "%", true) == 0 || strcmp(inputtext, "@", true) == 0 || strcmp(inputtext, "&", true) == 0)
    {
         SCM(playerid, -1, ".");
    }
    if(strfind(inputtext,"%") != -1)
    {
        return SendClientMessage(playerid, 0xFF6600FF, "В сообщение присутствуют запрещеные символы");
    }
    switch(dialogid)
    {
            case DIALOG_OWNABLE_TRAILER:
        {
            if(response)
            {
                new vehicleid = GetPlayerOwnableTrailerListitem(playerid);
                new index = GetVehicleData(vehicleid, V_ACTION_ID);
                if(vehicleid != INVALID_VEHICLE_ID)
                {
                    switch(listitem + 1)
                    {
                        case 1: // Открыть / закрыть
                        {
                            if(!IsPlayerInAnyVehicle(playerid))
                                return SendClientMessage(playerid, 0xCECECEFF, "Вы должны находиться в транспорте");


                            if(GetPlayerOwnableCars(playerid) == 0)
                                return SendClientMessage(playerid, 0xCECECEFF, "Вы должны находиться в личном транспорте");


                            new Float:pX,Float:pY,Float:pZ;
                            GetPlayerPos(playerid,pX,pY,pZ);
                            new Float:vX,Float:vY,Float:vZ;
                            GetVehiclePos(vehicleid,vX,vY,vZ);
                            if ((floatabs(pX-vX)<12.0)&&(floatabs(pY-vY)<12.0)&&(floatabs(pZ-vZ)<12.0)&& (vehicleid!=GetPlayerVehicleID(playerid)))
                            {
                                if(IsTrailerAttachedToVehicle(GetPlayerVehicleID(playerid)))
                                {
                                    DetachTrailerFromVehicle(GetPlayerVehicleID(playerid));
                                    GetVehiclePos(vehicleid, GetOwnableTrailerData(index, OT_POS_X), GetOwnableTrailerData(index, OT_POS_Y), GetOwnableTrailerData(index, OT_POS_Z));
                                    GetVehicleZAngle(vehicleid, GetOwnableTrailerData(index, OT_ANGLE));

                                    SaveOwnableTrailer(vehicleid);
                                }
                                else
                                {
                                    AttachTrailerToVehicle(vehicleid,GetPlayerVehicleID(playerid));
                                }
                            }
                            else SendClientMessage(playerid, 0x999999FF, "Вы должны находится возле дома на колёсах");
                            SetPVarInt(playerid, "go_list", 1);
                            //callcmd::lock(playerid, "1");
                        }
                        case 2: // Вставить / вытащить ключи
                        {
                            SetPVarInt(playerid, "go_list", 1);
                            if(vehicleid != INVALID_VEHICLE_ID)
                            {
                                new price = 5000;

                                if(GetPlayerGPSInfo(playerid, G_ENABLED) == GPS_STATUS_OFF)
                                {
                                    if(GetPlayerMoneyEx(playerid) >= price)
                                    {
                                        GivePlayerMoneyEx(playerid, -price, "Метка ТС на GPS", true, true);

                                        new Float: x, Float: y, Float: z;
                                        GetVehiclePos(vehicleid, x, y, z);

                                        EnablePlayerGPS(playerid, 55, x, y, z, "Местоположение Вашего транспорта отмечено на GPS");
                                        return 1;
                                    }
                                    else SendClientMessage(playerid, 0x999999FF, "Недостаточно денег");
                                }
                                else SendClientMessage(playerid, 0xCECECEFF, "На Вашем GPS уже отмечено место");
                            }
                        }
                        case 3: // Отметить транспорт на GPS
                        {
                            SetPVarInt(playerid, "go_list", 1);
                            if(DestroyOwnableTrailer(vehicleid))
                            {
                                new fmt_str[128];

                                new car_price = 1400000;
                                new percent = car_price * 20 / 100;
                                new price = car_price - percent;

                                SetPlayerTrailerData(playerid, GetPVarInt(playerid, "listitem_trailer"), INVALID_VEHICLE_ID);
                                AddPlayerData(playerid, P_BANK, +, price);

                                BankLog(playerid, price, "Продажа личного транспорта");

                                format(fmt_str, sizeof fmt_str, "UPDATE accounts SET bank=%d WHERE id=%d LIMIT 1", GetPlayerBankMoney(playerid), GetPlayerAccountID(playerid));
                                mysql_query(mysql, fmt_str, false);

                                SendClientMessage(playerid, 0x3399FFFF, "Вы продали личный дом на колёсах");

                                format(fmt_str, sizeof fmt_str, "Налоговый сбор составляет 30 процентов от его стоимости {FF9900}(%d руб)", percent);
                                SendClientMessage(playerid, 0xFFFFFFFF, fmt_str);

                                format(fmt_str, sizeof fmt_str, "На основной банковский счет переведено {FFFF00}%d руб", price);
                                SendClientMessage(playerid, 0x66CC00FF, fmt_str);

                                format(fmt_str, sizeof fmt_str, "~g~+%d rub", price);
                                GameText(playerid, fmt_str, 4000, 2);
                            }
                        }
                        case 4: // Содержимое багажника
                        {
                            SetVehiclePos(vehicleid, GetOwnableTrailerData(index,OT_POS_X), GetOwnableTrailerData(index,OT_POS_Y), GetOwnableTrailerData(index,OT_POS_Z));
                            SetVehicleZAngle(vehicleid, GetOwnableTrailerData(index, OT_ANGLE));
                        }
                        case 5: // Выгрузить транспорт
                        {
                            if(UnloadPlayerOwnableTrailer(playerid, GetPVarInt(playerid, "listitem_trailer")))
                                SendClientMessage(playerid, 0x66CC33FF, "Ваш трейлер успешно выгружен!");

                            else
                                SendClientMessage(playerid, 0x999999FF, "С момента загрузки данного трейлера еще не прошло 1 минуты");
                        }
                        default:
                            return 1;
                    }
                    //callcmd::car(playerid, "");
                }
            }
        }

 

 

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

1 ответ на этот вопрос

  • 0

@Mironchik прикрепите полный лог, не нужно обрезать его. 

И выделите строчки, которые показаны в сообщении лога 

2 часа назад, Mironchik сказал:

at C:\Users\fanti\OneDrive\Desktop\Мод 6.1\gamemodes\new.pwn:57310

 

2 часа назад, Mironchik сказал:

at C:\Users\fanti\OneDrive\Desktop\Мод 6.1\gamemodes\new.pwn:13

 

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты
Гость
Эта тема закрыта для публикации ответов.

  • Последние посетители   0 пользователей онлайн

    Ни одного зарегистрированного пользователя не просматривает данную страницу

  • Похожий контент

    • Mister Odin
      От Mister Odin
       
      new
       g_teleport_list[39][E_TELEPORT_LIST] = {  {"Спавн пгт.Батырево", 1802.3612, 2508.4824, 15.8887},  {"Спавн г.Арзамас", -113.5887, 977.7222, 12.0346},     {"Спавн г.Южный", 2744.2770, -2446.7246, 21.8988},     {"Центральный банк", 1852.020385,2040.791381,15.892713},  {"Рублёвка", -837.7783, 888.6161, 12.7232},  {"Казино", 1332.4252, 2358.7014, 17.6641},  {"Битва за контейнеры", 614.5167, 1722.3566, 12.0709},  {"Автосалон низкого класса", 2493.9616, -722.9544, 12.3315},  {"Автосалон среднего класса", 1407.7449, 455.4801, 13.1630},  {"Автосалон высокого класса", -14.0637, 2614.5664, 10.9892},   {"Мотосалон Harley Davidson", 785.720153, 750.465087, 12.000024},  {"Автошкола", 1909.174438,2227.679687,15.708162},  {"Военкомат", 1916.778564,2302.411376,15.574637},  {"Правительство области", -139.140975,593.789611,12.145712},  {"Отдел полиции №1 (ГИБДД)", 1906.805786,-2234.382812,11.257631},  {"Отдел полиции №2 (УМВД)", 2581.309326,-2416.139892,21.960090},  {"Отдел ФСБ", 1823.904663,2095.636718,15.848405},  {"Городская больница г.Арзамас", -285.797210,581.851562,12.120290},   {"СМИ", -317.708038,821.221679,13.051450},  {"Воинская часть", 1703.197265,1678.025878,15.279437},  {"Арзамасская ОПГ", 438.705322,1046.505126,12.002637},  {"Батыревская ОПГ", 1941.203857,2161.006591,15.705187},  {"Лыткаринская ОПГ", -2346.002441,75.257041,21.002962},  {"Шахта", 2381.5727, 1726.4451, -2.1506},  {"Завод", -1062.6697, 2204.1894, 38.0964},  {"Инкосация", 1864.1374, 2011.7136, 15.8546},  {"Транспортная Компания", 2362.1115, 1972.5627, 15.5530},  {"База механиков", 1840.918090,-118.025146,15.695312},  {"Курьерская служба доставки", 2764.509765,-2396.882568,21.890625},  {"Аренда автобуса(Южный)", 2771.041992,-2454.780761,21.845964},  {"Аренда автобуса(Арзамас)", -127.487670,943.652648,12.142824},   {"Аренда автобуса(Батырево)", 1798.986328,2529.591552,15.664262},  {"Гоночная трасса", -1568.7784, 1611.8305, 36.3971},  {"Дом на горе", -789.5397, -456.7479, 741.1422},  {"СТО и тюнинг-ателье", 1856.1375, -122.3266, 15.6888},  {"Аренда транспорта пгт.Батырево", 1763.641723,2255.673339,15.865348},  {"Аренда транспорта г.Арзамас", -36.923530,1360.673583,12.002090},  {"Аренда транспорта г.Южный", 1966.599975,-2603.943603,10.820312},  {"Тайный интерьер в Лыткарино", -2424.5818, 2846.3291, 40.7908} };