base mod created

This commit is contained in:
Mohammad-Ali Minaie
2018-10-08 09:07:47 -04:00
parent 0a7700c356
commit b86dedad2f
7848 changed files with 584664 additions and 1 deletions

View File

@@ -0,0 +1,147 @@
package net.minecraft.command;
import com.google.common.collect.Lists;
import java.util.Collections;
import java.util.List;
import javax.annotation.Nullable;
import net.minecraft.entity.Entity;
import net.minecraft.entity.player.EntityPlayerMP;
import net.minecraft.scoreboard.IScoreCriteria;
import net.minecraft.scoreboard.Score;
import net.minecraft.scoreboard.ScoreObjective;
import net.minecraft.scoreboard.Scoreboard;
import net.minecraft.server.MinecraftServer;
import net.minecraft.util.math.BlockPos;
public class CommandTrigger extends CommandBase
{
/**
* Gets the name of the command
*/
public String getName()
{
return "trigger";
}
/**
* Return the required permission level for this command.
*/
public int getRequiredPermissionLevel()
{
return 0;
}
/**
* Gets the usage string for the command.
*/
public String getUsage(ICommandSender sender)
{
return "commands.trigger.usage";
}
/**
* Callback for when the command is executed
*/
public void execute(MinecraftServer server, ICommandSender sender, String[] args) throws CommandException
{
if (args.length < 3)
{
throw new WrongUsageException("commands.trigger.usage", new Object[0]);
}
else
{
EntityPlayerMP entityplayermp;
if (sender instanceof EntityPlayerMP)
{
entityplayermp = (EntityPlayerMP)sender;
}
else
{
Entity entity = sender.getCommandSenderEntity();
if (!(entity instanceof EntityPlayerMP))
{
throw new CommandException("commands.trigger.invalidPlayer", new Object[0]);
}
entityplayermp = (EntityPlayerMP)entity;
}
Scoreboard scoreboard = server.getWorld(0).getScoreboard();
ScoreObjective scoreobjective = scoreboard.getObjective(args[0]);
if (scoreobjective != null && scoreobjective.getCriteria() == IScoreCriteria.TRIGGER)
{
int i = parseInt(args[2]);
if (!scoreboard.entityHasObjective(entityplayermp.getName(), scoreobjective))
{
throw new CommandException("commands.trigger.invalidObjective", new Object[] {args[0]});
}
else
{
Score score = scoreboard.getOrCreateScore(entityplayermp.getName(), scoreobjective);
if (score.isLocked())
{
throw new CommandException("commands.trigger.disabled", new Object[] {args[0]});
}
else
{
if ("set".equals(args[1]))
{
score.setScorePoints(i);
}
else
{
if (!"add".equals(args[1]))
{
throw new CommandException("commands.trigger.invalidMode", new Object[] {args[1]});
}
score.increaseScore(i);
}
score.setLocked(true);
if (entityplayermp.interactionManager.isCreative())
{
notifyCommandListener(sender, this, "commands.trigger.success", new Object[] {args[0], args[1], args[2]});
}
}
}
}
else
{
throw new CommandException("commands.trigger.invalidObjective", new Object[] {args[0]});
}
}
}
/**
* Get a list of options for when the user presses the TAB key
*/
public List<String> getTabCompletions(MinecraftServer server, ICommandSender sender, String[] args, @Nullable BlockPos targetPos)
{
if (args.length == 1)
{
Scoreboard scoreboard = server.getWorld(0).getScoreboard();
List<String> list = Lists.<String>newArrayList();
for (ScoreObjective scoreobjective : scoreboard.getScoreObjectives())
{
if (scoreobjective.getCriteria() == IScoreCriteria.TRIGGER)
{
list.add(scoreobjective.getName());
}
}
return getListOfStringsMatchingLastWord(args, (String[])list.toArray(new String[list.size()]));
}
else
{
return args.length == 2 ? getListOfStringsMatchingLastWord(args, new String[] {"add", "set"}) : Collections.emptyList();
}
}
}