Cache MessageFormats for Chat

This commit is contained in:
snowleo 2012-01-19 02:03:20 +01:00
parent a10f6850e5
commit 5f04d1867c
3 changed files with 26 additions and 7 deletions

View File

@ -1,6 +1,7 @@
package com.earth2me.essentials; package com.earth2me.essentials;
import com.earth2me.essentials.commands.IEssentialsCommand; import com.earth2me.essentials.commands.IEssentialsCommand;
import java.text.MessageFormat;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.Set; import java.util.Set;
@ -22,7 +23,7 @@ public interface ISettings extends IConf
long getBackupInterval(); long getBackupInterval();
String getChatFormat(String group); MessageFormat getChatFormat(String group);
int getChatRadius(); int getChatRadius();

View File

@ -3,6 +3,7 @@ package com.earth2me.essentials;
import static com.earth2me.essentials.I18n._; import static com.earth2me.essentials.I18n._;
import com.earth2me.essentials.commands.IEssentialsCommand; import com.earth2me.essentials.commands.IEssentialsCommand;
import java.io.File; import java.io.File;
import java.text.MessageFormat;
import java.util.*; import java.util.*;
import java.util.logging.Level; import java.util.logging.Level;
import java.util.logging.Logger; import java.util.logging.Logger;
@ -291,12 +292,26 @@ public class Settings implements ISettings
{ {
return config.getString("backup.command", null); return config.getString("backup.command", null);
} }
private Map<String, MessageFormat> chatFormats = new HashMap<String, MessageFormat>();
@Override @Override
public String getChatFormat(String group) public MessageFormat getChatFormat(String group)
{ {
return config.getString("chat.group-formats." + (group == null ? "Default" : group), MessageFormat mFormat = chatFormats.get(group);
if (mFormat == null)
{
String format = config.getString("chat.group-formats." + (group == null ? "Default" : group),
config.getString("chat.format", "&7[{GROUP}]&f {DISPLAYNAME}&7:&f {MESSAGE}")); config.getString("chat.format", "&7[{GROUP}]&f {DISPLAYNAME}&7:&f {MESSAGE}"));
format = Util.replaceColor(format);
format.replace("{DISPLAYNAME}", "%1$s");
format.replace("{GROUP}", "{0}");
format.replace("{MESSAGE}", "%2$s");
format.replace("{WORLDNAME}", "{1}");
format.replace("{SHORTWORLDNAME}", "{2}");
mFormat = new MessageFormat(format);
chatFormats.put(group, mFormat);
}
return mFormat;
} }
@Override @Override
@ -340,6 +355,7 @@ public class Settings implements ISettings
{ {
config.load(); config.load();
noGodWorlds = new HashSet<String>(config.getStringList("no-god-in-worlds", Collections.<String>emptyList())); noGodWorlds = new HashSet<String>(config.getStringList("no-god-in-worlds", Collections.<String>emptyList()));
chatFormats.clear();
} }
@Override @Override

View File

@ -42,6 +42,8 @@ public class EssentialsChatPlayerListenerLowest extends EssentialsChatPlayer
{ {
event.setMessage(Util.stripColor(event.getMessage())); event.setMessage(Util.stripColor(event.getMessage()));
} }
event.setFormat(ess.getSettings().getChatFormat(user.getGroup()).replace('&', '\u00a7').replace("\u00a7\u00a7", "&").replace("{DISPLAYNAME}", "%1$s").replace("{GROUP}", user.getGroup()).replace("{MESSAGE}", "%2$s").replace("{WORLDNAME}", user.getWorld().getName()).replace("{SHORTWORLDNAME}", user.getWorld().getName().substring(0, 1).toUpperCase(Locale.ENGLISH))); String group = user.getGroup();
String world = user.getWorld().getName();
event.setFormat(ess.getSettings().getChatFormat(group).format(new Object[] {group, world, world.substring(0, 1).toUpperCase(Locale.ENGLISH)}));
} }
} }