Правила форума Гаранты форума
Размещение рекламы AMX-X компилятор

Здравствуйте, гость Вход | Регистрация

Наши новости:

14-дек
24-апр
10-апр
11-апр

Ошибка в плагине VIP

Статус пользователя mysubcult
сообщение 18.11.2013, 17:06
Сообщение #1
Стаж: 12 лет

Сообщений: 382
Благодарностей: 28
Полезность: 86

Народ, всем доброго времени суток, помогите пожалуйста исправить плагин, а то уж именно он мне очень нравится, а посмотрел логи и там он выдает ошибки.
Скрытый текст
Код
L 11/18/2013 - 18:58:58: [AMXX] Displaying debug trace (plugin "Vip_weapon.amxx")
L 11/18/2013 - 18:58:58: [AMXX] Run time error 10: native error (native "message_begin")
L 11/18/2013 - 18:58:58: [AMXX]    [0] Vip_weapon.sma::ChatColor (line 238)
L 11/18/2013 - 18:58:58: [AMXX]    [1] Vip_weapon.sma::show_vipmenu (line 149)

До того, как я приписал debug после плагина, он выдавал вот еще что:
Скрытый текст
Код
L 11/18/2013 - 16:20:25: Plugin called message_begin with an invalid message id (0).
L 11/18/2013 - 16:20:25: [AMXX] Displaying debug trace (plugin "Vip_weapon.amxx")
L 11/18/2013 - 16:20:25: [AMXX] Run time error 10: native error (native "message_begin")
L 11/18/2013 - 16:20:25: [AMXX]    [0] Vip_weapon.sma::ChatColor (line 238)
L 11/18/2013 - 16:20:25: [AMXX]    [1] Vip_weapon.sma::show_vipmenu (line 109)
L 11/18/2013 - 16:20:28: Plugin called message_begin with an invalid message id (0).
L 11/18/2013 - 16:20:28: [AMXX] Displaying debug trace (plugin "Vip_weapon.amxx")
L 11/18/2013 - 16:20:28: [AMXX] Run time error 10: native error (native "message_begin")
L 11/18/2013 - 16:20:28: [AMXX]    [0] Vip_weapon.sma::ChatColor (line 238)
L 11/18/2013 - 16:20:28: [AMXX]    [1] Vip_weapon.sma::show_vipmenu (line 109)

А вот собственно сам плагин:
Скрытый текст
Код
/**
*       Modified by Safety1st
*         11/13/2013
*
*       Changes are:
*       - VIP tag is assigned for VIPs on every map
*       - added reset for round counter after Game Commencing / Game Restart
*       - some small fixes and optimizations
*/

#include <amxmodx>
#include <amxmisc>
#include <cstrike>
#include <fun>
#include <fakemeta_util>

#define VIP_FLAG ADMIN_LEVEL_D

new pistols[5] = {CSW_P228, CSW_ELITE, CSW_FIVESEVEN, CSW_USP, CSW_GLOCK18}

const PRIMARY_WEAPONS_BIT_SUM = (1<<CSW_SCOUT)|(1<<CSW_XM1014)|(1<<CSW_MAC10)|(1<<CSW_AUG)|(1<<CSW_UMP45)|(1<<CSW_SG550)|(1<<CSW_GALIL)|(1<<CSW_FAMAS)|(1<<CSW_AWP)|(1<<
CSW_MP5NAVY)|(1<<CSW_M249)|(1<<CSW_M3)|(1<<CSW_M4A1)|(1<<CSW_TMP)|(1<<CSW_G3SG1)|(1<<CSW_SG552)|(1<<CSW_AK47)|(1<<CSW_P90)

new round_number, g_round
new bool:has_used[33]

#define VIP_TAG (1<<2)

public plugin_init()
{
        register_plugin("Vip_weapon", "1.2f", "7eVen")
      
        register_event("ResetHUD", "ResetHUD", "be")
        register_event("HLTV", "event_round_start", "a", "1=0", "2=0")
        register_event( "TextMsg", "Event_NewGame", "a", "2=#Game_will_restart_in", "2=#Game_Commencing" )
        register_message( get_user_msgid( "ScoreAttrib" ), "msgScoreAttrib" )
      
        register_clcmd("vipmenu", "vip_menu")
      
        register_clcmd("say /adminka", "adminka")
        register_clcmd("say /vip","vipka")
      
        g_round = register_cvar("amx_vip_give", "3")
      
        register_clcmd("say", "handle_say")
}

