forked from circlecloud/MiaoChat
fix: 修复值存在特殊字符时错误的问题
Signed-off-by: 502647092 <admin@yumc.pw>
This commit is contained in:
parent
232ba7f95d
commit
6d7660f96c
13
pom.xml
13
pom.xml
@ -3,7 +3,7 @@
|
|||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<groupId>pw.yumc</groupId>
|
<groupId>pw.yumc</groupId>
|
||||||
<artifactId>MiaoChat</artifactId>
|
<artifactId>MiaoChat</artifactId>
|
||||||
<version>1.3</version>
|
<version>1.3.1</version>
|
||||||
<build>
|
<build>
|
||||||
<finalName>${project.name}</finalName>
|
<finalName>${project.name}</finalName>
|
||||||
<resources>
|
<resources>
|
||||||
@ -31,7 +31,6 @@
|
|||||||
<artifactSet>
|
<artifactSet>
|
||||||
<includes>
|
<includes>
|
||||||
<include>pw.yumc:YumCore</include>
|
<include>pw.yumc:YumCore</include>
|
||||||
<include>cn.citycraft:PluginHelper</include>
|
|
||||||
</includes>
|
</includes>
|
||||||
</artifactSet>
|
</artifactSet>
|
||||||
<relocations>
|
<relocations>
|
||||||
@ -39,10 +38,6 @@
|
|||||||
<pattern>pw.yumc.YumCore</pattern>
|
<pattern>pw.yumc.YumCore</pattern>
|
||||||
<shadedPattern>${project.groupId}.${project.artifactId}</shadedPattern>
|
<shadedPattern>${project.groupId}.${project.artifactId}</shadedPattern>
|
||||||
</relocation>
|
</relocation>
|
||||||
<relocation>
|
|
||||||
<pattern>cn.citycraft.PluginHelper</pattern>
|
|
||||||
<shadedPattern>${project.groupId}.${project.artifactId}</shadedPattern>
|
|
||||||
</relocation>
|
|
||||||
</relocations>
|
</relocations>
|
||||||
</configuration>
|
</configuration>
|
||||||
<executions>
|
<executions>
|
||||||
@ -110,12 +105,6 @@
|
|||||||
<type>jar</type>
|
<type>jar</type>
|
||||||
<version>1.10.2-R0.1-SNAPSHOT</version>
|
<version>1.10.2-R0.1-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
<dependency>
|
|
||||||
<groupId>cn.citycraft</groupId>
|
|
||||||
<artifactId>PluginHelper</artifactId>
|
|
||||||
<type>jar</type>
|
|
||||||
<version>1.0</version>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>pw.yumc</groupId>
|
<groupId>pw.yumc</groupId>
|
||||||
<artifactId>YumCore</artifactId>
|
<artifactId>YumCore</artifactId>
|
||||||
|
@ -49,26 +49,31 @@ public class ChatListener implements Listener {
|
|||||||
final Player p = e.getPlayer();
|
final Player p = e.getPlayer();
|
||||||
final ChatRule cr = cc.getChatRule(e.getPlayer());
|
final ChatRule cr = cc.getChatRule(e.getPlayer());
|
||||||
if (cr == null) {
|
if (cr == null) {
|
||||||
|
// Log.d("玩家: %s 未发现可用ChatRule!", p.getName());
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
e.setCancelled(true);
|
e.setCancelled(true);
|
||||||
final Tellraw tr = Tellraw.create();
|
final Tellraw tr = Tellraw.create();
|
||||||
handleChat(p, tr, cr, e);
|
handleChat(p, tr, cr, e.getMessage());
|
||||||
}
|
}
|
||||||
|
|
||||||
private void handleChat(final Player p, final Tellraw tr, final ChatRule cr, final AsyncPlayerChatEvent e) {
|
private void handleChat(final Player p, final Tellraw tr, final ChatRule cr, final String message) {
|
||||||
|
// Log.d("玩家: %s 使用 %s 规则 解析 %s", p.getName(), cr.getName(), message);
|
||||||
handleFormat(p, tr, cr);
|
handleFormat(p, tr, cr);
|
||||||
handleTellraw(p, tr, cr, e.getMessage());
|
handleTellraw(p, tr, cr, message);
|
||||||
handleSend(p, tr, cr);
|
handleSend(p, tr, cr.getRange());
|
||||||
}
|
}
|
||||||
|
|
||||||
private void handleFormat(final Player p, final Tellraw tr, final ChatRule cr) {
|
private void handleFormat(final Player p, final Tellraw tr, final ChatRule cr) {
|
||||||
final LinkedList<String> formats = cr.getFormats();
|
final LinkedList<String> formats = cr.getFormats();
|
||||||
|
// Log.d("处理前缀信息...");
|
||||||
for (final String format : formats) {
|
for (final String format : formats) {
|
||||||
final ChatMessagePart cmp = cc.getFormat(format);
|
final ChatMessagePart cmp = cc.getFormat(format);
|
||||||
if (cmp != null) {
|
if (cmp != null) {
|
||||||
|
// Log.d("解析格式: %s", format);
|
||||||
cmp.then(tr, p);
|
cmp.then(tr, p);
|
||||||
} else {
|
} else {
|
||||||
|
// Log.d("追加文本: %s", format);
|
||||||
tr.then(format);
|
tr.then(format);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -76,15 +81,21 @@ public class ChatListener implements Listener {
|
|||||||
|
|
||||||
private LinkedList<String> handleMessage(final LinkedList<String> il, String message) {
|
private LinkedList<String> handleMessage(final LinkedList<String> il, String message) {
|
||||||
final LinkedList<String> mlist = new LinkedList<>();
|
final LinkedList<String> mlist = new LinkedList<>();
|
||||||
|
// Log.d("处理聊天信息...");
|
||||||
if (!il.isEmpty()) {
|
if (!il.isEmpty()) {
|
||||||
for (final String k : il) {
|
for (final String k : il) {
|
||||||
final String[] args = message.split(k, 2);
|
final String[] args = message.split(k, 2);
|
||||||
mlist.add(args[0]);
|
if (!args[0].isEmpty()) {
|
||||||
|
// Log.d("追加文本: %s", args[0]);
|
||||||
|
mlist.add(args[0]);
|
||||||
|
}
|
||||||
|
// Log.d("解析物品: %s", args[0]);
|
||||||
mlist.add(k);
|
mlist.add(k);
|
||||||
message = args[1];
|
message = args[1];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (!message.isEmpty()) {
|
if (!message.isEmpty()) {
|
||||||
|
// Log.d("追加文本: %s", message);
|
||||||
mlist.add(message);
|
mlist.add(message);
|
||||||
}
|
}
|
||||||
return mlist;
|
return mlist;
|
||||||
@ -94,10 +105,12 @@ public class ChatListener implements Listener {
|
|||||||
final Matcher m = ITEM_PATTERN.matcher(message);
|
final Matcher m = ITEM_PATTERN.matcher(message);
|
||||||
final Set<String> temp = new HashSet<>();
|
final Set<String> temp = new HashSet<>();
|
||||||
final LinkedList<String> ilist = new LinkedList<>();
|
final LinkedList<String> ilist = new LinkedList<>();
|
||||||
|
// Log.d("处理聊天物品信息...");
|
||||||
while (m.find()) {
|
while (m.find()) {
|
||||||
final String key = m.group(0);
|
final String key = m.group(0);
|
||||||
if (key.length() == 2) {
|
if (key.length() == 2) {
|
||||||
if (temp.add(key)) {
|
if (temp.add(key)) {
|
||||||
|
// Log.d("解析物品关键词: %s", key);
|
||||||
ilist.add(key);
|
ilist.add(key);
|
||||||
} else {
|
} else {
|
||||||
return null;
|
return null;
|
||||||
@ -107,8 +120,7 @@ public class ChatListener implements Listener {
|
|||||||
return ilist;
|
return ilist;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void handleSend(final Player p, final Tellraw tr, final ChatRule cr) {
|
private void handleSend(final Player p, final Tellraw tr, final int range) {
|
||||||
final int range = cr.getRange();
|
|
||||||
Collection<? extends Entity> plist = Collections.emptyList();
|
Collection<? extends Entity> plist = Collections.emptyList();
|
||||||
if (range != 0) {
|
if (range != 0) {
|
||||||
plist = p.getNearbyEntities(range, range, range);
|
plist = p.getNearbyEntities(range, range, range);
|
||||||
@ -125,28 +137,35 @@ public class ChatListener implements Listener {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void handleTellraw(final Player player, final Tellraw tr, final ChatRule cr, String message) {
|
private void handleTellraw(final Player player, final Tellraw tr, final ChatRule cr, String message) {
|
||||||
if (message.isEmpty() || !cr.isItem()) {
|
if (message.isEmpty()) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (player.hasPermission("MiaoChat.color")) {
|
if (player.hasPermission("MiaoChat.color")) {
|
||||||
message = ChatColor.translateAlternateColorCodes('&', message);
|
message = ChatColor.translateAlternateColorCodes('&', message);
|
||||||
}
|
}
|
||||||
|
if (!cr.isItem()) {
|
||||||
|
tr.then(message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
final LinkedList<String> il = handlePattern(message);
|
final LinkedList<String> il = handlePattern(message);
|
||||||
if (il == null) {
|
if (il == null) {
|
||||||
Log.toSender(player, "§c不允许展示相同的物品!");
|
Log.toSender(player, "§c不允许展示相同的物品!");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
final LinkedList<String> ml = handleMessage(il, message);
|
final LinkedList<String> ml = handleMessage(il, message);
|
||||||
|
// Log.d("处理Tellraw格式...");
|
||||||
while (!ml.isEmpty()) {
|
while (!ml.isEmpty()) {
|
||||||
final String mm = ml.removeFirst();
|
final String mm = ml.removeFirst();
|
||||||
if (il.contains(mm)) {
|
if (il.contains(mm)) {
|
||||||
final char k = mm.charAt(1);
|
final char k = mm.charAt(1);
|
||||||
final ItemStack is = k == 'i' ? player.getItemInHand() : player.getInventory().getItem(k - '0' - 1);
|
final ItemStack is = k == 'i' ? player.getItemInHand() : player.getInventory().getItem(k - '0' - 1);
|
||||||
if (is != null && is.getType() != Material.AIR) {
|
if (is != null && is.getType() != Material.AIR) {
|
||||||
|
// Log.d("处理物品: %s", mm);
|
||||||
tr.then(String.format(ChatColor.translateAlternateColorCodes('&', cr.getItemformat()), L10N.getItemName(is)));
|
tr.then(String.format(ChatColor.translateAlternateColorCodes('&', cr.getItemformat()), L10N.getItemName(is)));
|
||||||
tr.item(is);
|
tr.item(is);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
// Log.d("追加聊天: %s", mm);
|
||||||
tr.then(mm);
|
tr.then(mm);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user