В теме 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 пользователей онлайн

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

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

    • Доналдо Фарекелка
      От Доналдо Фарекелка


      Скачать файл Arizona RolePlay || Ser
      Приветствую, этот мод я нашёл на просторах интернета. 
      Скачал мод у автора:  Developer Stravinskiy
      Доработал мод: Donaldo_Farekelka
       
      Предупреждаю! Мод сырой, багов стало меньше, но они есть.
      Мод: Баня, Подвал, В некоторых местах маппинг, система коронавируса, 8 лвл админок
       
      Информация:
      1) Dc_Cmd
      2) Mysql, mode, language - Всё настраивается теперь в pawno ( UPDATE: 1.1.0 )
      3) Административные права в данный момент можно выдать только через MYSQL ( BD ).
       
      То что я сделал ( Всё что я делаю сейчас, смотрите в изменениях ):
       
      Добавил Доналдо Фарекелка Добавлено 13.04.2023 Категория Моды Автор shenol (vk.com/donaldo_farekelka)  
    • KAIF
      От KAIF


      Скачать файл GTA RolePlay-МОД,СБОРКА
      !!!!!ВСЕГО ОДНА КОПИЯ!!!! 
      Единственный мод GTA RP.
       
      Фракции:
      Правительство
      ГИБДД
      Полиция Южного
      ФСБ
      ЦГБ-А
      Автошкола
      Китайская мафия
      Русская Мафия
      Итальянская Мафия
      Американская Мафия
      Чеченская Мафия
      ВВС
      МЧС
      ОПГ Тяп-Ляп
      ОПГ Хади-Такташ
      СМИ Южного
      ФСИН
      В комплекте идёт СБОРКА И МОД.
      Единственный мод GTA RP.
      Добавил KAIF Добавлено 01.01.2024 Категория Моды Автор Aleksandr  
    • gooding
      От gooding
      Доброго времени суток! Я выложил на продажу игровой мод RedRow RolePlay!
       
      17 ТИТУЛОВ, 14 КОСТЮМОВ (КАМЕРМЭН, ФЕЯ, СИ-ДЖЕЙ, ДЭДПУЛ, СПАНЧ БОБ, НИНДЗЯ, ДЕД МОРОЗ и другие!),
      BMW I8, BMW M5, BMW Vision M NEXT, Mercedes-Benz G-CLASS, Rolls-Royce Phantom! Система рулетки  (Исправлена, теперь не выпадает одно и то же),
      Автопарки Фракций (FBI и банд), МОД ОПТИМИЗИРОВАЛИ под ИГРУ, ДОБАВИЛИ НОВЫЙ АНТИЧИТ (Latest Nex-AC) и АНТИЧИТ настроен. Проделано много работы (Над модом работали полгода) и исправили множество багов.
       
      Что было добавлено?
      1. 17 титулов,
      2. 14 костюмов,
      3. Эксклюзивный транспорт (SandKing, Rolls-Royce Phantom, BMW I8, BMW M5, BMW Vision M NEXT, Mercedes-Benz G-CLASS).
      4. Автопарк ФБР и всех банд.
      5. Новый анти-чит.
      6. Оптимизация игрового мода.
      7. Премиум и уникальные возможности для владельцев Премиума.
      8. Команда /bonus, где можно получить бесплатно Red Coins.
      9. За АКТИВ даются Red Coins!
      10. Рестарт сервера в 5:00 по МСК.
      11. Радужный клист.
      12. Уникальный тюнинг для эксклюзивных машин и ускорение.
      13. Новая система банка.
      14. Исправлено множество багов.
      15. Новый маппинг.
    • Redmondd
      От Redmondd
      Хочу сделать команду /gpsoff, которая убирает метку