Вопросы

У меня есть команда prefix и мне нужно сделать что бы когда кто то выдавал префиксы писало в адм чат

        case D_MAKELEADER: {
            if(!response) return 1;
            new ID = GetPVarInt(playerid, "use_leader");
            new frac = GetPVarInt(playerid, "use_frac");
            format(FI[frac][fLeader], 24"%s", player_name[ID]);
            format(FI[frac][fAdmin],  24"%s", player_name[playerid]);

            new year, month, day;
            getdate(year, month, day);
            format(FI[frac][fTime],  53"%02i/%02i/%02i", day, month, year);

            PI[ID][pLeader] = FI[frac][fID];
            PI[ID][pMember] = FI[frac][fID];
            PI[ID][pRank]   = FI[frac][fMaxRang];
            PI[ID][pSpawn] = 2;
            static const f_str[] = ""W"%s"G" назначил Вас лидером организации "P"%s";
            new string[sizeof(f_str) +1 + (-2 + MAX_PLAYER_NAME) + (-2 + 24)];
            if(IsAGang(ID))
            {
                PI[ID][pHospital] = 0;
                SetPlayerHealth(ID, 100);
            }
            format(string,sizeof(string),f_str,player_name[playerid],FI[frac][fName]);
            SendOk(ID,string);

            format(string, sizeof(string), "[A] %s[%d] назначил %s[%d] на пост лидера %s",player_name[playerid],playerid,player_name[ID],ID,FI[frac][fName]);
            AdmMSG(0xAFAFAFAA, string,1);
            
            PI[ID][pFracSkin] = FI[frac][fSkin];
            PI[ID][pJob]        = 0;
            A_SetPlayerSkin(ID,PI[ID][pFracSkin]);
            SetPlayerColor(ID,gFractionSpawn[PI[ID][pMember]][fracColor]);
            start_work[ID] = 1;
            PI[ID][pSpawn] = 2;
            SaveAccount(ID);
            SaveFraction(frac);
            add_datefrac(ID);
        }

С этого стока можно взять проверку но как её изменить на нужную

значение префикса в бд записывается в pPrefix

