Fixed some aliasing bugs, added in commandAnnounce type of command, fixed /reply, changed the command list to be an ArrayList instead of Array.

This commit is contained in:
cerevisiae 2010-12-08 03:47:42 -06:00
parent 8f09d9c428
commit 4d1feb4f3b
3 changed files with 252 additions and 143 deletions

View File

@ -149,7 +149,7 @@ public class vMinecraftChat {
return 4; return 4;
else if("fk{}<>\"*()".indexOf(x) != -1) else if("fk{}<>\"*()".indexOf(x) != -1)
return 5; return 5;
else if("abcdeghjmnopqrsuvwxyzABCDEFGHJKLMNOPQRSTUVWXYZ1234567890\\/#?$%-=_+&^".indexOf(x) != -1) else if("abcdeghjmnopqrsuvwxyzABCDEFGHJKLMNOPQRSTUVWXYZ1234567890\\/#?$%-=_+&".indexOf(x) != -1)
return 6; return 6;
else if("@~".indexOf(x) != -1) else if("@~".indexOf(x) != -1)
return 7; return 7;
@ -311,7 +311,7 @@ public class vMinecraftChat {
{ {
//Special formatting for adminchat {Username} //Special formatting for adminchat {Username}
String adminchat = Colors.DarkPurple + "{" + getName(player) String adminchat = Colors.DarkPurple + "{" + getName(player)
+ Colors.DarkPurple +"}" + Colors.White + " "; + Colors.DarkPurple +"} ";
//Cut off the @ prefix //Cut off the @ prefix
if(message.startsWith("@")) if(message.startsWith("@"))
@ -352,7 +352,7 @@ public class vMinecraftChat {
+ Colors.White + "> "; + Colors.White + "> ";
if(vMinecraftSettings.getInstance().greentext()) { if(vMinecraftSettings.getInstance().greentext()) {
//Log the chat //Log the chat
log.log(Level.INFO, "<"+player.getName()+"> " +message); log.log(Level.INFO, "<"+player.getName()+"> " + message);
//Output the message //Output the message
gmsg(player, playerName + Colors.LightGreen + message); gmsg(player, playerName + Colors.LightGreen + message);

View File

@ -1,6 +1,7 @@
import java.io.IOException; import java.io.IOException;
import java.lang.reflect.InvocationTargetException; import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method; import java.lang.reflect.Method;
import java.util.ArrayList;
import java.util.logging.Level; import java.util.logging.Level;
import java.util.logging.Logger; import java.util.logging.Logger;
@ -28,6 +29,12 @@ public class vMinecraftCommands{
//===================================================================== //=====================================================================
public static void loadCommands(){ public static void loadCommands(){
//If we had commands we would add them here. //If we had commands we would add them here.
//register
//String: The command that will be used
//String: The name of the function that will be called when
// the command is used
//String(Optional): The help menu description
cl.register("/tp", "teleport"); cl.register("/tp", "teleport");
cl.register("/masstp", "masstp", "Teleports those with lower permissions to you"); cl.register("/masstp", "masstp", "Teleports those with lower permissions to you");
cl.register("/reload", "reload"); cl.register("/reload", "reload");
@ -40,22 +47,50 @@ public class vMinecraftCommands{
cl.register("/ezmodo", "invuln", "Toggle invulnerability"); cl.register("/ezmodo", "invuln", "Toggle invulnerability");
cl.register("/ezlist", "ezlist", "List invulnerable players"); cl.register("/ezlist", "ezlist", "List invulnerable players");
cl.register("/heal", "heal", "heal yourself or other players"); cl.register("/heal", "heal", "heal yourself or other players");
cl.register("/suicide", "suicide", "kill yourself... you loser"); cl.register("/suicide", "suicide", "Kill yourself... you loser");
cl.register("/a", "adminChatToggle", "toggle admin chat for every message"); cl.register("/a", "adminChatToggle", "Toggle admin chat for every message");
cl.register("/modify", "modifySplit"); cl.register("/modify", "modifySplit");
cl.register("/me", "me"); cl.register("/me", "me");
cl.register("/msg", "message"); cl.register("/msg", "message", "Send a message to a player /msg [Player] [Message]");
cl.register("/reply", "reply"); cl.register("/reply", "reply", "Reply to a player /reply [Message], Alias: /r");
//registerAlias
//String: The command that this will be called by
//String: The message that will be called when the first is entered
// Can be modified with %# to have it insert a player
// argument into that position.
// EX: Aliased command is
// cl.registerAlias("/test", "/i %0 100")
// Player uses /test wood
// The %0 will be replaced with wood for this instance
// and Player will be given 100 wood.
cl.registerAlias("/playerlist", "/who"); cl.registerAlias("/playerlist", "/who");
cl.registerAlias("/r", "/reply"); cl.registerAlias("/r", "/reply");
cl.registerAlias("/w", "/msg"); cl.registerAlias("/w", "/msg");
cl.registerAlias("/wrists", "/suicide"); cl.registerAlias("/wrists", "/suicide");
cl.registerAlias("/ci", "/clearinventory"); cl.registerAlias("/ci", "/clearinventory");
//registerMessage
//String: The command it will run on
//String: What will be displayed
// %p is the player calling the command
// %# is the argument number of the command.
// %#p is an argument number that will be required to be
// an online player
//String: The color the message will be
//int: The number of arguments required for the message to appear
//boolean: If the message should only display for admins
cl.registerMessage("/kick", "%p has kicked %0p", Colors.Blue, 1, false);
cl.registerMessage("/ban", "%p has banned %0p", Colors.Blue, 1, false);
cl.registerMessage("/ipban", "%p has IP banned %0p", Colors.Blue, 1, false);
cl.registerMessage("/time", "Time change thanks to %p", Colors.Blue, 1, true);
cl.registerMessage("/tp", "%p has teleported to %0p", Colors.Blue, 1, true);
} }
//===================================================================== //=====================================================================
//Function: me (/me) //Function: me (/me)
//Input: Player player: The player using the command //Input: Player player: The player using the command
// String[] args: Will contain the message the player sends
//Output: int: Exit Code //Output: int: Exit Code
//Use: The player uses this to emote, but now its colorful. //Use: The player uses this to emote, but now its colorful.
//===================================================================== //=====================================================================
@ -70,67 +105,90 @@ public class vMinecraftCommands{
//===================================================================== //=====================================================================
//Function: message (/msg, /w, /whisper) //Function: message (/msg, /w, /whisper)
//Input: Player player: The player using the command //Input: Player player: The player using the command
// String[] args: Will contain the target player name and
// message the player sends
//Output: int: Exit Code //Output: int: Exit Code
//Use: Send a message to a player //Use: Send a message to a player
//===================================================================== //=====================================================================
public static int message(Player player, String[] args) public static int message(Player player, String[] args)
{ {
String msg = etc.combineSplit(1, args, " "); if (args.length > 1) {
Player toPlayer = etc.getServer().matchPlayer(args[0]); String msg = etc.combineSplit(1, args, " ");
if (args.length < 1) { Player toPlayer = etc.getServer().matchPlayer(args[0]);
return EXIT_FAIL; if (toPlayer != null && args.length > 0) {
} else if (toPlayer != null) {
//Send the message to the targeted player and the sender //Send the message to the targeted player and the sender
vMinecraftChat.sendMessage(player, toPlayer, vMinecraftChat.sendMessage(player, toPlayer,
Colors.LightGreen + "[" + Colors.White + "From:" Colors.LightGreen + "[From:" + vMinecraftChat.getName(player)
+ vMinecraftChat.getName(player) + Colors.LightGreen + "] " + Colors.LightGreen + "] " + msg);
+ msg);
vMinecraftChat.sendMessage(player, player, vMinecraftChat.sendMessage(player, player,
Colors.LightGreen + "[" + Colors.White + "To:" Colors.LightGreen + "[To:" + vMinecraftChat.getName(toPlayer)
+ vMinecraftChat.getName(toPlayer) + Colors.LightGreen + "] " + Colors.LightGreen + "] " + msg);
+ msg);
//Set the last massager for each player //Set the last massager for each player
vMinecraftUsers.players.findProfile(player).setMessage(toPlayer); vMinecraftUsers.players.findProfile(player).setMessage(toPlayer);
vMinecraftUsers.players.findProfile(toPlayer).setMessage(player); vMinecraftUsers.players.findProfile(toPlayer).setMessage(player);
//Display the message to the log
log.log(Level.INFO, player.getName() + " whispered to " + toPlayer.getName()
+ ": " + msg);
} else {
vMinecraftChat.sendMessage(player, player, Colors.Rose
+ "No player by the name of " + args[0] + " could be found.");
}
} else { } else {
vMinecraftChat.sendMessage(player, player, Colors.Red vMinecraftChat.sendMessage(player, player, Colors.Rose
+ "No player by the name of " + args[0] + " could be found."); + "Usage is /msg [player] [message]");
} }
return EXIT_SUCCESS; return EXIT_SUCCESS;
} }
//===================================================================== //=====================================================================
//Function: reply (/r, /reply) //Function: reply (/r, /reply)
//Input: Player player: The player using the command //Input: Player player: The player using the command
// String[] args: Will contain the message the player sends
//Output: int: Exit Code //Output: int: Exit Code
//Use: Send a message to a player //Use: Send a message to a player
//===================================================================== //=====================================================================
public static int reply(Player player, String[] args) public static int reply(Player player, String[] args)
{ {
Player toPlayer = vMinecraftUsers.players.findProfile(player).getMessage(); //If the profile exists for the player
if (toPlayer != null) { if(vMinecraftUsers.players.findProfile(player) != null )
String msg = etc.combineSplit(1, args, " "); {
//Send the message to the targeted player and the sender Player toPlayer = vMinecraftUsers.players.findProfile(player).getMessage();
vMinecraftChat.sendMessage(player, toPlayer, if (toPlayer != null && args.length > 0) {
Colors.LightGreen + "[" + Colors.White + "From:" String msg = etc.combineSplit(0, args, " ");
+ vMinecraftChat.getName(player) + Colors.LightGreen + "] " + msg);
vMinecraftChat.sendMessage(player, player, //Send the message to the targeted player and the sender
Colors.LightGreen + "[" + Colors.White + "To:" vMinecraftChat.sendMessage(player, toPlayer,
+ vMinecraftChat.getName(toPlayer) + Colors.LightGreen + "] " + msg); Colors.LightGreen + "[From:" + vMinecraftChat.getName(player)
+ Colors.LightGreen + "] " + msg);
//Set the last messager for each player vMinecraftChat.sendMessage(player, player,
vMinecraftUsers.players.findProfile(player).setMessage(toPlayer); Colors.LightGreen + "[To:" + vMinecraftChat.getName(toPlayer)
vMinecraftUsers.players.findProfile(toPlayer).setMessage(player); + Colors.LightGreen + "] " + msg);
} else {
vMinecraftChat.sendMessage(player, player, //Set the last messager for each player
Colors.Red + "That person is no longer logged in."); vMinecraftUsers.players.findProfile(player).setMessage(toPlayer);
vMinecraftUsers.players.findProfile(toPlayer).setMessage(player);
//Display the message to the log
log.log(Level.INFO, player.getName() + " whispered to " + toPlayer.getName()
+ ": " + msg);
} else {
vMinecraftChat.sendMessage(player, player,
Colors.Rose + "The person you last message has logged off");
}
} }
return EXIT_SUCCESS; return EXIT_SUCCESS;
} }
public static int addIgnored(Player player, String[] args)
{
return EXIT_SUCCESS;
}
//===================================================================== //=====================================================================
//Function: adminChatToggle (/a) //Function: adminChatToggle (/a)
//Input: Player player: The player using the command //Input: Player player: The player using the command
// String[] args: Ignored
//Output: int: Exit Code //Output: int: Exit Code
//Use: Toggles the player into admin chat. Every message they //Use: Toggles the player into admin chat. Every message they
// send will be piped to admin chat. // send will be piped to admin chat.
@ -605,19 +663,6 @@ public class vMinecraftCommands{
//if(cur) //if(cur)
return EXIT_SUCCESS; return EXIT_SUCCESS;
} }
//=====================================================================
//Function: privateMessage(/msg)
//Input: long time: The time to reverse to.
//Output: int: Exit Code
//Use: List all invulnerable players
//=====================================================================
public static int privateMessage(Player player, String[] message)
{
long curTime = etc.getServer().getRelativeTime();
//if(cur)
return EXIT_SUCCESS;
}
} }
//===================================================================== //=====================================================================
@ -626,11 +671,11 @@ public class vMinecraftCommands{
//Author: cerevisiae //Author: cerevisiae
//===================================================================== //=====================================================================
class commandList { class commandList {
command[] commands; ArrayList<command> commands;
protected static final Logger log = Logger.getLogger("Minecraft"); protected static final Logger log = Logger.getLogger("Minecraft");
static final int EXIT_FAIL = 0, static final int EXIT_FAIL = 0,
EXIT_SUCCESS = 1, EXIT_SUCCESS = 1,
EXIT_CONTINUE = 2; EXIT_CONTINUE = 2;
//===================================================================== //=====================================================================
//Function: commandList //Function: commandList
@ -639,7 +684,7 @@ class commandList {
//Use: Initialize the array of commands //Use: Initialize the array of commands
//===================================================================== //=====================================================================
public commandList(){ public commandList(){
commands = new command[0]; commands = new ArrayList<command>();
} }
//===================================================================== //=====================================================================
@ -649,28 +694,15 @@ class commandList {
//Output: boolean: Whether the command was input successfully or not //Output: boolean: Whether the command was input successfully or not
//Use: Registers a command to the command list for checking later //Use: Registers a command to the command list for checking later
//===================================================================== //=====================================================================
public boolean register(String name, String func){ public boolean register(String name, String func)
{
//If the command list isn't empty //Check to make sure the command doesn't already exist
if(commands.length > 0) for(command temp : commands)
{ if(temp.getName().equalsIgnoreCase(name))
//Check to make sure the command doesn't already exist return false;
for(int i = 0; i < commands.length; i++)
if(commands[i].getName().equalsIgnoreCase(name))
return false;
//Create a new temp array
command[] temp = new command[commands.length + 1];
//Copy the old command list over
System.arraycopy(commands, 0, temp, 0, commands.length);
//Set commands to equal the new array
commands = temp;
} else {
commands = new command[1];
}
//Add the new function to the list //Add the new function to the list
commands[commands.length - 1] = new command(name, func); commands.add(new command(name, func));
//exit successfully //exit successfully
return true; return true;
@ -699,62 +731,37 @@ class commandList {
//Output: boolean: Whether the command was input successfully or not //Output: boolean: Whether the command was input successfully or not
//Use: Registers a command to the command list for checking later //Use: Registers a command to the command list for checking later
//===================================================================== //=====================================================================
public boolean registerAlias(String name, String com, String[] args){ public boolean registerAlias(String name, String com)
{
//If the command list isn't empty //Check to make sure the command doesn't already exist
if(commands.length > 0) for(command temp : commands)
{ if(temp.getName().equalsIgnoreCase(name))
//Check to make sure the command doesn't already exist return false;
for(int i = 0; i < commands.length; i++)
if(commands[i].getName().equalsIgnoreCase(name))
return false;
//Create a new temp array
command[] temp = new command[commands.length + 1];
//Copy the old command list over
System.arraycopy(commands, 0, temp, 0, commands.length);
//Set commands to equal the new array
commands = temp;
} else {
commands = new command[1];
}
//Add the new function to the list //Add the new function to the list
commands[commands.length - 1] = new commandRef(name, com, args); commands.add(new commandRef(name, com));
//exit successfully //exit successfully
return true; return true;
} }
//===================================================================== //=====================================================================
//Function: register //Function: registerMessage
//Input: String name: The name of the command //Input: String name: The name of the command
// String func: The function to be called // String msg: The message to be displayed
// boolean admin: If the message is displayed to admins only
//Output: boolean: Whether the command was input successfully or not //Output: boolean: Whether the command was input successfully or not
//Use: Registers a command to the command list for checking later //Use: Registers a command to the command list for checking later
//===================================================================== //=====================================================================
public boolean registerAlias(String name, String com){ public boolean registerMessage(String name, String msg, String clr, int args, boolean admin)
{
//If the command list isn't empty //Check to make sure the command doesn't already exist
if(commands.length > 0) for(command temp : commands)
{ if(temp.getName().equalsIgnoreCase(name))
//Check to make sure the command doesn't already exist return false;
for(int i = 0; i < commands.length; i++)
if(commands[i].getName().equalsIgnoreCase(name))
return false;
//Create a new temp array
command[] temp = new command[commands.length + 1];
//Copy the old command list over
System.arraycopy(commands, 0, temp, 0, commands.length);
//Set commands to equal the new array
commands = temp;
} else {
commands = new command[1];
}
//Add the new function to the list //Add the new function to the list
commands[commands.length - 1] = new commandRef(name, com); commands.add(new commandAnnounce(name, msg, clr, args, admin));
//exit successfully //exit successfully
return true; return true;
@ -865,20 +872,6 @@ class commandList {
private String reference; private String reference;
private String[] args; private String[] args;
//=====================================================================
//Function: command
//Input: String name: The command name
// String com: The command to run
// String[] arg: the arguments to apply
//Output: None
//Use: Initialize the command
//=====================================================================
public commandRef(String name, String com, String[] arg){
super(name, "");
reference = com;
args = arg;
}
//===================================================================== //=====================================================================
//Function: command //Function: command
//Input: String name: The command name //Input: String name: The command name
@ -888,8 +881,14 @@ class commandList {
//===================================================================== //=====================================================================
public commandRef(String name, String com){ public commandRef(String name, String com){
super(name, ""); super(name, "");
reference = com;
args = null; //Get the reference name
String[]temp = com.split(" ");
reference = temp[0];
//Get the arguments
args = new String[temp.length - 1];
System.arraycopy(temp, 1, args, 0, temp.length - 1);
} }
@ -901,15 +900,18 @@ class commandList {
//===================================================================== //=====================================================================
int call(Player player, String[] arg) int call(Player player, String[] arg)
{ {
if(args != null) { String[] temp = new String[0];
String[] temp = new String[args.length]; int lastSet = 0,
argCount = 0;
//If there are args set with the function
if(args != null && args.length > 0) {
temp = new String[args.length];
System.arraycopy(args, 0, temp, 0, args.length); System.arraycopy(args, 0, temp, 0, args.length);
//Insert the arguments into the pre-set arguments //Insert the arguments into the pre-set arguments
int lastSet = 0,
argCount = 0;
for(String argument : temp) for(String argument : temp)
{ {
if(argument.startsWith("%")) if(argument.startsWith("%") && argument.length() > 1)
{ {
int argNum = Integer.parseInt(argument.substring(1)); int argNum = Integer.parseInt(argument.substring(1));
if( argNum < arg.length ) if( argNum < arg.length )
@ -920,6 +922,10 @@ class commandList {
} }
lastSet++; lastSet++;
} }
}
//If there are args being input
if(arg.length > 0) {
//Append the rest of the arguments to the argument array //Append the rest of the arguments to the argument array
if(lastSet < temp.length + arg.length - argCount) if(lastSet < temp.length + arg.length - argCount)
{ {
@ -930,6 +936,7 @@ class commandList {
temp = temp2; temp = temp2;
} }
log.log(Level.INFO, reference + " " + etc.combineSplit(0, temp, " "));
//Call the referenced command //Call the referenced command
player.command(reference + " " + etc.combineSplit(0, temp, " ")); player.command(reference + " " + etc.combineSplit(0, temp, " "));
} else } else
@ -937,4 +944,103 @@ class commandList {
return EXIT_SUCCESS; return EXIT_SUCCESS;
} }
} }
//=====================================================================
//Class: commandAnnounce
//Use: Announces when a command is used
//Author: cerevisiae
//=====================================================================
private class commandAnnounce extends command
{
private String message;
private boolean admin;
private int minArgs;
private String color;
//=====================================================================
//Function: commandAnnounce
//Input: String name: The command name
// String msg: The message to announce
//Output: None
//Use: Initialize the command
//=====================================================================
public commandAnnounce(String name, String msg, String clr, int args, boolean admn){
super(name, "");
message = msg;
admin = admn;
minArgs = args;
color = clr;
}
//=====================================================================
//Function: call
//Input: String[] arg: The arguments for the command
//Output: boolean: If the command was called successfully
//Use: Attempts to call the command
//=====================================================================
int call(Player player, String[] arg)
{
//Make sure the player can use the command first
if(!player.canUseCommand(super.commandName))
return EXIT_FAIL;
//Make sure the command is long enough to fire
if(minArgs < arg.length)
return EXIT_FAIL;
if(vMinecraftSettings.getInstance().globalmessages())
{
//Split up the message
String[] temp = message.split(" ");
//Insert the arguments into the message
int i = 0;
for(String argument : temp)
{
if(argument.startsWith("%") && argument.length() > 1)
{
char position = argument.charAt(1);
//Replace %p with the player name
if(position == 'p')
temp[i] = vMinecraftChat.getName(player) + color;
else if( Character.isDigit(position) && Character.getNumericValue(position) < arg.length )
{
//If the argument is specified to be a player insert it if the
//player is found or exit if they aren't
if(argument.length() > 2 && argument.charAt(2) == 'p')
{
Player targetName = etc.getServer().matchPlayer(arg[Character.getNumericValue(position)]);
if(targetName != null)
temp[i] = vMinecraftChat.getName(targetName) + color;
else
return EXIT_FAIL;
}
//Replace %# with the argument at position #
else
temp[i] = arg[Character.getNumericValue(position)];
}
}
i++;
}
message = etc.combineSplit(0, temp, " ");
//If it's an admin message only
if(admin)
{
for (Player p: etc.getServer().getPlayerList()) {
//If p is not null
if (p != null) {
//And if p is an admin or has access to adminchat send message
if (p.isAdmin()) {
vMinecraftChat.sendMessage(player, p, color + message);
}
}
}
} else
vMinecraftChat.gmsg(player, message);
}
return EXIT_FAIL;
}
}
} }

View File

@ -87,6 +87,7 @@ public class vMinecraftUsers {
//===================================================================== //=====================================================================
class PlayerList class PlayerList
{ {
protected static final Logger log = Logger.getLogger("Minecraft");
ArrayList<PlayerProfile> players; ArrayList<PlayerProfile> players;
//===================================================================== //=====================================================================
@ -165,6 +166,7 @@ class PlayerList
public PlayerProfile(Player player) public PlayerProfile(Player player)
{ {
//Declare things //Declare things
playerName = player.getName();
nickName = new String(); nickName = new String();
tag = new String(); tag = new String();
suffix = new String(); suffix = new String();
@ -386,8 +388,9 @@ class PlayerList
//===================================================================== //=====================================================================
public Player getMessage() public Player getMessage()
{ {
if(lastMessage != null)
return etc.getServer().matchPlayer(lastMessage); return etc.getServer().matchPlayer(lastMessage);
return null;
} }
} }
} }