feat: 完善服务获取类

merge/2/HEAD
coding 2018-05-16 16:08:27 +00:00
parent 0492275eb2
commit d2ebd8fa7e
2 changed files with 41 additions and 6 deletions

View File

@ -7,7 +7,6 @@
/*global Java, base, module, exports, require, __FILE__*/
var Bukkit = MServer;
var Server = Bukkit.server;
var PluginManager = Server.pluginManager;
exports.$ = Bukkit;
/**
* 获取NMS版本
@ -53,6 +52,7 @@ exports.players = function () {
* 插件管理
* @type {{manager: *, get: exports.plugin.get, load: exports.plugin.load}}
*/
var PluginManager = Server.pluginManager;
exports.plugin = {
/**
* 插件管理工具
@ -80,6 +80,26 @@ exports.plugin = {
},
self: PluginManager.getPlugin('MiaoScript')
};
/**
* 服务管理
* @type {{manager: *, get: exports.plugin.get, load: exports.plugin.load}}
*/
var ServicesManager = Server.servicesManager;
exports.service = {
/**
* 服务管理工具
*/
manager: ServicesManager,
/**
* 获得服务实例
* @param name 插件名称
* @returns {*}
*/
get: function (name) {
var reg = ServicesManager.getRegistration(base.getClass(name));
return reg && reg.provider || null;
}
}
/**
* 公告
* @param message 消息

View File

@ -32,14 +32,29 @@ exports.plugin = {
* @returns {*}
*/
load: function (name) {
var plugin = this.get(name);
if (ext.notNull(plugin) && !plugin.isEnabled()) {
PluginManager.enablePlugin(plugin);
}
return PluginManager.isPluginEnabled(name);
return PluginManager.isLoaded(name);
},
self: PluginManager.getPlugin('miaoscript').orElse(undefined)
};
/**
* 服务管理
* @type {{manager: *, get: exports.plugin.get, load: exports.plugin.load}}
*/
var ServicesManager = Sponge.serviceManager;
exports.service = {
/*
* 服务管理工具
*/
manager: ServicesManager,
/**
* 获得服务实例
* @param name 插件名称
* @returns {*}
*/
get: function (name) {
return ServicesManager.provide(base.getClass(name)).orElse(null);
}
}
/**
* 获取玩家
*/