CMD:setprefix(playerid, params[])
{
    if(PI[playerid][pAdmin] < 5 || dostup[playerid] == 0return true;
    if(sscanf(params, "ds[120]",params[0], params[1], params[2])) return SendEsp(playerid, "/setprefix [ID] [èìÿ ïðåôèêñà]");//[èä öâåòà]

    // PI[params[0]][pPrefix] = params[1];
    strmid(PI[params[0]][pPrefix],params[1], 0, strlen(params[1]), 32);
    PI[params[0]][pPrefixColor] = params[2];
    // UpdatePlayerData(params[0],"pPrefix", PI[params[0]][pPrefix]);

    new query[300];
    format(query,sizeof(query),"UPDATE `accounts` SET `pPrefix` = '%s' WHERE `pID` = '%d' LIMIT 1",PI[params[0]][pPrefix],PI[params[0]][pID]);
    mysql_tquery(connects, query,"","");

    format(query,sizeof(query),"UPDATE `accounts` SET `pPrefixColor` = '%s' WHERE `pID` = '%d' LIMIT 1",PI[params[0]][pPrefixColor],PI[params[0]][pID]);
    mysql_tquery(connects, query,"","");
    return true;
}

 

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


Ссылка на сообщение

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

  • 1
CMD:setprefix(playerid, params[])
{
    if(PI[playerid][pAdmin] < 5 || dostup[playerid] == 0return true;
    if(sscanf(params, "ds[120]",params[0], params[1])) return SendEsp(playerid, "/setprefix [ID] [имя префикса]");//[ид цвета]


    new query[144];
    format(query,sizeof(query),"UPDATE `accounts` SET `pPrefix` = '%s' WHERE `pID` = '%d' LIMIT 1",params[1],PI[params[0]][pID]);
    mysql_tquery(connects, query,"","");

    new string[128];      
    format(string, sizeof(string), "%s выдал префикс %s администратору %s", player_name[playerid], params[1], player_name[params[0]]);  
    AdmMSG(0xAFAFAFAA, string,1);
    return true;
}

Замените полностью команду

Отредактировано пользователем Holmo

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


Ссылка на сообщение
  • 0

@viktor666 перед return true команды setprefix можно добавить это:

new string[128];
format(string, sizeof(string), "%s выдал префикс %s администратору %s", PI[playerid][pName], PI[params[0]][pPrefix], PI[params[0]][pName]);
AdmMSG(0xAFAFAFAA, string,1);

 

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


Ссылка на сообщение
  • 0

@keyl Так?

CMD:setprefix(playerid, params[])
{
    if(PI[playerid][pAdmin] < 5 || dostup[playerid] == 0return true;
    new string[128];
    format(string, sizeof(string), "%s выдал префикс %s администратору %s", PI[playerid][pName], PI[params[0]][pPrefix], PI[params[0]][pName]);
    AdmMSG(0xAFAFAFAA, string,1);
    if(sscanf(params, "ds[120]",params[0], params[1], params[2])) return SendEsp(playerid, "/setprefix [ID] [имя префикса]");//[ид цвета]

    // PI[params[0]][pPrefix] = params[1];
    strmid(PI[params[0]][pPrefix],params[1], 0, strlen(params[1]), 32);
    PI[params[0]][pPrefixColor] = params[2];
    // UpdatePlayerData(params[0],"pPrefix", PI[params[0]][pPrefix]);

    new query[300];
    format(query,sizeof(query),"UPDATE `accounts` SET `pPrefix` = '%s' WHERE `pID` = '%d' LIMIT 1",PI[params[0]][pPrefix],PI[params[0]][pID]);
    mysql_tquery(connects, query,"","");

    format(query,sizeof(query),"UPDATE `accounts` SET `pPrefixColor` = '%s' WHERE `pID` = '%d' LIMIT 1",PI[params[0]][pPrefixColor],PI[params[0]][pID]);
    mysql_tquery(connects, query,"","");
    

 

и проблема 

 : error 017: undefined symbol "pName"; did you mean "fName"?



1 Error.

 

скорее всего место pName нужно 

player_name т.к в pinfo нет pname

но как это сделать

 

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


Ссылка на сообщение
  • 0

сделал так format(string, sizeof(string), "%s выдал префикс %s администратору %s", player_name[playerid], PI[params[0]][pPrefix], player_name[playerid]); щас проверю работу

 

Сделал так 

    format(string, sizeof(string), "%s выдал префикс %s администратору %s", player_name[playerid], playerid,player_name[params[0]][pPrefix], player_name[playerid]);

Но пишет только Carlo_JJ выдал префикс администратору а мне нужно Carlo_JJ выдал префикс ГА администратору Carlo_JJ

Как сделать? помогите

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


Ссылка на сообщение
  • 0

Должно уже работать всё

@viktor666 

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


Ссылка на сообщение
  • 0

@Holmo 

Но пишет только Carlo_JJ выдал префикс администратору а мне нужно Carlo_JJ выдал префикс ГА администратору Carlo_JJ

Как сделать? помогите

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


Ссылка на сообщение
  • 0

полную команду скиньте и скриншот из игры после того, как выдали префикс

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


Ссылка на сообщение
  • 0
CMD:setprefix(playerid, params[])
{
    if(PI[playerid][pAdmin] < 5 || dostup[playerid] == 0return true;
    new string[128];
    format(string, sizeof(string), "%s выдал префикс %s администратору %s", player_name[playerid], playerid,player_name[params[0]][pPrefix], player_name[playerid]);
    AdmMSG(0xAFAFAFAA, string,1);
    if(sscanf(params, "ds[120]",params[0], params[1], params[2])) return SendEsp(playerid, "/setprefix [ID] [имя префикса]");//[ид цвета]

    // PI[params[0]][pPrefix] = params[1];
    strmid(PI[params[0]][pPrefix],params[1], 0, strlen(params[1]), 32);
    PI[params[0]][pPrefixColor] = params[2];
    // UpdatePlayerData(params[0],"pPrefix", PI[params[0]][pPrefix]);

    new query[300];
    format(query,sizeof(query),"UPDATE `accounts` SET `pPrefix` = '%s' WHERE `pID` = '%d' LIMIT 1",PI[params[0]][pPrefix],PI[params[0]][pID]);
    mysql_tquery(connects, query,"","");

    format(query,sizeof(query),"UPDATE `accounts` SET `pPrefixColor` = '%s' WHERE `pID` = '%d' LIMIT 1",PI[params[0]][pPrefixColor],PI[params[0]][pID]);
    mysql_tquery(connects, query,"","");
    return true;
}

 

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


Ссылка на сообщение
  • 0

а каким образом должно показывать выданный префикс, если вы сделали отправку сообщения до ВСЕХ проверок? o.O
 

new string[128];  

format(string, sizeof(string), "%s выдал префикс %s администратору %s", player_name[playerid], playerid,player_name[params[0]][pPrefix], player_name[playerid]);     
AdmMSG(0xAFAFAFAA, string,1);

в конец это просто добавьте, а в начале удалите...

Отредактировано пользователем Holmo

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


Ссылка на сообщение
  • 0

 

@Holmo так?

CMD:setprefix(playerid, params[])
{
    if(PI[playerid][pAdmin] < 5 || dostup[playerid] == 0return true;
    if(sscanf(params, "ds[120]",params[0], params[1], params[2])) return SendEsp(playerid, "/setprefix [ID] [имя префикса]");//[ид цвета]

    // PI[params[0]][pPrefix] = params[1];
    strmid(PI[params[0]][pPrefix],params[1], 0, strlen(params[1]), 32);
    PI[params[0]][pPrefixColor] = params[2];
    // UpdatePlayerData(params[0],"pPrefix", PI[params[0]][pPrefix]);

    new query[300];
    format(query,sizeof(query),"UPDATE `accounts` SET `pPrefix` = '%s' WHERE `pID` = '%d' LIMIT 1",PI[params[0]][pPrefix],PI[params[0]][pID]);
    mysql_tquery(connects, query,"","");

    format(query,sizeof(query),"UPDATE `accounts` SET `pPrefixColor` = '%s' WHERE `pID` = '%d' LIMIT 1",PI[params[0]][pPrefixColor],PI[params[0]][pID]);
    mysql_tquery(connects, query,"","");
    new string[128];
    format(string, sizeof(string), "%s выдал префикс %s администратору %s", player_name[playerid], playerid,player_name[params[0]][pPrefix], player_name[playerid]);
    AdmMSG(0xAFAFAFAA, string,1);
    return true;
}

 

Отредактировано пользователем viktor666

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


Ссылка на сообщение
  • 0

@Holmo такая проблема теперь пишет Carlo_JJ выдал префикс администратору arlo_JJ (1 буквы ника не хватает) и не пишет какой префикс выдали ("%s выдал префикс %s администратору %s")

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


Ссылка на сообщение
  • 0
new string[128];     

format(string, sizeof(string), "%s выдал префикс %s администратору %s", player_name[playerid], player_name[params[0]][pPrefix], player_name[params[0]]); 
AdmMSG(0xAFAFAFAA, string,1);

замените.

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


Ссылка на сообщение
  • 0

@Holmo Carlo_JJ выдал префикс arlo_JJ администратору Carlo_JJ теперь(нужно что бы место arlo_JJ было название префикса)

 

@Holmo Понял что мой гавнокод нужно менять и решил переписать )

Помогло.

Закрыто

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


Ссылка на сообщение
Гость
Эта тема закрыта для публикации ответов.
  • Последние посетители   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} };