#23

You need utils.inc

or just

Код:
ReturnUser(text[], playerid = INVALID_PLAYER_ID)
{
	new pos = 0;
	while (text[pos] < 0x21) // Strip out leading spaces
	{
		if (text[pos] == 0) return INVALID_PLAYER_ID; // No passed text
		pos++;
	}
	new userid = INVALID_PLAYER_ID;
	if (IsNumeric(text[pos])) // Check whole passed string
	{
		// If they have a numeric name you have a problem (although names are checked on id failure)
		userid = strval(text[pos]);
		if (userid >=0 && userid < MAX_PLAYERS)
		{
			if(!IsPlayerConnected(userid))
			{
				/*if (playerid != INVALID_PLAYER_ID)
				{
					SendClientMessage(playerid, 0xFF0000AA, "User not connected");
				}*/
				userid = INVALID_PLAYER_ID;
			}
			else
			{
				return userid; // A player was found
			}
		}
		/*else
		{
			if (playerid != INVALID_PLAYER_ID)
			{
				SendClientMessage(playerid, 0xFF0000AA, "Invalid user ID");
			}
			userid = INVALID_PLAYER_ID;
		}
		return userid;*/
		// Removed for fallthrough code
	}
	// They entered [part of] a name or the id search failed (check names just incase)
	new len = strlen(text[pos]);
	new count = 0;
	new name[MAX_PLAYER_NAME];
	for (new i = 0; i < MAX_PLAYERS; i++)
	{
		if (IsPlayerConnected(i))
		{
			GetPlayerName(i, name, sizeof (name));
			if (strcmp(name, text[pos], true, len) == 0) // Check segment of name
			{
				if (len == strlen(name)) // Exact match
				{
					return i; // Return the exact player on an exact match
					// Otherwise if there are two players:
					// Me and MeYou any time you entered Me it would find both
					// And never be able to return just Me's id
				}
				else // Partial match
				{
					count++;
					userid = i;
				}
			}
		}
	}
	if (count != 1)
	{
		if (playerid != INVALID_PLAYER_ID)
		{
			if (count)
			{
				SendClientMessage(playerid, 0xFF0000AA, "Multiple users found, please narrow search");
			}
			else
			{
				SendClientMessage(playerid, 0xFF0000AA, "No matching user found");
			}
		}
		userid = INVALID_PLAYER_ID;
	}
	return userid; // INVALID_USER_ID for bad return
}
Reply


Messages In This Thread
dcmd - by Kar - 19.06.2010, 00:12
Re: dcmd - by Antonio [G-RP] - 19.06.2010, 00:16
Re: dcmd - by Kar - 19.06.2010, 00:18
Re: dcmd - by Antonio [G-RP] - 19.06.2010, 00:21
Re: dcmd - by Kar - 19.06.2010, 00:25
Re: dcmd - by Antonio [G-RP] - 19.06.2010, 00:30
Re: dcmd - by Kar - 19.06.2010, 00:33
Re: dcmd - by Antonio [G-RP] - 19.06.2010, 00:36
Re: dcmd - by Kar - 19.06.2010, 00:40
Re: dcmd - by Antonio [G-RP] - 19.06.2010, 00:48
Re: dcmd - by Kar - 19.06.2010, 00:49
Re: dcmd - by TheInnocentOne - 19.06.2010, 03:53
Re: dcmd - by Kar - 19.06.2010, 03:55
Re: dcmd - by ledzep - 19.06.2010, 04:47
Re: dcmd - by Kar - 19.06.2010, 04:55
Re: dcmd - by ledzep - 19.06.2010, 06:10
Re: dcmd - by Kar - 19.06.2010, 06:21
Re: dcmd - by ledzep - 19.06.2010, 06:23
Re: dcmd - by Antonio [G-RP] - 19.06.2010, 06:26
Re: dcmd - by ledzep - 19.06.2010, 06:44
Re: dcmd - by Kar - 19.06.2010, 07:43
Re: dcmd - by Kar - 19.06.2010, 07:48
Re: dcmd - by ledzep - 19.06.2010, 08:03

Forum Jump:


Users browsing this thread: 1 Guest(s)