mirror of
https://github.com/mcMMO-Dev/mcMMO.git
synced 2026-02-18 17:53:00 +01:00
Compare commits
13 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
23719ace47 | ||
|
|
33882983e9 | ||
|
|
5aecedc074 | ||
|
|
69bf17a619 | ||
|
|
0292d3eefb | ||
|
|
0cd3e4ed84 | ||
|
|
3a26194a71 | ||
|
|
1313e3fe4b | ||
|
|
b2f400f61a | ||
|
|
9aa676cee1 | ||
|
|
eabf0f7f82 | ||
|
|
d0171809ec | ||
|
|
410c946faf |
@@ -7,10 +7,11 @@ Key:
|
|||||||
! Change
|
! Change
|
||||||
- Removal
|
- Removal
|
||||||
|
|
||||||
Version 1.4.03-dev
|
Version 1.4.03
|
||||||
+ Added option to advanced.yml to determine the # of enchant levels used when buffing Super Breaker & Giga Drill Breaker
|
+ Added option to advanced.yml to determine the # of enchant levels used when buffing Super Breaker & Giga Drill Breaker
|
||||||
+ Improved stats display for child skills
|
+ Improved stats display for child skills
|
||||||
+ Added cooldown between using Chimaera Wings
|
+ Added cooldown between using Chimaera Wings
|
||||||
|
= Fixed bug with '/party chat (on|off)' and '/partychat (on|off)' not working
|
||||||
= Fixed bug with Repair not decreasing enchanting levels properly
|
= Fixed bug with Repair not decreasing enchanting levels properly
|
||||||
= Fixed bug with Smelting not properly tracking furnaces
|
= Fixed bug with Smelting not properly tracking furnaces
|
||||||
= Fixed bug with Blast Mining not dropping blocks correctly
|
= Fixed bug with Blast Mining not dropping blocks correctly
|
||||||
@@ -28,8 +29,10 @@ Version 1.4.03-dev
|
|||||||
= Fixed bug where the 'mcmmo.commands.ptp.world.all' was registered twice
|
= Fixed bug where the 'mcmmo.commands.ptp.world.all' was registered twice
|
||||||
= Fixed bug where Beast Lore wouldn't work on friendly pets
|
= Fixed bug where Beast Lore wouldn't work on friendly pets
|
||||||
= Fixed bug where Deflect was calculated based on the attacker, not the defender. (We really did this time!)
|
= Fixed bug where Deflect was calculated based on the attacker, not the defender. (We really did this time!)
|
||||||
|
= Fixed bug where Treefeller would not deal durability damage when the axe "splinters into dozens of pieces"
|
||||||
! Moved the Salvage unlock level from config.yml to advanced.yml
|
! Moved the Salvage unlock level from config.yml to advanced.yml
|
||||||
! Changed how Chimaera Wings are acquired, you need to craft them now. (By default, use 5 feathers in a shapeless recipe)
|
! Changed how Chimaera Wings are acquired, you need to craft them now. (By default, use 5 feathers in a shapeless recipe)
|
||||||
|
! Changed how Chimaera Wings teleport players to the spawnpoint, will now check if the location is safe
|
||||||
- Removed option to disable Salvage via the config file. This should be handled via permissions instead.
|
- Removed option to disable Salvage via the config file. This should be handled via permissions instead.
|
||||||
- Removed the option to use Woodcutting without an axe from the config file.
|
- Removed the option to use Woodcutting without an axe from the config file.
|
||||||
|
|
||||||
|
|||||||
2
pom.xml
2
pom.xml
@@ -2,7 +2,7 @@
|
|||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<groupId>com.gmail.nossr50.mcMMO</groupId>
|
<groupId>com.gmail.nossr50.mcMMO</groupId>
|
||||||
<artifactId>mcMMO</artifactId>
|
<artifactId>mcMMO</artifactId>
|
||||||
<version>1.4.03-dev1</version>
|
<version>1.4.03</version>
|
||||||
<name>mcMMO</name>
|
<name>mcMMO</name>
|
||||||
<url>https://github.com/mcMMO-Dev/mcMMO</url>
|
<url>https://github.com/mcMMO-Dev/mcMMO</url>
|
||||||
<issueManagement>
|
<issueManagement>
|
||||||
|
|||||||
@@ -7,6 +7,8 @@ import org.bukkit.entity.Player;
|
|||||||
|
|
||||||
import com.gmail.nossr50.chat.ChatMode;
|
import com.gmail.nossr50.chat.ChatMode;
|
||||||
import com.gmail.nossr50.datatypes.player.McMMOPlayer;
|
import com.gmail.nossr50.datatypes.player.McMMOPlayer;
|
||||||
|
import com.gmail.nossr50.locale.LocaleLoader;
|
||||||
|
import com.gmail.nossr50.util.commands.CommandUtils;
|
||||||
import com.gmail.nossr50.util.player.UserManager;
|
import com.gmail.nossr50.util.player.UserManager;
|
||||||
|
|
||||||
public abstract class ChatCommand implements CommandExecutor {
|
public abstract class ChatCommand implements CommandExecutor {
|
||||||
@@ -21,8 +23,8 @@ public abstract class ChatCommand implements CommandExecutor {
|
|||||||
public boolean onCommand(CommandSender sender, Command command, String label, String[] args) {
|
public boolean onCommand(CommandSender sender, Command command, String label, String[] args) {
|
||||||
switch (args.length) {
|
switch (args.length) {
|
||||||
case 0:
|
case 0:
|
||||||
if (!(sender instanceof Player)) {
|
if (CommandUtils.noConsoleUsage(sender)) {
|
||||||
return false;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
mcMMOPlayer = UserManager.getPlayer((Player) sender);
|
mcMMOPlayer = UserManager.getPlayer((Player) sender);
|
||||||
@@ -38,19 +40,23 @@ public abstract class ChatCommand implements CommandExecutor {
|
|||||||
|
|
||||||
case 1:
|
case 1:
|
||||||
if (args[0].equalsIgnoreCase("on")) {
|
if (args[0].equalsIgnoreCase("on")) {
|
||||||
if (!(sender instanceof Player)) {
|
if (CommandUtils.noConsoleUsage(sender)) {
|
||||||
return false;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
mcMMOPlayer = UserManager.getPlayer((Player) sender);
|
||||||
|
|
||||||
enableChatMode(sender);
|
enableChatMode(sender);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (args[0].equalsIgnoreCase("off")) {
|
if (args[0].equalsIgnoreCase("off")) {
|
||||||
if (!(sender instanceof Player)) {
|
if (CommandUtils.noConsoleUsage(sender)) {
|
||||||
return false;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
mcMMOPlayer = UserManager.getPlayer((Player) sender);
|
||||||
|
|
||||||
disableChatMode(sender);
|
disableChatMode(sender);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@@ -78,11 +84,21 @@ public abstract class ChatCommand implements CommandExecutor {
|
|||||||
protected abstract void handleChatSending(CommandSender sender, String[] args);
|
protected abstract void handleChatSending(CommandSender sender, String[] args);
|
||||||
|
|
||||||
private void enableChatMode(CommandSender sender) {
|
private void enableChatMode(CommandSender sender) {
|
||||||
|
if (chatMode == ChatMode.PARTY && mcMMOPlayer.getParty() == null) {
|
||||||
|
sender.sendMessage(LocaleLoader.getString("Commands.Party.None"));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
chatMode.enable(mcMMOPlayer);
|
chatMode.enable(mcMMOPlayer);
|
||||||
sender.sendMessage(chatMode.getEnabledMessage());
|
sender.sendMessage(chatMode.getEnabledMessage());
|
||||||
}
|
}
|
||||||
|
|
||||||
private void disableChatMode(CommandSender sender) {
|
private void disableChatMode(CommandSender sender) {
|
||||||
|
if (chatMode == ChatMode.PARTY && mcMMOPlayer.getParty() == null) {
|
||||||
|
sender.sendMessage(LocaleLoader.getString("Commands.Party.None"));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
chatMode.disable(mcMMOPlayer);
|
chatMode.disable(mcMMOPlayer);
|
||||||
sender.sendMessage(chatMode.getDisabledMessage());
|
sender.sendMessage(chatMode.getDisabledMessage());
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -5,7 +5,7 @@ import org.bukkit.command.CommandExecutor;
|
|||||||
import org.bukkit.command.CommandSender;
|
import org.bukkit.command.CommandSender;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
import com.gmail.nossr50.commands.chat.PartyChatCommand;
|
import com.gmail.nossr50.mcMMO;
|
||||||
import com.gmail.nossr50.datatypes.player.McMMOPlayer;
|
import com.gmail.nossr50.datatypes.player.McMMOPlayer;
|
||||||
import com.gmail.nossr50.locale.LocaleLoader;
|
import com.gmail.nossr50.locale.LocaleLoader;
|
||||||
import com.gmail.nossr50.util.Permissions;
|
import com.gmail.nossr50.util.Permissions;
|
||||||
@@ -31,8 +31,8 @@ public class PartyCommand implements CommandExecutor {
|
|||||||
private CommandExecutor partyRenameCommand = new PartyRenameCommand();
|
private CommandExecutor partyRenameCommand = new PartyRenameCommand();
|
||||||
private CommandExecutor partyInfoCommand = new PartyInfoCommand();
|
private CommandExecutor partyInfoCommand = new PartyInfoCommand();
|
||||||
private CommandExecutor partyHelpCommand = new PartyHelpCommand();
|
private CommandExecutor partyHelpCommand = new PartyHelpCommand();
|
||||||
private CommandExecutor partyTeleportCommand = new PtpCommand();
|
private CommandExecutor partyTeleportCommand = mcMMO.p.getCommand("ptp").getExecutor();
|
||||||
private CommandExecutor partyChatCommand = new PartyChatCommand();
|
private CommandExecutor partyChatCommand = mcMMO.p.getCommand("partychat").getExecutor();
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean onCommand(CommandSender sender, Command command, String label, String[] args) {
|
public boolean onCommand(CommandSender sender, Command command, String label, String[] args) {
|
||||||
|
|||||||
@@ -97,6 +97,6 @@ public class PartyInfoCommand implements CommandExecutor {
|
|||||||
|
|
||||||
player.sendMessage(LocaleLoader.getString("Commands.Party.Members.Header"));
|
player.sendMessage(LocaleLoader.getString("Commands.Party.Members.Header"));
|
||||||
player.sendMessage(LocaleLoader.getString("Commands.Party.MembersNear", membersNear, membersOnline));
|
player.sendMessage(LocaleLoader.getString("Commands.Party.MembersNear", membersNear, membersOnline));
|
||||||
player.sendMessage(LocaleLoader.getString("Commands.Party.Members", createMembersList()));
|
player.sendMessage(createMembersList());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -23,15 +23,15 @@ public class McrankCommand implements CommandExecutor {
|
|||||||
public boolean onCommand(CommandSender sender, Command command, String label, String[] args) {
|
public boolean onCommand(CommandSender sender, Command command, String label, String[] args) {
|
||||||
switch (args.length) {
|
switch (args.length) {
|
||||||
case 0:
|
case 0:
|
||||||
|
if (!(sender instanceof Player)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
if (!Permissions.mcrank(sender)) {
|
if (!Permissions.mcrank(sender)) {
|
||||||
sender.sendMessage(command.getPermissionMessage());
|
sender.sendMessage(command.getPermissionMessage());
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!(sender instanceof Player)) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (Config.getInstance().getUseMySQL()) {
|
if (Config.getInstance().getUseMySQL()) {
|
||||||
sqlDisplay(sender, sender.getName());
|
sqlDisplay(sender, sender.getName());
|
||||||
}
|
}
|
||||||
@@ -94,11 +94,7 @@ public class McrankCommand implements CommandExecutor {
|
|||||||
for (SkillType skillType : SkillType.values()) {
|
for (SkillType skillType : SkillType.values()) {
|
||||||
int[] rankInts = LeaderboardManager.getPlayerRank(playerName, skillType);
|
int[] rankInts = LeaderboardManager.getPlayerRank(playerName, skillType);
|
||||||
|
|
||||||
if (skillType.isChildSkill()) {
|
if ((sender instanceof Player && !Permissions.skillEnabled(sender, skillType)) || skillType.isChildSkill()) {
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ((sender instanceof Player) && !Permissions.skillEnabled((Player) sender, skillType)) {
|
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -79,18 +79,18 @@ public class MctopCommand implements CommandExecutor {
|
|||||||
|
|
||||||
if (sql) {
|
if (sql) {
|
||||||
if (skill.equalsIgnoreCase("all")) {
|
if (skill.equalsIgnoreCase("all")) {
|
||||||
sqlDisplay(page, "taming+mining+woodcutting+repair+unarmed+herbalism+excavation+archery+swords+axes+acrobatics+fishing", sender, command);
|
sqlDisplay(page, "taming+mining+woodcutting+repair+unarmed+herbalism+excavation+archery+swords+axes+acrobatics+fishing", sender);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
sqlDisplay(page, skill, sender, command);
|
sqlDisplay(page, skill, sender);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
flatfileDisplay(page, skill, sender, command);
|
flatfileDisplay(page, skill, sender);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void flatfileDisplay(int page, String skill, CommandSender sender, Command command) {
|
private void flatfileDisplay(int page, String skill, CommandSender sender) {
|
||||||
LeaderboardManager.updateLeaderboards(); // Make sure we have the latest information
|
LeaderboardManager.updateLeaderboards(); // Make sure we have the latest information
|
||||||
|
|
||||||
String[] info = LeaderboardManager.retrieveInfo(skill, page);
|
String[] info = LeaderboardManager.retrieveInfo(skill, page);
|
||||||
@@ -122,7 +122,7 @@ public class MctopCommand implements CommandExecutor {
|
|||||||
sender.sendMessage(LocaleLoader.getString("Commands.mctop.Tip"));
|
sender.sendMessage(LocaleLoader.getString("Commands.mctop.Tip"));
|
||||||
}
|
}
|
||||||
|
|
||||||
private void sqlDisplay(int page, String query, CommandSender sender, Command command) {
|
private void sqlDisplay(int page, String query, CommandSender sender) {
|
||||||
mcMMO.p.getServer().getScheduler().runTaskAsynchronously(mcMMO.p, new MctopCommandAsyncTask(page, query, sender, command));
|
mcMMO.p.getServer().getScheduler().runTaskAsynchronously(mcMMO.p, new MctopCommandAsyncTask(page, query, sender));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -60,79 +60,79 @@ public final class LeaderboardManager {
|
|||||||
ArrayList<String> players = new ArrayList<String>();
|
ArrayList<String> players = new ArrayList<String>();
|
||||||
|
|
||||||
while ((line = in.readLine()) != null) {
|
while ((line = in.readLine()) != null) {
|
||||||
String[] character = line.split(":");
|
String[] data = line.split(":");
|
||||||
|
|
||||||
String p = character[0];
|
String playerName = data[0];
|
||||||
int powerLevel = 0;
|
int powerLevel = 0;
|
||||||
|
|
||||||
// Prevent the same player from being added multiple times (I'd like to note that this shouldn't happen...)
|
// Prevent the same player from being added multiple times (I'd like to note that this shouldn't happen...)
|
||||||
if (players.contains(p)) {
|
if (players.contains(playerName)) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
players.add(p);
|
players.add(playerName);
|
||||||
|
|
||||||
if (character.length > 1 && StringUtils.isInt(character[1])) {
|
if (data.length > 1 && StringUtils.isInt(data[1])) {
|
||||||
mining.add(new PlayerStat(p, Integer.parseInt(character[1])));
|
mining.add(new PlayerStat(playerName, Integer.parseInt(data[1])));
|
||||||
powerLevel += Integer.parseInt(character[1]);
|
powerLevel += Integer.parseInt(data[1]);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (character.length > 5 && StringUtils.isInt(character[5])) {
|
if (data.length > 5 && StringUtils.isInt(data[5])) {
|
||||||
woodcutting.add(new PlayerStat(p, Integer.parseInt(character[5])));
|
woodcutting.add(new PlayerStat(playerName, Integer.parseInt(data[5])));
|
||||||
powerLevel += Integer.parseInt(character[5]);
|
powerLevel += Integer.parseInt(data[5]);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (character.length > 7 && StringUtils.isInt(character[7])) {
|
if (data.length > 7 && StringUtils.isInt(data[7])) {
|
||||||
repair.add(new PlayerStat(p, Integer.parseInt(character[7])));
|
repair.add(new PlayerStat(playerName, Integer.parseInt(data[7])));
|
||||||
powerLevel += Integer.parseInt(character[7]);
|
powerLevel += Integer.parseInt(data[7]);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (character.length > 8 && StringUtils.isInt(character[8])) {
|
if (data.length > 8 && StringUtils.isInt(data[8])) {
|
||||||
unarmed.add(new PlayerStat(p, Integer.parseInt(character[8])));
|
unarmed.add(new PlayerStat(playerName, Integer.parseInt(data[8])));
|
||||||
powerLevel += Integer.parseInt(character[8]);
|
powerLevel += Integer.parseInt(data[8]);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (character.length > 9 && StringUtils.isInt(character[9])) {
|
if (data.length > 9 && StringUtils.isInt(data[9])) {
|
||||||
herbalism.add(new PlayerStat(p, Integer.parseInt(character[9])));
|
herbalism.add(new PlayerStat(playerName, Integer.parseInt(data[9])));
|
||||||
powerLevel += Integer.parseInt(character[9]);
|
powerLevel += Integer.parseInt(data[9]);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (character.length > 10 && StringUtils.isInt(character[10])) {
|
if (data.length > 10 && StringUtils.isInt(data[10])) {
|
||||||
excavation.add(new PlayerStat(p, Integer.parseInt(character[10])));
|
excavation.add(new PlayerStat(playerName, Integer.parseInt(data[10])));
|
||||||
powerLevel += Integer.parseInt(character[10]);
|
powerLevel += Integer.parseInt(data[10]);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (character.length > 11 && StringUtils.isInt(character[11])) {
|
if (data.length > 11 && StringUtils.isInt(data[11])) {
|
||||||
archery.add(new PlayerStat(p, Integer.parseInt(character[11])));
|
archery.add(new PlayerStat(playerName, Integer.parseInt(data[11])));
|
||||||
powerLevel += Integer.parseInt(character[11]);
|
powerLevel += Integer.parseInt(data[11]);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (character.length > 12 && StringUtils.isInt(character[12])) {
|
if (data.length > 12 && StringUtils.isInt(data[12])) {
|
||||||
swords.add(new PlayerStat(p, Integer.parseInt(character[12])));
|
swords.add(new PlayerStat(playerName, Integer.parseInt(data[12])));
|
||||||
powerLevel += Integer.parseInt(character[12]);
|
powerLevel += Integer.parseInt(data[12]);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (character.length > 13 && StringUtils.isInt(character[13])) {
|
if (data.length > 13 && StringUtils.isInt(data[13])) {
|
||||||
axes.add(new PlayerStat(p, Integer.parseInt(character[13])));
|
axes.add(new PlayerStat(playerName, Integer.parseInt(data[13])));
|
||||||
powerLevel += Integer.parseInt(character[13]);
|
powerLevel += Integer.parseInt(data[13]);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (character.length > 14 && StringUtils.isInt(character[14])) {
|
if (data.length > 14 && StringUtils.isInt(data[14])) {
|
||||||
acrobatics.add(new PlayerStat(p, Integer.parseInt(character[14])));
|
acrobatics.add(new PlayerStat(playerName, Integer.parseInt(data[14])));
|
||||||
powerLevel += Integer.parseInt(character[14]);
|
powerLevel += Integer.parseInt(data[14]);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (character.length > 24 && StringUtils.isInt(character[24])) {
|
if (data.length > 24 && StringUtils.isInt(data[24])) {
|
||||||
taming.add(new PlayerStat(p, Integer.parseInt(character[24])));
|
taming.add(new PlayerStat(playerName, Integer.parseInt(data[24])));
|
||||||
powerLevel += Integer.parseInt(character[24]);
|
powerLevel += Integer.parseInt(data[24]);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (character.length > 34 && StringUtils.isInt(character[34])) {
|
if (data.length > 34 && StringUtils.isInt(data[34])) {
|
||||||
fishing.add(new PlayerStat(p, Integer.parseInt(character[34])));
|
fishing.add(new PlayerStat(playerName, Integer.parseInt(data[34])));
|
||||||
powerLevel += Integer.parseInt(character[34]);
|
powerLevel += Integer.parseInt(data[34]);
|
||||||
}
|
}
|
||||||
|
|
||||||
powerLevels.add(new PlayerStat(p, powerLevel));
|
powerLevels.add(new PlayerStat(playerName, powerLevel));
|
||||||
}
|
}
|
||||||
in.close();
|
in.close();
|
||||||
}
|
}
|
||||||
@@ -188,72 +188,22 @@ public final class LeaderboardManager {
|
|||||||
statsList = playerStatHash.get(SkillType.getSkill(skillType));
|
statsList = playerStatHash.get(SkillType.getSkill(skillType));
|
||||||
}
|
}
|
||||||
|
|
||||||
int destination;
|
int destination = (pageNumber - 1) * 10;
|
||||||
|
|
||||||
// How many lines to skip through
|
for (int i = 0; i < 10; i++) {
|
||||||
if (pageNumber == 1) {
|
PlayerStat ps = statsList.get(destination + i);
|
||||||
destination = 0;
|
info[i] = ps.name + ":" + ps.statVal;
|
||||||
}
|
|
||||||
else {
|
|
||||||
destination = (pageNumber * 10) - 9;
|
|
||||||
}
|
|
||||||
|
|
||||||
int currentPos = 0;
|
|
||||||
|
|
||||||
for (PlayerStat ps : statsList) {
|
|
||||||
if (currentPos == 10) {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (destination > 1) {
|
|
||||||
destination--;
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
info[currentPos] = ps.name + ":" + ps.statVal;
|
|
||||||
currentPos++;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return info;
|
return info;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static int[] getPlayerRank(String playerName) {
|
public static int[] getPlayerRank(String playerName) {
|
||||||
int currentPos = 1;
|
return getPlayerRank(playerName, powerLevels);
|
||||||
|
|
||||||
if (powerLevels != null) {
|
|
||||||
for (PlayerStat stat : powerLevels) {
|
|
||||||
if (stat.name.equalsIgnoreCase(playerName)) {
|
|
||||||
return new int[] {currentPos, stat.statVal};
|
|
||||||
}
|
|
||||||
|
|
||||||
currentPos++;
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
return new int[] {0, 0};
|
|
||||||
}
|
|
||||||
|
|
||||||
return new int[] {0, 0};
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public static int[] getPlayerRank(String playerName, SkillType skillType) {
|
public static int[] getPlayerRank(String playerName, SkillType skillType) {
|
||||||
int currentPos = 1;
|
return getPlayerRank(playerName, playerStatHash.get(skillType));
|
||||||
List<PlayerStat> statsList = playerStatHash.get(skillType);
|
|
||||||
|
|
||||||
if (statsList != null) {
|
|
||||||
for (PlayerStat stat : statsList) {
|
|
||||||
if (stat.name.equalsIgnoreCase(playerName)) {
|
|
||||||
return new int[] {currentPos, stat.statVal};
|
|
||||||
}
|
|
||||||
|
|
||||||
currentPos++;
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
return new int[] {0, 0};
|
|
||||||
}
|
|
||||||
|
|
||||||
return new int[] {0, 0};
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public static boolean removeFlatFileUser(String playerName) {
|
public static boolean removeFlatFileUser(String playerName) {
|
||||||
@@ -315,8 +265,9 @@ public final class LeaderboardManager {
|
|||||||
mcMMO.p.getLogger().info("Purging powerless users...");
|
mcMMO.p.getLogger().info("Purging powerless users...");
|
||||||
|
|
||||||
int purgedUsers = 0;
|
int purgedUsers = 0;
|
||||||
|
|
||||||
for (PlayerStat stat : powerLevels) {
|
for (PlayerStat stat : powerLevels) {
|
||||||
if (stat.statVal == 0 && removeFlatFileUser(stat.name) && !mcMMO.p.getServer().getOfflinePlayer(stat.name).isOnline()) {
|
if (stat.statVal == 0 && !mcMMO.p.getServer().getOfflinePlayer(stat.name).isOnline() && removeFlatFileUser(stat.name)) {
|
||||||
purgedUsers++;
|
purgedUsers++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -394,6 +345,24 @@ public final class LeaderboardManager {
|
|||||||
return removedPlayers;
|
return removedPlayers;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static int[] getPlayerRank(String playerName, List<PlayerStat> statsList) {
|
||||||
|
int currentPos = 1;
|
||||||
|
|
||||||
|
if (statsList == null) {
|
||||||
|
return new int[] {0, 0};
|
||||||
|
}
|
||||||
|
|
||||||
|
for (PlayerStat stat : statsList) {
|
||||||
|
if (stat.name.equalsIgnoreCase(playerName)) {
|
||||||
|
return new int[] {currentPos, stat.statVal};
|
||||||
|
}
|
||||||
|
|
||||||
|
currentPos++;
|
||||||
|
}
|
||||||
|
|
||||||
|
return new int[] {0, 0};
|
||||||
|
}
|
||||||
|
|
||||||
private static class SkillComparator implements Comparator<PlayerStat> {
|
private static class SkillComparator implements Comparator<PlayerStat> {
|
||||||
@Override
|
@Override
|
||||||
public int compare(PlayerStat o1, PlayerStat o2) {
|
public int compare(PlayerStat o1, PlayerStat o2) {
|
||||||
|
|||||||
@@ -153,6 +153,8 @@ public class InventoryListener implements Listener {
|
|||||||
|
|
||||||
@EventHandler(priority = EventPriority.MONITOR, ignoreCancelled = true)
|
@EventHandler(priority = EventPriority.MONITOR, ignoreCancelled = true)
|
||||||
public void onInventoryClickEvent(InventoryClickEvent event) {
|
public void onInventoryClickEvent(InventoryClickEvent event) {
|
||||||
|
if (event.getSlot() >= 0) {
|
||||||
SkillUtils.removeAbilityBuff(event.getCurrentItem());
|
SkillUtils.removeAbilityBuff(event.getCurrentItem());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|||||||
@@ -32,11 +32,7 @@ public class McrankCommandAsyncTask implements Runnable {
|
|||||||
sender.sendMessage(LocaleLoader.getString("Commands.mcrank.Player", playerName));
|
sender.sendMessage(LocaleLoader.getString("Commands.mcrank.Player", playerName));
|
||||||
|
|
||||||
for (SkillType skillType : SkillType.values()) {
|
for (SkillType skillType : SkillType.values()) {
|
||||||
if (skillType.isChildSkill()) {
|
if ((sender instanceof Player && !Permissions.skillEnabled(sender, skillType)) || skillType.isChildSkill()) {
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ((sender instanceof Player) && !Permissions.skillEnabled((Player) sender, skillType)) {
|
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -4,15 +4,12 @@ import java.util.ArrayList;
|
|||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
|
|
||||||
import org.bukkit.ChatColor;
|
import org.bukkit.ChatColor;
|
||||||
import org.bukkit.command.Command;
|
|
||||||
import org.bukkit.command.CommandSender;
|
import org.bukkit.command.CommandSender;
|
||||||
|
|
||||||
import com.gmail.nossr50.mcMMO;
|
import com.gmail.nossr50.mcMMO;
|
||||||
import com.gmail.nossr50.config.Config;
|
import com.gmail.nossr50.config.Config;
|
||||||
import com.gmail.nossr50.database.DatabaseManager;
|
import com.gmail.nossr50.database.DatabaseManager;
|
||||||
import com.gmail.nossr50.datatypes.skills.SkillType;
|
|
||||||
import com.gmail.nossr50.locale.LocaleLoader;
|
import com.gmail.nossr50.locale.LocaleLoader;
|
||||||
import com.gmail.nossr50.util.Permissions;
|
|
||||||
import com.gmail.nossr50.util.StringUtils;
|
import com.gmail.nossr50.util.StringUtils;
|
||||||
|
|
||||||
public class MctopCommandAsyncTask implements Runnable {
|
public class MctopCommandAsyncTask implements Runnable {
|
||||||
@@ -20,23 +17,15 @@ public class MctopCommandAsyncTask implements Runnable {
|
|||||||
private CommandSender sender;
|
private CommandSender sender;
|
||||||
private String query;
|
private String query;
|
||||||
private int page;
|
private int page;
|
||||||
private Command command;
|
|
||||||
|
|
||||||
public MctopCommandAsyncTask(int page, String query, CommandSender sender, Command command) {
|
public MctopCommandAsyncTask(int page, String query, CommandSender sender) {
|
||||||
this.page = page;
|
this.page = page;
|
||||||
this.query = query;
|
this.query = query;
|
||||||
this.sender = sender;
|
this.sender = sender;
|
||||||
this.command = command;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
if (!query.equalsIgnoreCase("taming+mining+woodcutting+repair+unarmed+herbalism+excavation+archery+swords+axes+acrobatics+fishing")) {
|
|
||||||
if (!Permissions.mctop(sender, SkillType.getSkill(query))) {
|
|
||||||
sender.sendMessage(command.getPermissionMessage());
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
String tablePrefix = Config.getInstance().getMySQLTablePrefix();
|
String tablePrefix = Config.getInstance().getMySQLTablePrefix();
|
||||||
final HashMap<Integer, ArrayList<String>> userslist = DatabaseManager.read("SELECT " + query + ", user, NOW() FROM " + tablePrefix + "users JOIN " + tablePrefix + "skills ON (user_id = id) WHERE " + query + " > 0 ORDER BY " + query + " DESC, user LIMIT " + ((page * 10) - 10) + ",10");
|
final HashMap<Integer, ArrayList<String>> userslist = DatabaseManager.read("SELECT " + query + ", user, NOW() FROM " + tablePrefix + "users JOIN " + tablePrefix + "skills ON (user_id = id) WHERE " + query + " > 0 ORDER BY " + query + " DESC, user LIMIT " + ((page * 10) - 10) + ",10");
|
||||||
mcMMO.p.getServer().getScheduler().scheduleSyncDelayedTask(mcMMO.p, new Runnable() {
|
mcMMO.p.getServer().getScheduler().scheduleSyncDelayedTask(mcMMO.p, new Runnable() {
|
||||||
|
|||||||
@@ -232,6 +232,7 @@ public final class Woodcutting {
|
|||||||
short maxDurability = ModUtils.isCustomTool(inHand) ? ModUtils.getToolFromItemStack(inHand).getDurability() : inHandMaterial.getMaxDurability();
|
short maxDurability = ModUtils.isCustomTool(inHand) ? ModUtils.getToolFromItemStack(inHand).getDurability() : inHandMaterial.getMaxDurability();
|
||||||
|
|
||||||
if (finalDurability >= maxDurability) {
|
if (finalDurability >= maxDurability) {
|
||||||
|
inHand.setDurability(maxDurability);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -4,17 +4,20 @@ import java.util.ArrayList;
|
|||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
import org.bukkit.ChatColor;
|
import org.bukkit.ChatColor;
|
||||||
|
import org.bukkit.Location;
|
||||||
import org.bukkit.Material;
|
import org.bukkit.Material;
|
||||||
import org.bukkit.block.Block;
|
import org.bukkit.Sound;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
import org.bukkit.inventory.ItemStack;
|
import org.bukkit.inventory.ItemStack;
|
||||||
import org.bukkit.inventory.ShapelessRecipe;
|
import org.bukkit.inventory.ShapelessRecipe;
|
||||||
import org.bukkit.inventory.meta.ItemMeta;
|
import org.bukkit.inventory.meta.ItemMeta;
|
||||||
|
import org.bukkit.util.Vector;
|
||||||
|
|
||||||
import com.gmail.nossr50.config.Config;
|
import com.gmail.nossr50.config.Config;
|
||||||
import com.gmail.nossr50.locale.LocaleLoader;
|
import com.gmail.nossr50.locale.LocaleLoader;
|
||||||
import com.gmail.nossr50.metrics.MetricsManager;
|
import com.gmail.nossr50.metrics.MetricsManager;
|
||||||
import com.gmail.nossr50.util.player.UserManager;
|
import com.gmail.nossr50.util.player.UserManager;
|
||||||
|
import com.gmail.nossr50.util.skills.CombatUtils;
|
||||||
import com.gmail.nossr50.util.skills.SkillUtils;
|
import com.gmail.nossr50.util.skills.SkillUtils;
|
||||||
|
|
||||||
public final class ChimaeraWing {
|
public final class ChimaeraWing {
|
||||||
@@ -32,7 +35,7 @@ public final class ChimaeraWing {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
Block block = player.getLocation().getBlock();
|
Location location = player.getLocation();
|
||||||
int amount = inHand.getAmount();
|
int amount = inHand.getAmount();
|
||||||
long recentlyHurt = UserManager.getPlayer(player).getRecentlyHurt();
|
long recentlyHurt = UserManager.getPlayer(player).getRecentlyHurt();
|
||||||
long lastChimaeraWing = (UserManager.getPlayer(player).getLastChimaeraTeleport());
|
long lastChimaeraWing = (UserManager.getPlayer(player).getLastChimaeraTeleport());
|
||||||
@@ -43,37 +46,47 @@ public final class ChimaeraWing {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (SkillUtils.cooldownOver(recentlyHurt * Misc.TIME_CONVERSION_FACTOR, 60, player) && amount >= Config.getInstance().getChimaeraUseCost()) {
|
if (!SkillUtils.cooldownOver(recentlyHurt * Misc.TIME_CONVERSION_FACTOR, 60, player)) {
|
||||||
|
player.sendMessage(LocaleLoader.getString("Item.Injured.Wait", SkillUtils.calculateTimeLeft(recentlyHurt * Misc.TIME_CONVERSION_FACTOR, 60, player)));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (amount <= Config.getInstance().getChimaeraUseCost()) {
|
||||||
|
player.sendMessage(LocaleLoader.getString("Skills.NeedMore", "Chimaera Wings")); //TODO Locale!
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
player.setItemInHand(new ItemStack(getChimaeraWing(amount - Config.getInstance().getChimaeraUseCost())));
|
player.setItemInHand(new ItemStack(getChimaeraWing(amount - Config.getInstance().getChimaeraUseCost())));
|
||||||
|
|
||||||
if (Config.getInstance().getChimaeraPreventUseUnderground()) {
|
if (Config.getInstance().getChimaeraPreventUseUnderground()) {
|
||||||
for (int y = 1; block.getY() + y < player.getWorld().getMaxHeight(); y++) {
|
|
||||||
if (!(block.getRelative(0, y, 0).getType() == Material.AIR)) {
|
if (location.getY() < player.getWorld().getHighestBlockYAt(location)) {
|
||||||
player.sendMessage(LocaleLoader.getString("Item.ChimaeraWing.Fail"));
|
player.sendMessage(LocaleLoader.getString("Item.ChimaeraWing.Fail"));
|
||||||
player.teleport(block.getRelative(0, y - 1, 0).getLocation());
|
player.setVelocity(new Vector(0, 0.5D, 0));
|
||||||
|
CombatUtils.dealDamage(player, Misc.getRandom().nextInt(player.getHealth() - 10));
|
||||||
|
UserManager.getPlayer(player).actualizeLastChimaeraTeleport();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
if (player.getBedSpawnLocation() != null) {
|
if (player.getBedSpawnLocation() != null) {
|
||||||
player.teleport(player.getBedSpawnLocation());
|
player.teleport(player.getBedSpawnLocation());
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
player.teleport(player.getWorld().getSpawnLocation());
|
Location spawnLocation = player.getWorld().getSpawnLocation();
|
||||||
|
if (spawnLocation.getBlock().getType() == Material.AIR) {
|
||||||
|
player.teleport(spawnLocation);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
player.teleport(player.getWorld().getHighestBlockAt(spawnLocation).getLocation());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
UserManager.getPlayer(player).actualizeLastChimaeraTeleport();
|
UserManager.getPlayer(player).actualizeLastChimaeraTeleport();
|
||||||
MetricsManager.chimeraWingUsed();
|
MetricsManager.chimeraWingUsed();
|
||||||
|
player.playSound(location, Sound.BAT_TAKEOFF, Misc.BAT_VOLUME, Misc.BAT_PITCH);
|
||||||
player.sendMessage(LocaleLoader.getString("Item.ChimaeraWing.Pass"));
|
player.sendMessage(LocaleLoader.getString("Item.ChimaeraWing.Pass"));
|
||||||
}
|
}
|
||||||
else if (!SkillUtils.cooldownOver(recentlyHurt, 60 * Misc.TIME_CONVERSION_FACTOR, player) && amount >= Config.getInstance().getChimaeraUseCost()) {
|
|
||||||
player.sendMessage(LocaleLoader.getString("Item.Injured.Wait", SkillUtils.calculateTimeLeft(recentlyHurt, 60, player)));
|
|
||||||
}
|
|
||||||
else if (amount <= Config.getInstance().getChimaeraUseCost()) {
|
|
||||||
player.sendMessage(LocaleLoader.getString("Skills.NeedMore", "Chimaera Wings")); //TODO Locale!
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public static ItemStack getChimaeraWing(int amount) {
|
public static ItemStack getChimaeraWing(int amount) {
|
||||||
|
|||||||
@@ -26,6 +26,8 @@ public final class Misc {
|
|||||||
public static final float FIZZ_VOLUME = 0.5F;
|
public static final float FIZZ_VOLUME = 0.5F;
|
||||||
public static final float POP_PITCH = ((getRandom().nextFloat() - getRandom().nextFloat()) * 0.7F + 1.0F) * 2.0F;
|
public static final float POP_PITCH = ((getRandom().nextFloat() - getRandom().nextFloat()) * 0.7F + 1.0F) * 2.0F;
|
||||||
public static final float POP_VOLUME = 0.2F;
|
public static final float POP_VOLUME = 0.2F;
|
||||||
|
public static final float BAT_VOLUME = 1.0F;
|
||||||
|
public static final float BAT_PITCH = 0.6F;
|
||||||
|
|
||||||
private Misc() {};
|
private Misc() {};
|
||||||
|
|
||||||
|
|||||||
@@ -464,7 +464,6 @@ Commands.Party.AlreadyExists=[[DARK_RED]]Party {0} already exists!
|
|||||||
Commands.Party.Kick=[[RED]]You were kicked from party {0}!
|
Commands.Party.Kick=[[RED]]You were kicked from party {0}!
|
||||||
Commands.Party.Leave=[[RED]]You have left that party
|
Commands.Party.Leave=[[RED]]You have left that party
|
||||||
Commands.Party.Members.Header=[[RED]]-----[][[GREEN]]MEMBERS[[RED]][]-----
|
Commands.Party.Members.Header=[[RED]]-----[][[GREEN]]MEMBERS[[RED]][]-----
|
||||||
Commands.Party.Members={0}
|
|
||||||
Commands.Party.None=[[RED]]You are not in a party.
|
Commands.Party.None=[[RED]]You are not in a party.
|
||||||
Commands.Party.Quit=[[RED]]- Leave your current party
|
Commands.Party.Quit=[[RED]]- Leave your current party
|
||||||
Commands.Party.Teleport=<player> [[RED]]- Teleport to party member
|
Commands.Party.Teleport=<player> [[RED]]- Teleport to party member
|
||||||
|
|||||||
Reference in New Issue
Block a user