stock drop_weapons(id, dropwhat)
{
        static weapons[32], num, i, weaponid
        num = 0
        get_user_weapons(id, weapons, num)

        for(i = 0; i < num; i++)
        {
                weaponid = weapons[i]

                if(dropwhat == 1 && ((1<<weaponid) & PRIMARY_WEAPONS_BIT_SUM))
                {
                        static wname[32]
                        get_weaponname(weaponid, wname, sizeof wname - 1)
                        engclient_cmd(id, "drop", wname)
                }
        }
}

public vip_menu(id)
{
        if ( ! ( get_user_flags ( id ) & VIP_FLAG )  )  
        {
                ChatColor ( id, "^3[^4 V.I.P^3 ] ^1 Только для ^4[V.I.P]")
                return PLUGIN_HANDLED;
        }      
      
        if( is_mapname( "awp_" ) || is_mapname("35hp_") || is_mapname("aim_")) {
                ChatColor ( id, "^3[^4 V.I.P^3 ] ^1 На текущей карте оружейка отключена!" )
                return PLUGIN_HANDLED;
        }
      
        new menu = menu_create("\r Оружейка \w[\y V.I.P \w]", "show_vipmenu")

        menu_additem(menu, "\wВзять \r[\y Famas \r]\r", "1")
        menu_additem(menu, "\wВзять \r[\y M4A1 \r]\r", "2")
        menu_additem(menu, "\wВзять \r[\y AK47 \r]\r", "3")
        menu_additem(menu, "\wВзять \r[\y AWP \r]\r", "4")
      
        menu_setprop(menu, MPROP_NEXTNAME, "Дальше")
        menu_setprop(menu, MPROP_BACKNAME, "Назад")
        menu_setprop(menu, MPROP_EXITNAME, "Выход")
        menu_setprop(menu, MPROP_EXIT,MEXIT_ALL)
      
        menu_display(id,menu,0)
        return PLUGIN_HANDLED;
}

public show_vipmenu(id, menu, item)
{      
        if(item == MENU_EXIT)
        {
                menu_destroy(menu)
                return PLUGIN_HANDLED;
        }
      
        if(is_user_alive(id)&& !has_used[id] )
        {
                new pRound = get_pcvar_num(g_round)
                if ( round_number < pRound )
                {
                        ChatColor ( id, "^3[^4 V.I.P^3 ] ^1 Доступно со %d раунда!", pRound )
                        return PLUGIN_HANDLED;
                }  
              
                new data[6], iName[64], access, callback
                menu_item_getinfo(menu, item, access, data, 5, iName, 63, callback)
              
                new key = str_to_num(data)
              
                switch(key)
                {
                case 1:
                        {
                                drop_weapons(id, 1)
                                give_item( id, "weapon_famas" )
                                cs_set_user_bpammo( id , CSW_FAMAS, 90 )
                        }
                case 2:
                        {
                                drop_weapons(id, 1)
                                give_item( id, "weapon_m4a1" )
                                cs_set_user_bpammo( id , CSW_M4A1, 90 )
                        }
                case 3:
                        {
                                drop_weapons(id, 1)
                                give_item( id, "weapon_ak47" )
                                cs_set_user_bpammo( id , CSW_AK47, 90 )
                        }
                case 4:
                        {
                                drop_weapons(id, 1)
                                give_item( id, "weapon_awp" )
                                cs_set_user_bpammo( id , CSW_AWP, 30 )
                        }
                }
                has_used[id] = true;
        }
        else
        {
                ChatColor ( id, "^3[^4 V.I.P^3 ] ^1 Вы уже использовали.Подождите..." )
                return PLUGIN_HANDLED;
        }
        return PLUGIN_HANDLED;
}

public event_round_start()
{
        round_number++
        arrayset(has_used, false, 33)
}

public Event_NewGame() {
        round_number = 0
}

public adminka(id)
{
        show_motd( id, "adminka.txt", "Покупка - Админки!" )
}

