Fix async access to bukkit code

This commit is contained in:
snowleo 2013-02-08 21:16:21 +01:00
parent 2ca171a3f4
commit 379e75f3e6

View file

@ -15,7 +15,6 @@ import java.util.logging.Level;
import java.util.logging.Logger; import java.util.logging.Logger;
import org.bukkit.Bukkit; import org.bukkit.Bukkit;
import org.bukkit.Location; import org.bukkit.Location;
import org.bukkit.Material;
import org.bukkit.entity.Player; import org.bukkit.entity.Player;
import org.bukkit.event.Listener; import org.bukkit.event.Listener;
import org.bukkit.event.player.PlayerJoinEvent; import org.bukkit.event.player.PlayerJoinEvent;
@ -97,34 +96,41 @@ public class EssentialsSpawnPlayerListener implements Listener
ess.scheduleSyncDelayedTask(new NewPlayerTeleport(user), 1L); ess.scheduleSyncDelayedTask(new NewPlayerTeleport(user), 1L);
} }
//This method allows for multiple line player announce messages using multiline yaml syntax #EasterEgg ess.scheduleSyncDelayedTask(new Runnable()
if (ess.getSettings().getAnnounceNewPlayers())
{ {
final IText output = new KeywordReplacer(ess.getSettings().getAnnounceNewPlayerFormat(), user, ess); @Override
final SimpleTextPager pager = new SimpleTextPager(output); public void run()
for (String line : pager.getLines())
{ {
ess.broadcastMessage(user, line); //This method allows for multiple line player announce messages using multiline yaml syntax #EasterEgg
} if (ess.getSettings().getAnnounceNewPlayers())
} {
final IText output = new KeywordReplacer(ess.getSettings().getAnnounceNewPlayerFormat(), user, ess);
final SimpleTextPager pager = new SimpleTextPager(output);
final String kitName = ess.getSettings().getNewPlayerKit(); for (String line : pager.getLines())
if (!kitName.isEmpty()) {
{ ess.broadcastMessage(user, line);
try }
{ }
final Map<String, Object> kit = ess.getSettings().getKit(kitName.toLowerCase(Locale.ENGLISH));
final List<String> items = Kit.getItems(user, kit);
Kit.expandItems(ess, user, items);
}
catch (Exception ex)
{
LOGGER.log(Level.WARNING, ex.getMessage());
}
}
LOGGER.log(Level.FINE, "New player join"); final String kitName = ess.getSettings().getNewPlayerKit();
if (!kitName.isEmpty())
{
try
{
final Map<String, Object> kit = ess.getSettings().getKit(kitName.toLowerCase(Locale.ENGLISH));
final List<String> items = Kit.getItems(user, kit);
Kit.expandItems(ess, user, items);
}
catch (Exception ex)
{
LOGGER.log(Level.WARNING, ex.getMessage());
}
}
LOGGER.log(Level.FINE, "New player join");
}
});
} }