lylechriss

ELO

May 3rd, 2016
421
1
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
Pawn 16.89 KB | None | 1 0
  1. /*Köszönet  Mike-nak és R_Hehl-nek az ELO Rankrendszerért: https://forums.alliedmods.net/showpost.php?p=728645&postcount=1
  2. mforce-nak és Akosch:.-nak a segítségért. :)*/
  3.  
  4. /*
  5. v1.2.0 - Rankból olvas [csstats]
  6. v1.1.0 - sql.cfg-ből olvas SQL adatokat, chat rendszer bekerült.
  7. v1.0.0 - Alap rendszer elkészítése.
  8. */
  9.  
  10. #include <amxmodx>
  11. #include <amxmisc>
  12. #include <csstats>
  13. #include <colorchat>
  14. #include <sqlx>
  15.  
  16. enum _:DATA
  17. {
  18.     Cht_Prefix[32],
  19.     Name[32],
  20.     Min_ELO,
  21.     Max_ELO
  22. }
  23.  
  24. new const g_Ranks[19][DATA] = {
  25.     {"Unranked", "Unranked", -1, 0},
  26.     {"Silver I", "Silver I", 0, 199},
  27.     {"Silver II", "Silver II", 200, 399},
  28.     {"Silver III", "Silver III", 400, 799},
  29.     {"Silver IV", "Silver IV", 800, 1199},
  30.     {"SE", "Silver Elite", 1200, 1599},
  31.     {"SEM", "Silver Elite Master", 1600, 1999},
  32.     {"Nova I", "Gold Nova I", 2000, 2399},
  33.     {"Nova II", "Gold Nova II", 2400, 2799},
  34.     {"Nova III", "Gold Nova III", 2800, 3199},
  35.     {"Nova Master", "Gold Nova Master", 3200, 3599},
  36.     {"Kala", "Master Guardian I", 3600, 3999},
  37.     {"Kala II", "Master Guardian II", 4000, 4499},
  38.     {"Kereszt Kala", "Master Guardian Elite", 4500, 4999},
  39.     {"Sheriff", "Distinguished Master Guardian", 5000, 5999},
  40.     {"Sas", "Legendary Eagle", 6000, 6999},
  41.     {"Sas II", "Legendary Eagle Master", 7000, 7999},
  42.     {"Supreme", "Supreme Master First Class", 8000, 9999},
  43.     {"Global", "The Global Elite", 10000, 0}
  44. }
  45.  
  46. #define GetBit(%1,%2)       (%1 & (1 << (%2 & 31)))
  47. #define SetBit(%1,%2)       %1 |= (1 << (%2 & 31))
  48. #define ResetBit(%1,%2)     %1 &= ~(1 << (%2 & 31))
  49.  
  50. new bitadmin, bitelo
  51.  
  52. new const SQL_INFO[4][32]
  53. new Handle:g_SqlTuple
  54.  
  55. new const Prefix[] = {"ELO"}
  56.  
  57. new cvar_kValue, cvar_Advert
  58.  
  59. enum _:P_DATA
  60. {
  61.     Rank,
  62.     Rating,
  63.     Kills,
  64.     Deaths,
  65.     SessionRating,
  66.     SessionKills,
  67.     SessionDeaths,
  68.     Name[64],
  69.     AuthId[32],
  70.     bool:Notify
  71. }
  72. new g_PlayerDatas[33][P_DATA]
  73. new bool:roundend
  74.  
  75. enum _:TOP
  76. {
  77.     Name[32],
  78.     Kills,
  79.     Deaths,
  80.     Rating
  81. }
  82. new const g_Top10[10][TOP]
  83.  
  84. public plugin_init() {
  85.     register_plugin("ELO Stats", "1.1.0", "LyleChriss")
  86.    
  87.     cvar_kValue = register_cvar("amx_elo_k", "16.0")
  88.     cvar_Advert = register_cvar("amx_elo_ads", "60.0")
  89.    
  90.     // Rank
  91.     register_clcmd("say elo", "SQL_Rank")
  92.     register_clcmd("say .elo", "SQL_Rank")
  93.     register_clcmd("say !elo", "SQL_Rank")
  94.     register_clcmd("say /elo", "SQL_Rank")
  95.     // Top10
  96.     register_clcmd("say top10", "SQL_Top10")
  97.     register_clcmd("say .top10", "SQL_Top10")
  98.     register_clcmd("say !top10", "SQL_Top10")
  99.     register_clcmd("say /top10", "SQL_Top10")
  100.     // Session Stats
  101.     register_clcmd("say session", "SessionStats")
  102.     register_clcmd("say .session", "SessionStats")
  103.     register_clcmd("say !session", "SessionStats")
  104.     register_clcmd("say /session", "SessionStats")
  105.     // ELO Notify
  106.     register_clcmd("say notify", "Notification")
  107.     register_clcmd("say .notify", "Notification")
  108.     register_clcmd("say !notify", "Notification")
  109.     register_clcmd("say /notify", "Notification")
  110.  
  111.     register_event("DeathMsg", "eDeathMsg", "a")
  112.     register_logevent("logevent_round_start", 2, "1=Round_Start")
  113.     register_logevent("logevent_round_end", 2, "1=Round_End")
  114.    
  115.     //Chat cuccok
  116.     register_clcmd("say", "HandlerSay");
  117.     register_clcmd("say_team", "HandlerSayTeam");
  118.     register_event("ResetHUD", "eResetHUD", "be");
  119.    
  120.     if(get_pcvar_float(cvar_Advert) > 0.0)
  121.         set_task(get_pcvar_float(cvar_Advert), "Advertise", _, _, _, "b")
  122.        
  123.     get_cvar_string("amx_sql_host", SQL_INFO[0], charsmax(SQL_INFO[]))
  124.     get_cvar_string("amx_sql_user", SQL_INFO[1], charsmax(SQL_INFO[]))
  125.     get_cvar_string("amx_sql_pass", SQL_INFO[2], charsmax(SQL_INFO[]))
  126.     get_cvar_string("amx_sql_db", SQL_INFO[3], charsmax(SQL_INFO[]))
  127. }
  128.  
  129. public eDeathMsg()
  130. {
  131.     ResetBit(bitelo, read_data(2))
  132.     if(!roundend)
  133.     {
  134.         new attacker = read_data(1)
  135.         new victim = read_data(2)
  136.        
  137.         if(attacker != victim)
  138.         {
  139.             new Float:rating = float(g_PlayerDatas[victim][Rating]-g_PlayerDatas[attacker][Rating])
  140.             new Float:prob = 1.0/(power(floatround(rating)/400, 10)+1)
  141.             new diff = floatround(get_pcvar_float(cvar_kValue)*(1.0-prob))
  142.            
  143.             g_PlayerDatas[victim][Rating] -= diff
  144.             g_PlayerDatas[attacker][Rating] += diff
  145.             g_PlayerDatas[victim][SessionRating] -= diff
  146.             g_PlayerDatas[attacker][SessionRating] += diff
  147.             g_PlayerDatas[victim][Deaths]++
  148.             g_PlayerDatas[attacker][Kills]++
  149.             g_PlayerDatas[victim][SessionDeaths]++
  150.             g_PlayerDatas[attacker][SessionKills]++
  151.             Update_SQL(victim)
  152.             Update_SQL(attacker)
  153.            
  154.             new victName[32]; get_user_name(victim, victName, charsmax(victName))
  155.             new attaName[32]; get_user_name(attacker, attaName, charsmax(attaName))
  156.            
  157.             if(g_PlayerDatas[attacker][Notify])
  158.             {
  159.                 ColorChat(attacker, NORMAL, "^4[%s]^1 Megölted (^4%i^1) ^3%s^1-t (^4%i^1), ezért kaptál ^4%i ^1pontot.", Prefix, g_PlayerDatas[attacker][Rating], victName, g_PlayerDatas[victim][Rating], diff)
  160.             }
  161.             if(g_PlayerDatas[victim][Notify])
  162.             {
  163.                 ColorChat(victim, NORMAL, "^4[%s]^1 Megölt téged (^4%i^1) ^3%s^1 (^4%i^1), ezért vesztettél ^4%i ^1pontot.", Prefix, g_PlayerDatas[victim][Rating], victName, g_PlayerDatas[attacker][Rating], diff)
  164.             }
  165.         }
  166.     }
  167. }
  168.  
  169. public logevent_round_start()   roundend=false
  170.  
  171. public logevent_round_end() roundend=true
  172.  
  173. public eResetHUD(id, level, cid) SetBit(bitelo, id)
  174.  
  175. public plugin_cfg()
  176. {
  177.     g_SqlTuple = SQL_MakeDbTuple(SQL_INFO[0],SQL_INFO[1],SQL_INFO[2],SQL_INFO[3])
  178.    
  179.     SQL_ThreadQuery(g_SqlTuple,"createTableThread", "CREATE TABLE IF NOT EXISTS `elo_ranking` (authid varchar(32) NOT NULL, name varchar(64) NOT NULL, rating int(8) NOT NULL, kills int(8) NOT NULL, deaths int(8) NOT NULL, notify int(2) NOT NULL)")
  180. }
  181.  
  182. public createTableThread(FailState, Handle:Query, Error[], Errcode, Data[], DataSize, Float:Queuetime)
  183. {
  184.     if(FailState == TQUERY_CONNECT_FAILED)
  185.         set_fail_state("Nem lehet csatlakozni az adatbazishoz.")
  186.     else if(FailState == TQUERY_QUERY_FAILED)
  187.         set_fail_state("Query Error")
  188.     if(Errcode)
  189.         log_amx("Hiba: %s",Error)
  190. }
  191.  
  192. public client_putinserver(id)
  193. {
  194.     arrayset(g_PlayerDatas[id], 0, 7)
  195.     g_PlayerDatas[id][SessionRating] = 1600
  196.     g_PlayerDatas[id][Rating] = -1
  197.     g_PlayerDatas[id][Name][0] = EOS
  198.     g_PlayerDatas[id][AuthId][0] = EOS
  199.     g_PlayerDatas[id][Notify] = true
  200.    
  201.     if(get_user_flags(id) & ADMIN_CHAT) SetBit(bitadmin, id)
  202.     else ResetBit(bitadmin, id)
  203.    
  204.     if(!is_user_bot(id) && !is_user_hltv(id))
  205.     {
  206.         get_user_name(id, g_PlayerDatas[id][Name], charsmax(g_PlayerDatas[][Name]))
  207.         get_user_authid(id, g_PlayerDatas[id][AuthId], charsmax(g_PlayerDatas[][AuthId]))
  208.         if(contain(g_PlayerDatas[id][AuthId], "_ID_LAN") != -1) get_user_ip(id, g_PlayerDatas[id][AuthId], charsmax(g_PlayerDatas[][AuthId]), 1)
  209.         new szStats[8], szBHits[8]
  210.         get_user_stats(id, szStats, szBHits)
  211.         g_PlayerDatas[id][Kills] = szStats[0]
  212.         g_PlayerDatas[id][Deaths] = szStats[1]
  213.         Load_SQL(id)
  214.     }
  215. }
  216.  
  217. public client_infochanged(id)
  218. {
  219.     if(!is_user_connected(id))
  220.         return PLUGIN_HANDLED
  221.    
  222.     get_user_info(id, "name", g_PlayerDatas[id][Name], charsmax(g_PlayerDatas[][Name]))
  223.    
  224.     return PLUGIN_CONTINUE
  225. }
  226.  
  227. public client_disconnect(id)
  228. {
  229.     ResetBit(bitelo, id)
  230.    
  231.     new szStats[8], szBHits[8]
  232.     get_user_stats(id, szStats, szBHits)
  233.     g_PlayerDatas[id][Kills] = szStats[0]
  234.     g_PlayerDatas[id][Deaths] = szStats[1]
  235.    
  236.     if(!is_user_bot(id) && !is_user_hltv(id)) Update_SQL(id)
  237.    
  238.     arrayset(g_PlayerDatas[id], 0, 7)
  239.     g_PlayerDatas[id][SessionRating] = 1600
  240.     g_PlayerDatas[id][Rating] = -1
  241.     g_PlayerDatas[id][Name][0] = EOS
  242.     g_PlayerDatas[id][AuthId][0] = EOS
  243.     g_PlayerDatas[id][Notify] = true
  244. }
  245.  
  246. public Load_SQL(id)
  247. {
  248.     static Query[512]
  249.     new Data[1]; Data[0] = id
  250.    
  251.     formatex(Query, charsmax(Query), "SELECT * FROM `elo_ranking` WHERE authid = ^"%s^";", g_PlayerDatas[id][AuthId])
  252.     SQL_ThreadQuery(g_SqlTuple, "QuerySelectData", Query, Data, 1)
  253. }
  254.  
  255. public QuerySelectData(FailState, Handle:Query, Error[], Errcode, Data[], DataSize, Float:Queuetime)
  256. {
  257.     if(FailState == TQUERY_CONNECT_FAILED || FailState == TQUERY_QUERY_FAILED)
  258.     {
  259.         log_amx("%s", Error)
  260.         return
  261.     }
  262.     else
  263.     {
  264.         new id = Data[0];
  265.  
  266.         if(SQL_NumRows(Query) > 0)
  267.         {
  268.             g_PlayerDatas[id][Kills] = SQL_ReadResult(Query, SQL_FieldNameToNum(Query, "kills"))
  269.             g_PlayerDatas[id][Deaths] = SQL_ReadResult(Query, SQL_FieldNameToNum(Query, "deaths"))
  270.             g_PlayerDatas[id][Rating] = SQL_ReadResult(Query, SQL_FieldNameToNum(Query, "rating"))
  271.             g_PlayerDatas[id][Notify] = SQL_ReadResult(Query, SQL_FieldNameToNum(Query, "notify"))
  272.         }
  273.         else
  274.         {
  275.             Save_SQL(id)
  276.         }
  277.     }
  278. }
  279.  
  280. public Save_SQL(id)
  281. {
  282.     static Query[512]
  283.     formatex(Query, charsmax(Query), "INSERT INTO `elo_ranking` (`authid`, `name`, `rating`, `kills`, `deaths`, `notify`) VALUES (^"%s^", ^"%s^", ^"1600^", ^"0^", ^"0v, ^"0^")", g_PlayerDatas[id][AuthId], g_PlayerDatas[id][Name])
  284.     SQL_ThreadQuery(g_SqlTuple, "QuerySetData", Query)
  285. }
  286.  
  287. public Update_SQL(id)
  288. {
  289.     static Query[512]
  290.     formatex(Query, charsmax(Query), "UPDATE `elo_ranking` SET `name` = ^"%s^", `rating` = %d, `kills` = %d, `deaths` = %d, `notify` = %d WHERE `authid` = ^"%s^";", g_PlayerDatas[id][Name], g_PlayerDatas[id][Rating], g_PlayerDatas[id][Kills], g_PlayerDatas[id][Deaths], g_PlayerDatas[id][Notify], g_PlayerDatas[id][AuthId])
  291.    
  292.     SQL_ThreadQuery(g_SqlTuple, "QuerySetData", Query)
  293. }
  294.  
  295. public QuerySetData(FailState, Handle:Query, Error[], Errcode, Data[], DataSize, Float:Queuetime)
  296. {
  297.     if(FailState == TQUERY_CONNECT_FAILED || FailState == TQUERY_QUERY_FAILED)
  298.     {
  299.         log_amx("%s", Error)
  300.         return
  301.     }
  302. }
  303.  
  304. public SQL_Rank(id)
  305. {
  306.     static Query[512]
  307.     new Data[1]; Data[0] = id
  308.     formatex(Query, charsmax(Query), "SELECT COUNT(*) FROM `elo_ranking` WHERE `rating`>%i", g_PlayerDatas[id][Rating])
  309.     SQL_ThreadQuery(g_SqlTuple, "QueryRank", Query, Data, 1)
  310. }
  311.  
  312. public QueryRank(FailState, Handle:Query, Error[], Errcode, Data[], DataSize, Float:Queuetime)
  313. {
  314.     if(FailState == TQUERY_CONNECT_FAILED || FailState == TQUERY_QUERY_FAILED)
  315.     {
  316.         log_amx("%s", Error)
  317.         return
  318.     }
  319.     else
  320.     {
  321.         g_PlayerDatas[Data[0]][Rank] = SQL_ReadResult(Query, P_DATA)
  322.         g_PlayerDatas[Data[0]][Rank] ++
  323.     }
  324.     SQL_ThreadQuery(Query, "QueryCount", "SELECT COUNT(*) FROM `elo_ranking`", Data, 1)
  325. }
  326.  
  327. public QueryCount(FailState, Handle:Query, Error[], Errcode, Data[], DataSize, Float:Queuetime)
  328. {
  329.     if(FailState == TQUERY_CONNECT_FAILED || FailState == TQUERY_QUERY_FAILED)
  330.     {
  331.         log_amx("%s", Error)
  332.         return
  333.     }
  334.     else
  335.     {
  336.         new id = Data[0]
  337.         new Float:kpd = g_PlayerDatas[id][Deaths]==0?1.0:float(g_PlayerDatas[id][Kills]/g_PlayerDatas[id][Deaths])
  338.         ColorChat(id, NORMAL, "^4[%s] ^1ELO pontjaid: ^4%i ^1| Rangod: ^4%s ^1| Rankod: ^4%i ^1| KPD: ^4%.2f", Prefix, g_PlayerDatas[id][Rating], get_user_rang(g_PlayerDatas[id][Rating], 0, 0), g_PlayerDatas[id][Rank], kpd)
  339.     }
  340. }
  341.  
  342. public SQL_Top10(id)
  343. {
  344.     new Data[1]; Data[0] = id
  345.     SQL_ThreadQuery(g_SqlTuple, "QueryTop10", "SELECT `name`, `rating` FROM `elo_ranking` ORDER BY `rating` DESC LIMIT 10", Data, 1)
  346. }
  347.  
  348. public QueryTop10(FailState, Handle:Query, Error[], Errcode, Data[], DataSize, Float:Queuetime)
  349. {
  350.     if(FailState == TQUERY_CONNECT_FAILED || FailState == TQUERY_QUERY_FAILED)
  351.     {
  352.         log_amx("%s", Error)
  353.         return
  354.     }
  355.     else
  356.     {
  357.         new i
  358.         while(SQL_MoreResults(Query))
  359.         {
  360.             SQL_ReadResult(Query, SQL_FieldNameToNum(Query, "name"), g_Top10[i][Name], charsmax(g_Top10[][Name]))
  361.             g_Top10[i][Kills] = SQL_ReadResult(Query, SQL_FieldNameToNum(Query, "kills"))
  362.             g_Top10[i][Deaths] = SQL_ReadResult(Query, SQL_FieldNameToNum(Query, "deaths"))
  363.             g_Top10[i][Rating] = SQL_ReadResult(Query, SQL_FieldNameToNum(Query, "rating"))
  364.             i++
  365.         }
  366.         ShowTopMOTD(Data[0])
  367.     }
  368. }
  369.  
  370. public ShowTopMOTD(id)
  371. {
  372.     static Menu[1024]
  373.     new Len
  374.    
  375.     Len += formatex(Menu[Len], charsmax(Menu) - Len, "<center><table border=^"1^">")
  376.     Len += formatex(Menu[Len], charsmax(Menu) - Len, "<body bgcolor=#000000><table style=^"color: #00FFFF^">")
  377.     Len += formatex(Menu[Len], charsmax(Menu) - Len, "<td>Név</td><td>Rang</td><td>Ölések</td><td>Halálok</td><td>Pontszám</td>")
  378.     for(new i; i< 10; i++)
  379.         Len += formatex(Menu[Len], charsmax(Menu) - Len, "<tr><td>%s</td><td>%s</td><td>%i</td><td>%i</td><td>%i</td></tr>", g_Top10[i][Name], get_user_rang(g_Top10[i][Rating], 0, 0), g_Top10[i][Kills], g_Top10[i][Deaths], g_Top10[i][Rating])
  380.    
  381.     Len += formatex(Menu[Len], charsmax(Menu) - Len, "</table></center>")
  382.     show_motd(id, Menu, "ELO Rankrendszer | TOP10")
  383. }
  384.  
  385. public SessionStats(id) ColorChat(id, NORMAL, "^4[%s]^3(Részeredmények) ^1ELO pontjaid: ^4%i ^1| Rangod: ^4%s ^1| Ölések: ^4%i ^1| Halálok: ^4%i", Prefix, g_PlayerDatas[id][SessionRating], get_user_rang(g_PlayerDatas[id][SessionRating], 0, 0), g_PlayerDatas[id][SessionKills], g_PlayerDatas[id][SessionDeaths])
  386.  
  387. public Notification(id)
  388. {
  389.     if(g_PlayerDatas[id][Notify])
  390.     {
  391.         ColorChat(id, NORMAL, "^4[%s] ^3Kikapcsoltad ^1az értesítéseket! Bekapcsolásukhoz újra írd be a parancsot.", Prefix)
  392.         g_PlayerDatas[id][Notify] = false
  393.     }
  394.     else
  395.     {
  396.         ColorChat(id, NORMAL, "^4[%s] ^3Bekapcsoltad ^1az értesítéseket! Kikapcsolásukhoz újra írd be a parancsot.", Prefix)
  397.         g_PlayerDatas[id][Notify] = true
  398.     }
  399. }
  400.  
  401. public Advertise()
  402. {
  403.     switch(random_num(0, 3))
  404.     {
  405.         case 0: ColorChat(0, NORMAL, "^4[%s] ^1Rankod megnézéséhez írd be: ^4/elo", Prefix)
  406.         case 1: ColorChat(0, NORMAL, "^4[%s] ^1Szeretnéd tudni, kik a legjobbak? Írd be: ^4/top10", Prefix)
  407.         case 2: ColorChat(0, NORMAL, "^4[%s] ^1Tudd meg, hogyan teljesítesz a mapon! Írd be: ^4/session", Prefix)
  408.         case 3: ColorChat(0, NORMAL, "^4[%s] ^1Ki szeretnéd kapcsolni az értesítéseket? Írd be: ^4/notify", Prefix)
  409.     }
  410. }
  411.  
  412. public HandlerSay(id) return uzenetformazas(id, false)
  413. public HandlerSayTeam(id) return uzenetformazas(id, true)
  414.  
  415. uzenetformazas(id, bool:csapat)
  416. {
  417. #define MAX_BIT 180
  418.     static uzenet[MAX_BIT], stringkonvertalas[charsmax(uzenet) * 2 + 1];
  419.     read_args(uzenet, charsmax(uzenet));
  420.     remove_quotes(uzenet);
  421.  
  422.     if(uzenet[0] == EOS || uzenet[0] == '/' || equal(uzenet, " "))
  423.         return PLUGIN_HANDLED_MAIN;
  424.  
  425.     static fullos, tagek[MAX_BIT], team_lekeres, sTeam[16];
  426.     team_lekeres  = get_user_team(id, sTeam, charsmax(sTeam));
  427.  
  428.     switch(team_lekeres)
  429.     {
  430.         case 1: fullos = formatex(tagek, charsmax(tagek), "%s%s", GetBit(bitelo, id) ? "^1" : "^1*Halott* ", csapat ? "^1[T] " : "");
  431.         case 2: fullos = formatex(tagek, charsmax(tagek), "%s%s", GetBit(bitelo, id) ? "^1" : "^1*Halott* ", csapat ? "^1[CT] " : "");
  432.         default:fullos = formatex(tagek, charsmax(tagek), "^1*Spec* ");
  433.     }
  434.    
  435.     if(get_user_flags(id)&ADMIN_IMMUNITY)
  436.         fullos += formatex(tagek[fullos], charsmax(tagek)-fullos, "^4[Tulaj]")
  437.     else if(get_user_flags(id)&ADMIN_LEVEL_G)
  438.         fullos += formatex(tagek[fullos], charsmax(tagek)-fullos, "^4[FĹ‘admin]")
  439.     else if((get_user_flags(id)&ADMIN_BAN) && (get_user_flags(id)&ADMIN_LEVEL_F))
  440.         fullos += formatex(tagek[fullos], charsmax(tagek)-fullos, "^4[Admin+VIP]")
  441.     else if(get_user_flags(id)&ADMIN_BAN)
  442.         fullos += formatex(tagek[fullos], charsmax(tagek)-fullos, "^4[Admin]")
  443.     else if(get_user_flags(id)&ADMIN_LEVEL_F)
  444.         fullos += formatex(tagek[fullos], charsmax(tagek)-fullos, "^4[VIP]")
  445.    
  446.     fullos += formatex(tagek[fullos], charsmax(tagek)-fullos, "^4[%s]", get_user_rang(g_PlayerDatas[id][Rating], 0, 0))
  447.    
  448.     if(is_user_admin(id))   fullos += formatex(tagek[fullos], charsmax(tagek) - fullos, "^3%%s1^1 :  ^4%%s2");
  449.     else    formatex(tagek[fullos], charsmax(tagek) - fullos, "^3%%s1^1 :  %%s2");
  450.    
  451.     stringkonvertalas = uzenet;
  452.     replace_all( stringkonvertalas, charsmax( stringkonvertalas ), "", " " );
  453.     replace_all( stringkonvertalas, charsmax( stringkonvertalas ), "", " " );
  454.  
  455.     static bitlimit; bitlimit = MAX_BIT;
  456.     while(fullos + strlen(stringkonvertalas) > MAX_BIT) stringkonvertalas[bitlimit -= 10] = 0;
  457.  
  458.     static players[32], pcount; get_players(players, pcount, "c");
  459.     switch(csapat)
  460.     {
  461.         case true:
  462.         {
  463.             for(new i; i < pcount; i++)
  464.             {              
  465.                 if(GetBit(bitadmin, players[i]) || (GetBit(bitelo, id) == GetBit(bitelo, players[i]) && team_lekeres == get_user_team(players[i])))
  466.                     PrintChat(players[i], id, tagek, stringkonvertalas);
  467.             }                              
  468.         }
  469.         case false:
  470.         {  
  471.             for(new i; i < pcount; i++)
  472.                 PrintChat(players[i], id, tagek, stringkonvertalas);
  473.         }
  474.     }
  475.     static sAuthId[25], sName[32];
  476.     get_user_name(id, sName, charsmax(sName));
  477.     get_user_authid(id, sAuthId, charsmax(sAuthId));
  478.     log_message("^"%s<%d><%s><%s>^" %s ^"%s^"", sName, get_user_userid(id), sAuthId, sTeam, csapat ? "say_team" : "say" , stringkonvertalas);  
  479.     return PLUGIN_HANDLED;
  480. }
  481.  
  482. PrintChat(iReceiver, iSender, const tagek[], const uzenet[])
  483. {
  484.     message_begin(MSG_ONE, 76, .player=iReceiver);
  485.     write_byte(iSender);
  486.     write_string(tagek);
  487.     write_string("");
  488.     write_string(uzenet);
  489.     message_end();
  490. }
  491.  
  492. public plugin_end() SQL_FreeHandle(g_SqlTuple)
  493.  
  494. stock get_user_rang(Usr_Rating, diff, minus)
  495. {
  496.     for(new i; i<sizeof(g_Ranks); i++)
  497.     {
  498.         if(i == charsmax(g_Ranks))
  499.         {
  500.             if(minus == 1)  return g_Ranks[i-diff][Cht_Prefix]
  501.             else    return g_Ranks[i+diff][Cht_Prefix]
  502.         }
  503.         if(g_Ranks[i][Min_ELO] < Usr_Rating && g_Ranks[i][Max_ELO] > Usr_Rating)
  504.         {
  505.             if(minus == 1)  return g_Ranks[i-diff][Cht_Prefix]
  506.             else    return g_Ranks[i+diff][Cht_Prefix]
  507.         }
  508.     }
  509.     return 0;
  510. }
Add Comment
Please, Sign In to add comment