Вопросы

Доброго времени суток. Имеется у меня команда, которую переделывал господин odosenok. Команда - /gmx (рестарт сервера).

Раньше команда была без таймера (рестарт происходил сразу). Я попросил, чтобы мне сделали с таймером. То бишь, вводишь /gmx [5-300 секунд]. Через время, которое указываешь, будет произведён рестарт. Но, увы. После переделки эта команда вообще отказалась работать. После её вода совершенно никакого ответа.

CMD:gmx(playerid, params[])
{
	if(PI[playerid][pAdmin] == 8) return 1;
	else if(AdminLogged[playerid] == false) return SCM(playerid, COLOR_GREY, YouAreNotLoggedInAsAdmin);
	
	if(isnull(params)) return SCM(playerid, COLOR_WHITE, "• {66CC00}[ Подсказка ] {ffffff}Введите: /gmx [0 - 300 секунд]");
	new sec;
	if(sscanf(params, "d", sec)) return SCM(playerid, COLOR_WHITE, "• {66CC00}[ Подсказка ] {ffffff}Введите: /gmx [0 - 300 секунд]");
	else if(!(5 <= sec <= 300)) return SCM(playerid, COLOR_WHITE, "Время от 5 до 300 секунд");
	
	static timerid;
	if(sec == 0)
	{
		KillTimer(timerid);
		SendMesAll(COLOR_RED, "Администратор %s отменил технический перезапуск сервера", AdminName(playerid));
	}
	else
	{
		timerid = SetTimer("GameModeExitDelay", 1000*sec, false);
		GameTextForAll( "~b~RESTART", 5000, 3);
		SaveAcc();
		SaveWarehouse();
		foreach(new i: Player)
		{
			if(!PlayerLogged[i]) continue;
			SCM(i,COLOR_RED,"Технический перезапуск сервера. Приносим свои извинения.");
		}
	}
	return 1;
}

Прошу помощи.

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


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

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

  • 0

Эту строку:

else if(!(5 <= sec <= 300)) return SCM(playerid, COLOR_WHITE, "Время от 5 до 300 секунд");

Замените этой:

else if(!(5 <= sec <= 300) && sec != 0) return SCM(playerid, COLOR_WHITE, "Время от 5 до 300 секунд, либо 0");

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


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

ну во первых 

static timerid; new sec; в начала мода...

а во вторых скидывай GameModeExitDelay

ну и в третих 

else if(!(5 <= sec >= 300)) return SCM(playerid, COLOR_WHITE, "Время от 5 до 300 секунд");

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

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


Ссылка на сообщение
  • 0
4 часа назад, MuhammadPawn сказал:

else if(!(5 <= sec >= 300)) return SCM(playerid, COLOR_WHITE, "Время от 5 до 300 секунд");

 

Не-не, правильно там проверка на время была. Теаерь время должно быть больше 5 и больше 300..

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


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

@odosenok 

Цитата

от 5 до 300

¬¬ 

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


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

@MuhammadPawn двойное неравенство в первом примере составлено верно. Чтобы не запутаться, можно запомнить, что практически всегда они составляются с одинаковыми знаками в обеих частях. 

@Supreme Касаемо проблемы, то необходимо всегда помнить, что отладка наше все. Замените команду этим кодом, после вызовите ее на сервере и скиньте логи (server_log.txt). 

Спойлер

CMD:gmx(playerid, params[])
{
    if(PI[playerid][pAdmin] == 8) return 1;
    else if(AdminLogged[playerid] == false) return SCM(playerid, COLOR_GREY, YouAreNotLoggedInAsAdmin);

    if(isnull(params)) return SCM(playerid, COLOR_WHITE, "• {66CC00}[ Подсказка ] {ffffff}Введите: /gmx [0 - 300 секунд]");
    new sec;
    if(sscanf(params, "d", sec)) return SCM(playerid, COLOR_WHITE, "• {66CC00}[ Подсказка ] {ffffff}Введите: /gmx [0 - 300 секунд]");
    else if(!(5 <= sec <= 300)) return SCM(playerid, COLOR_WHITE, "Время от 5 до 300 секунд");

    printf("[#DEBUG] sec - %d", sec);
    static timerid;
    if(sec == 0)
    {
        KillTimer(timerid);
        SendMesAll(COLOR_RED, "Администратор %s отменил технический перезапуск сервера", AdminName(playerid));
    }
    else
    {
        print("[#DEBUG] before SetTimer");
        timerid = SetTimer("GameModeExitDelay", 1000*sec, false);
        print("[#DEBUG] after SetTimer"); 
        GameTextForAll( "~b~RESTART", 5000, 3);
        SaveAcc();
        SaveWarehouse();
        foreach(new i: Player)
        {
            if(!PlayerLogged[i]) continue;
            SCM(i,COLOR_RED,"Технический перезапуск сервера. Приносим свои извинения.");
        }
    }
    return 1;
}

 

 

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


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

