В теме 11 сообщений

Данная команда создана для проверки IP адреса игрока.

CMD:ip(playerid, params[])
{
	// ваша проверка на администратора
	if(isnull(params))
		return 0;
	if(sscanf(params, "u", params[0]))
		return SendClientMessage(playerid, 0xFF0000FF, "{FFC800}[Команда] {FFFFFF}Используй: {4080FF}/ip [ID]") & 0;
	if(params[0] == INVALID_PLAYER_ID) 
		return 0;
	
	new string[59+(-2+15)+1];
	GetPlayerIp(params[0], string, sizeof string);
	format(string, sizeof string, "{FFC800}[Информация] {FFFFFF}IP игрока на данный момент: %s", string);
	SendClientMessage(playerid, 0xFF00FFFF, string);
	return 1;
}

 

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

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


Ссылка на сообщение
Поделиться на другие сайты

Немножко подправил команду. @Rich_Hen, коротко об изменениях:

  1. Спецификатор "u" в нативной функции sscanf возвращает либо ID введенного игрока, либо INVALID_PLAYER_ID (игрок не подключен). То есть сама библиотека вместо вас проверяет, подключен ли вообще такой игрок. Поэтому использовать IsPlayerConnected для params[0] не есть логично правильно.
  2. Вы всегда должны иметь возможность отслеживать результат работы любой функции. Потому не нужно от балды лепить "return true" (1) или "return false" (0). Каждый литерал должен нести соответствующий смысл: если функция успешно выполнена, возвратите успех (1), в противном же случае сделайте возврат неудачи (0). Так, в случае, если не введено ничего в поле аргументов (первое условие) или игрок не подключен (второе условие), мы возвращаем неудачу, ибо функция не выполнилась как нужно.
  3. В начале я добавил проверку "isnull". Это макрос, который проверяет, не является ли строка пустой. Таким образом, прежде, чем вызывать нативную функцию, мы используем обычную проверку на по типу "a != b?". Ибо время вызова нативной функции во много раз больше времени работы этого макроса (понятно, что это тысячные доли секунд, но так или иначе есть понятие оптимизация).
  4. Использовались функции, которые необязательно должны быть во всех игровых модах (типа SendServerMessage). Не следует выкладывать на публику код, имеющий большое число зависимостей. Это же касается и константных выражений, присутствующих исключительно в вашем моде.

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


Ссылка на сообщение
Поделиться на другие сайты

Стандартный код, нахрена?

Убери этот код, от него глаза болят!

 

Pawn.CMD /
CMD:ip(playerid,params[])
{
	// Проверка на админку
	static
		id,
		ip[16],
		string[50+16];
	if(sscanf(params,"i",id))
		return SendClientMessage(playerid,-1,"CMD: /ip [id]");

	if(id == INVALID_PLAYER_ID)
		return SendClientMesage(playerid,-1,"Такого ID не существует!");

	GetPlayerIp(id,ip,16);

	format(string,50+16,"[Информация]: У игрока под ID: %i, IP адрес: %s",
		id,ip);
	SendClientMessage(playerid,-1,string);

	string[0] = EOS;
		
	return 1;
}

 

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


Ссылка на сообщение
Поделиться на другие сайты

@HamanSamp, и что вы этим добились? Если игрок под ID 100 не в сети, то команда все равно для него будет работать, но некорректно. Так что у меня большие сомнения, от чьего кода болят глаза.

Статические переменные здесь тоже бессмысленны. Команда явно не будет использоваться каждую минуту, что жаль тратить время на выделение данных.

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


Ссылка на сообщение
Поделиться на другие сайты

@odosenok Хах. Про static давно знаком? Если незнаком, можешь прочитать, на многих форумах их полно, разницы нету. Я про IsPlayerConnected помолчу, ведь лучше всегда работать через переменную, которая указывала бы мне авторизацию игрока. 

И от выше кода человека, глаза плавятся. 

 

 

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


Ссылка на сообщение
Поделиться на другие сайты

В самой ф-ии GetPlayerIp есть проверка на подключение игрока, см. https://wiki.sa-mp.com/wiki/GetPlayerIp_RU

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


Ссылка на сообщение
Поделиться на другие сайты

@HamanSamp, спецификатором, указывающим на ID полученного игрока, "i" не является. Я вам указыввю на конкретный косяк (хотя вариант @DEST гораздо практичнее (здесь признаю и свою недоработку)), а вы мне утверждаете обратное. В моих знаниях оператора static можете не сомневаться. Я уже аргументировал: не вижу смысла хранить переменные данной команды в сегменте данных, поскольку эта команда используется нечасто. То же самое, что в глобальные переменные вынести и использовать в участке кода, который будет использоваться от силы пару раз в сутки. Хотя по сути выгоды от этого никакой.

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


Ссылка на сообщение
Поделиться на другие сайты

"u" удобней использовать, так как не только ID можно вводить, но и ник, и часть ника и все это будет конвертировано в ID. 

По поводу переменной, хранящей состояние игрока (подключен или нет). Фактически тоже самое реализовано в самом сервере и проверяется с помощью ф-ии IsPlayerConnected, которая, в свою очередь, встроена во многие другие стандартные функции. 

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


Ссылка на сообщение
Поделиться на другие сайты

@DEST не думаю что это бы являлось практичной. Ведь, если игрок не авторизовался на сервере, его нет смысла проверять, неверно ли? @odosenok А насчёт static, команду используют ежечасно по несколько раз, есть смысл ставить static. 

И да, насчёт ассамблера, на форуме его найти можно? Глубоко изучить хочется, а то на разных форумах ничего не понятно.

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