public vipka(id)
{
        show_motd( id, "vip.txt", "Покупка - V.I.P" )
}

public ResetHUD(id)
{
        if( is_mapname( "awp_" ) || is_mapname("35hp_") || is_mapname("aim_") )
                return
      
        set_task(0.5, "VIP", id + 6910)
}

public VIP(TaskID)
{      
        new id = TaskID - 6910

        if ( is_user_alive(id) && get_user_flags(id) & VIP_FLAG )
        {
                for (new i = 0; i < 5; i++)
                {
                        if (fm_strip_user_gun(id, pistols[i]))
                        {
                                break;
                        }      
                        give_item( id, "weapon_hegrenade" )
                        give_item( id, "weapon_flashbang" )
                        give_item( id, "weapon_flashbang" )
                        give_item( id, "weapon_smokegrenade" )
                        give_item( id, "item_assaultsuit" )
                        give_item( id, "item_thighpack" )
                        give_item( id, "weapon_deagle")
                      
                        give_item( id, "ammo_50ae" )
                        give_item( id, "ammo_50ae" )
                        give_item( id, "ammo_50ae" )
                        give_item( id, "ammo_50ae" )
                        give_item( id, "ammo_50ae" )  
                }
        }
}

public msgScoreAttrib(const MsgId, const MsgType, const MsgDest) { //xpaw's code
        if ( get_user_flags(get_msg_arg_int(1)) & VIP_FLAG && !get_msg_arg_int(2) )
                set_msg_arg_int( 2, ARG_BYTE, VIP_TAG )
}

stock ChatColor(const id, const input[], any:...)
{
        new count = 1, players[32], iPlayer
        static msg[192], iMsgSayText
        vformat(msg, 191, input, 3)

        if ( !iMsgSayText )
                get_user_msgid("SayText")
      
        replace_all(msg, 191, "!g", "^4") // Green Color
        replace_all(msg, 191, "!y ", "^1") // Default Color
        replace_all(msg, 191, "!team", "^3") // Team Color
        replace_all(msg, 191, "!team2", "^0") // Team2 Color
      
        if (id) players[0] = id; else get_players(players, count, "ch")
        {
                for (new i = 0; i < count; i++)
                {
                        if (is_user_connected(players[i]))
                        {
                                iPlayer = players[i]
                                message_begin(MSG_ONE_UNRELIABLE, iMsgSayText, _, iPlayer)
                                write_byte(iPlayer);
                                write_string(msg);
                                message_end();
                        }
                }
        }
}

stock is_mapname( const szNameMap[ ] )
{
        new szMap[ 32 ];
        get_mapname( szMap , charsmax( szMap ) );
        if( containi ( szMap , szNameMap ) != -1 )
                return 1;
      
        return 0;
}

Всем заранее спасибо за помощь.

Отредактировал: mysubcult, - 18.11.2013, 17:19
Перейти в начало страницы         Просмотр профиля    Отправить личное сообщение
   Цитировать сообщение
XyLiGaN
сообщение 18.11.2013, 17:10
Сообщение #2
Стаж: 13 лет
Город: Югорск

Сообщений: 11668
Благодарностей: 6450
Полезность: 1052

Меценат Меценат

Цитата
Modified by Safety1st
Цитата
register_plugin("Vip_weapon", "1.2f", "7eVen")
good.gif
Перейти в начало страницы         Просмотр профиля    Отправить личное сообщение
Поблагодарили 1 раз
   + Цитировать сообщение
Статус пользователя mysubcult
сообщение 18.11.2013, 17:13
Сообщение #3
Стаж: 12 лет

Сообщений: 382
Благодарностей: 28
Полезность: 86

Цитата(XyLiGaN @ 18.11.2013, 19:10) *
good.gif

Это я просто просил человека отредактировать, чтобы на картах aim и awp оружейка не работала, но статус VIP в статистике работал, он это сделал, но вот видимо этой проблемы не заметил.
Перейти в начало страницы         Просмотр профиля    Отправить личное сообщение
   + Цитировать сообщение
urpok
сообщение 18.11.2013, 17:16
Сообщение #4
Стаж: 13 лет

Сообщений: 890
Благодарностей: 164
Полезность: 0

