/
PluginTag.java
206 lines (171 loc) · 5.9 KB
/
PluginTag.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
package com.denizenscript.denizen.objects;
import com.denizenscript.denizen.utilities.debugging.Debug;
import com.denizenscript.denizencore.objects.*;
import com.denizenscript.denizencore.objects.core.ElementTag;
import com.denizenscript.denizencore.objects.core.ListTag;
import com.denizenscript.denizencore.tags.Attribute;
import com.denizenscript.denizencore.tags.ObjectTagProcessor;
import com.denizenscript.denizencore.tags.TagContext;
import com.denizenscript.denizencore.tags.TagRunnable;
import com.denizenscript.denizencore.utilities.CoreUtilities;
import org.bukkit.Bukkit;
import org.bukkit.plugin.Plugin;
public class PluginTag implements ObjectTag {
// <--[language]
// @name PluginTag Objects
// @group Object System
// @description
// A PluginTag represents a Bukkit plugin on the server.
//
// These use the object notation "pl@".
// The identity format for plugins is the plugin's registered name.
// For example, 'pl@Denizen'.
//
// -->
//////////////////
// Object Fetcher
////////////////
@Deprecated
public static PluginTag valueOf(String string) {
return valueOf(string, null);
}
/**
* Gets a PluginTag from a string format.
*
* @param string The plugin in string form. (pl@PluginName)
* @return The PluginTag value. If the string is incorrectly formatted or
* the specified plugin is invalid, this is null.
*/
@Fetchable("pl")
public static PluginTag valueOf(String string, TagContext context) {
if (string == null) {
return null;
}
string = CoreUtilities.toLowerCase(string).replace("pl@", "");
try {
// Attempt to match from plugin list, as PluginManager#getPlugin is case sensitive
for (Plugin plugin : Bukkit.getServer().getPluginManager().getPlugins()) {
if (string.equalsIgnoreCase(plugin.getName())) {
return new PluginTag(plugin);
}
}
}
catch (Exception e) {
Debug.echoError("Invalid plugin name specified, or plugin is not enabled: " + string);
}
return null;
}
public static boolean matches(String arg) {
if (CoreUtilities.toLowerCase(arg).startsWith("pl@")) {
return true;
}
for (Plugin plugin : Bukkit.getServer().getPluginManager().getPlugins()) {
if (arg.equalsIgnoreCase(plugin.getName())) {
return true;
}
}
return false;
}
/////////////////////
// Constructors
//////////////////
public PluginTag(Plugin plugin) {
this.plugin = plugin;
}
/////////////////////
// Instance Fields/Methods
/////////////////
private Plugin plugin;
public Plugin getPlugin() {
return plugin;
}
/////////////////////
// ObjectTag Methods
///////////////////
private String prefix = "Plugin";
@Override
public String getObjectType() {
return "Plugin";
}
@Override
public String getPrefix() {
return prefix;
}
@Override
public boolean isUnique() {
return true;
}
@Override
public String identify() {
return "pl@" + plugin.getName();
}
@Override
public String identifySimple() {
return identify();
}
@Override
public String toString() {
return identify();
}
@Override
public PluginTag setPrefix(String prefix) {
this.prefix = prefix;
return this;
}
public static void registerTags() {
// <--[tag]
// @attribute <PluginTag.name>
// @returns ElementTag
// @description
// Gets the name of this plugin.
// -->
registerTag("name", (attribute, object) -> {
return new ElementTag(object.plugin.getName());
});
// <--[tag]
// @attribute <PluginTag.version>
// @returns ElementTag
// @description
// Gets the version for the plugin specified.
// -->
registerTag("version", (attribute, object) -> {
return new ElementTag(object.plugin.getDescription().getVersion());
});
// <--[tag]
// @attribute <PluginTag.description>
// @returns ElementTag
// @description
// Gets the description for the plugin specified.
// -->
registerTag("description", (attribute, object) -> {
return new ElementTag(object.plugin.getDescription().getDescription());
});
// <--[tag]
// @attribute <PluginTag.authors>
// @returns ListTag
// @description
// Gets the list of authors for the plugin specified.
// -->
registerTag("authors", (attribute, object) -> {
return new ListTag(object.plugin.getDescription().getAuthors());
});
// <--[tag]
// @attribute <PluginTag.type>
// @returns ElementTag
// @description
// Always returns 'Plugin' for PluginTag objects. All objects fetchable by the Object Fetcher will return the
// type of object that is fulfilling this attribute.
// -->
registerTag("type", (attribute, object) -> {
return new ElementTag("Plugin");
});
}
public static ObjectTagProcessor<PluginTag> tagProcessor = new ObjectTagProcessor<>();
public static void registerTag(String name, TagRunnable.ObjectInterface<PluginTag> runnable, String... variants) {
tagProcessor.registerTag(name, runnable, variants);
}
@Override
public ObjectTag getObjectAttribute(Attribute attribute) {
return tagProcessor.getObjectAttribute(this, attribute);
}
}