server crashes when using this filterscript
#1

got these errors from Crashdetect.so with House.amx right before it crashes
Код:
1:00] [debug] #0  00000c6c in OnPlayerEnterCheckpoint () from House.amx
[10:21:00] [debug] Backtrace (most recent call first):
[10:21:00] [debug] Server crashed while executing House.amx
[10:20:58] [debug] #1  00028714 in OnDialogResponse () from House.amx
[10:20:58] [debug] #0  00014d10 in ?? () from House.amx
[10:20:58] [debug] Backtrace (most recent call first):
[10:20:58] [debug]   Accessing element at negative index -1
[10:20:58] [debug] Run time error 4: "Array index out of bounds"
and here is OnPlayerEnterCheckpoint
pawn Код:
public OnPlayerEnterCheckpoint(playerid, checkpointid)
{
    if(GetPlayerState(playerid) == PLAYER_STATE_ONFOOT)
    {
        new string[256], tmpstring[50];
        foreach(Houses, h)
        {
            if(checkpointid == HouseCPOut[h])
            {
                new WantedInHouse;
                for(new i=0;i<MAX_PLAYERS;i++)
                {
                    if(GetPVarInt(i, "LastHouseCP") == h && (GetPlayerWantedLevel(i) > 0))WantedInHouse=1;
                }
                if(IsCop(playerid))
                {
                    if(WantedInHouse==1)
                    {
                        SetPVarInt(playerid, "LastHouseCP", h);
                        if(!strcmp(hInfo[h][HouseOwner], pNick(playerid), CASE_SENSETIVE) || GetPVarInt(playerid,"AdminMode")==1)
                        {
                            SetPlayerHouseInterior(playerid, h);
                            SendClientMessage(playerid,COLOR_CYAN,"Type /housemenu to access the house menu!");
                            break;
                        }
                        format(tmpstring, sizeof(tmpstring), "HouseKeys_%d", h);
                        if(GetPVarInt(playerid, tmpstring) == 1)
                        {
                            SetPlayerHouseInterior(playerid, h);
                            break;
                        }
                        if(strcmp(hInfo[h][HouseOwner], pNick(playerid), CASE_SENSETIVE) && strcmp(hInfo[h][HouseOwner], INVALID_HOWNER_NAME, CASE_SENSETIVE))
                        {
                            if(hInfo[h][HousePassword] == udb_hash("INVALID_HOUSE_PASSWORD"))
                            {
                                switch(hInfo[h][ForSale])
                                {
                                    case 0: ShowInfoBox(playerid, LABELTEXT2, hInfo[h][HouseName], hInfo[h][HouseOwner], hInfo[h][HouseValue], h);
                                    case 1: ShowPlayerDialog(playerid, HOUSEMENU+23, DIALOG_STYLE_LIST, INFORMATION_HEADER, "Buy House (Step 1)\nBreak Down Door", "Select", "Cancel");
                                }
                                break;
                            }
                            if(hInfo[h][HousePassword] != udb_hash("INVALID_HOUSE_PASSWORD"))
                            {
                                switch(hInfo[h][ForSale])
                                {
                                    case 0: ShowPlayerDialog(playerid, HOUSEMENU+28, DIALOG_STYLE_LIST, INFORMATION_HEADER, "Enter House Using Password\nBreak Down Door", "Select", "Cancel");
                                    case 1: ShowPlayerDialog(playerid, HOUSEMENU+23, DIALOG_STYLE_LIST, INFORMATION_HEADER, "Buy House (Step 1)\nBreak Down Door", "Select", "Cancel");
                                }
                                break;
                            }
                        }
                        if(!strcmp(hInfo[h][HouseOwner], INVALID_HOWNER_NAME, CASE_SENSETIVE) && hInfo[h][HouseValue] > 0 && GetPVarInt(playerid, "JustCreatedHouse") == 0)
                        {
                            format(string, sizeof(string), HMENU_BUY_HOUSE, hInfo[h][HouseValue]);
                            ShowPlayerDialog(playerid, HOUSEMENU+4, DIALOG_STYLE_MSGBOX, INFORMATION_HEADER, string, "Buy", "Cancel");
                            break;
                        }
                    }
                    else
                    {
                        SetPVarInt(playerid, "LastHouseCP", h);
                        if(!strcmp(hInfo[h][HouseOwner], pNick(playerid), CASE_SENSETIVE))
                        {
                            SetPlayerHouseInterior(playerid, h);
                            SendClientMessage(playerid,COLOR_CYAN,"Type /housemenu to access the house menu!");
                            //ShowInfoBoxEx(playerid, COLOUR_INFO, I_HMENU);
                            break;
                        }
                        format(tmpstring, sizeof(tmpstring), "HouseKeys_%d", h);
                        if(GetPVarInt(playerid, tmpstring) == 1)
                        {
                            SetPlayerHouseInterior(playerid, h);
                            break;
                        }
                        if(strcmp(hInfo[h][HouseOwner], pNick(playerid), CASE_SENSETIVE) && strcmp(hInfo[h][HouseOwner], INVALID_HOWNER_NAME, CASE_SENSETIVE))
                        {
                            if(hInfo[h][HousePassword] == udb_hash("INVALID_HOUSE_PASSWORD"))
                            {
                                switch(hInfo[h][ForSale])
                                {
                                    case 0: ShowInfoBox(playerid, LABELTEXT2, hInfo[h][HouseName], hInfo[h][HouseOwner], hInfo[h][HouseValue], h);
                                    case 1:
                                    {
                                        switch(hInfo[h][HousePrivacy])
                                        {
                                            case 0: ShowPlayerDialog(playerid, HOUSEMENU+23, DIALOG_STYLE_LIST, INFORMATION_HEADER, "Buy House (Step 1)", "Select", "Cancel");
                                            case 1: ShowPlayerDialog(playerid, HOUSEMENU+23, DIALOG_STYLE_LIST, INFORMATION_HEADER, "Buy House (Step 1)\nEnter House", "Select", "Cancel");
                                        }
                                    }
                                }
                                break;
                            }
                            if(hInfo[h][HousePassword] != udb_hash("INVALID_HOUSE_PASSWORD"))
                            {
                                switch(hInfo[h][ForSale])
                                {
                                    case 0:
                                    {
                                        switch(hInfo[h][HousePrivacy])
                                        {
                                            case 0: ShowPlayerDialog(playerid, HOUSEMENU+28, DIALOG_STYLE_LIST, INFORMATION_HEADER, "Enter House Using Password", "Select", "Cancel");
                                            case 1: ShowPlayerDialog(playerid, HOUSEMENU+28, DIALOG_STYLE_LIST, INFORMATION_HEADER, "Enter House Using Password\nEnter House", "Select", "Cancel");
                                        }
                                    }
                                    case 1: ShowPlayerDialog(playerid, HOUSEMENU+23, DIALOG_STYLE_LIST, INFORMATION_HEADER, "Buy House (Step 1)\nEnter House", "Select", "Cancel");
                                }
                                break;
                            }
                        }
                        if(!strcmp(hInfo[h][HouseOwner], INVALID_HOWNER_NAME, CASE_SENSETIVE) && hInfo[h][HouseValue] > 0 && GetPVarInt(playerid, "JustCreatedHouse") == 0)
                        {
                            format(string, sizeof(string), HMENU_BUY_HOUSE, hInfo[h][HouseValue]);
                            ShowPlayerDialog(playerid, HOUSEMENU+4, DIALOG_STYLE_MSGBOX, INFORMATION_HEADER, string, "Buy", "Cancel");
                            break;
                        }
                    }
                }
                else
                {
                    if(IsCop(playerid))
                    {
                        SetPVarInt(playerid, "LastHouseCP", h);
                        if(!strcmp(hInfo[h][HouseOwner], pNick(playerid), CASE_SENSETIVE))
                        {
                            SetPlayerHouseInterior(playerid, h);
                            SendClientMessage(playerid,COLOR_CYAN,"Type /housemenu to access the house menu!");
                            //ShowInfoBoxEx(playerid, COLOUR_INFO, I_HMENU);
                            break;
                        }
                        format(tmpstring, sizeof(tmpstring), "HouseKeys_%d", h);
                        if(GetPVarInt(playerid, tmpstring) == 1)
                        {
                            SetPlayerHouseInterior(playerid, h);
                            break;
                        }
                        if(strcmp(hInfo[h][HouseOwner], pNick(playerid), CASE_SENSETIVE) && strcmp(hInfo[h][HouseOwner], INVALID_HOWNER_NAME, CASE_SENSETIVE))
                        {
                            if(hInfo[h][HousePassword] == udb_hash("INVALID_HOUSE_PASSWORD"))
                            {
                                switch(hInfo[h][ForSale])
                                {
                                    case 0: ShowInfoBox(playerid, LABELTEXT2, hInfo[h][HouseName], hInfo[h][HouseOwner], hInfo[h][HouseValue], h);
                                    case 1:
                                    {
                                        switch(hInfo[h][HousePrivacy])
                                        {
                                            case 0: ShowPlayerDialog(playerid, HOUSEMENU+23, DIALOG_STYLE_LIST, INFORMATION_HEADER, "Buy House (Step 1)", "Select", "Cancel");
                                            case 1: ShowPlayerDialog(playerid, HOUSEMENU+23, DIALOG_STYLE_LIST, INFORMATION_HEADER, "Buy House (Step 1)\nEnter House", "Select", "Cancel");
                                        }
                                    }
                                }
                                break;
                            }
                            if(hInfo[h][HousePassword] != udb_hash("INVALID_HOUSE_PASSWORD"))
                            {
                                switch(hInfo[h][ForSale])
                                {
                                    case 0:
                                    {
                                        switch(hInfo[h][HousePrivacy])
                                        {
                                            case 0: ShowPlayerDialog(playerid, HOUSEMENU+28, DIALOG_STYLE_LIST, INFORMATION_HEADER, "Enter House Using Password", "Select", "Cancel");
                                            case 1: ShowPlayerDialog(playerid, HOUSEMENU+28, DIALOG_STYLE_LIST, INFORMATION_HEADER, "Enter House Using Password\nEnter House", "Select", "Cancel");
                                        }
                                    }
                                    case 1: ShowPlayerDialog(playerid, HOUSEMENU+23, DIALOG_STYLE_LIST, INFORMATION_HEADER, "Buy House (Step 1)\nEnter House", "Select", "Cancel");
                                }
                                break;
                            }
                        }
                        if(!strcmp(hInfo[h][HouseOwner], INVALID_HOWNER_NAME, CASE_SENSETIVE) && hInfo[h][HouseValue] > 0 && GetPVarInt(playerid, "JustCreatedHouse") == 0)
                        {
                            format(string, sizeof(string), HMENU_BUY_HOUSE, hInfo[h][HouseValue]);
                            ShowPlayerDialog(playerid, HOUSEMENU+4, DIALOG_STYLE_MSGBOX, INFORMATION_HEADER, string, "Buy", "Cancel");
                            break;
                        }
                    }
                    else
                    {
                        SetPVarInt(playerid, "LastHouseCP", h);
                        if(!strcmp(hInfo[h][HouseOwner], pNick(playerid), CASE_SENSETIVE))
                        {
                            SetPlayerHouseInterior(playerid, h);
                            SendClientMessage(playerid,COLOR_CYAN,"Type /housemenu to access the house menu!");
                            //ShowInfoBoxEx(playerid, COLOUR_INFO, I_HMENU);
                            break;
                        }
                        format(tmpstring, sizeof(tmpstring), "HouseKeys_%d", h);
                        if(GetPVarInt(playerid, tmpstring) == 1)
                        {
                            SetPlayerHouseInterior(playerid, h);
                            break;
                        }
                        if(strcmp(hInfo[h][HouseOwner], pNick(playerid), CASE_SENSETIVE) && strcmp(hInfo[h][HouseOwner], INVALID_HOWNER_NAME, CASE_SENSETIVE))
                        {
                            if(hInfo[h][HousePassword] == udb_hash("INVALID_HOUSE_PASSWORD"))
                            {
                                switch(hInfo[h][ForSale])
                                {
                                    case 0: ShowInfoBox(playerid, LABELTEXT2, hInfo[h][HouseName], hInfo[h][HouseOwner], hInfo[h][HouseValue], h);
                                    case 1:
                                    {
                                        switch(hInfo[h][HousePrivacy])
                                        {
                                            case 0: ShowPlayerDialog(playerid, HOUSEMENU+23, DIALOG_STYLE_LIST, INFORMATION_HEADER, "Buy House (Step 1)\nBreak In", "Select", "Cancel");
                                            case 1: ShowPlayerDialog(playerid, HOUSEMENU+23, DIALOG_STYLE_LIST, INFORMATION_HEADER, "Buy House (Step 1)\nBreak In\nEnter House", "Select", "Cancel");
                                        }
                                    }
                                }
                                break;
                            }
                            if(hInfo[h][HousePassword] != udb_hash("INVALID_HOUSE_PASSWORD"))
                            {
                                switch(hInfo[h][ForSale])
                                {
                                    case 0:
                                    {
                                        switch(hInfo[h][HousePrivacy])
                                        {
                                            case 0: ShowPlayerDialog(playerid, HOUSEMENU+28, DIALOG_STYLE_LIST, INFORMATION_HEADER, "Enter House Using Password\nBreak In", "Select", "Cancel");
                                            case 1: ShowPlayerDialog(playerid, HOUSEMENU+28, DIALOG_STYLE_LIST, INFORMATION_HEADER, "Enter House Using Password\nBreak In\nEnter House", "Select", "Cancel");
                                        }
                                    }
                                    case 1: ShowPlayerDialog(playerid, HOUSEMENU+23, DIALOG_STYLE_LIST, INFORMATION_HEADER, "Buy House (Step 1)\nBreak In\nEnter House", "Select", "Cancel");
                                }
                                break;
                            }
                        }
                        if(!strcmp(hInfo[h][HouseOwner], INVALID_HOWNER_NAME, CASE_SENSETIVE) && hInfo[h][HouseValue] > 0 && GetPVarInt(playerid, "JustCreatedHouse") == 0)
                        {
                            format(string, sizeof(string), HMENU_BUY_HOUSE, hInfo[h][HouseValue]);
                            ShowPlayerDialog(playerid, HOUSEMENU+4, DIALOG_STYLE_MSGBOX, INFORMATION_HEADER, string, "Buy", "Cancel");
                            break;
                        }
                    }
                }
            }
            if(checkpointid == HouseCPInt[h])
            {
                switch(GetPVarInt(playerid, "HousePreview"))
                {
                    case 0: ExitHouse(playerid, h);
                    #if GH_HINTERIOR_UPGRADE == true
                    case 1:
                    {
                        GetPVarString(playerid, "HousePrevName", tmpstring, 50);
                        format(string, sizeof(string), HMENU_BUY_HINTERIOR, tmpstring, GetPVarInt(playerid, "HousePrevValue"));
                        ShowPlayerDialog(playerid, HOUSEMENU+17, DIALOG_STYLE_MSGBOX, INFORMATION_HEADER, string, "Buy", "Cancel");
                    }
                    #endif
                }
                break;
            }
        }
    }
    return 1;
}
Reply


Messages In This Thread
server crashes when using this filterscript - by vvhy - 19.07.2012, 14:30
Re: server crashes when using this filterscript - by SA-MPDrifter - 19.07.2012, 14:44
Re: server crashes when using this filterscript - by vvhy - 19.07.2012, 14:51
Re: server crashes when using this filterscript - by vvhy - 19.07.2012, 16:01

Forum Jump:


Users browsing this thread: 1 Guest(s)