@DEST Команду заменил. Захожу на сервер, ввожу команду (с таймером и без) - ноль реакции. В логах никакой информации нет.

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


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

@Supreme тогда в самое начало команды перед первой проверкой добавьте: 

print("[#DEBUG] command triggered!"); 

после проделайте все те же действия. 

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


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

@DEST [19:06:09] [#DEBUG] command triggered!

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


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

@Supreme значит, команда не выполняется из-за того, что у Вас уровень админки 8, что не подходит по условиям проверки. 

замените == на != 

Я думаю, что это должно было использоваться. 

После зайдите на сервер и проверьте. Если все будет работать, то все printf из команды можно удалить. 

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


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

@DESTЧто-то перепутал я. "==" заменил на "<", работает теперь. НО, отменить рестарт невозможно. Пишу /gmx 0, мне высвечивается:"Время от 5 до 300 секунд". Как-то исправить можно? Если поставить от 0 до 300, то отключение будет работать?

Теперь нужно разобраться с этой частью кода:

    else
    {
        timerid = SetTimer("GameModeExitDelay", 1000*sec, false);
        GameTextForAll( "~b~RESTART", 5000, 3);
        SaveAcc();
        SaveWarehouse();
        foreach(new i: Player)
        {
            if(!PlayerLogged[i]) continue;
            SCM(i,COLOR_RED,"Технический перезапуск сервера. Приносим свои извинения.");
        }
    }

Как сделать так, чтобы всё сохранение происходило уже в момент рестарта? Ведь пока будет идти время, игроки могут за это время приобрести/продать что-то, а получается, что сохранение уже произошло :с . 

Надо бы текст "Технический перезапуск ...." убрать, но в момент, когда администратор запустит рестарт, в общий чат будет такое сообщение "Администратор %s запустил таймер на перезапуск сервера - %d секунд", лишь после этого запустится "timerid = SetTimer("GameModeExitDelay", 1000*sec, false);", а за 5 секунд до самого рестарта "GameModeExitDelay" всех игроков кикает с сервера, и в этот же момент происходит сохранение, а затем и перезагрузка. Хелп ми, профессионалс пиплс ♥

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

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


Ссылка на сообщение
Гость
Эта тема закрыта для публикации ответов.
  • Последние посетители   0 пользователей онлайн

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

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

    • KAIF
      От KAIF


      Скачать файл GTA RolePlay-МОД,СБОРКА
      !!!!!ВСЕГО ОДНА КОПИЯ!!!! 
      Единственный мод GTA RP.
       
      Фракции:
      Правительство
      ГИБДД
      Полиция Южного
      ФСБ
      ЦГБ-А
      Автошкола
      Китайская мафия
      Русская Мафия
      Итальянская Мафия
      Американская Мафия
      Чеченская Мафия
      ВВС
      МЧС
      ОПГ Тяп-Ляп
      ОПГ Хади-Такташ
      СМИ Южного
      ФСИН
      В комплекте идёт СБОРКА И МОД.
      Единственный мод GTA RP.
      Добавил KAIF Добавлено 01.01.2024 Категория Моды Автор Aleksandr  
    • KAIF
      От KAIF
      !!!!!ВСЕГО ОДНА КОПИЯ!!!! 
      Единственный мод GTA RP.
       
      Фракции:
      Правительство
      ГИБДД
      Полиция Южного
      ФСБ
      ЦГБ-А
      Автошкола
      Китайская мафия
      Русская Мафия
      Итальянская Мафия
      Американская Мафия
      Чеченская Мафия
      ВВС
      МЧС
      ОПГ Тяп-Ляп
      ОПГ Хади-Такташ
      СМИ Южного
      ФСИН
      В комплекте идёт СБОРКА И МОД.
      Единственный мод GTA RP.
    • Узбек
      От Узбек
      Всем добрый вечер ребят! 
      Я начинающий, сегодня я вам сливаю команду 2(шт) на технические работы
      Ловите