Ваш вопрос не соответствует содержимому данной темы, что приравнивается к оффтопу. Пожалуйста, оставьте свой вопрос в соответствующем разделе ("Флейм"), предварительно воспользовавшись поиском по форуму.

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


Ссылка на сообщение
Поделиться на другие сайты

@HamanSamp, а вы думаете, что "u" в спецификаторе как-то по-другому работает? Точно также проверяет.

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


Ссылка на сообщение
Поделиться на другие сайты

@HamanSamp Внимательние

Спойлер



CMD:ip(playerid,params[])
{
    //проверка на админа
    static
        id,
        ip[16],
        string[50+16];
    if(sscanf(params,"i",id))
        return SendClientMessage(playerid,-1,"CMD: /ip [id]");

    if(id == INVALID_PLAYER_ID)
        return SendClientMessage(playerid,-1,"Такого ID не существует!");

    GetPlayerIp(id,ip,16);

    format(string,50+16,"[Информация]: У игрока под ID: %i, IP адрес: %s",
        id,ip);
    SendClientMessage(playerid,-1,string);

    string[0] = EOS;

    return 1;
}


 

 

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

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

3.2. Код больше 10 строк необходимо брать в теги "Код" и "Спойлер". Как это сделать рассказано в разделе "FAQ".

Устное предупреждение.

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


Ссылка на сообщение
Поделиться на другие сайты

Для публикации сообщений создайте учётную запись или авторизуйтесь

Вы должны быть пользователем, чтобы оставить комментарий

Создать учетную запись

Зарегистрируйте новую учётную запись в нашем сообществе. Это очень просто!


Регистрация нового пользователя

Войти

Уже есть аккаунт? Войти в систему.


Войти

  • Последние посетители   0 пользователей онлайн

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

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

    • gooding
      От gooding


      Скачать файл PAR RP | Доработанный мод Cruela RP | Без багов
      Всем здравствуйте, уважаемые читатели. Я много времени потратил на доработку данного игрового мода, чтобы его выставить на форум.
      Лог доработок можно посмотреть внизу, а скриншоты игрового мода внизу и верху.
      Основа данного мода: Cruela RP
       
       

      Добавил gooding Добавлено 20.11.2024 Категория Моды Автор GOODING (Я)  
    • gooding
      От gooding
      Всем здравствуйте, уважаемые читатели. Я много времени потратил на доработку данного игрового мода, чтобы его выставить на форум.
      Лог доработок можно посмотреть внизу, а скриншоты игрового мода внизу и верху.
      Основа данного мода: Cruela RP
       
       

    • Max Luilchack
      От Max Luilchack
      Нужен человек который сможет сделать примерную карту Украины для сервера crmp mobile. Если есть желающие пишите в дс: lamarlml
    • Yashich
      От Yashich
      Возникла проблема, не работает команда /giverank Что здесь может работать не так? Заранее спасибо за ответ)
      Вот строки кода связанные с этой командой (мод Аризона)
       
      CMD:giverank(playerid, params[]) {     if(PI[playerid][pMember]<=0)return 0;     if(PI[playerid][pRank] < 9 && PI[playerid][pLeader] == 0) return SCM(playerid, COLOR_RED, !"Отказано в доступе!");     if(sscanf(params,"ud",params[0],params[1])) return SCM(playerid, COLOR_RED, !"Используйте: /giverank [id] [rank]");     if(!ProxDetectorS(8.0, playerid, params[0])) return SCM(playerid, COLOR_GREY, !"Вы должны находиться рядом с игроком!");     if(PI[params[0]][pLeader] > 0 ) return SCM(playerid, COLOR_RED, !"Вы не можете изменять ранг лидеру");     if(params[1] < 1) return SCM(playerid, COLOR_GREY, !"Нельзя повысить до этого ранга");     if(Clother[params[0]]!=-1)return 0;     if(GetPlayerVirtualWorld(playerid)!=GetPlayerVirtualWorld(params[0]))return 0;     if(!IsPlayerConnected(params[0])) return SCM(playerid, COLOR_GREY, !"Игрок не найден");     if(PI[playerid][pRank] <= PI[params[0]][pRank]) return SCM(playerid, COLOR_GREY, !"Вы не можете повысить/понизить этого игрока");     if(PI[playerid][pRank] == 9 && params[1] > 8) return SCM(playerid, COLOR_RED, !"Нельзя выдать ранг больше 8");     if(params[1] > 9) return SCM(playerid, COLOR_GREY, !"Нельзя повысить до этого ранга");     if(PI[params[0]][pMember] != PI[playerid][pMember]) return SCM(playerid, COLOR_GREY, !"Игрок находиться в другой организации!");     str_1[0] = EOS;     f(str_1,100,"Лидер %s %s до %i ранга",PN(playerid),PI[params[0]][pRank] > params[1] ? ("понизил"):("повысил"),params[1]);     SCM(params[0],COLOR_LIGHTBLUE,str_1);     f(str_1,100,"Вы %sи игрока %s до %i ранга",PI[params[0]][pRank] > params[1] ? ("понизил"):("повысил"),PN(params[0]),params[1]);     SCM(playerid,COLOR_LIGHTBLUE,str_1);     PI[params[0]][pRank] = params[1];     UpdatePlayerDataInt(params[0], "Rank", params[1]);     if(PI[params[0]][pSex] == 2) if(TeamDuty{params[0]}) SetPlayerSkinEx(params[0],GOrgSkins[GetTeamID(params[0])][params[1]]), TogglePlayerControllable(params[0],true);     else if(TeamDuty{params[0]}) SetPlayerSkinEx(params[0],MOrgSkins[GetTeamID(params[0])][params[1]]), TogglePlayerControllable(params[0],true);     return 1; }