Вопросы

Здравствуйте, у меня на сервере движок ZC_MD, sscanf. 

На днях сделал команду, но она работает не правильно. При выдаче блокировке в оффлайне указывает не верную причину и кол-во дней.

 

Спойлер

CMD:offban(playerid,params[])
{
    if(Login[playerid]==0) return false;
    if(PInfo[playerid][pAdmin] < 3) return false;
    if(!IsPlayerConnected(playerid)) return false;
    new name[24], days, banreason[20];
    if(sscanf(params, "s[32]s()", name, days, banreason)) return SCM(playerid,COLOR_VLADISLAVTIROFLISH, "Èñïîëüçóéòå: /offbarn [Íèê èãðîêà] [Ïðè÷èíà]");
      SetPVarString(playerid,"OffBanReason", banreason); // Ïðèñâàâàåì ïðè÷èíó ê PVar
       SetPVarInt(playerid,"OffBanDay", days); // Ïðèñâàèâàåì äíè ê PVar
    if(PInfo[params[0]][pAdmin] >= PInfo[playerid][pAdmin]) return SCM(playerid,COLOR_RED, "Âû íå ìîæåòå çàáëîêèðîâàòü àäìèíèñòðàòîðа!");
    format(Text, 200,"SELECT `pName` FROM `users` WHERE `pName` = '%s'", name);
    mysql_function_query(ConnectBD, Text, true, "CheckOffBan","dss", playerid, banreason);
    return true;
}

 

Помогите.

 

Отредактировано пользователем odosenok
Причина: занес код в соответствующий тег.

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


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

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

  • 0
if(sscanf(params, "s[24]ds[20]", name, days, banreason)) return SCM(playerid,COLOR_VLADISLAVTIROFLISH, "Èñïîëüçóéòå: /offbarn [Íèê èãðîêà] [Ïðè÷èíà]");

замените свою строку этой в команде /offban

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


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

@Vladislavmap191 функцию CheckOffBan скиньте

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


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

forward CheckOffBan(playerid, string[], banreason[]);
public CheckOffBan(playerid, string[], banreason[])
{
    new rows[2];
    cache_get_data(rows[0], rows[1]);
    if(rows[0])
    {
        new reason[32];
        GetPVarString(playerid,"OffBanReason",reason,sizeof(reason)); // Достаём причину из PVar
        GetPVarInt(playerid,"OffBanDay");
        format(Text, 456, "UPDATE `users` SET `BDAYS` = '%d', `pBan` = '1', `pBanReason` = '%s', `pBanWho` = '%s' WHERE `pName` = '%s'", GetPVarInt(playerid,"OffBanDay"), reason, PInfo[playerid][pName] ,string);
        QueryEmpty(ConnectBD, Text);
        format(Text, 256, "UPDATE `users` SET `GIVEBAN` = CURDATE() WHERE `pName` = '%s'", string);
        QueryEmpty(ConnectBD, Text);
        format(Text, 256, "UPDATE `users` SET `GIVEDBAN` = CURDATE() WHERE `pName` = '%s'", string);
        QueryEmpty(ConnectBD, Text);
        format(Text, 256, "UPDATE `users` SET `LOSTBAN` = (CURDATE() + INTERVAL '%d' DAY) WHERE `pName` = '%s'", GetPVarInt(playerid,"OffBanDay"), string);
        QueryEmpty(ConnectBD, Text);
        format(Text, 256, "UPDATE `users` SET `BDAYS`=DATEDIFF(`LOSTBAN`, `GIVEDBAN`) WHERE `pName` = '%s'", string);
        QueryEmpty(ConnectBD, Text);
        format(Text, 128, "Администратор %s[%d] забанил игрока %s на %d дней в оффлайне. Причина: %s", PInfo[playerid][pName],playerid, string, GetPVarInt(playerid,"OffBanDay"), reason);
        SendClientMessageToAll(0xFF6347AA,Text);
        format(Text,sizeof(Text),"[OFF-BAN] Администратор %s[%d] забанил игрока %s на %d дней в оффлайне. Причина: %s",PInfo[playerid][pName],playerid, string, GetPVarInt(playerid,"OffBanDay"),reason);
         DeletePVar(playerid,"OffBanReason"); // Удаляем PVar
        DeletePVar(playerid,"OffBanDay"); // Удаляем PVar
    }
    else
    {
        SCM(playerid, -1,"Аккаунт игрока не найден!");
    }
    return 1;
}

 

 

