Вопросы

Здравствуйте, у меня на сервере движок 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 пользователей онлайн

    Ни одного зарегистрированного пользователя не просматривает данную страницу

  • Похожий контент

    • dante34538
      От dante34538
      Группа ВКонтакте : vk.com/always_mobile
      В группе в описание находятся ссылки на сайт,а так-же на форум
      Добавляй наш IP-Aдрес в избранное: one.always-rp.9ab.ru:1177

      Запуск сервера планируется 28 апреля.

      На сервере имеется один город Los Santos,если онлайн будет повышаться буду открывать LV,SF и фракции добавлять в эти города.

      Будем стараться реализовывать все предложения

      Надеюсь на вашу поддержку, думаю что-то да и получится.

      (В скором времени будет сделан лаунчер и клиент на Android)

      Информация о проекте:
       
      Мод проекта в некоторых местах будет напоминать Samp RolePlay,но это не значит, что делается фулл копия Samp Rp, нет!
       
      На проекте делаются свои системы и они уже есть там, но некоторые функции систем напоминают Samp Rp

      Скриншоты проекта(мода) опубликовываются в группе ВКонтакте, так-же на форуме
       
      После открытия мы начнём делать свои обновления(именно свои!) и будем переписывать системы мода
    • gooding
      От gooding


      Скачать файл ELITE RP | МОД БОНУСНОГО ПРОЕКТА
      Доброго времени суток, уважаемые читатели, я выставил на продажу мод ELITE RP !
      Что же в этом моде уникального?
      - Работы из реальной жизни. (Яндекс Еда  CDEK  Инкассатор)
      - Кланы. (Тиктокеры, Блоггеры, Хамы, Министры, Звери, Сосиски, Сладкие, Ублюдки, Цари и Прокуроры)
      - Радужный, Мигающий клист.
      - Донат-плюшки.
      - Неон на автомобиль, Supreme-наклейка.
      - Брони-транспорт.
      - Кейсы. (SILVER, MEGA, SUPER)
      - ДМ-зона.
      - Эксклюзивные аксессуары.
      - Lamborgini Gold.
      - Новые мафии. (ОПГ)
      - Привилегии для машины. (10.000 HP, телепортация личного транспорта)
      - Система банкоматов.
      - Таксопарки. (VIP-класса и Business)
      - Уникальная система управления личным транспортом. (/cars)
      - Новая система казино.
      - Свой маппинг.
      И многое другое!

      Мод будет дополняться!
      Добавил gooding Добавлено 20.04.2024 Категория Моды Автор gooding  
    • tivan666ban
      От tivan666ban
      Скажите пожалуйста почему этот код(знаю что ещё не допиленный) 
      выдаёт эти ошибки