1
0
mirror of https://e.coding.net/circlecloud/VbariableAPI.git synced 2024-12-27 07:28:50 +00:00

更新部分API操作...

Signed-off-by: 502647092 <jtb1@163.com>
This commit is contained in:
502647092 2016-01-31 20:38:30 +08:00
parent c974c98a19
commit 3b544cd3ad
2 changed files with 78 additions and 4 deletions

View File

@ -1,13 +1,66 @@
/**
*
*/
package cn.citycraft.VbariableAPI;
import java.util.HashMap;
import java.util.Map;
import java.util.Map.Entry;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
import org.bukkit.ChatColor;
import org.bukkit.entity.Player;
/**
*
*
* @since 2016年1月30日 上午9:29:54
* @author
*/
public class VAPI {
private static final Pattern PLACEHOLDER_PATTERN = Pattern.compile("[%]([a-zA-Z0-9_.-@-]+)[%]");
private static final Pattern BRACKET_PLACEHOLDER_PATTERN = Pattern.compile("[{]([a-zA-Z0-9_.-@-]+)[}]");
private static Map<String, VariableHook> placeholders = new HashMap<>();
public static boolean registerPlaceholderHook(final String plugin, final VariableHook placeholderHook) {
if (plugin == null || placeholderHook == null || VAPI.placeholders.containsKey(plugin)) {
return false;
}
VAPI.placeholders.put(plugin, placeholderHook);
return true;
}
public static String replaceVariable(final Player player, String text) {
if (text == null || VAPI.placeholders == null || VAPI.placeholders.isEmpty()) {
return text;
}
final Matcher placeholderMatcher = VAPI.PLACEHOLDER_PATTERN.matcher(text);
while (placeholderMatcher.find()) {
final String format = placeholderMatcher.group(1);
final StringBuilder pluginBuilder = new StringBuilder();
char[] formatArray;
int i;
for (formatArray = format.toCharArray(), i = 0; i < formatArray.length && formatArray[i] != '_'; ++i) {
pluginBuilder.append(formatArray[i]);
}
final String pl = pluginBuilder.toString();
final StringBuilder identifierBuilder = new StringBuilder();
for (int b = i + 1; b < formatArray.length; ++b) {
identifierBuilder.append(formatArray[b]);
}
String identifier = identifierBuilder.toString();
if (identifier.isEmpty()) {
identifier = pl;
}
for (final Entry<String, VariableHook> registered : placeholders.entrySet()) {
if (pl.equalsIgnoreCase(registered.getKey())) {
final VariableReplaceEvent vre = new VariableReplaceEvent(player, identifier);
final String value = registered.getValue().onVariableReplace(vre);
if (value == null) {
continue;
}
text = text.replaceAll("%" + format + "%", Matcher.quoteReplacement(value));
}
}
}
return ChatColor.translateAlternateColorCodes('&', text);
}
}

View File

@ -0,0 +1,21 @@
name: ${project.artifactId}
description: ${project.description}
main: ${project.groupId}.${project.artifactId}.${project.artifactId}
version: ${project.version}-git-${env.GIT_COMMIT}
author: 喵♂呜
website: ${jenkins.url}/job/${project.artifactId}/
commands:
${project.artifactId}:
description: ${project.artifactId} - ${project.description}
aliases:
- vapi
usage: §b使用/${project.artifactId} help 查看帮助!
permission: ${project.artifactId}.reload
permission-message: §c你没有 <permission> 的权限来执行此命令!
permissions:
${project.artifactId}.use:
description: ${project.artifactId} 使用!
default: op
${project.artifactId}.reload:
description: 重新载入插件!
default: op