Желательно под сполер загнать.
Что-то подсказывает, что надо debug прописать: Vip_weapon.amxx debug
Перейти в начало страницы         Просмотр профиля    Отправить личное сообщение
Поблагодарили 1 раз
   + Цитировать сообщение
Статус пользователя mysubcult
сообщение 18.11.2013, 17:18
Сообщение #5
Стаж: 12 лет

Сообщений: 382
Благодарностей: 28
Полезность: 86

Цитата(HeBuguMka @ 18.11.2013, 19:16) *
Желательно под сполер загнать.
Что-то подсказывает, что надо debug прописать: Vip_weapon.amxx debug

Так я же там написал, что debug добавил, пару ошибок из-за этого ушло, но все равно некоторые остались.
Перейти в начало страницы         Просмотр профиля    Отправить личное сообщение
   + Цитировать сообщение
urpok
сообщение 18.11.2013, 17:48
Сообщение #6
Стаж: 13 лет

Сообщений: 890
Благодарностей: 164
Полезность: 0

Цитата(mysubcult @ 18.11.2013, 18:18) *
Так я же там написал, что debug добавил, пару ошибок из-за этого ушло, но все равно некоторые остались.


Как и написано, ошибка текста в этих строчках, пересмотри, может там рус. текст выделывается.
[0] Vip_weapon.sma::ChatColor (line 238) = цветной чат не реагирует, что-то не то.
[1] Vip_weapon.sma::show_vipmenu (line 109) = отображение меню, то же что-то не то.

Отредактировал: HeBuguMka, - 18.11.2013, 17:49
Перейти в начало страницы         Просмотр профиля    Отправить личное сообщение
Поблагодарили 1 раз
   + Цитировать сообщение
Статус пользователя mysubcult
сообщение 18.11.2013, 17:52
Сообщение #7
Стаж: 12 лет

Сообщений: 382
Благодарностей: 28
Полезность: 86

Цитата(HeBuguMka @ 18.11.2013, 19:48) *
Как и написано, ошибка текста в этих строчках, пересмотри, может там рус. текст выделывается.
[0] Vip_weapon.sma::ChatColor (line 238) = цветной чат не реагирует, что-то не то.
[1] Vip_weapon.sma::show_vipmenu (line 109) = отображение меню, то же что-то не то.

Я просто в этом вообще не бум-бум. Вот 238 строка:
Код
                                message_begin(MSG_ONE_UNRELIABLE, iMsgSayText, _, iPlayer)

