#if defined _colorchat_included #endinput #endif #define _colorchat_included /* ColorChat Support */ #define RED Red #define BLUE Blue #define GREY Grey #define ColorChat client_print_color /* ColorChat Support */ enum { Grey = 33, Red, Blue }; stock client_print_color(id, sender, const fmt[], any:...) { // check if id is different from 0 if( id && !is_user_connected(id) ) { return 0; } static const szTeamName[][] = { "", "TERRORIST", "CT" }; new szMessage[192]; new iParams = numargs(); // Specific player code if( id ) { if( iParams == 3 ) { copy(szMessage, charsmax(szMessage), fmt); // copy so message length doesn't exceed critical 192 value } else { vformat(szMessage, charsmax(szMessage), fmt, 4); } if( sender > Grey ) { if( sender > Blue ) { sender = id; } else { _CC_TeamInfo(id, sender, szTeamName[sender-Grey]); } } _CC_SayText(id, sender, szMessage); } // Send message to all players else { // Figure out if at least 1 player is connected // so we don't execute useless useless code if not new iPlayers[32], iNum; get_players(iPlayers, iNum, "ch"); if( !iNum ) { return 0; } new iMlNumber, i, j; new Array:aStoreML = ArrayCreate(); if( iParams >= 5 ) // ML can be used { for(j=3; j Grey ) { _CC_TeamInfo(0, sender, szTeamName[sender-Grey]); } _CC_SayText(0, sender, szMessage); return 1; } } if( sender > Blue ) { sender = 0; // use receiver index } for(--iNum; iNum>=0; iNum--) { id = iPlayers[iNum]; if( iMlNumber ) { for(j=0; j Grey ) { _CC_TeamInfo(id, sender, szTeamName[sender-Grey]); } _CC_SayText(id, sender, szMessage); } ArrayDestroy(aStoreML); } return 1; } stock _CC_TeamInfo(iReceiver, iSender, szTeam[]) { static iTeamInfo = 0; if( !iTeamInfo ) { iTeamInfo = get_user_msgid("TeamInfo"); } message_begin(iReceiver ? MSG_ONE : MSG_ALL, iTeamInfo, _, iReceiver); write_byte(iSender); write_string(szTeam); message_end(); } stock _CC_SayText(iReceiver, iSender, szMessage[]) { static iSayText = 0; if( !iSayText ) { iSayText = get_user_msgid("SayText"); } message_begin(iReceiver ? MSG_ONE : MSG_ALL, iSayText, _, iReceiver); write_byte(iSender ? iSender : iReceiver); write_string(szMessage); message_end(); } stock register_dictionary_colored(const filename[]) { if( !register_dictionary(filename) ) { return 0; } new szFileName[256]; get_localinfo("amxx_datadir", szFileName, charsmax(szFileName)); format(szFileName, charsmax(szFileName), "%s/lang/%s", szFileName, filename); new fp = fopen(szFileName, "rt"); if( !fp ) { log_amx("Failed to open %s", szFileName); return 0; } new szBuffer[512], szLang[3], szKey[64], szTranslation[256], TransKey:iKey; while( !feof(fp) ) { fgets(fp, szBuffer, charsmax(szBuffer)); trim(szBuffer); if( szBuffer[0] == '[' ) { strtok(szBuffer[1], szLang, charsmax(szLang), szBuffer, 1, ']'); } else if( szBuffer[0] ) { strbreak(szBuffer, szKey, charsmax(szKey), szTranslation, charsmax(szTranslation)); iKey = GetLangTransKey(szKey); if( iKey != TransKey_Bad ) { replace_all(szTranslation, charsmax(szTranslation), "!g", "^4"); replace_all(szTranslation, charsmax(szTranslation), "!t", "^3"); replace_all(szTranslation, charsmax(szTranslation), "!n", "^1"); AddTranslation(szLang, iKey, szTranslation[2]); } } } fclose(fp); return 1; }