Отредактировано пользователем odosenok
Причина: занес код в соответствующий тег

Заметка от Cawfee , создано

Просмотрите внимательно тему с руководством по публикации большого кода.

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


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

@Vladislavmap191 предпоследнюю строчку в команде /offban замените: 

mysql_function_query(ConnectBD, Text, true, "CheckOffBan","dss", playerid, name, banreason);

 

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


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

Теперь он пишет, то что аккаунты на найдены. Хотя они есть.

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


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

@Vladislavmap191 теперь в конце команды перед return добавить следующую строку: 

printf("DEBUG /offban: Name: %s, Reason: %s, Days: %d", name, banreason, days); 

После на сервере введите команду, а логи скиньте сюда. 

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


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

13:23:39] sscanf warning: Strings without a length are deprecated, please add a destination size.
[13:23:39] sscanf warning: Unknown format specifier '(', skipping.
[13:23:39] sscanf warning: Unknown format specifier ')', skipping.
[13:23:39] sscanf warning: Format specifier does not match parameter count.
[13:23:39] DEBUG /offban: Name: 0, Reason: , Days: 51
[13:23:43] [chat] [Artem_Makeyvskiy]: анименчик
[13:24:04] [chat] [Vlad_Naumov]: он afk
[13:24:06] [chat] [Artem_Makeyvskiy]: почему когда тебя не было сервер был назван типо ОБТ
[13:24:21] [chat] [Vlad_Naumov]: Сори пж я серьёзн себе хотел дать хп
[13:24:48] [chat] [Vlad_Naumov]: Извиняешь?
[13:25:02] [chat] [Artem_Makeyvskiy]: уйди
[13:25:03] [chat] [Vlad_Naumov]: Баг?
[13:25:11] [chat] [Vlad_Naumov]: Отойдика
[13:25:22] [chat] [Artem_Makeyvskiy]: я на самый верх залазил
[13:25:24] [chat] [Vlad_Naumov]: Это не баг.

 

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

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


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

@DEST Спасибо большое, проблема решилась. Можешь еще помочь с выдачей варна оффлайн?

Спойлер

CMD:offwarn(playerid,params[])
{
    if(Login[playerid]==0) return false;
    if(PInfo[playerid][pAdmin] < 3) return false;
    if(!IsPlayerConnected(playerid)) return false;
    new banreason[20];
    if(sscanf(params, "s[32]s()", params[0],banreason)) return SCM(playerid,COLOR_VLADOS , "Èñïîëüçóéòå: /offwarn [Íèê èãðîêà] [Ïðè÷èíà]");
    if(PInfo[params[0]][pAdmin] >= PInfo[playerid][pAdmin]) return SCM(playerid,COLOR_RED, "Âû íå ìîæåòå ïðèìåíèòü ýòî äåéñòâèå ê àäìèíèñòðàòîðó!");
    format(Text, 200,"SELECT `pName` FROM `users` WHERE `pName` = '%s'", params[0]);
    mysql_function_query(ConnectBD, Text, true, "CheckOffBan","dss", playerid, banreason);
    return true;
}

 

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


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

@Vladislavmap191 Для каждого вопроса - новая тема. Если эта проблема решена, пометьте сообщение, которое Вам помогло галочкой и создайте новую тему для нового вопроса. 

Выдержка из правил форума: 

Цитата

2.8. Если вы нашли ответ на свой вопрос, рекомендуется поощрить автора лучшего ответа поднятием репутации, а также обязательно пометить ответ на вопрос лучшим. 

 

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


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

Спасибо, проблема решилась. Можно закрывать тему.

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


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