Мне вообще ни о чем не говорит...=(
Перейти в начало страницы         Просмотр профиля    Отправить личное сообщение
   + Цитировать сообщение
urpok
сообщение 18.11.2013, 18:00
Сообщение #8
Стаж: 13 лет

Сообщений: 890
Благодарностей: 164
Полезность: 0

Цитата(mysubcult @ 18.11.2013, 18:52) *
Я просто в этом вообще не бум-бум. Вот 238 строка:
Код
                                message_begin(MSG_ONE_UNRELIABLE, iMsgSayText, _, iPlayer)

Мне вообще ни о чем не говорит...=(


Ответ хранится в Lang файле к этому плагину, пересмотри ещё раз .txt файл, и сохрани его в UTF8 без BOM. (может покажется дикостью, но я некоторые плаги, если они даже и без рус. чата, тоже сохраняю так, странно, но всё работает)
Перейти в начало страницы         Просмотр профиля    Отправить личное сообщение
Поблагодарили 1 раз
   + Цитировать сообщение
Статус пользователя mysubcult
сообщение 18.11.2013, 18:01
Сообщение #9
Стаж: 12 лет

Сообщений: 382
Благодарностей: 28
Полезность: 86

Цитата(HeBuguMka @ 18.11.2013, 20:00) *
Ответ хранится в Lang файле к этому плагину, пересмотри ещё раз .txt файл, и сохрани его в UTF8 без BOM. (может покажется дикостью, но я некоторые плаги, если они даже и без рус. чата, тоже сохраняю так, странно, но всё работает)

У этого плагина нет lang файлов, все че есть, все вот внутри него, кодировка стоит UTF8 без BOM...
p.s. и кстати в игре перестала появляться вот эта надпись, о том, что доступно с 3 раунда....

Отредактировал: mysubcult, - 18.11.2013, 18:03
Перейти в начало страницы         Просмотр профиля    Отправить личное сообщение
   + Цитировать сообщение
Статус пользователя mysubcult
сообщение 18.11.2013, 19:48
Сообщение #10
Стаж: 12 лет

Сообщений: 382
Благодарностей: 28
Полезность: 86

Никто не поможет?
Перейти в начало страницы         Просмотр профиля    Отправить личное сообщение
   + Цитировать сообщение
urpok
сообщение 18.11.2013, 19:50
Сообщение #11
Стаж: 13 лет

Сообщений: 890
Благодарностей: 164
Полезность: 0

Цитата(mysubcult @ 18.11.2013, 20:48) *
Никто не поможет?


Приду домой, попробую поставить это же плаг, проверю. Посмотрю, будут ли ошибки, потом отпишу.
Перейти в начало страницы         Просмотр профиля    Отправить личное сообщение
   + Цитировать сообщение
Safety1st
сообщение 18.11.2013, 20:10
Сообщение #12
Стаж: 14 лет
Город: Moscow

Сообщений: 7228
Благодарностей: 8071
Полезность: 196

Исправил.
[attachment=21799:vip_7eVen_1118.sma]
Перейти в начало страницы         Просмотр профиля    Отправить личное сообщение
Поблагодарили 1 раз
   + Цитировать сообщение
Статус пользователя mysubcult
сообщение 18.11.2013, 21:12
Сообщение #13
Стаж: 12 лет

Сообщений: 382
Благодарностей: 28
Полезность: 86

Цитата(Safety1st @ 18.11.2013, 22:10) *
Исправил.
[attachment=21799:vip_7eVen_1118.sma]

Спасибо большое! А в чем проблема была?
Перейти в начало страницы         Просмотр профиля    Отправить личное сообщение
   + Цитировать сообщение
Статус пользователя mysubcult
сообщение 18.11.2013, 22:14
Сообщение #14
Стаж: 12 лет

Сообщений: 382
Благодарностей: 28
Полезность: 86

Цитата(Safety1st @ 18.11.2013, 22:10) *
Исправил.
[attachment=21799:vip_7eVen_1118.sma]

Стали появляться сообщения, что оружейка доступна с 3 раунда, но в логах все равно вот это:
Код
L 11/19/2013 - 00:11:52: Start of error session.
L 11/19/2013 - 00:11:52: Info (map "de_kabul") (file "addons/amxmodx/logs/error_20131119.log")
L 11/19/2013 - 00:11:52: Function "handle_say" was not found
L 11/19/2013 - 00:11:52: [AMXX] Displaying debug trace (plugin "Vip_weapon.amxx")
L 11/19/2013 - 00:11:52: [AMXX] Run time error 19: function not found
L 11/19/2013 - 00:11:52: [AMXX]    [0] Vip_weapon.sma::plugin_init (line 45)
Перейти в начало страницы         Просмотр профиля    Отправить личное сообщение
   + Цитировать сообщение
Safety1st
сообщение 19.11.2013, 23:38
Сообщение #15
Стаж: 14 лет
Город: Moscow

Сообщений: 7228
Благодарностей: 8071
Полезность: 196

Вот как-то так.
Прикрепленный файл  vip_7eVen_1120.sma ( 6,25 килобайт ) Кол-во скачиваний: 45
Надоел он мне уже :)
Перейти в начало страницы         Просмотр профиля    Отправить личное сообщение
Поблагодарили 1 раз
   + Цитировать сообщение
Статус пользователя mysubcult
сообщение 20.11.2013, 7:06
Сообщение #16
Стаж: 12 лет

Сообщений: 382
Благодарностей: 28
Полезность: 86

Цитата(Safety1st @ 20.11.2013, 1:38) *
Вот как-то так.
Прикрепленный файл  vip_7eVen_1120.sma ( 6,25 килобайт ) Кол-во скачиваний: 45
Надоел он мне уже :)

Спасибо, сегодня поставлю.
Перейти в начало страницы         Просмотр профиля    Отправить личное сообщение
   + Цитировать сообщение
  Ответить в данную темуНачать новую тему
 
0 пользователей и 1 гостей читают эту тему: