Compare commits
256 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 5f0c3bbdd4 | |||
| bf3638dda0 | |||
| 842335edbe | |||
| f573d0c758 | |||
| 13b04a904e | |||
| 2c1eea5bc1 | |||
| 8a07e85fda | |||
| 32db0bba56 | |||
| b417d8ff08 | |||
| 6fd7038ffe | |||
| 321b21a947 | |||
| 0ae7346678 | |||
| 7114876046 | |||
| 01fcc1337a | |||
| 476f7acc39 | |||
| 5b11be11da | |||
| 80c6b123c1 | |||
| a7a40b374b | |||
| 9888f908e9 | |||
| 73ada5fd17 | |||
| 79f151de5c | |||
| 16fcbfa69c | |||
| 7e1111470c | |||
| d407631072 | |||
| 4d7b27188a | |||
| 7bd8302b24 | |||
| b065bcd843 | |||
| c8a31b6d5a | |||
| 75492c77e8 | |||
| 8dbbb369b2 | |||
| 24ba6bd353 | |||
| a02bd6dc95 | |||
| 21cf867f43 | |||
| 4290d1132e | |||
| 1ed5dd1d24 | |||
| d751dc8614 | |||
| c45bbb9821 | |||
| c9ca4ffd39 | |||
| 5943d6882f | |||
| d24d0d39a1 | |||
| 95cd8c4889 | |||
| 78fcbbe9a5 | |||
| baa6e95222 | |||
| 3a045bd335 | |||
| dd28d9fae5 | |||
| 72bd6b4c9c | |||
| 58478116c6 | |||
| d29efb2332 | |||
| 0899276530 | |||
| 5c3ed4e36d | |||
| b926951656 | |||
| b47acf69ea | |||
| 63aef1fe60 | |||
| 541a3bb96b | |||
| 873964575b | |||
| 54af491399 | |||
| 43d9b97347 | |||
| 25aef3ed62 | |||
| c622abecda | |||
| f527c225fe | |||
| 26eceac330 | |||
| f5702c5080 | |||
| 101f152da7 | |||
| 97db272041 | |||
| a5ca0c2346 | |||
| aab94fe5ea | |||
| d3d7a9cdbf | |||
| 9dee4b3a60 | |||
| f1863c3b39 | |||
| 0120e84f3f | |||
| 00130f549c | |||
| fafcd09cc1 | |||
| 2bd8f0c5ff | |||
| 695a490296 | |||
| 1a546470a5 | |||
| e68c17576a | |||
| eaee2f9c91 | |||
| 3596fc0804 | |||
| 5e89872477 | |||
| c12670bd9e | |||
| b9ef3f2e33 | |||
| 4b3176e98e | |||
| 4922f6a39d | |||
| 195c84e1ae | |||
| 7d63a57991 | |||
| 1931391cba | |||
| 2dda9bd0fc | |||
| 937b24ecda | |||
| c9eff3dae4 | |||
| 098a4f8557 | |||
| 8566c6a883 | |||
| 0584ec9d85 | |||
| 87f197fe06 | |||
| 860946a44b | |||
| f40eddd5e3 | |||
| b67474f7ff | |||
| 8e5588ca23 | |||
| acbeda9659 | |||
| a4c549d446 | |||
| c311d3fdb1 | |||
| 1c29a059d9 | |||
| d22b72f10a | |||
| e74cfda86b | |||
| 24fe3b9026 | |||
| ee9ae408ec | |||
| d679915062 | |||
| eaa11ac89e | |||
| 5ddfb1c40f | |||
| da68821a1f | |||
| ec65d00f28 | |||
| a2c3eff622 | |||
| 8d2422fd64 | |||
| 9bc6cc1ff2 | |||
| 6fc3592536 | |||
| 49b96b3ac4 | |||
| 73b9c2f163 | |||
| f5a7a269e4 | |||
| 662e70b72c | |||
| b71ce1b24d | |||
| 1ea8966f26 | |||
| 0ed3f1fbd5 | |||
| f4b461409b | |||
| ace2c48ae2 | |||
| 39861b2c46 | |||
| 6c9ea9fb74 | |||
| 15f09abce0 | |||
| eb832a0830 | |||
| 1d35c836fc | |||
| e53f2cea76 | |||
| 1395865d8a | |||
| bae5355c1b | |||
| 41d2edc719 | |||
| d608e2c066 | |||
| e7c22b5961 | |||
| 18b46cdcc7 | |||
| d057fd5464 | |||
| 247c566219 | |||
| ed9fec281c | |||
| 15197355c5 | |||
| 988bb3b914 | |||
| 47048a5b1b | |||
| b3539d419e | |||
| c10247e241 | |||
| 553632e6ba | |||
| 6b7a729e65 | |||
| 488eecba07 | |||
| ce431aded4 | |||
| 525fde9f51 | |||
| ca11db68a6 | |||
| 3f475a7dc1 | |||
| e7d44af48c | |||
| 0b416adfd2 | |||
| 429cece606 | |||
| c34b744994 | |||
| 4d64a5d264 | |||
| 13c0584749 | |||
| f5f50d0dd6 | |||
| 0176cabd41 | |||
| a3f8451842 | |||
| 9ea4a067f1 | |||
| 3143851969 | |||
| 7e4c44eadd | |||
| e323467ed8 | |||
| eba21c08dc | |||
| a872172fff | |||
| c996fa6873 | |||
| 8616c3fe22 | |||
| 407de98468 | |||
| c13668dbe2 | |||
| a0b334b151 | |||
| d7e8b05573 | |||
| 9fd4b51d98 | |||
| 246867b999 | |||
| 381ea25b46 | |||
| 6d81a72106 | |||
| f20171f898 | |||
| eaf491f74d | |||
| 49f886c5ba | |||
| 3cf83023eb | |||
| 9f64f89222 | |||
| bdecc96fcf | |||
| f660b4a4f8 | |||
| e8d41e8a43 | |||
| d9e2b50953 | |||
| 93c83cac94 | |||
| b506d06173 | |||
| 8d81d6938e | |||
| d90264194c | |||
| cc96519e80 | |||
| 982e14953c | |||
| b0409c46ba | |||
| fb3eb9704f | |||
| effa43d42f | |||
| 06684939bc | |||
| 9eb052addb | |||
| 9acd824656 | |||
| 61195accc9 | |||
| 568f723c06 | |||
| bca12d6f02 | |||
| 9b3d76b6dd | |||
| 84d9eb8881 | |||
| 6b4d0cc64c | |||
| 1d783ebd1f | |||
| 87ac658a22 | |||
| b793ec192f | |||
| 606bbb3991 | |||
| cacde0627b | |||
| 6f5254497f | |||
| 2639fbd818 | |||
| 93997cd695 | |||
| 268f5d2837 | |||
| 5642a93974 | |||
| 85fe0cf87a | |||
| f4ea32862f | |||
| eaf1456771 | |||
| 9546881691 | |||
| 94ebbf3cba | |||
| 9e650aa203 | |||
| 7ce0705d41 | |||
| 106e429a3f | |||
| 05d12b347a | |||
| 7bf5f53afd | |||
| e4bb878648 | |||
| d724feaec0 | |||
| 9cb614bebd | |||
| 7d6269b2d3 | |||
| eae0ff2c1e | |||
| 093a3dda00 | |||
| 93ec202894 | |||
| a780467d87 | |||
| 0102b172f3 | |||
| 64111732fb | |||
| ffa62ee243 | |||
| bd9af562f2 | |||
| 59108bab27 | |||
| 6258ae83d0 | |||
| 9fa3ed704a | |||
| a76858d626 | |||
| 55a6b33110 | |||
| b87b94aade | |||
| 4110ed2c20 | |||
| 3cbc101eff | |||
| 221b821085 | |||
| 7331cfaa55 | |||
| 40d020ef67 | |||
| eea2a225e8 | |||
| 48f7f0fdbb | |||
| 99ed76f9bb | |||
| 7f21fa67ee | |||
| 8584709828 | |||
| d1f58e7482 | |||
| 1bd35aef6d | |||
| fdf1088564 | |||
| 7bb4d1f6a3 | |||
| b8c3d0d19d | |||
| a616a07553 |
4
.gitignore
vendored
4
.gitignore
vendored
@@ -1,4 +1,8 @@
|
||||
.vscode
|
||||
.theia
|
||||
node_modules
|
||||
dist
|
||||
package-lock.json
|
||||
yarn.lock
|
||||
packages/nashorn/docs
|
||||
!packages/types/dist
|
||||
|
||||
10
.gitpod.Dockerfile
vendored
Normal file
10
.gitpod.Dockerfile
vendored
Normal file
@@ -0,0 +1,10 @@
|
||||
FROM gitpod/workspace-full
|
||||
|
||||
USER gitpod
|
||||
|
||||
# Install custom tools, runtime, etc. using apt-get
|
||||
# For example, the command below would install "bastet" - a command line tetris clone:
|
||||
#
|
||||
# RUN sudo apt-get -q update && # sudo apt-get install -yq bastet && # sudo rm -rf /var/lib/apt/lists/*
|
||||
#
|
||||
# More information: https://www.gitpod.io/docs/config-docker/
|
||||
5
.gitpod.yml
Normal file
5
.gitpod.yml
Normal file
@@ -0,0 +1,5 @@
|
||||
tasks:
|
||||
- init: yarn && yarn bs && yarn build
|
||||
command: yarn watch
|
||||
# image:
|
||||
# file: .gitpod.Dockerfile
|
||||
23
.npmignore
Normal file
23
.npmignore
Normal file
@@ -0,0 +1,23 @@
|
||||
test
|
||||
typings
|
||||
bundled
|
||||
build
|
||||
coverage
|
||||
docs
|
||||
wiki
|
||||
gulpfile.js
|
||||
bower.json
|
||||
karma.conf.js
|
||||
tsconfig.json
|
||||
typings.json
|
||||
CONTRIBUTING.md
|
||||
ISSUE_TEMPLATE.md
|
||||
PULL_REQUEST_TEMPLATE.md
|
||||
tslint.json
|
||||
wallaby.js
|
||||
.travis.yml
|
||||
.gitignore
|
||||
.vscode
|
||||
.theia
|
||||
type_definitions
|
||||
tsconfig.tsbuildinfo
|
||||
14
README.MD
14
README.MD
@@ -11,12 +11,24 @@
|
||||
├─api 全平台兼容的接口
|
||||
├─core 核心代码 用于引导加载
|
||||
├─common 公共类库代码 例如 http reflect 模块
|
||||
├─client NodeJS的Minecraft客户端 用于调试插件
|
||||
├─container IOC容器 用于注入具体实现
|
||||
├─ployfill Nashorn 的一些自定义增强
|
||||
├─nashorn Nashorn 的类型定义
|
||||
├─bungee BungeeCordAPI内部实现
|
||||
├─bukkit BukkitAPI内部实现
|
||||
├─sponge SpongeAPI内部实现
|
||||
├─nukkit NukkitAPI内部实现
|
||||
├─plugin 插件管理器
|
||||
├─websocket Netty的WebSocket注入
|
||||
├─type Java的类型定义
|
||||
| ├─bungee BungeeCord类型定义
|
||||
| ├─bukkit Bukkit类型定义
|
||||
| ├─sponge Sponge类型定义
|
||||
| └─nukkit Nukkit类型定义
|
||||
└─plugins 这里当然是插件啦
|
||||
├─bungee 只兼容BungeeCord的插件
|
||||
├─bukkit 只兼容Bukkit的插件
|
||||
└─sponge 只兼容Sponge的插件
|
||||
├─sponge 只兼容Sponge的插件
|
||||
└─nukkit 只兼容Nukkit的插件
|
||||
```
|
||||
|
||||
62
cli.sh
62
cli.sh
@@ -1,62 +0,0 @@
|
||||
#!/bin/bash
|
||||
SHELL_PREFIX="[FAAS-CLI]"
|
||||
# Shell Base Script
|
||||
set -e
|
||||
|
||||
c_red="\033[38;5;1m"
|
||||
c_blue="\033[38;5;4m"
|
||||
c_green="\033[38;5;2m"
|
||||
c_reset="\033[0m"
|
||||
c_yellow="\033[38;5;3m"
|
||||
|
||||
c_prefix="${c_blue}${SHELL_PREFIX}>>${c_reset}"
|
||||
|
||||
dateStr() {
|
||||
echo -e "[$(date '+%H:%M:%S')]"
|
||||
}
|
||||
|
||||
info() {
|
||||
echo -e "${c_prefix}$(dateStr) ${*}"
|
||||
}
|
||||
|
||||
warn() {
|
||||
echo -e "${c_prefix}$(dateStr) ${c_yellow}${*}${c_reset}"
|
||||
}
|
||||
|
||||
error() {
|
||||
echo -e "${c_prefix}$(dateStr) ${c_red}${*}${c_reset}"
|
||||
}
|
||||
#====================
|
||||
cd $(dirname $0)
|
||||
|
||||
# User Input Variable
|
||||
action=
|
||||
|
||||
while [[ $# -gt 0 ]]; do
|
||||
case "$1" in
|
||||
-a)
|
||||
action="$2"
|
||||
shift
|
||||
;;
|
||||
-*)
|
||||
echo "Illegal option $1"
|
||||
;;
|
||||
esac
|
||||
shift $(( $# > 0 ? 1 : 0 ))
|
||||
done
|
||||
|
||||
case "${action}" in
|
||||
undo)
|
||||
hash=$(git log -n 1 --format=format:%H)
|
||||
tag=$(git tag -l --contains=${hash})
|
||||
if [[ -z "${tag}" ]]; then
|
||||
error "last commit not have tag exit..."
|
||||
exit 0
|
||||
fi
|
||||
git reset HEAD^
|
||||
git tag -d ${tag}
|
||||
git push origin master -f
|
||||
git push origin :${tag}
|
||||
;;
|
||||
esac
|
||||
|
||||
325
doc/MCBBS.MD
325
doc/MCBBS.MD
@@ -1,318 +1,11 @@
|
||||
为了方便阅读 我对帖子进行了分页 请点击目录阅读!
|
||||
- 构建状态 [](https://ci.yumc.pw/job/Minecraft/job/MiaoScript/)
|
||||
- 当前版本 
|
||||
- 下载地址 [](http://w.yumc.pw/free.html#MiaoScript-download)
|
||||
- 更新日志 [](https://docs.yumc.pw/MiaoScript/CHANGELOG.html)
|
||||
- 安装文档 [](https://docs.yumc.pw/MiaoScript/1-user/1.1-check-env.html)
|
||||
- 开发文档 [](https://docs.yumc.pw/MiaoScript/2-develop/1.1-check-env.html)
|
||||
- 兼容服务端 Spigot CatServer Sponge BungeeCord Nukkit(没错 他还兼容Nukkit)
|
||||
|
||||
## 插件简介
|
||||
### 腐竹版本(开发中)
|
||||
|
||||
- 此插件可以实现跨端使用 `TypeScript` 开发 脚本插件
|
||||
- 目前已经兼容 `Spigot` `Sponge`
|
||||
- 后续计划兼容 `BungeeCord` `Nukkit`
|
||||
|
||||
## 起源 (可以略过)
|
||||
|
||||
### 简介
|
||||
|
||||
> 这个坑是我自己刨的 但是发现坑太大 需要更多的人一起填
|
||||
|
||||
### 起源
|
||||
|
||||
- 诞生于 `2016年08月25日` 这是 Git 上的第一个提交 具体啥时候我也忘了
|
||||
- 起初 `MiaoScript` 只是用于服务器其他插件的变量执行 并且依赖于PAPI(不知道是啥的自己百度)
|
||||
- 比如 [`MiaoMenu`](http://w.yumc.pw/zc/MiaoMenu.html) 的部分复杂脚本
|
||||
- 比如 [`MiaoChat`](http://mcbbs.net/thread-631240-1-1.html) 的聊天变量
|
||||
- 突然有一天 圈内的大佬 `QSB` @qiu1995 过来找我 说能不能用脚本监听玩家的事件
|
||||
- PS: 这货自从用过 `DeluxeMenu` 之后就喜欢上了用JS写菜单
|
||||
- 当初感觉没啥问题 就出了第一个简易的 `MiaoScript` 版本 还是用 yml 做的配置文件
|
||||
- 但是由于设计 BukkitAPI 等内容 对Java要求太高 后来 邱也弃坑了 我也弃坑了
|
||||
|
||||
### 刨坑
|
||||
|
||||
- 时隔多年(也就一年) 看到了Sponge的兴起 (估摸着是MCPC系列的MOD端都弃坑了)
|
||||
- 同时 这期间 收到很多腐竹的单子 但是又是非常基础的东西
|
||||
- 比如 开服给玩家发一条消息啦
|
||||
- 比如 修改玩家某些数据啦
|
||||
- 这些东西实际上也就几行代码的事情
|
||||
- 同时 很多想入坑 插件开发 但是又有一些被卡死在环境搭建上
|
||||
- 比如 `Bukkit` 需要 `BukkitAPI`
|
||||
- `Sponge` 需要 `SpongeAPI` 如果涉及 `MOD` 还要 `Forge` 环境
|
||||
- 再或者 BungeeCord 的插件开发 我也是经常懒得搞
|
||||
- 当然 最主要的是 某个 咕咕咕的群 天天有人问我 喵系插件能不能支持 Sponge
|
||||
- 内心当然是拒绝的 现在要上班养老婆孩子(咳咳 不要以为我是大叔 我也才刚毕业而已) 那里还有时间免费给你们写插件
|
||||
- 于是乎 我又想起了当初的 `MiaoScript`
|
||||
- 突发奇想 一个插件的雏形出现在我的脑海中
|
||||
- 可以兼容多种服务器
|
||||
- 不需要开发环境 有记事本就可以开发
|
||||
- 语法要简单 比如 JavaScript
|
||||
- 能够自动搜索安装依赖(毕竟很多人天天问我为何喵系插件跑不起来 都是缺少PAPI)
|
||||
- 能够不重启更新插件(当然得保证代码安全的前提下)
|
||||
- 在 2017年9月14号(距离 第一个版本正式版发布(2016-09-21) 相差一年整)
|
||||
- 一个全新的 `MiaoScript` 诞生了
|
||||
- Java部分代码 只有一个启动类
|
||||
- 核心全部由 JS 编写
|
||||
- 兼容 `CommonJS` 规范
|
||||
- 实时重载
|
||||
|
||||
### 进展
|
||||
|
||||
- [项目发布](https://git.yumc.pw/502647092/MiaoScript/releases)
|
||||
- [项目代码](https://git.yumc.pw/502647092/MiaoScript)
|
||||
- [项目脑图](http://naotu.baidu.com/file/293b9a0fc7cef23c69de81c55e3617d5?token=1eee8fd759198eb7)
|
||||
|
||||
### 规划
|
||||
|
||||
- 初期只会支持JS类型的插件开发
|
||||
- 二期会出一个建议版本的MS脚本 可以用简单的语法实现简单的功能
|
||||
- 各个层级会有依赖控制 比如 `MS脚本 => JS脚本 => 调用Java原生API`
|
||||
|
||||
## 框架设计
|
||||
|
||||
### MiaoScript TS 实现
|
||||
|
||||
项目具体实现 由 TypeScript 进行编写 然后编译至 `es5` 用于兼容 Java8 的 `Nashorn`
|
||||
|
||||
### Project Structure
|
||||
|
||||
```txt
|
||||
└─packages
|
||||
├─api 全平台兼容的接口
|
||||
├─core 核心代码 用于引导加载
|
||||
├─common 公共类库代码 例如 http reflect 模块
|
||||
├─container IOC容器 用于注入具体实现
|
||||
├─nashorn Nashorn 的类型定义
|
||||
├─bukkit BukkitAPI内部实现
|
||||
├─sponge SpongeAPI内部实现
|
||||
├─plugin 插件管理器
|
||||
└─plugins 这里当然是插件啦
|
||||
├─bukkit 只兼容Bukkit的插件
|
||||
└─sponge 只兼容Sponge的插件
|
||||
```
|
||||
|
||||
详细的内容就不逼逼了 自己看代码吧
|
||||
|
||||
Github: https://github.com/circlecloud/ms
|
||||
|
||||
## 插件开发基础
|
||||
|
||||
### 开发IDE (推荐VSCode或者MiaoScrit在线IDE)
|
||||
|
||||
如果只是简单的开发 你可用记事本 (但是没有任何补全和错误提示)
|
||||
|
||||
### 开发环境准备(针对高级用户))
|
||||
|
||||
- 安装 `NodeJS` 和 `Yarn`
|
||||
- 拉取代码
|
||||
- `git clone https://github.com/circlecloud/ms.git`
|
||||
- 进入目录 `ms`
|
||||
- 安装 npm 包
|
||||
- `yarn`
|
||||
- 编译一次生成对应的类库
|
||||
- `yarn build`
|
||||
|
||||
### 直接在 MiaoScript Online WebIDE 开发
|
||||
|
||||
填坑中...
|
||||
|
||||
## 基本插件框架
|
||||
|
||||
### HelloWorld 示例插件
|
||||
|
||||
先来一个 `HelloWorld.ts` 插件示范!
|
||||
|
||||
```ts
|
||||
import { plugin, interfaces, cmd, listener, tab } from '@ms/plugin'
|
||||
|
||||
@plugin({ name: 'HelloWorld', version: '1.0.0', author: 'MiaoWoo', source: __filename })
|
||||
export class HelloWorld extends interfaces.Plugin {
|
||||
load() {
|
||||
this.logger.log('Test Plugin load from MiaoScript Plugin System...');
|
||||
}
|
||||
enable() {
|
||||
this.logger.log('Test Plugin enable from MiaoScript Plugin System...');
|
||||
}
|
||||
disable() {
|
||||
this.logger.log('Test Plugin disable from MiaoScript Plugin System...');
|
||||
}
|
||||
|
||||
bukkitload() {
|
||||
this.logger.log('Load When ServerType is Bukkit!')
|
||||
}
|
||||
bukkitenable() {
|
||||
this.logger.log('Enable When ServerType is Bukkit!')
|
||||
}
|
||||
bukkitdisable() {
|
||||
this.logger.log('Disable When ServerType is Bukkit!')
|
||||
}
|
||||
|
||||
spongeload() {
|
||||
this.logger.log('Load When ServerType is Sponge!')
|
||||
}
|
||||
spongeenable() {
|
||||
this.logger.log('Enable When ServerType is Sponge!')
|
||||
}
|
||||
spongedisable() {
|
||||
this.logger.log('Disable When ServerType is Sponge!')
|
||||
}
|
||||
|
||||
@cmd()
|
||||
hello(sender: any, command: string, args: string[]) {
|
||||
this.logger.log(sender, command, args);
|
||||
this.logger.sender(sender, JSON.stringify({ command, args }));
|
||||
}
|
||||
|
||||
@tab()
|
||||
tabhello(_sender: any, _command: string, _args: string[]) {
|
||||
return ['world']
|
||||
}
|
||||
|
||||
@listener({ servertype: 'bukkit' })
|
||||
playerjoin(event: any) {
|
||||
this.logger.console(`§aBukkit PlayerJoinEvent: §b${event.player.name}`)
|
||||
setTimeout(() => this.logger.sender(event.player, `§a欢迎来到 §bMiaoScript §a的世界!`), 10);
|
||||
}
|
||||
|
||||
@listener({ servertype: 'sponge' })
|
||||
clientconnectionevent$join(event: any) {
|
||||
this.logger.console(`§aSponge ClientConnectionEvent.Join: §b${event.targetEntity.name}`)
|
||||
setTimeout(() => this.logger.sender(event.targetEntity, `§a欢迎来到 §bMiaoScript §a的世界!`), 10);
|
||||
}
|
||||
}
|
||||
|
||||
```
|
||||
|
||||
- 进入 `ms`目录
|
||||
- 执行编译 `yarn build:plugins`
|
||||
- 从 `packages/plugins/dist` 中复制 `HelloWorld.js` 文件 到对应的插件目录
|
||||
- Bukkit: plugins/MiaoScript/plugins/
|
||||
- Sponge: config/miaoscript/plugins/
|
||||
- 重载 `MiaoScript`
|
||||
- 打开客户端进入游戏 预览一下效果
|
||||
- 从 Spigot 服务端进入
|
||||

|
||||

|
||||
- 从 Sponge 服务端进入
|
||||

|
||||

|
||||
|
||||
## 注册插件
|
||||
|
||||
- 从上面的示例可以看到 一个插件 通过注解 `@plugin` 即可启动
|
||||
- 此注解接受一个 `PluginMetadata` 对象 定义如下
|
||||
```ts
|
||||
export interface PluginMetadata {
|
||||
/**
|
||||
* 插件名称
|
||||
*/
|
||||
name: string;
|
||||
/**
|
||||
* 前缀
|
||||
*/
|
||||
prefix?: string;
|
||||
/**
|
||||
* 插件版本
|
||||
*/
|
||||
version: string;
|
||||
/**
|
||||
* 插件版本
|
||||
*/
|
||||
author: string | string[];
|
||||
/**
|
||||
* 插件源文件 必须指定为 __filename
|
||||
*/
|
||||
source: string;
|
||||
/**
|
||||
* 插件本体
|
||||
*/
|
||||
target?: any;
|
||||
}
|
||||
```
|
||||
|
||||
### 插件生命周期
|
||||
|
||||
MiaoScript的生命周期遵循了 Bukkit 的生命周期
|
||||
|
||||
MiaoScript针对不同的服务端 提供了扩展的周期
|
||||
以服务端类型开头阶段名结束 例如 `bukkitload` `spongeenbale`
|
||||
扩展的生命周期只会在特定的服务器执行
|
||||
|
||||
### load 加载阶段
|
||||
|
||||
此阶段通常用于初始化基础配置 数据库链接等
|
||||
某些对外提供功能的插件 需要在此阶段初始化完成
|
||||
|
||||
### enable 启动阶段
|
||||
|
||||
此阶段通常用于注册命令 注册事件等
|
||||
由于命令和事件 MiaoScript 已经托管了 所以开发者可以直接用注解实现
|
||||
|
||||
### disable 关闭阶段
|
||||
|
||||
此阶段通常用于注销命令 注销事件等
|
||||
由于命令和事件 MiaoScript 已经托管了 所以开发者可以直接用注解实现
|
||||
|
||||
## 注册命令/补全
|
||||
|
||||
### cmd 命令
|
||||
|
||||
命令 就是玩家在Minecraft中执行命令 下面是一个示例的命令
|
||||
|
||||
- 命令是一个 `function` 通过 `@cmd` 注解注册
|
||||
- 命令注册时默认使用方法名称为命令名称 当前你可以传入 name 参数指定命令名称 例如 `{name: 'test'}`
|
||||
- 接受三个参数 `sender: any, command: string, args: string[]`
|
||||
- 分别代表 命令发送者 命令名称 命令参数
|
||||
|
||||
```ts
|
||||
@cmd()
|
||||
hello(sender: any, command: string, args: string[]) {
|
||||
this.logger.log(sender, command, args);
|
||||
this.logger.sender(sender, JSON.stringify({ command, args }));
|
||||
}
|
||||
```
|
||||
|
||||
### tab 补全
|
||||
|
||||
补全就是 玩家在Minecraft执行命令时 使用 Tab键 补全
|
||||
|
||||
- 补全是一个 `functio` 一般以 `tab` 开头 需要补全的命令结尾 通过 `@tab` 注解注册
|
||||
- 补全注册时默认使用方法名称为补全名称 当前你可以传入 name 参数指定命令名称 例如 `{name: 'test'}`
|
||||
- 接受三个参数 `sender: any, command: string, args: string[]`
|
||||
- 分别代表 命令发送者 命令名称 命令参数
|
||||
|
||||
_注意: 当补全命令未注册时 补全无效! 且补全和命令必须在同一个Class内!_
|
||||
|
||||
```ts
|
||||
@tab()
|
||||
tabhello(_sender: any, _command: string, _args: string[]) {
|
||||
return ['world']
|
||||
}
|
||||
```
|
||||
|
||||
## 监听事件
|
||||
|
||||
事件是指 Minecraft 中发生的各种事情
|
||||
|
||||
- 监听事件是一个 `function` 通过 `@listener` 注册
|
||||
- 事件名称默认为方法名称
|
||||
- 所有类型服务端的事件 MiaoScript 都会进行一次映射 方便使用
|
||||
- 例如 `PlayerJoinEvent` 会映射为 `PlayerJoinEvent, playerjoinevent, playerjoin` 等
|
||||
- 一般规则就是 类名直接小写 如果遇到子类 则保留 `$`
|
||||
- 例如 `ClientConnectionEvent.Join` 会映射为 `clientconnectionevent$join`
|
||||
- 事件的注可以传入 `servertype` 来指定这个事件类型的服务端加载 默认是所有服务端都加载
|
||||
- 事件监听方法的第一个参数就是本次事件的具体内容 (这里就需要自己去查询对应的JavaDoc了)
|
||||
|
||||
```ts
|
||||
@listener({ servertype: 'bukkit' })
|
||||
playerjoin(event: any) {
|
||||
this.logger.console(`§aBukkit PlayerJoinEvent: §b${event.player.name}`)
|
||||
setTimeout(() => this.logger.sender(event.player, `§a欢迎来到 §bMiaoScript §a的世界!`), 10);
|
||||
}
|
||||
|
||||
@listener({ servertype: 'sponge' })
|
||||
clientconnectionevent$join(event: any) {
|
||||
this.logger.console(`§aSponge ClientConnectionEvent.Join: §b${event.targetEntity.name}`)
|
||||
setTimeout(() => this.logger.sender(event.targetEntity, `§a欢迎来到 §bMiaoScript §a的世界!`), 10);
|
||||
}
|
||||
```
|
||||
|
||||
## 插件列表
|
||||
|
||||
暂无
|
||||
|
||||
> 注意: 一楼的列表是老版本的 新版本无法加载!
|
||||
- 先上几张图
|
||||
|
||||
@@ -1,5 +1,5 @@
|
||||
{
|
||||
"version": "0.1.1",
|
||||
"version": "0.7.0",
|
||||
"useWorkspaces": true,
|
||||
"npmClient": "yarn",
|
||||
"packages": [
|
||||
|
||||
16
package.json
16
package.json
@@ -6,16 +6,20 @@
|
||||
"author": "MiaoWoo <admin@yumc.pw>",
|
||||
"license": "MIT",
|
||||
"scripts": {
|
||||
"clean": "npx lerna run clean",
|
||||
"watch": "npx lerna run watch --parallel",
|
||||
"build": "npx lerna run build",
|
||||
"build:plugins": "npx lerna run build --scope=@ms/plugins",
|
||||
"lp": "npx lerna publish"
|
||||
"bs": "lerna bootstrap",
|
||||
"clean": "lerna run clean",
|
||||
"watch": "lerna run watch --parallel",
|
||||
"build": "lerna run build --scope=\"@ccms/!(plugins)\"",
|
||||
"build:plugins": "lerna run build --scope=\"@ccms/plugins\"",
|
||||
"ug": "yarn upgrade-interactive --latest",
|
||||
"np": "lerna exec \"npm publish --registry https://registry.npmjs.org\" --scope=\"@ccms/!(client|plugins)\"",
|
||||
"lsp": "npm login --registry=https://registry.npmjs.org --scope=@ccms",
|
||||
"lp": "lerna publish"
|
||||
},
|
||||
"workspaces": [
|
||||
"packages/*"
|
||||
],
|
||||
"devDependencies": {
|
||||
"lerna": "^3.16.4"
|
||||
"lerna": "^3.21.0"
|
||||
}
|
||||
}
|
||||
|
||||
1
packages/amqp/.npmignore
Symbolic link
1
packages/amqp/.npmignore
Symbolic link
@@ -0,0 +1 @@
|
||||
../../.npmignore
|
||||
32
packages/amqp/package.json
Normal file
32
packages/amqp/package.json
Normal file
@@ -0,0 +1,32 @@
|
||||
{
|
||||
"name": "@ccms/amqp",
|
||||
"version": "0.7.0",
|
||||
"description": "MiaoScript amqp package",
|
||||
"keywords": [
|
||||
"miaoscript",
|
||||
"minecraft",
|
||||
"bukkit",
|
||||
"sponge"
|
||||
],
|
||||
"author": "MiaoWoo <admin@yumc.pw>",
|
||||
"homepage": "https://github.com/circlecloud/ms.git",
|
||||
"license": "ISC",
|
||||
"main": "dist/index.js",
|
||||
"scripts": {
|
||||
"clean": "rimraf dist",
|
||||
"watch": "tsc --watch",
|
||||
"build": "yarn clean && tsc",
|
||||
"test": "echo \"Error: run tests from root\" && exit 1"
|
||||
},
|
||||
"dependencies": {
|
||||
"@ccms/api": "^0.7.0",
|
||||
"@ccms/nashorn": "^0.7.0",
|
||||
"@ccms/common": "^0.7.0",
|
||||
"@ccms/container": "^0.7.0"
|
||||
},
|
||||
"devDependencies": {
|
||||
"reflect-metadata": "^0.1.13",
|
||||
"rimraf": "^3.0.2",
|
||||
"typescript": "^3.9.2"
|
||||
}
|
||||
}
|
||||
14
packages/amqp/src/adapter/admin.ts
Normal file
14
packages/amqp/src/adapter/admin.ts
Normal file
@@ -0,0 +1,14 @@
|
||||
import { ConnectionFactoryAdapter } from "./connection"
|
||||
import { RabbitTemplateAdapter } from "./template"
|
||||
|
||||
export const RabbitAdmin = Java.type('org.springframework.amqp.rabbit.core.RabbitAdmin')
|
||||
|
||||
export class RabbitAdminAdapter {
|
||||
private _Handler: org.springframework.amqp.rabbit.core.RabbitAdmin
|
||||
constructor(config: RabbitTemplateAdapter | org.springframework.amqp.rabbit.core.RabbitTemplate | ConnectionFactoryAdapter | org.springframework.amqp.rabbit.connection.ConnectionFactory) {
|
||||
this._Handler = new RabbitAdmin((config instanceof RabbitTemplateAdapter || config instanceof ConnectionFactoryAdapter) ? config.getHandler() : config)
|
||||
}
|
||||
getHandler(): org.springframework.amqp.rabbit.core.RabbitAdmin {
|
||||
return this._Handler
|
||||
}
|
||||
}
|
||||
30
packages/amqp/src/adapter/callback.ts
Normal file
30
packages/amqp/src/adapter/callback.ts
Normal file
@@ -0,0 +1,30 @@
|
||||
export const ConfirmCallback = Java.type('org.springframework.amqp.rabbit.core.RabbitTemplate.ConfirmCallback')
|
||||
export const ReturnCallback = Java.type('org.springframework.amqp.rabbit.core.RabbitTemplate.ReturnCallback')
|
||||
|
||||
export abstract class ConfirmCallbackAdapter {
|
||||
private _Handler: org.springframework.amqp.rabbit.core.RabbitTemplate.ConfirmCallback
|
||||
constructor() {
|
||||
let ConfirmCallbackImpl = Java.extend(ReturnCallback, {
|
||||
confirm: (correlationData: org.springframework.amqp.rabbit.connection.CorrelationData, ack: boolean, cause: string) => this.confirm(correlationData, ack, cause)
|
||||
})
|
||||
this._Handler = new ConfirmCallbackImpl()
|
||||
}
|
||||
abstract confirm(correlationData: org.springframework.amqp.rabbit.connection.CorrelationData, ack: boolean, cause: string)
|
||||
getHandler() {
|
||||
return this._Handler
|
||||
}
|
||||
}
|
||||
|
||||
export abstract class ReturnCallbackAdapter {
|
||||
private _Handler: org.springframework.amqp.rabbit.core.RabbitTemplate.ReturnCallback
|
||||
constructor() {
|
||||
let ReturnCallbackImpl = Java.extend(ReturnCallback, {
|
||||
returnedMessage: (message: org.springframework.amqp.core.Message, replyCode: number, replyText: string, exchange: string, routingKey: string) => this.returnedMessage(message, replyCode, replyText, exchange, routingKey)
|
||||
})
|
||||
this._Handler = new ReturnCallbackImpl()
|
||||
}
|
||||
abstract returnedMessage(message: org.springframework.amqp.core.Message, replyCode: number, replyText: string, exchange: string, routingKey: string)
|
||||
getHandler() {
|
||||
return this._Handler
|
||||
}
|
||||
}
|
||||
31
packages/amqp/src/adapter/connection.ts
Normal file
31
packages/amqp/src/adapter/connection.ts
Normal file
@@ -0,0 +1,31 @@
|
||||
import threadPool from '@ccms/common/dist/thread-pool'
|
||||
|
||||
export const ConnectionFactory = Java.type('org.springframework.amqp.rabbit.connection.ConnectionFactory')
|
||||
const CachingConnectionFactory = Java.type('org.springframework.amqp.rabbit.connection.CachingConnectionFactory')
|
||||
interface ConnectionConfig {
|
||||
url: string,
|
||||
username?: string,
|
||||
password?: string,
|
||||
publisherConfirms?: boolean
|
||||
cacheSize?: number
|
||||
}
|
||||
|
||||
export class ConnectionFactoryAdapter {
|
||||
private _Handler: org.springframework.amqp.rabbit.connection.CachingConnectionFactory
|
||||
|
||||
constructor(config: ConnectionConfig) {
|
||||
if (!config.url) { throw new Error('Connection UrI Can\'t be undefiend!') }
|
||||
config = { publisherConfirms: true, cacheSize: 50, ...config }
|
||||
this._Handler = new CachingConnectionFactory(new java.net.URI(config.url))
|
||||
config.username && this._Handler.setUsername(config.username)
|
||||
config.password && this._Handler.setPassword(config.password)
|
||||
this._Handler.setPublisherConfirms(config.publisherConfirms)
|
||||
this._Handler.setExecutor(threadPool.create({
|
||||
groupName: '@ccms/amqp-rabbit'
|
||||
}))
|
||||
this._Handler.setChannelCacheSize(config.cacheSize)
|
||||
}
|
||||
getHandler() {
|
||||
return this._Handler
|
||||
}
|
||||
}
|
||||
30
packages/amqp/src/adapter/container.ts
Normal file
30
packages/amqp/src/adapter/container.ts
Normal file
@@ -0,0 +1,30 @@
|
||||
import { ConnectionFactoryAdapter, ConnectionFactory } from "./connection"
|
||||
import { ChannelAwareMessageListenerAdapter, ChannelAwareMessageListener } from "./listener"
|
||||
|
||||
export const SimpleMessageListenerContainer = org.springframework.amqp.rabbit.listener.SimpleMessageListenerContainer
|
||||
export const AcknowledgeMode = org.springframework.amqp.core.AcknowledgeMode
|
||||
interface ContainerConfig {
|
||||
connectionFactory: ConnectionFactoryAdapter | typeof ConnectionFactory
|
||||
queueNames: string[]
|
||||
messageListener: ChannelAwareMessageListenerAdapter | typeof ChannelAwareMessageListener
|
||||
maxConcurrentConsumers?: number
|
||||
concurrentConsumers?: number
|
||||
acknowledgeMode?: org.springframework.amqp.core.AcknowledgeMode
|
||||
}
|
||||
|
||||
export class MessageListenerContainerAdapter {
|
||||
private _Handler: org.springframework.amqp.rabbit.listener.SimpleMessageListenerContainer
|
||||
constructor(config: ContainerConfig) {
|
||||
config = { concurrentConsumers: 5, maxConcurrentConsumers: 10, acknowledgeMode: AcknowledgeMode.AUTO, ...config }
|
||||
this._Handler = new SimpleMessageListenerContainer(config.connectionFactory instanceof ConnectionFactoryAdapter ? config.connectionFactory.getHandler() : config.connectionFactory)
|
||||
//@ts-ignore
|
||||
this._Handler.setQueueNames(config.queueNames)
|
||||
this._Handler.setMaxConcurrentConsumers(config.maxConcurrentConsumers)
|
||||
this._Handler.setConcurrentConsumers(config.concurrentConsumers)
|
||||
this._Handler.setAcknowledgeMode(config.acknowledgeMode)
|
||||
this._Handler.setMessageListener(config.messageListener instanceof ChannelAwareMessageListenerAdapter ? config.messageListener.getHandler() : config.messageListener)
|
||||
}
|
||||
getHandler() {
|
||||
return this._Handler
|
||||
}
|
||||
}
|
||||
37
packages/amqp/src/adapter/converter.ts
Normal file
37
packages/amqp/src/adapter/converter.ts
Normal file
@@ -0,0 +1,37 @@
|
||||
const JavaString = Java.type('java.lang.String')
|
||||
const MessageProperties = org.springframework.amqp.core.MessageProperties
|
||||
const Message = org.springframework.amqp.core.Message
|
||||
|
||||
export const MessageConverter = Java.type('org.springframework.amqp.support.converter.MessageConverter')
|
||||
|
||||
export class MessageConverterAdapter {
|
||||
private _Handler: org.springframework.amqp.support.converter.MessageConverter
|
||||
constructor() {
|
||||
var MessageConverterImpl = Java.extend(MessageConverter, {
|
||||
toMessage: (object: any, messageProperties: org.springframework.amqp.core.MessageProperties) => this.toMessage(object, messageProperties),
|
||||
fromMessage: (message: org.springframework.amqp.core.Message) => this.fromMessage(message)
|
||||
})
|
||||
this._Handler = new MessageConverterImpl()
|
||||
}
|
||||
toMessage(object: any, messageProperties: org.springframework.amqp.core.MessageProperties) {
|
||||
if (typeof object == "string") {
|
||||
messageProperties.setContentType(MessageProperties.CONTENT_TYPE_TEXT_PLAIN)
|
||||
return new Message(new JavaString(object).getBytes(), messageProperties)
|
||||
} else {
|
||||
messageProperties.setContentType(MessageProperties.CONTENT_TYPE_JSON)
|
||||
return new Message(new JavaString(JSON.stringify(object)).getBytes(), messageProperties)
|
||||
}
|
||||
}
|
||||
fromMessage(message: org.springframework.amqp.core.Message) {
|
||||
if (message.getMessageProperties().getContentType() == MessageProperties.CONTENT_TYPE_TEXT_PLAIN) {
|
||||
return new JavaString(message.getBody(), message.getMessageProperties().getContentEncoding())
|
||||
}
|
||||
if (message.getMessageProperties().getContentType() == MessageProperties.CONTENT_TYPE_JSON) {
|
||||
return JSON.parse(new JavaString(message.getBody(), message.getMessageProperties().getContentEncoding()))
|
||||
}
|
||||
return message
|
||||
}
|
||||
getHandler() {
|
||||
return this._Handler
|
||||
}
|
||||
}
|
||||
7
packages/amqp/src/adapter/index.ts
Normal file
7
packages/amqp/src/adapter/index.ts
Normal file
@@ -0,0 +1,7 @@
|
||||
export * from './admin'
|
||||
export * from './callback'
|
||||
export * from './connection'
|
||||
export * from './container'
|
||||
export * from './converter'
|
||||
export * from './listener'
|
||||
export * from './template'
|
||||
49
packages/amqp/src/adapter/listener.ts
Normal file
49
packages/amqp/src/adapter/listener.ts
Normal file
@@ -0,0 +1,49 @@
|
||||
const JavaString = Java.type('java.lang.String')
|
||||
export const MessageProperties = org.springframework.amqp.core.MessageProperties
|
||||
export const ChannelAwareMessageListener = Java.type('org.springframework.amqp.rabbit.listener.api.ChannelAwareMessageListener')
|
||||
export const AmqpRejectAndDontRequeueException = org.springframework.amqp.AmqpRejectAndDontRequeueException
|
||||
export const Channel: com.rabbitmq.client.Channel = Java.type('com.rabbitmq.client.Channel')
|
||||
export const Message = org.springframework.amqp.core.Message
|
||||
export type MessageHandler<T> = (content: T, message: org.springframework.amqp.core.Message, channel: com.rabbitmq.client.Channel) => any
|
||||
export abstract class ChannelAwareMessageListenerAdapter<T = any> {
|
||||
private _Handler: org.springframework.amqp.rabbit.listener.api.ChannelAwareMessageListener
|
||||
constructor(manual: boolean = false) {
|
||||
let ChannelAwareMessageListenerImpl = Java.extend(ChannelAwareMessageListener, {
|
||||
onMessage: (message: org.springframework.amqp.core.Message, channel: com.rabbitmq.client.Channel) => {
|
||||
let content = new JavaString(message.getBody(), message.getMessageProperties().getContentEncoding() || "UTF-8")
|
||||
try {
|
||||
if (message.getMessageProperties().getContentType() == MessageProperties.CONTENT_TYPE_JSON) {
|
||||
content = JSON.parse(content)
|
||||
}
|
||||
} catch (error) {
|
||||
if (manual) {
|
||||
channel.basicReject(message.getMessageProperties().getDeliveryTag(), true)
|
||||
} else {
|
||||
throw new AmqpRejectAndDontRequeueException(`${error}`, error)
|
||||
}
|
||||
}
|
||||
manual ? this.manualOnMessage(content, message, channel) : this.onMessage(content, message, channel)
|
||||
}
|
||||
})
|
||||
this._Handler = new ChannelAwareMessageListenerImpl()
|
||||
}
|
||||
abstract onMessage(content: T, message: org.springframework.amqp.core.Message, channel: com.rabbitmq.client.Channel): any
|
||||
onError(error: Error, message: org.springframework.amqp.core.Message, channel: com.rabbitmq.client.Channel): any { }
|
||||
getHandler() {
|
||||
return this._Handler
|
||||
}
|
||||
private manualOnMessage(content: T, message: org.springframework.amqp.core.Message, channel: com.rabbitmq.client.Channel) {
|
||||
let deliveryTag = message.getMessageProperties().getDeliveryTag()
|
||||
try {
|
||||
if (this.onMessage(content, message, channel)) {
|
||||
channel.basicAck(deliveryTag, false)
|
||||
} else if (message.getMessageProperties().getRedelivered()) {
|
||||
channel.basicReject(deliveryTag, true)
|
||||
} else {
|
||||
channel.basicNack(deliveryTag, false, true)
|
||||
}
|
||||
} catch (error) {
|
||||
channel.basicReject(deliveryTag, this.onError(error, message, channel))
|
||||
}
|
||||
}
|
||||
}
|
||||
27
packages/amqp/src/adapter/template.ts
Normal file
27
packages/amqp/src/adapter/template.ts
Normal file
@@ -0,0 +1,27 @@
|
||||
import { MessageConverterAdapter } from "./converter"
|
||||
import { ConnectionFactoryAdapter } from "./connection"
|
||||
import { ConfirmCallbackAdapter, ReturnCallbackAdapter } from "./callback"
|
||||
|
||||
export const RabbitTemplate = Java.type('org.springframework.amqp.rabbit.core.RabbitTemplate')
|
||||
|
||||
interface TemplateConfig {
|
||||
connectionFactory: ConnectionFactoryAdapter | org.springframework.amqp.rabbit.connection.ConnectionFactory
|
||||
confirmCallback?: ConfirmCallbackAdapter
|
||||
returnCallback?: ReturnCallbackAdapter
|
||||
messageConverter?: MessageConverterAdapter
|
||||
}
|
||||
export class RabbitTemplateAdapter {
|
||||
private _Handler: org.springframework.amqp.rabbit.core.RabbitTemplate
|
||||
constructor(config: TemplateConfig) {
|
||||
config = { messageConverter: new MessageConverterAdapter(), ...config }
|
||||
console.debug(JSON.stringify(config))
|
||||
this._Handler = new RabbitTemplate(config.connectionFactory instanceof ConnectionFactoryAdapter ? config.connectionFactory.getHandler() : config.connectionFactory)
|
||||
config.returnCallback && this._Handler.setReturnCallback(config.returnCallback.getHandler())
|
||||
config.confirmCallback && this._Handler.setConfirmCallback(config.confirmCallback.getHandler())
|
||||
config.messageConverter && this._Handler.setMessageConverter(config.messageConverter.getHandler())
|
||||
}
|
||||
|
||||
getHandler() {
|
||||
return this._Handler
|
||||
}
|
||||
}
|
||||
90
packages/amqp/src/admin.ts
Normal file
90
packages/amqp/src/admin.ts
Normal file
@@ -0,0 +1,90 @@
|
||||
import { JSClass } from "@ccms/container"
|
||||
import { RabbitAdminAdapter, MessageListenerContainerAdapter, AcknowledgeMode, MessageHandler, ChannelAwareMessageListenerAdapter } from "./adapter"
|
||||
|
||||
const RabbitAdmin = Java.type('org.springframework.amqp.rabbit.core.RabbitAdmin')
|
||||
|
||||
export class AmqpAdmin {
|
||||
@JSClass('org.springframework.amqp.core.TopicExchange')
|
||||
private TopicExchange: typeof org.springframework.amqp.core.TopicExchange
|
||||
@JSClass('org.springframework.amqp.core.Queue')
|
||||
private Queue: typeof org.springframework.amqp.core.Queue
|
||||
@JSClass('org.springframework.amqp.core.Binding')
|
||||
private Binding: typeof org.springframework.amqp.core.Binding
|
||||
|
||||
@JSClass('org.springframework.amqp.core.Binding.DestinationType')
|
||||
private DestinationType: typeof org.springframework.amqp.core.Binding.DestinationType
|
||||
|
||||
private amqpAdmin: org.springframework.amqp.rabbit.core.RabbitAdmin
|
||||
|
||||
constructor(amqpAdmin: org.springframework.amqp.rabbit.core.RabbitAdmin | any) {
|
||||
if (amqpAdmin instanceof RabbitAdmin) {
|
||||
this.amqpAdmin = amqpAdmin
|
||||
} else if (amqpAdmin instanceof RabbitAdminAdapter) {
|
||||
this.amqpAdmin = amqpAdmin.getHandler()
|
||||
} else {
|
||||
this.amqpAdmin = new RabbitAdminAdapter(amqpAdmin).getHandler()
|
||||
}
|
||||
}
|
||||
|
||||
getHandler() {
|
||||
return this.amqpAdmin
|
||||
}
|
||||
|
||||
getQueueProperties(name: string) {
|
||||
return this.amqpAdmin.getQueueProperties(name)
|
||||
}
|
||||
|
||||
declareExchange(name: string) {
|
||||
let exchange = new this.TopicExchange(name, true, false)
|
||||
this.amqpAdmin.declareExchange(exchange)
|
||||
return this
|
||||
}
|
||||
|
||||
declareQueue(name: string) {
|
||||
let queue = new this.Queue(name, true)
|
||||
this.amqpAdmin.declareQueue(queue)
|
||||
return this
|
||||
}
|
||||
|
||||
declareBinding(queue: string, exchange: string, routerKey: string, argument: any = null) {
|
||||
let binding = new this.Binding(queue, this.DestinationType.QUEUE, exchange, routerKey, argument)
|
||||
this.amqpAdmin.declareBinding(binding)
|
||||
return this
|
||||
}
|
||||
|
||||
declareQueueAndBindExchange(queue: string, exchange: string, routerKey: string) {
|
||||
return this.declareQueue(queue).declareExchange(exchange).declareBinding(queue, exchange, routerKey)
|
||||
}
|
||||
|
||||
createContainer<T>(queue: string, listener: MessageHandler<T>, acknowledgeMode = AcknowledgeMode.AUTO) {
|
||||
let connection = this.amqpAdmin.getRabbitTemplate().getConnectionFactory()
|
||||
return new MessageListenerContainerAdapter({
|
||||
connectionFactory: connection,
|
||||
queueNames: [queue],
|
||||
messageListener: new SimpleMessageHandler(listener),
|
||||
acknowledgeMode: acknowledgeMode
|
||||
}).getHandler()
|
||||
}
|
||||
|
||||
send()
|
||||
send() {
|
||||
|
||||
}
|
||||
|
||||
getTemplate() {
|
||||
return this.amqpAdmin.getRabbitTemplate()
|
||||
}
|
||||
|
||||
close() {
|
||||
this.getTemplate().stop()
|
||||
}
|
||||
}
|
||||
|
||||
export class SimpleMessageHandler extends ChannelAwareMessageListenerAdapter {
|
||||
constructor(private handler: MessageHandler<any>) {
|
||||
super()
|
||||
}
|
||||
onMessage(content: any, message: org.springframework.amqp.core.Message, channel: com.rabbitmq.client.Channel) {
|
||||
return this.handler(content, message, channel)
|
||||
}
|
||||
}
|
||||
3
packages/amqp/src/constants.ts
Normal file
3
packages/amqp/src/constants.ts
Normal file
@@ -0,0 +1,3 @@
|
||||
export const METADATA_KEY = {
|
||||
|
||||
}
|
||||
34
packages/amqp/src/index.ts
Normal file
34
packages/amqp/src/index.ts
Normal file
@@ -0,0 +1,34 @@
|
||||
/// <reference types="@ccms/nashorn" />
|
||||
/// <reference types="@ccms/types/dist/typings/jdk" />
|
||||
/// <reference types="@ccms/types/dist/typings/spring" />
|
||||
/// <reference types="@ccms/types/dist/typings/spring/amqp" />
|
||||
/// <reference types="@ccms/types/dist/typings/rabbitmq" />
|
||||
|
||||
import { amqp } from '@ccms/api'
|
||||
import { getContainer, reduceMetadata } from '@ccms/container'
|
||||
|
||||
function init() {
|
||||
const beanFactory = base.getInstance().getAutowireCapableBeanFactory()
|
||||
getContainer().bind(amqp.rabbit.Template).toDynamicValue((ctx) => {
|
||||
let metadata = reduceMetadata(ctx)
|
||||
if (!metadata.named) {
|
||||
return beanFactory.getBean('rabbitTemplate')
|
||||
} else {
|
||||
return beanFactory.getBean(`${metadata.named}-rabbitTemplate`)
|
||||
}
|
||||
})
|
||||
getContainer().bind(amqp.rabbit.Admin).toDynamicValue((ctx) => {
|
||||
let metadata = reduceMetadata(ctx)
|
||||
if (!metadata.named) {
|
||||
return beanFactory.getBean('rabbitAdmin')
|
||||
} else {
|
||||
return beanFactory.getBean(`${metadata.named}-rabbitAdmin`)
|
||||
}
|
||||
})
|
||||
}
|
||||
init()
|
||||
|
||||
export * from './admin'
|
||||
export * from './adapter'
|
||||
export * from './manager'
|
||||
export * from './constants'
|
||||
5
packages/amqp/src/listener.ts
Normal file
5
packages/amqp/src/listener.ts
Normal file
@@ -0,0 +1,5 @@
|
||||
export class AmqpListener {
|
||||
constructor() {
|
||||
|
||||
}
|
||||
}
|
||||
18
packages/amqp/src/manager.ts
Normal file
18
packages/amqp/src/manager.ts
Normal file
@@ -0,0 +1,18 @@
|
||||
import { amqp } from "@ccms/api"
|
||||
import { provideSingleton } from "@ccms/container"
|
||||
|
||||
import { ConnectionFactoryAdapter, RabbitTemplateAdapter, RabbitAdminAdapter } from "./adapter"
|
||||
import { AmqpAdmin } from "./admin"
|
||||
|
||||
@provideSingleton(amqp.Manager)
|
||||
export class AmqpManager {
|
||||
createConnection(url: string, username: string, password: string) {
|
||||
return new ConnectionFactoryAdapter({ url, username, password })
|
||||
}
|
||||
createTemplate(adapter: ConnectionFactoryAdapter) {
|
||||
return new RabbitTemplateAdapter({ connectionFactory: adapter })
|
||||
}
|
||||
createAdmin(adapter: RabbitTemplateAdapter | ConnectionFactoryAdapter) {
|
||||
return new AmqpAdmin(new RabbitAdminAdapter(adapter))
|
||||
}
|
||||
}
|
||||
7
packages/amqp/tsconfig.json
Normal file
7
packages/amqp/tsconfig.json
Normal file
@@ -0,0 +1,7 @@
|
||||
{
|
||||
"extends": "../../tsconfig.json",
|
||||
"compilerOptions": {
|
||||
"baseUrl": "src",
|
||||
"outDir": "dist"
|
||||
}
|
||||
}
|
||||
4
packages/api/.gitignore
vendored
4
packages/api/.gitignore
vendored
@@ -1,4 +0,0 @@
|
||||
/node_modules
|
||||
/dist
|
||||
/package-lock.json
|
||||
/yarn.lock
|
||||
@@ -1,22 +0,0 @@
|
||||
src
|
||||
test
|
||||
typings
|
||||
bundled
|
||||
build
|
||||
coverage
|
||||
docs
|
||||
wiki
|
||||
gulpfile.js
|
||||
bower.json
|
||||
karma.conf.js
|
||||
tsconfig.json
|
||||
typings.json
|
||||
CONTRIBUTING.md
|
||||
ISSUE_TEMPLATE.md
|
||||
PULL_REQUEST_TEMPLATE.md
|
||||
tslint.json
|
||||
wallaby.js
|
||||
.travis.yml
|
||||
.gitignore
|
||||
.vscode
|
||||
type_definitions
|
||||
1
packages/api/.npmignore
Symbolic link
1
packages/api/.npmignore
Symbolic link
@@ -0,0 +1 @@
|
||||
../../.npmignore
|
||||
@@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@ms/api",
|
||||
"version": "0.1.1",
|
||||
"name": "@ccms/api",
|
||||
"version": "0.7.0",
|
||||
"description": "MiaoScript api package",
|
||||
"keywords": [
|
||||
"miaoscript",
|
||||
@@ -12,22 +12,23 @@
|
||||
"homepage": "https://github.com/circlecloud/ms.git",
|
||||
"license": "ISC",
|
||||
"main": "dist/index.js",
|
||||
"publishConfig": {
|
||||
"registry": "https://repo.yumc.pw/repository/npm-hosted/"
|
||||
},
|
||||
"scripts": {
|
||||
"clean": "rimraf dist",
|
||||
"watch": "npx tsc --watch",
|
||||
"build": "yarn clean && npx tsc",
|
||||
"watch": "tsc --watch",
|
||||
"build": "yarn clean && tsc",
|
||||
"test": "echo \"Error: run tests from root\" && exit 1"
|
||||
},
|
||||
"dependencies": {
|
||||
"@ms/common": "^0.1.0",
|
||||
"@ms/container": "^0.1.0"
|
||||
"@ccms/container": "^0.7.0",
|
||||
"@ccms/ployfill": "^0.7.0",
|
||||
"@ccms/common": "^0.7.0",
|
||||
"base64-js": "^1.3.1",
|
||||
"source-map-builder": "^0.0.7"
|
||||
},
|
||||
"devDependencies": {
|
||||
"@types/base64-js": "^1.2.5",
|
||||
"reflect-metadata": "^0.1.13",
|
||||
"rimraf": "^3.0.0",
|
||||
"typescript": "^3.6.2"
|
||||
"rimraf": "^3.0.2",
|
||||
"typescript": "^3.9.2"
|
||||
}
|
||||
}
|
||||
66
packages/api/src/channel.ts
Normal file
66
packages/api/src/channel.ts
Normal file
@@ -0,0 +1,66 @@
|
||||
import { injectable } from "@ccms/container";
|
||||
|
||||
export namespace channel {
|
||||
/**
|
||||
* handle plugin message
|
||||
* @param data byte[]
|
||||
*/
|
||||
export type ChannelListener = (data: any, exts?: any) => void
|
||||
|
||||
@injectable()
|
||||
export abstract class Channel {
|
||||
private listenerMap = [];
|
||||
/**
|
||||
* 注册通道
|
||||
* @param plugin 插件
|
||||
* @param channel 通道
|
||||
* @param exec 执行器
|
||||
*/
|
||||
listen(plugin: any, channel: string, exec: ChannelListener) {
|
||||
if (!plugin || !plugin.description || !plugin.description.name) throw new TypeError('Plugin can\'t be undefiend!');
|
||||
let name = plugin.description.name;
|
||||
let listener = this.register(channel, exec)
|
||||
if (!this.listenerMap[name]) this.listenerMap[name] = [];
|
||||
let offExec = () => {
|
||||
this.unregister(channel, listener);
|
||||
console.debug(`[${name}] unregister channel ${channel}`);
|
||||
};
|
||||
var off = {
|
||||
channel,
|
||||
listener,
|
||||
off: offExec
|
||||
};
|
||||
this.listenerMap[name].push(off);
|
||||
console.debug(`[${name}] register channel ${channel} => ${exec.name || '[anonymous]'}`);
|
||||
return off;
|
||||
}
|
||||
/**
|
||||
* 关闭插件注册的通道
|
||||
* @param plugin 插件
|
||||
*/
|
||||
disable(plugin: any) {
|
||||
var channelCache = this.listenerMap[plugin.description.name];
|
||||
if (channelCache) {
|
||||
channelCache.forEach(t => t.off());
|
||||
delete this.listenerMap[plugin.description.name];
|
||||
}
|
||||
}
|
||||
/**
|
||||
* Send Channel Message
|
||||
* @param player recover target
|
||||
* @param channel ChannelName
|
||||
* @param data byte[]
|
||||
*/
|
||||
abstract send(player: any, channel: string, data: any)
|
||||
/**
|
||||
* register channel
|
||||
* @param channel ChannelName
|
||||
*/
|
||||
abstract register(channel: string, listener: ChannelListener): any
|
||||
/**
|
||||
* unregister channel
|
||||
* @param channel ChannelName
|
||||
*/
|
||||
abstract unregister(channel: string, listener?: any): void
|
||||
}
|
||||
}
|
||||
@@ -1,67 +1,78 @@
|
||||
import { injectable } from "@ms/container";
|
||||
import i18n from '@ccms/i18n'
|
||||
import { injectable } from "@ccms/container"
|
||||
import { plugin } from './interfaces'
|
||||
|
||||
export namespace command {
|
||||
@injectable()
|
||||
export abstract class Command {
|
||||
on(plugin: any, name: string, exec: { cmd: Function, tab?: Function }) {
|
||||
var cmd = this.create(plugin, name);
|
||||
console.debug(`插件 ${plugin.description.name} 创建命令 ${name}(${cmd})...`)
|
||||
/**
|
||||
* 注册插件命令
|
||||
* @param plugin 插件
|
||||
* @param name 命令
|
||||
* @param exec 执行器
|
||||
*/
|
||||
on(plugin: plugin.Plugin, name: string, exec: { cmd: Function, tab?: Function }) {
|
||||
var cmd = this.create(plugin, name)
|
||||
if (!cmd) { throw Error("") }
|
||||
console.debug(i18n.translate("ms.api.command.register", { plugin: plugin.description.name, name, cmd }))
|
||||
if (exec.cmd && typeof exec.cmd === "function") {
|
||||
this.onCommand(plugin, cmd, exec.cmd);
|
||||
this.onCommand(plugin, cmd, exec.cmd)
|
||||
} else {
|
||||
throw Error("CommandExec Must be a function... Input: " + exec.cmd)
|
||||
throw Error(i18n.translate("ms.api.command.register.input.error", { exec: exec.cmd }))
|
||||
}
|
||||
if (exec.tab && typeof exec.tab === "function") {
|
||||
this.onTabComplete(plugin, cmd, exec.tab);
|
||||
this.onTabComplete(plugin, cmd, exec.tab)
|
||||
}
|
||||
}
|
||||
off(plugin: any, name: string) {
|
||||
console.debug(`插件 ${plugin.description.name} 注销命令 ${name}...`)
|
||||
this.remove(plugin, name);
|
||||
}
|
||||
/**
|
||||
* Create Server Command Object
|
||||
* 取消命令注册
|
||||
* @param plugin 插件
|
||||
* @param name 命令
|
||||
*/
|
||||
protected abstract create(plugin: any, command: string);
|
||||
protected abstract remove(plugin: any, command: string);
|
||||
protected abstract onCommand(plugin: any, command: any, executor: Function);
|
||||
protected abstract onTabComplete(plugin: any, command: any, tabCompleter: Function);
|
||||
off(plugin: plugin.Plugin, name: string) {
|
||||
console.debug(i18n.translate("ms.api.command.unregister", { plugin: plugin.description.name, name }))
|
||||
this.remove(plugin, name)
|
||||
}
|
||||
|
||||
protected setExecutor(plugin: any, command: any, executor: Function) {
|
||||
return (sender: any, _, command: string, args: string[]) => {
|
||||
protected abstract create(plugin: plugin.Plugin, command: string): any
|
||||
protected abstract remove(plugin: plugin.Plugin, command: string): void
|
||||
protected abstract onCommand(plugin: plugin.Plugin, command: any, executor: Function)
|
||||
protected abstract onTabComplete(plugin: plugin.Plugin, command: any, tabCompleter: Function)
|
||||
protected setExecutor(plugin: plugin.Plugin, command: any, executor: Function) {
|
||||
return (sender: any, _: any, command: string, args: string[]) => {
|
||||
try {
|
||||
return executor(sender, command, Java.from(args));
|
||||
return executor(sender, command, Java.from(args))
|
||||
} catch (ex) {
|
||||
console.console(`§6玩家 §a${sender.name} §6执行 §b${plugin.description.name} §6插件 §d${command} ${Java.from(args).join(' ')} §6命令时发生异常 §4${ex}`);
|
||||
console.ex(ex);
|
||||
console.sender(sender, [`§6执行 §b${plugin.description.name} §6插件 §d${command} ${Java.from(args).join(' ')} §6命令时发生异常`, ...console.stack(ex)])
|
||||
return true;
|
||||
console.i18n("ms.api.command.execute.error", { player: sender.name, plugin: plugin.description.name, command, args: Java.from(args).join(' '), ex })
|
||||
console.ex(ex)
|
||||
if (sender.name != 'CONSOLE') {
|
||||
console.sender(sender, [i18n.translate("ms.api.command.execute.error", { player: sender.name, plugin: plugin.description.name, command, args: Java.from(args).join(' '), ex }), ...console.stack(ex)])
|
||||
}
|
||||
return true
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
protected setTabCompleter(plugin: any, command: any, tabCompleter: Function) {
|
||||
return (sender: any, _, command: string, args: string[]) => {
|
||||
protected setTabCompleter(plugin: plugin.Plugin, command: any, tabCompleter: Function) {
|
||||
return (sender: any, _: any, command: string, args: string[]) => {
|
||||
try {
|
||||
var token = args[args.length - 1];
|
||||
var complete = tabCompleter(sender, command, Java.from(args)) || [];
|
||||
return this.copyPartialMatches(complete, token);
|
||||
var token = args[args.length - 1]
|
||||
var complete = tabCompleter(sender, command, Java.from(args)) || []
|
||||
return this.copyPartialMatches(complete, token)
|
||||
} catch (ex) {
|
||||
console.console(`§6玩家 §a${sender.name} §6执行 §b${plugin.description.name} §6插件 §d${command} ${Java.from(args).join(' ')} §6补全时发生异常 §4${ex}`);
|
||||
console.ex(ex);
|
||||
console.sender(sender, [`§6执行 §b${plugin.description.name} §6插件 §d${command} ${Java.from(args).join(' ')} §6补全时发生异常 §4${ex}`, ...console.stack(ex)]);
|
||||
return [];
|
||||
console.i18n("ms.api.command.tab.completer.error", { sender: sender.name, plugin: plugin.description.name, command, args: Java.from(args).join(' '), ex })
|
||||
console.ex(ex)
|
||||
console.sender(sender, [i18n.translate("ms.api.command.tab.completer.error", { sender: sender.name, plugin: plugin.description.name, command, args: Java.from(args).join(' '), ex }), ...console.stack(ex)])
|
||||
return []
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
protected copyPartialMatches(complete: string[], token: string, array: string[] = []): string[] {
|
||||
if (!token) { return complete }
|
||||
complete.forEach(function (e) {
|
||||
if (typeof e === "string" && e.toLowerCase().startsWith(token.toLowerCase())) {
|
||||
array.push(e)
|
||||
}
|
||||
});
|
||||
})
|
||||
return array
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1,150 +1,228 @@
|
||||
let Arrays = Java.type('java.util.Arrays');
|
||||
let Level = Java.type('java.util.logging.Level');
|
||||
let ignoreLogPrefix = ['java.', 'net.minecraft.', 'org.bukkit.', 'jdk.nashorn.'];
|
||||
import i18m from '@ccms/i18n'
|
||||
import { SourceMapBuilder } from 'source-map-builder'
|
||||
import * as base64 from 'base64-js'
|
||||
|
||||
const Arrays = Java.type('java.util.Arrays')
|
||||
const Level = Java.type('java.util.logging.Level')
|
||||
const Paths = Java.type('java.nio.file.Paths')
|
||||
const ignoreLogPrefix = ['java.', 'javax.', 'sun.', 'net.minecraft.', 'org.bukkit.', 'jdk.nashorn.', 'io.netty.', 'org.spongepowered.', 'org.apache', 'org.springframework']
|
||||
|
||||
enum LogLevel {
|
||||
ALL,
|
||||
TRACE,
|
||||
DEBUG,
|
||||
INFO,
|
||||
WARN,
|
||||
ERROR,
|
||||
FATAL,
|
||||
OFF
|
||||
}
|
||||
|
||||
export class MiaoScriptConsole implements Console {
|
||||
Console: NodeJS.ConsoleConstructor;
|
||||
Console: NodeJS.ConsoleConstructor
|
||||
|
||||
private _name: string = '';
|
||||
private static sourceMaps: { [key: string]: SourceMapBuilder } = {}
|
||||
private static sourceFileMaps: { [key: string]: string } = {}
|
||||
private _name: string = ''
|
||||
private _level: LogLevel = LogLevel.INFO
|
||||
|
||||
protected logger: any;
|
||||
protected prefix: string = '§6[§bMiaoScript§6]§r ';
|
||||
protected logger: any
|
||||
protected prefix: string = '§6[§bMiaoScript§6]§r '
|
||||
|
||||
constructor(name?: string) {
|
||||
this.name = name;
|
||||
this.logger = global.logger;
|
||||
this.name = name
|
||||
this.logger = global.logger
|
||||
if (global.debug) {
|
||||
this._level = LogLevel.DEBUG
|
||||
}
|
||||
if (global.level?.toUpperCase() === "TRACE") {
|
||||
this._level = LogLevel.TRACE
|
||||
}
|
||||
}
|
||||
|
||||
get name() {
|
||||
return this._name;
|
||||
return this._name
|
||||
}
|
||||
|
||||
set name(name: string) {
|
||||
if (name) {
|
||||
this._name = `[${name}] `;
|
||||
this._name = `[${name}] `
|
||||
// noinspection JSUnusedGlobalSymbols
|
||||
this.prefix = `§6[§cMS§6][§b${name}§6]§r `;
|
||||
this.prefix = `§6[§cMS§6][§b${name}§6]§r `
|
||||
}
|
||||
}
|
||||
log(...args): void {
|
||||
this.logger.info(this.name + args.join(' '));
|
||||
log(...args: any[]): void {
|
||||
this.logger.info(this.name + args.join(' '))
|
||||
}
|
||||
info(...args) {
|
||||
this.logger.info(this.name + args.join(' '));
|
||||
};
|
||||
warn(...args) {
|
||||
this.logger.warning(this.name + args.join(' '));
|
||||
};
|
||||
error(...args) {
|
||||
this.logger.log(Level.SEVERE, this.name + args.join(' '));
|
||||
};
|
||||
debug(...args) {
|
||||
info(...args: any[]) {
|
||||
this.logger.info(this.name + args.join(' '))
|
||||
}
|
||||
warn(...args: any[]) {
|
||||
this.logger.warning(this.name + args.join(' '))
|
||||
}
|
||||
error(...args: any[]) {
|
||||
this.logger.log(Level.SEVERE, this.name + args.join(' '))
|
||||
}
|
||||
debug(...args: any[]) {
|
||||
if (global.debug) {
|
||||
this.logger.info(this.name + '[DEBUG] ' + args.join(' '));
|
||||
this.logger.info(this.name + '[DEBUG] ' + args.join(' '))
|
||||
}
|
||||
}
|
||||
trace(...args: any[]): void {
|
||||
if (this._level <= LogLevel.TRACE) {
|
||||
this.logger.info(this.name + '[TRACE] ' + args.join(' '))
|
||||
}
|
||||
}
|
||||
};
|
||||
sender(...args) {
|
||||
this.info(args)
|
||||
}
|
||||
console(...args) {
|
||||
this.info(args)
|
||||
}
|
||||
object(obj) {
|
||||
for (var i in obj) {
|
||||
this.logger(i, '=>', obj[i])
|
||||
i18n(name: string, param?: { [key: string]: any }) {
|
||||
this.console(i18m.translate(name, param))
|
||||
}
|
||||
object(obj) {
|
||||
for (const i in obj) {
|
||||
this.info(i, '=>', obj[i])
|
||||
}
|
||||
}
|
||||
};
|
||||
ex(ex: Error) {
|
||||
this.stack(ex).forEach(line => this.console(line))
|
||||
};
|
||||
stack(ex: Error): string[] {
|
||||
var stack = ex.getStackTrace();
|
||||
var cache = ['§4' + ex];
|
||||
}
|
||||
readSourceMap(fileName: string, lineNumber: number) {
|
||||
try {
|
||||
if (fileName.endsWith('js')) {
|
||||
if (MiaoScriptConsole.sourceMaps[fileName] === undefined) {
|
||||
MiaoScriptConsole.sourceMaps[fileName] = null
|
||||
let sourceLine = base.read(fileName).split('\n')
|
||||
let lastLine = sourceLine[sourceLine.length - 1]
|
||||
if (lastLine.startsWith('//# sourceMappingURL=')) {
|
||||
let sourceContent = null
|
||||
let sourceMappingURL = lastLine.split('sourceMappingURL=', 2)[1]
|
||||
if (sourceMappingURL.startsWith('data:application/jsonbase64,')) {
|
||||
sourceContent = String.fromCharCode(...Array.from(base64.toByteArray(sourceMappingURL.split(',', 2)[1])))
|
||||
} else if (sourceMappingURL.startsWith('http')) {
|
||||
// TODO
|
||||
} else {
|
||||
let file = Paths.get(Paths.get(fileName, '..', sourceMappingURL).toFile().getCanonicalPath()).toFile()
|
||||
if (file.exists()) { sourceContent = base.read(file) }
|
||||
}
|
||||
if (sourceContent) {
|
||||
MiaoScriptConsole.sourceMaps[fileName] = new SourceMapBuilder(JSON.parse(sourceContent))
|
||||
MiaoScriptConsole.sourceFileMaps[fileName] = Paths.get(fileName, '..', MiaoScriptConsole.sourceMaps[fileName].sources[0]).toFile().getCanonicalPath()
|
||||
}
|
||||
}
|
||||
}
|
||||
if (MiaoScriptConsole.sourceMaps[fileName]) {
|
||||
let sourceMapping = MiaoScriptConsole.sourceMaps[fileName].getSource(lineNumber, 25, true, true)
|
||||
fileName = MiaoScriptConsole.sourceFileMaps[fileName]
|
||||
if (sourceMapping && lineNumber != sourceMapping.mapping.sourceLine) { lineNumber = sourceMapping.mapping.sourceLine }
|
||||
}
|
||||
}
|
||||
} catch (error) {
|
||||
console.debug('search source map', fileName, 'line', lineNumber, 'error:', error)
|
||||
}
|
||||
return {
|
||||
fileName,
|
||||
lineNumber
|
||||
}
|
||||
}
|
||||
stack(ex: Error, color: boolean = true): string[] {
|
||||
let stack = ex.getStackTrace()
|
||||
let cache = [(color ? '§c' : '') + ex]
|
||||
//@ts-ignore
|
||||
if (stack.class) {
|
||||
stack = Arrays.asList(stack)
|
||||
}
|
||||
stack.forEach(function(trace) {
|
||||
stack.forEach(trace => {
|
||||
if (!trace.fileName || trace.fileName.startsWith('jar:file:') || trace.fileName.startsWith('file:')) { return }
|
||||
if (trace.className.startsWith('<')) {
|
||||
var fileName = trace.fileName
|
||||
let { fileName, lineNumber } = this.readSourceMap(trace.fileName, trace.lineNumber)
|
||||
if (fileName.startsWith(root)) { fileName = fileName.split(root)[1] }
|
||||
cache.push(` §e->§c ${fileName} => §4${trace.methodName}:${trace.lineNumber}`)
|
||||
if (color) {
|
||||
cache.push(` §e->§c ${fileName}:${lineNumber} => §4${trace.methodName}`)
|
||||
} else {
|
||||
var className = trace.className;
|
||||
var fileName = trace.fileName
|
||||
cache.push(` -> ${fileName}:${lineNumber} => ${trace.methodName}`)
|
||||
}
|
||||
} else {
|
||||
let className = trace.className
|
||||
var fileName = trace.fileName as string
|
||||
if (className.startsWith('jdk.nashorn.internal.scripts')) {
|
||||
className = className.substr(className.lastIndexOf('$') + 1)
|
||||
var { fileName, lineNumber } = this.readSourceMap(trace.fileName, trace.lineNumber)
|
||||
if (fileName.startsWith(root)) { fileName = fileName.split(root)[1] }
|
||||
} else {
|
||||
for (var prefix in ignoreLogPrefix) {
|
||||
for (let prefix in ignoreLogPrefix) {
|
||||
if (className.startsWith(ignoreLogPrefix[prefix])) {
|
||||
return;
|
||||
return
|
||||
}
|
||||
}
|
||||
}
|
||||
cache.push(` §e->§c ${className}.${trace.methodName}(§4${fileName}:${trace.lineNumber}§c)`);
|
||||
if (color) {
|
||||
cache.push(` §e->§c ${className}.${trace.methodName}(§4${fileName}:${lineNumber}§c)`)
|
||||
} else {
|
||||
cache.push(` -> ${className}.${trace.methodName}(${fileName}:${lineNumber})`)
|
||||
}
|
||||
});
|
||||
return cache;
|
||||
}
|
||||
})
|
||||
return cache
|
||||
}
|
||||
assert(value: any, message?: string, ...optionalParams: any[]): void {
|
||||
throw new Error("Method not implemented.");
|
||||
throw new Error("Method not implemented.")
|
||||
}
|
||||
clear(): void {
|
||||
throw new Error("Method not implemented.");
|
||||
throw new Error("Method not implemented.")
|
||||
}
|
||||
count(label?: string): void {
|
||||
throw new Error("Method not implemented.");
|
||||
throw new Error("Method not implemented.")
|
||||
}
|
||||
countReset(label?: string): void {
|
||||
throw new Error("Method not implemented.");
|
||||
throw new Error("Method not implemented.")
|
||||
}
|
||||
dir(obj: any, options?: NodeJS.InspectOptions): void {
|
||||
throw new Error("Method not implemented.");
|
||||
throw new Error("Method not implemented.")
|
||||
}
|
||||
dirxml(...data: any[]): void {
|
||||
throw new Error("Method not implemented.");
|
||||
throw new Error("Method not implemented.")
|
||||
}
|
||||
group(...label: any[]): void {
|
||||
throw new Error("Method not implemented.");
|
||||
throw new Error("Method not implemented.")
|
||||
}
|
||||
groupCollapsed(...label: any[]): void {
|
||||
throw new Error("Method not implemented.");
|
||||
throw new Error("Method not implemented.")
|
||||
}
|
||||
groupEnd(): void {
|
||||
throw new Error("Method not implemented.");
|
||||
throw new Error("Method not implemented.")
|
||||
}
|
||||
table(tabularData: any, properties?: string[]): void {
|
||||
throw new Error("Method not implemented.");
|
||||
throw new Error("Method not implemented.")
|
||||
}
|
||||
time(label?: string): void {
|
||||
throw new Error("Method not implemented.");
|
||||
throw new Error("Method not implemented.")
|
||||
}
|
||||
timeEnd(label?: string): void {
|
||||
throw new Error("Method not implemented.");
|
||||
throw new Error("Method not implemented.")
|
||||
}
|
||||
timeLog(label?: string, ...data: any[]): void {
|
||||
throw new Error("Method not implemented.");
|
||||
}
|
||||
trace(message?: any, ...optionalParams: any[]): void {
|
||||
throw new Error("Method not implemented.");
|
||||
throw new Error("Method not implemented.")
|
||||
}
|
||||
markTimeline(label?: string): void {
|
||||
throw new Error("Method not implemented.");
|
||||
throw new Error("Method not implemented.")
|
||||
}
|
||||
profile(label?: string): void {
|
||||
throw new Error("Method not implemented.");
|
||||
throw new Error("Method not implemented.")
|
||||
}
|
||||
profileEnd(label?: string): void {
|
||||
throw new Error("Method not implemented.");
|
||||
throw new Error("Method not implemented.")
|
||||
}
|
||||
timeStamp(label?: string): void {
|
||||
throw new Error("Method not implemented.");
|
||||
throw new Error("Method not implemented.")
|
||||
}
|
||||
timeline(label?: string): void {
|
||||
throw new Error("Method not implemented.");
|
||||
throw new Error("Method not implemented.")
|
||||
}
|
||||
timelineEnd(label?: string): void {
|
||||
throw new Error("Method not implemented.");
|
||||
throw new Error("Method not implemented.")
|
||||
}
|
||||
}
|
||||
|
||||
17
packages/api/src/constants.ts
Normal file
17
packages/api/src/constants.ts
Normal file
@@ -0,0 +1,17 @@
|
||||
export namespace constants {
|
||||
export namespace Reflect {
|
||||
export const Method = {
|
||||
getServerConnection: [/*spigot 1.8.8*/'aq',/*spigot 1.12.2*/ 'an', /*spigot 1.14.4+*/'getServerConnection', /*catserver 1.12.2*/'func_147137_ag']
|
||||
}
|
||||
export const Field = {
|
||||
listeningChannels: [/*spigot 1.8.8-1.12.2*/'g', /*spigot 1.14.4*/'f', /*spigot 1.15.2+*/'listeningChannels', /*catserver 1.12.2*/'field_151274_e']
|
||||
}
|
||||
}
|
||||
export enum ServerType {
|
||||
Bukkit = 'bukkit',
|
||||
Sponge = 'sponge',
|
||||
Nukkit = 'nukkit',
|
||||
Bungee = 'bungee',
|
||||
Spring = 'spring'
|
||||
}
|
||||
}
|
||||
@@ -1,54 +1,60 @@
|
||||
'use strict';
|
||||
/**
|
||||
* MiaoScript Event处理类
|
||||
*/
|
||||
import '@ms/core'
|
||||
import '@ms/nashorn'
|
||||
import { injectable } from '@ms/container'
|
||||
import i18n from '@ccms/i18n'
|
||||
import { injectable, unmanaged } from '@ccms/container'
|
||||
|
||||
const Thread = Java.type("java.lang.Thread");
|
||||
const Thread = Java.type('java.lang.Thread');
|
||||
|
||||
export namespace event {
|
||||
/**
|
||||
* 事件监听优先级
|
||||
*/
|
||||
export enum EventPriority {
|
||||
LOWEST = "LOWEST",
|
||||
LOW = "LOW",
|
||||
NORMAL = "NORMAL",
|
||||
HIGH = "HIGH",
|
||||
HIGHEST = "HIGHEST",
|
||||
MONITOR = "MONITOR",
|
||||
}
|
||||
|
||||
@injectable()
|
||||
export abstract class Event {
|
||||
// export EventPriority to blockly
|
||||
public EventPriority = EventPriority;
|
||||
|
||||
private mapEvent = [];
|
||||
private listenerMap = [];
|
||||
private baseEventDir = '';
|
||||
|
||||
constructor(baseEventDir: string) {
|
||||
protected baseEventDir = '';
|
||||
|
||||
constructor(@unmanaged() baseEventDir: string) {
|
||||
this.baseEventDir = baseEventDir;
|
||||
}
|
||||
|
||||
/**
|
||||
* 扫描包 org.bukkit.event 下的所有事件
|
||||
* 映射简写名称 org.bukkit.event.player.PlayerLoginEvent => playerloginevent
|
||||
* abstract event map function
|
||||
* ig: org.bukkit.event.player.PlayerLoginEvent => playerloginevent
|
||||
* org.spongepowered.api.event.game.GameRegistryEvent.Register => gameregistryevent$register
|
||||
*/
|
||||
mapEventName() {
|
||||
if (this.baseEventDir === "") {
|
||||
throw new Error("事件基础包名为空 无法进行事件映射!");
|
||||
}
|
||||
var count = 0;
|
||||
var dirs = Thread.currentThread().getContextClassLoader().getResources(this.baseEventDir);
|
||||
while (dirs.hasMoreElements()) {
|
||||
var url = dirs.nextElement();
|
||||
var protocol = url.protocol;
|
||||
if (protocol === "jar") {
|
||||
// noinspection JSUnresolvedVariable
|
||||
var jar = url.openConnection().jarFile;
|
||||
var entries = jar.entries();
|
||||
if (this.baseEventDir === "") { throw new Error(i18n.translate('ms.api.event.empty.event.dir')); }
|
||||
let count = 0;
|
||||
let jar = this.getJarFile(this.baseEventDir);
|
||||
let entries = jar.entries();
|
||||
while (entries.hasMoreElements()) {
|
||||
var entry = entries.nextElement();
|
||||
var name = entry.name;
|
||||
// 以 org/bukkit/event 开头 并且以 .class 结尾
|
||||
let entry = entries.nextElement();
|
||||
let name = entry.name;
|
||||
if (name.startsWith(this.baseEventDir) && name.endsWith(".class")) {
|
||||
var i = name.replaceAll('/', '.');
|
||||
// replace name to qualifiedName
|
||||
let qualifiedName = name.replaceAll('/', '.');
|
||||
try {
|
||||
var clz = base.getClass(i.substring(0, i.length - 6));
|
||||
// 继承于 org.bukkit.event.Event 访问符为Public
|
||||
if (this.isValidEvent(clz)) {
|
||||
var simpleName = this.class2Name(clz).toLowerCase();
|
||||
console.debug(`Mapping Event [${clz.canonicalName}] => ${simpleName}`);
|
||||
this.mapEvent[simpleName] = clz;
|
||||
let clazz = base.getClass(qualifiedName.substring(0, qualifiedName.length - 6));
|
||||
if (this.isValidEvent(clazz)) {
|
||||
let simpleName = this.class2Name(clazz).toLowerCase();
|
||||
console.trace(i18n.translate("ms.api.event.mapping", { canonicalName: clazz.canonicalName, simpleName }));
|
||||
this.mapEvent[simpleName] = clazz;
|
||||
count++;
|
||||
}
|
||||
} catch (ex) {
|
||||
@@ -56,73 +62,82 @@ export namespace event {
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
return count;
|
||||
};
|
||||
}
|
||||
|
||||
class2Name(clazz) {
|
||||
getJarFile(resource: string, loader?: any) {
|
||||
let dirs = (loader || Thread.currentThread().getContextClassLoader()).getResources(resource);
|
||||
if (dirs.hasMoreElements()) {
|
||||
let url = dirs.nextElement();
|
||||
if (url.protocol === "jar") { return url.openConnection().jarFile; }
|
||||
}
|
||||
throw new Error(i18n.translate("ms.api.event.resource.not.found", { resource }))
|
||||
}
|
||||
|
||||
class2Name(clazz: any) {
|
||||
return clazz.simpleName;
|
||||
};
|
||||
}
|
||||
|
||||
name2Class(name, event) {
|
||||
var eventCls = this.mapEvent[event.toLowerCase()] || this.mapEvent[event.toLowerCase() + 'event'];
|
||||
name2Class(name: any, event: string) {
|
||||
let eventCls = this.mapEvent[event.toLowerCase()] || this.mapEvent[event.toLowerCase() + 'event'];
|
||||
if (!eventCls) {
|
||||
try {
|
||||
eventCls = base.getClass(eventCls);
|
||||
this.mapEvent[event] = eventCls;
|
||||
} catch (ex) {
|
||||
console.console(`§6插件 §b${name} §6注册事件 §c${event} §6失败 §4事件未找到!`);
|
||||
console.ex(new Error(`插件 ${name} 注册事件 ${event} 失败 事件未找到!`));
|
||||
console.i18n("ms.api.event.not.found", { name, event })
|
||||
return;
|
||||
}
|
||||
}
|
||||
return eventCls;
|
||||
};
|
||||
}
|
||||
|
||||
execute(name, exec, eventCls) {
|
||||
return (...args) => {
|
||||
return (...args: any[]) => {
|
||||
try {
|
||||
var time = new Date().getTime()
|
||||
exec(args[args.length - 1]);
|
||||
var cost = new Date().getTime() - time;
|
||||
let event = args[args.length - 1];
|
||||
if (eventCls.isAssignableFrom(event.getClass())) {
|
||||
let time = Date.now()
|
||||
exec(event);
|
||||
let cost = Date.now() - time;
|
||||
if (cost > 20) {
|
||||
console.console(`§c注意! §6插件 §b${name} §6处理 §d${this.class2Name(eventCls)} §6事件 §c耗时 §4${cost}ms !`)
|
||||
console.i18n("ms.api.event.execute.slow", { name, event: this.class2Name(eventCls), cost })
|
||||
}
|
||||
}
|
||||
} catch (ex) {
|
||||
console.console(`§6插件 §b${name} §6处理 §d${this.class2Name(eventCls)} §6事件时发生异常 §4${ex}`);
|
||||
console.i18n("ms.api.event.execute.error", { name, event: this.class2Name(eventCls), ex })
|
||||
console.ex(ex);
|
||||
}
|
||||
};
|
||||
};
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* 添加事件监听
|
||||
* @param plugin
|
||||
* @param event
|
||||
* @param plugin {any}
|
||||
* @param event {string}
|
||||
* @param exec {function}
|
||||
* @param priority [LOWEST,LOW,NORMAL,HIGH,HIGHEST,MONITOR]
|
||||
* @param priority {string} [LOWEST,LOW,NORMAL,HIGH,HIGHEST,MONITOR]
|
||||
* @param ignoreCancel
|
||||
*/
|
||||
listen(plugin, event, exec, priority = 'NORMAL', ignoreCancel = false) {
|
||||
if (!plugin || !plugin.description || !plugin.description.name) throw new TypeError('插件名称为空 请检查传入参数!');
|
||||
listen(plugin: any, event: string, exec: (event: any) => void, priority: EventPriority = EventPriority.NORMAL, ignoreCancel = false) {
|
||||
if (!plugin || !plugin.description || !plugin.description.name) throw new TypeError(i18n.translate("ms.api.event.listen.plugin.name.empty"));
|
||||
var name = plugin.description.name;
|
||||
var eventCls = this.name2Class(name, event);
|
||||
if (!eventCls) { return; }
|
||||
if (typeof priority === 'boolean') {
|
||||
ignoreCancel = priority;
|
||||
priority = 'NORMAL';
|
||||
priority = EventPriority.NORMAL;
|
||||
}
|
||||
priority = priority || 'NORMAL';
|
||||
priority = priority || EventPriority.NORMAL;
|
||||
ignoreCancel = ignoreCancel || false;
|
||||
// noinspection JSUnusedGlobalSymbols
|
||||
var listener = this.register(eventCls, this.execute(name, exec, eventCls), priority, ignoreCancel);
|
||||
var listenerMap = this.listenerMap;
|
||||
// 添加到缓存 用于关闭插件的时候关闭事件
|
||||
// add to cache Be used for close plugin to close event
|
||||
if (!listenerMap[name]) listenerMap[name] = [];
|
||||
var offExec = () => {
|
||||
this.unregister(eventCls, listener);
|
||||
console.debug(`插件 ${name} 注销事件 ${this.class2Name(eventCls)}`);
|
||||
console.debug(i18n.translate("ms.api.event.unregister", { name, event: this.class2Name(eventCls) }));
|
||||
};
|
||||
var off = {
|
||||
event: eventCls,
|
||||
@@ -131,10 +146,14 @@ export namespace event {
|
||||
};
|
||||
listenerMap[name].push(off);
|
||||
// noinspection JSUnresolvedVariable
|
||||
console.debug(`插件 ${name} 注册事件 ${this.class2Name(eventCls)} => ${exec.name || '匿名方法'}`);
|
||||
console.debug(i18n.translate("ms.api.event.register", { name, event: this.class2Name(eventCls) }));
|
||||
return off;
|
||||
}
|
||||
|
||||
/**
|
||||
* 关闭插件监听任务
|
||||
* @param plugin 插件
|
||||
*/
|
||||
disable(plugin: any) {
|
||||
var eventCache = this.listenerMap[plugin.description.name];
|
||||
if (eventCache) {
|
||||
@@ -143,8 +162,24 @@ export namespace event {
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* 判断
|
||||
* @param clazz 事件类
|
||||
*/
|
||||
abstract isValidEvent(clazz: any): boolean;
|
||||
/**
|
||||
* 注册事件
|
||||
* @param eventCls 事件类
|
||||
* @param exec 执行器
|
||||
* @param priority 优先级
|
||||
* @param ignoreCancel 是否忽略已取消的事件
|
||||
*/
|
||||
abstract register(eventCls: any, exec: Function, priority: any, ignoreCancel: boolean): any;
|
||||
/**
|
||||
* 取消监听事件
|
||||
* @param event 事件
|
||||
* @param listener 监听器
|
||||
*/
|
||||
abstract unregister(event: any, listener: any): void;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1,7 +1,8 @@
|
||||
/// <reference path="./typings/global.ts" />
|
||||
|
||||
import "@ccms/nashorn"
|
||||
export * from './task'
|
||||
export * from './event'
|
||||
export * from './console'
|
||||
export * from './channel'
|
||||
export * from './command'
|
||||
export * from './constants'
|
||||
export * from './interfaces'
|
||||
|
||||
7
packages/api/src/interfaces/amqp.ts
Normal file
7
packages/api/src/interfaces/amqp.ts
Normal file
@@ -0,0 +1,7 @@
|
||||
export namespace amqp {
|
||||
export const Manager = Symbol('AmqpManager')
|
||||
export namespace rabbit {
|
||||
export const Admin = Symbol('RabbitAdmin')
|
||||
export const Template = Symbol('RabbitTemplate')
|
||||
}
|
||||
}
|
||||
5
packages/api/src/interfaces/database.ts
Normal file
5
packages/api/src/interfaces/database.ts
Normal file
@@ -0,0 +1,5 @@
|
||||
export namespace database {
|
||||
export const DataBaseManager = Symbol("DataBaseManager");
|
||||
export const DataSource = Symbol("DataSource");
|
||||
export const DataBase = Symbol("DataBase");
|
||||
}
|
||||
@@ -1,2 +1,5 @@
|
||||
export * from './web'
|
||||
export * from './amqp'
|
||||
export * from './plugin'
|
||||
export * from './server'
|
||||
export * from './database'
|
||||
|
||||
@@ -1,28 +1,148 @@
|
||||
import { Container } from "@ms/container";
|
||||
|
||||
export namespace plugin {
|
||||
/**
|
||||
* MiaoScript Plugin
|
||||
*/
|
||||
export const Plugin = Symbol("Plugin");
|
||||
export const Plugin = Symbol("Plugin")
|
||||
/**
|
||||
* MiaoScript Plugin Folder
|
||||
*/
|
||||
export const PluginFolder = Symbol("PluginFolder")
|
||||
/**
|
||||
* Runtime Plugin Instance
|
||||
*/
|
||||
export const PluginInstance = Symbol("PluginInstance");
|
||||
export const PluginInstance = Symbol("PluginInstance")
|
||||
/**
|
||||
* MiaoScript Plugin Manager
|
||||
* MiaoScript Plugin Manager Symbol
|
||||
*/
|
||||
export const PluginManager = Symbol("PluginManager");
|
||||
export const PluginManager = Symbol("PluginManager")
|
||||
/**
|
||||
* MiaoScript Plugin Manager
|
||||
* MiaoScript Plugin Manager Interface
|
||||
*/
|
||||
export interface PluginManager {
|
||||
scan(folder: string): void;
|
||||
build(container: Container): void;
|
||||
load(...args: any[]): void;
|
||||
enable(...args: any[]): void;
|
||||
disable(...args: any[]): void;
|
||||
reload(...args: any[]): void;
|
||||
getPlugins(): Map<string, any>;
|
||||
scan(folder: string): void
|
||||
build(): void
|
||||
loadFromFile(file: string, scanner?: plugin.PluginScanner): Plugin
|
||||
load(...args: any[]): void
|
||||
enable(...args: any[]): void
|
||||
disable(...args: any[]): void
|
||||
reload(...args: any[]): void
|
||||
getPlugin(name: string): plugin.Plugin
|
||||
getPlugins(): Map<string, plugin.Plugin>
|
||||
}
|
||||
export const PluginScanner = Symbol("PluginScanner")
|
||||
/**
|
||||
* 插件扫描器
|
||||
*/
|
||||
export interface PluginScanner {
|
||||
/**
|
||||
* 扫描器类型
|
||||
*/
|
||||
type: string
|
||||
/**
|
||||
* 扫描插件 返回插件加载列表
|
||||
* @param target 扫描目标
|
||||
*/
|
||||
scan(target: any): string[]
|
||||
/**
|
||||
* 加载扫描到的目标
|
||||
* @param target 加载目标
|
||||
*/
|
||||
load(target: any): any
|
||||
}
|
||||
export const PluginLoader = Symbol("PluginLoader")
|
||||
/**
|
||||
* 插件加载器
|
||||
*/
|
||||
export interface PluginLoader {
|
||||
/**
|
||||
* 加载器类型
|
||||
*/
|
||||
type: string
|
||||
/**
|
||||
* 加载插件 获取元数据
|
||||
* @param target 加载目标
|
||||
* @param result 扫描器加载的结果
|
||||
*/
|
||||
require(target: any, result: any): PluginMetadata
|
||||
/**
|
||||
* 构建插件
|
||||
* @param metadata 插件元信息
|
||||
*/
|
||||
build(metadata: any): Plugin
|
||||
/**
|
||||
* Load 阶段
|
||||
* @param plugin 插件
|
||||
*/
|
||||
load(plugin: Plugin): void
|
||||
/**
|
||||
* Enable 阶段
|
||||
* @param plugin 插件
|
||||
*/
|
||||
enable(plugin: Plugin): void
|
||||
/**
|
||||
* Disable 阶段
|
||||
* @param plugin 插件
|
||||
*/
|
||||
disable(plugin: Plugin): void
|
||||
/**
|
||||
* Reload 阶段
|
||||
* @param plugin 插件
|
||||
*/
|
||||
reload(plugin: Plugin): void
|
||||
}
|
||||
export interface Plugin {
|
||||
description: PluginMetadata
|
||||
logger: Console
|
||||
load(): void
|
||||
enable(): void
|
||||
disable(): void
|
||||
}
|
||||
export interface BaseMetadata {
|
||||
/**
|
||||
* 名称 为空则为对象名称
|
||||
*/
|
||||
name?: string
|
||||
/**
|
||||
* 支持的服务器列表 为空则代表所有
|
||||
*/
|
||||
servers?: string[]
|
||||
}
|
||||
export interface PluginMetadata extends BaseMetadata {
|
||||
/**
|
||||
* 插件名称
|
||||
*/
|
||||
name: string
|
||||
/**
|
||||
* 前缀
|
||||
*/
|
||||
prefix?: string
|
||||
/**
|
||||
* 插件版本
|
||||
*/
|
||||
version: string
|
||||
/**
|
||||
* 插件版本
|
||||
*/
|
||||
author: string | string[]
|
||||
/**
|
||||
* 插件源文件 必须指定为 __filename
|
||||
*/
|
||||
source: string
|
||||
/**
|
||||
* 插件类型 默认为 ioc 执行 MiaoScript 加载逻辑
|
||||
*/
|
||||
type?: string
|
||||
/**
|
||||
* 插件扫描器
|
||||
*/
|
||||
scanner?: PluginScanner
|
||||
/**
|
||||
* 插件加载器
|
||||
*/
|
||||
loader?: PluginLoader
|
||||
/**
|
||||
* 插件本体
|
||||
*/
|
||||
target?: any
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1,4 +0,0 @@
|
||||
export namespace server {
|
||||
export const ServerType = Symbol("ServerType");
|
||||
export const Console = Symbol("Console");
|
||||
}
|
||||
143
packages/api/src/interfaces/server/index.ts
Normal file
143
packages/api/src/interfaces/server/index.ts
Normal file
@@ -0,0 +1,143 @@
|
||||
import * as reflect from '@ccms/common/dist/reflect'
|
||||
import { injectable } from '@ccms/container'
|
||||
|
||||
import { NativePluginManager } from './native_plugin'
|
||||
import { constants } from '../../constants'
|
||||
|
||||
export namespace server {
|
||||
/**
|
||||
* Runtime ServerType
|
||||
*/
|
||||
export const ServerType = Symbol("ServerType")
|
||||
/**
|
||||
* Runtime Console
|
||||
*/
|
||||
export const Console = Symbol("Console")
|
||||
/**
|
||||
* MiaoScript Server
|
||||
*/
|
||||
export const Server = Symbol("Server")
|
||||
/**
|
||||
* Runtime Server Instance
|
||||
*/
|
||||
export const ServerInstance = Symbol("ServerInstance")
|
||||
/**
|
||||
* MiaoScript Server
|
||||
*/
|
||||
export interface Server {
|
||||
getVersion(): string
|
||||
getPlayer(name: string): any
|
||||
getOnlinePlayers(): any[]
|
||||
getConsoleSender(): any
|
||||
getService(service: string): any
|
||||
dispatchCommand(sender: string | any, command: string): boolean
|
||||
dispatchConsoleCommand(command: string): boolean
|
||||
getPluginsFolder(): string
|
||||
getNativePluginManager(): NativePluginManager
|
||||
getDedicatedServer?(): any
|
||||
getNettyPipeline(): any
|
||||
getRootLogger(): any
|
||||
sendJson(sender: string | any, json: object | string): void
|
||||
tabComplete?(sender: string | any, input: string, index?: number): string[]
|
||||
}
|
||||
@injectable()
|
||||
export abstract class ReflectServer implements server.Server {
|
||||
protected pipeline: any
|
||||
protected rootLogger: any
|
||||
|
||||
constructor() {
|
||||
this.reflect()
|
||||
}
|
||||
|
||||
getVersion(): string {
|
||||
throw new Error("Method not implemented.")
|
||||
}
|
||||
getPlayer(name: string) {
|
||||
throw new Error("Method not implemented.")
|
||||
}
|
||||
getOnlinePlayers(): any[] {
|
||||
throw new Error("Method not implemented.")
|
||||
}
|
||||
getConsoleSender() {
|
||||
throw new Error("Method not implemented.")
|
||||
}
|
||||
getService(service: string) {
|
||||
throw new Error("Method not implemented.")
|
||||
}
|
||||
dispatchCommand(sender: any, command: string): boolean {
|
||||
throw new Error("Method not implemented.")
|
||||
}
|
||||
dispatchConsoleCommand(command: string): boolean {
|
||||
throw new Error("Method not implemented.")
|
||||
}
|
||||
getPluginsFolder(): string {
|
||||
throw new Error("Method not implemented.")
|
||||
}
|
||||
getNativePluginManager(): NativePluginManager {
|
||||
throw new Error("Method not implemented.")
|
||||
}
|
||||
getDedicatedServer() {
|
||||
throw new Error("Method not implemented.")
|
||||
}
|
||||
getNettyPipeline() {
|
||||
throw new Error("Method not implemented.")
|
||||
}
|
||||
getRootLogger() {
|
||||
throw new Error("Method not implemented.")
|
||||
}
|
||||
sendJson(sender: any, json: string | object): void {
|
||||
throw new Error("Method not implemented.")
|
||||
}
|
||||
tabComplete?(sender: any, input: string, index?: number): string[] {
|
||||
throw new Error("Method not implemented.")
|
||||
}
|
||||
protected reflect() {
|
||||
try {
|
||||
let consoleServer = this.getDedicatedServer()
|
||||
this.reflectPipeline(consoleServer)
|
||||
this.reflectRootLogger(consoleServer)
|
||||
} catch (error) {
|
||||
console.error('Error When Reflect MinecraftServer!', error)
|
||||
console.ex(error)
|
||||
}
|
||||
}
|
||||
protected reflectPipeline(consoleServer: any) {
|
||||
let connection: any
|
||||
let promise: any
|
||||
for (const method of constants.Reflect.Method.getServerConnection) {
|
||||
try {
|
||||
connection = reflect.on(consoleServer).call(method).get()
|
||||
if (connection.class.name.indexOf('ServerConnection') !== -1
|
||||
|| connection.class.name.indexOf('NetworkSystem') !== -1) { break }
|
||||
connection = undefined
|
||||
} catch (error) { }
|
||||
}
|
||||
if (!connection) { console.error("Can't found ServerConnection!"); return }
|
||||
for (const field of constants.Reflect.Field.listeningChannels) {
|
||||
try {
|
||||
promise = reflect.on(connection).get(field).get().get(0)
|
||||
if (promise.class.name.indexOf('Promise') !== -1) { break }
|
||||
promise = undefined
|
||||
} catch (error) { }
|
||||
}
|
||||
if (!promise) { console.error("Can't found listeningChannels!"); return }
|
||||
this.pipeline = reflect.on(promise).get('channel').get().pipeline()
|
||||
}
|
||||
protected reflectRootLogger(consoleServer: any) {
|
||||
try {
|
||||
this.rootLogger = reflect.on(consoleServer).get('LOGGER').get().parent
|
||||
} catch (error) {
|
||||
try { this.rootLogger = reflect.on(consoleServer).get(0).get().parent } catch (error) { }
|
||||
}
|
||||
if (this.rootLogger && this.rootLogger.class.name.indexOf('Logger') === -1) {
|
||||
console.error('Error Logger Class: ' + this.rootLogger.class.name)
|
||||
this.rootLogger = undefined
|
||||
}
|
||||
// get root logger
|
||||
for (let index = 0; index < 5 && this.rootLogger.parent; index++) {
|
||||
this.rootLogger = this.rootLogger.parent
|
||||
}
|
||||
if (!this.rootLogger) { console.error("Can't found rootLogger!") }
|
||||
}
|
||||
}
|
||||
}
|
||||
6
packages/api/src/interfaces/server/native_plugin.ts
Normal file
6
packages/api/src/interfaces/server/native_plugin.ts
Normal file
@@ -0,0 +1,6 @@
|
||||
export interface NativePluginManager {
|
||||
load(name: string): boolean;
|
||||
unload(name: string): boolean;
|
||||
reload(name: string): boolean;
|
||||
delete(name: string): boolean;
|
||||
}
|
||||
3
packages/api/src/interfaces/web.ts
Normal file
3
packages/api/src/interfaces/web.ts
Normal file
@@ -0,0 +1,3 @@
|
||||
export namespace web {
|
||||
export const Server = Symbol('Server')
|
||||
}
|
||||
@@ -1,9 +1,20 @@
|
||||
import { injectable, DefaultContainer as container } from "@ms/container";
|
||||
|
||||
export namespace task {
|
||||
export const TaskManager = Symbol('TaskManager')
|
||||
export interface TaskManager {
|
||||
/**
|
||||
* 创建任务
|
||||
* @param func 任务内容
|
||||
*/
|
||||
create(func: Function): task.Task;
|
||||
/**
|
||||
* 在主线程执行代码
|
||||
* @param func 执行内容
|
||||
*/
|
||||
callSyncMethod(func: Function): any;
|
||||
/**
|
||||
* 关闭任务管理器
|
||||
*/
|
||||
disable();
|
||||
}
|
||||
/**
|
||||
* 任务抽象
|
||||
@@ -20,31 +31,47 @@ export namespace task {
|
||||
this.func = func;
|
||||
}
|
||||
|
||||
/**
|
||||
* 设置任务异步执行
|
||||
* @param isAsync 是否异步
|
||||
*/
|
||||
async(isAsync: boolean = true): task.Task {
|
||||
this.isAsync = isAsync;
|
||||
return this;
|
||||
}
|
||||
|
||||
/**
|
||||
* 设置任务延时执行
|
||||
* @param tick 延时 Tick
|
||||
*/
|
||||
later(tick: number): task.Task {
|
||||
this.laterTime = tick;
|
||||
return this;
|
||||
}
|
||||
|
||||
/**
|
||||
* 设置任务循环执行
|
||||
* @param tick 循环时间 Tick
|
||||
*/
|
||||
timer(tick: number): task.Task {
|
||||
this.interval = tick;
|
||||
return this;
|
||||
}
|
||||
|
||||
protected run(): void {
|
||||
protected run(...args: any[]): void {
|
||||
try {
|
||||
this.func();
|
||||
this.func(...args);
|
||||
} catch (ex) {
|
||||
console.console('§4插件执行任务时发生错误', ex)
|
||||
console.ex(ex);
|
||||
}
|
||||
}
|
||||
|
||||
abstract submit(): Cancelable;
|
||||
/**
|
||||
* 提交任务
|
||||
* @param args 任务参数
|
||||
*/
|
||||
abstract submit(...args: any[]): Cancelable;
|
||||
}
|
||||
/**
|
||||
* 返可取消的对象
|
||||
|
||||
@@ -1,24 +0,0 @@
|
||||
declare global {
|
||||
namespace NodeJS {
|
||||
interface Global {
|
||||
logger: any;
|
||||
debug: boolean;
|
||||
noop: Function;
|
||||
console: Console;
|
||||
}
|
||||
}
|
||||
var root: string;
|
||||
var base: Core;
|
||||
var ScriptEngineContextHolder: any;
|
||||
function engineLoad(str: string): any;
|
||||
interface Core {
|
||||
getClass(name: String);
|
||||
}
|
||||
interface Console {
|
||||
ex(err: Error): void;
|
||||
stack(err: Error): string[];
|
||||
sender(...args: any): void;
|
||||
console(...args: any): void;
|
||||
}
|
||||
}
|
||||
export { }
|
||||
4
packages/bukkit/.gitignore
vendored
4
packages/bukkit/.gitignore
vendored
@@ -1,4 +0,0 @@
|
||||
/node_modules
|
||||
/dist
|
||||
/package-lock.json
|
||||
/yarn.lock
|
||||
@@ -1,22 +0,0 @@
|
||||
src
|
||||
test
|
||||
typings
|
||||
bundled
|
||||
build
|
||||
coverage
|
||||
docs
|
||||
wiki
|
||||
gulpfile.js
|
||||
bower.json
|
||||
karma.conf.js
|
||||
tsconfig.json
|
||||
typings.json
|
||||
CONTRIBUTING.md
|
||||
ISSUE_TEMPLATE.md
|
||||
PULL_REQUEST_TEMPLATE.md
|
||||
tslint.json
|
||||
wallaby.js
|
||||
.travis.yml
|
||||
.gitignore
|
||||
.vscode
|
||||
type_definitions
|
||||
1
packages/bukkit/.npmignore
Symbolic link
1
packages/bukkit/.npmignore
Symbolic link
@@ -0,0 +1 @@
|
||||
../../.npmignore
|
||||
@@ -1,7 +1,7 @@
|
||||
{
|
||||
"name": "@ms/bukkit",
|
||||
"version": "0.1.1",
|
||||
"description": "MiaoScript api package",
|
||||
"name": "@ccms/bukkit",
|
||||
"version": "0.7.0",
|
||||
"description": "MiaoScript bukkit package",
|
||||
"keywords": [
|
||||
"miaoscript",
|
||||
"minecraft",
|
||||
@@ -12,23 +12,20 @@
|
||||
"homepage": "https://github.com/circlecloud/ms.git",
|
||||
"license": "ISC",
|
||||
"main": "dist/index.js",
|
||||
"publishConfig": {
|
||||
"registry": "https://repo.yumc.pw/repository/npm-hosted/"
|
||||
},
|
||||
"scripts": {
|
||||
"clean": "rimraf dist",
|
||||
"watch": "npx tsc --watch",
|
||||
"build": "yarn clean && npx tsc",
|
||||
"watch": "tsc --watch",
|
||||
"build": "yarn clean && tsc",
|
||||
"test": "echo \"Error: run tests from root\" && exit 1"
|
||||
},
|
||||
"devDependencies": {
|
||||
"reflect-metadata": "^0.1.13",
|
||||
"rimraf": "^3.0.0",
|
||||
"typescript": "^3.6.2"
|
||||
"rimraf": "^3.0.2",
|
||||
"typescript": "^3.9.2"
|
||||
},
|
||||
"dependencies": {
|
||||
"@ms/api": "^0.1.1",
|
||||
"@ms/common": "^0.1.0",
|
||||
"@ms/container": "^0.1.0"
|
||||
"@ccms/api": "^0.7.0",
|
||||
"@ccms/common": "^0.7.0",
|
||||
"@ccms/container": "^0.7.0"
|
||||
}
|
||||
}
|
||||
|
||||
28
packages/bukkit/src/channel.ts
Normal file
28
packages/bukkit/src/channel.ts
Normal file
@@ -0,0 +1,28 @@
|
||||
import { channel, plugin } from '@ccms/api'
|
||||
import { inject, provideSingleton } from '@ccms/container'
|
||||
|
||||
const Bukkit = org.bukkit.Bukkit
|
||||
const PluginMessageListener = Java.type("org.bukkit.plugin.messaging.PluginMessageListener")
|
||||
const Messenger = Bukkit.getMessenger()
|
||||
|
||||
@provideSingleton(channel.Channel)
|
||||
export class BukkitChannel extends channel.Channel {
|
||||
@inject(plugin.PluginInstance)
|
||||
private pluginInstance: any;
|
||||
|
||||
send(player: any, channel: string, data: any) {
|
||||
player.sendPluginMessage(this.pluginInstance, channel, data);
|
||||
}
|
||||
register(channel: string, listener: channel.ChannelListener) {
|
||||
Messenger.registerIncomingPluginChannel(this.pluginInstance, channel, new PluginMessageListener({
|
||||
onPluginMessageReceived: (/**String */ channel, /**Player */ player, /**byte[] */data) => {
|
||||
listener(data, { channel, player, data })
|
||||
}
|
||||
}));
|
||||
Messenger.registerOutgoingPluginChannel(this.pluginInstance, channel);
|
||||
}
|
||||
unregister(channel: string, listener: any) {
|
||||
Messenger.unregisterIncomingPluginChannel(this.pluginInstance, channel)
|
||||
Messenger.unregisterOutgoingPluginChannel(this.pluginInstance, channel)
|
||||
}
|
||||
}
|
||||
@@ -1,15 +1,15 @@
|
||||
import '@ms/nashorn'
|
||||
import '@ccms/nashorn'
|
||||
|
||||
import { command, plugin } from '@ms/api'
|
||||
import * as reflect from '@ms/common/dist/reflect'
|
||||
import { injectable, postConstruct, inject } from '@ms/container'
|
||||
import { command, plugin } from '@ccms/api'
|
||||
import * as reflect from '@ccms/common/dist/reflect'
|
||||
import { provideSingleton, postConstruct, inject } from '@ccms/container'
|
||||
|
||||
let Bukkit = org.bukkit.Bukkit;
|
||||
let TabCompleter = Java.type('org.bukkit.command.TabCompleter');
|
||||
let PluginCommand = Java.type('org.bukkit.command.PluginCommand');
|
||||
let CommandExecutor = Java.type('org.bukkit.command.CommandExecutor');
|
||||
|
||||
@injectable()
|
||||
@provideSingleton(command.Command)
|
||||
export class BukkitCommand extends command.Command {
|
||||
@inject(plugin.PluginInstance)
|
||||
private pluginInstance: any
|
||||
@@ -19,7 +19,6 @@ export class BukkitCommand extends command.Command {
|
||||
init() {
|
||||
this.commandMap = reflect.on(Bukkit.getPluginManager()).get('commandMap').get();
|
||||
}
|
||||
|
||||
create(plugin: any, command: string) {
|
||||
var cmd = this.commandMap.getCommand(command)
|
||||
if (cmd && cmd instanceof PluginCommand) { return cmd };
|
||||
|
||||
@@ -1,11 +1,11 @@
|
||||
import { MiaoScriptConsole } from '@ms/api'
|
||||
import { MiaoScriptConsole } from '@ccms/api'
|
||||
|
||||
let Bukkit = org.bukkit.Bukkit;
|
||||
|
||||
export class BukkitConsole extends MiaoScriptConsole {
|
||||
sender(sender, ...args) {
|
||||
if (!(sender instanceof org.bukkit.command.CommandSender)) {
|
||||
this.error("第一个参数未实现 org.bukkit.command.CommandSender 无法发送消息!")
|
||||
if (!(sender instanceof Java.type('org.bukkit.command.CommandSender'))) {
|
||||
this.error(`First parameter ${sender} not instanceof org.bukkit.command.CommandSender can't send message!`)
|
||||
return;
|
||||
}
|
||||
if (Object.prototype.toString.call(args[0]) === "[object Array]") {
|
||||
@@ -14,7 +14,7 @@ export class BukkitConsole extends MiaoScriptConsole {
|
||||
sender.sendMessage(this.prefix + args.join(' '));
|
||||
}
|
||||
}
|
||||
console(...args): void {
|
||||
console(...args: string[]): void {
|
||||
this.sender(Bukkit.getConsoleSender(), args.join(' '));
|
||||
}
|
||||
}
|
||||
|
||||
114
packages/bukkit/src/enhance/chat.ts
Normal file
114
packages/bukkit/src/enhance/chat.ts
Normal file
@@ -0,0 +1,114 @@
|
||||
/*global Java, base, module, exports, require*/
|
||||
var nmsChatSerializerClass;
|
||||
var nmsChatSerializerMethod;
|
||||
var packetTypeConstructor;
|
||||
var nmsChatMessageTypeClass;
|
||||
var chatMessageTypes;
|
||||
|
||||
var RemapUtils;
|
||||
|
||||
var playerConnectionFieldName;
|
||||
var sendPacketMethod;
|
||||
|
||||
var downgrade = false;
|
||||
/**
|
||||
* 获取NMS版本
|
||||
*/
|
||||
//@ts-ignore
|
||||
var nmsVersion = org.bukkit.Bukkit.server.class.name.split('.')[3];
|
||||
/**
|
||||
* 获取NMS类
|
||||
*/
|
||||
function nmsCls(name) {
|
||||
return base.getClass(['net.minecraft.server', nmsVersion, name].join('.'))
|
||||
}
|
||||
|
||||
function remapMethod(clazz: any, origin: string, test: string, params) {
|
||||
try {
|
||||
return clazz.getMethod(origin, params)
|
||||
} catch (ex) {
|
||||
if (RemapUtils) {
|
||||
return clazz.getMethod(RemapUtils.mapMethod(clazz, origin, params), params)
|
||||
} else {
|
||||
return clazz.getMethod(test, params)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
function remapFieldName(clazz: any, origin: string, test: string) {
|
||||
try {
|
||||
return clazz.getField(origin)
|
||||
} catch (ex) {
|
||||
if (RemapUtils) {
|
||||
return clazz.getField(RemapUtils.mapFieldName(clazz, origin))
|
||||
} else {
|
||||
return clazz.getField(test)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
function init() {
|
||||
try {
|
||||
RemapUtils = Java.type('catserver.server.remapper.RemapUtils');
|
||||
} catch (ex) {
|
||||
}
|
||||
nmsChatSerializerClass = nmsCls(nmsVersion.split("_")[1] > 7 ? "IChatBaseComponent$ChatSerializer" : "ChatSerializer");
|
||||
nmsChatSerializerMethod = remapMethod(nmsChatSerializerClass, 'a', 'func_150699_a', base.getClass('java.lang.String'))
|
||||
var packetTypeClass = nmsCls("PacketPlayOutChat");
|
||||
Java.from(packetTypeClass.constructors).forEach(function(c) {
|
||||
if (c.parameterTypes.length === 2) {
|
||||
packetTypeConstructor = c
|
||||
}
|
||||
});
|
||||
nmsChatMessageTypeClass = packetTypeConstructor.parameterTypes[1];
|
||||
if (nmsChatMessageTypeClass.isEnum()) {
|
||||
chatMessageTypes = nmsChatMessageTypeClass.getEnumConstants();
|
||||
} else {
|
||||
switch (nmsChatMessageTypeClass.name) {
|
||||
case "int":
|
||||
//@ts-ignore
|
||||
nmsChatMessageTypeClass = java.lang.Integer;
|
||||
break;
|
||||
case "byte":
|
||||
//@ts-ignore
|
||||
nmsChatMessageTypeClass = java.lang.Byte;
|
||||
break;
|
||||
}
|
||||
}
|
||||
var entityPlayerClass = nmsCls('EntityPlayer');
|
||||
var packetClass = nmsCls('Packet');
|
||||
var playerConnectionField = remapFieldName(entityPlayerClass, 'playerConnection', 'field_71135_a')
|
||||
playerConnectionFieldName = playerConnectionField.getName()
|
||||
sendPacketMethod = remapMethod(playerConnectionField.getType(), 'sendPacket', 'func_179290_a', packetClass)
|
||||
}
|
||||
|
||||
function json(sender, json) {
|
||||
if (downgrade) {
|
||||
return '/tellraw ' + sender.name + ' ' + json
|
||||
} else {
|
||||
send(sender, json, 0);
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
function send(sender, json, type) {
|
||||
//@ts-ignore
|
||||
sendPacket(sender, packetTypeConstructor.newInstance(nmsChatSerializerMethod.invoke(null, json), chatMessageTypes == null ? nmsChatMessageTypeClass.valueOf(java.lang.String.valueOf(type)) : chatMessageTypes[type]))
|
||||
}
|
||||
|
||||
function sendPacket(player, p) {
|
||||
sendPacketMethod.invoke(player.handle[playerConnectionFieldName], p)
|
||||
}
|
||||
|
||||
try {
|
||||
init();
|
||||
} catch (ex) {
|
||||
org.bukkit.Bukkit.getConsoleSender().sendMessage(`§6[§cMS§6][§bbukkit§6][§achat§6] §cNMS Inject Error §4${ex} §cDowngrade to Command Mode...`)
|
||||
downgrade = true;
|
||||
}
|
||||
|
||||
let chat = {
|
||||
json
|
||||
}
|
||||
|
||||
export default chat
|
||||
@@ -1,15 +1,15 @@
|
||||
import { event, server, plugin } from '@ms/api'
|
||||
import { injectable, inject } from '@ms/container';
|
||||
import * as reflect from '@ms/common/dist/reflect'
|
||||
import { event, plugin } from '@ccms/api'
|
||||
import { inject, provideSingleton } from '@ccms/container';
|
||||
import * as reflect from '@ccms/common/dist/reflect'
|
||||
|
||||
let Bukkit = Java.type("org.bukkit.Bukkit");
|
||||
let Event = Java.type("org.bukkit.event.Event");
|
||||
let Modifier = Java.type("java.lang.reflect.Modifier");
|
||||
let Listener = Java.type("org.bukkit.event.Listener");
|
||||
let EventPriority = Java.type("org.bukkit.event.EventPriority");
|
||||
let EventExecutor = Java.type("org.bukkit.plugin.EventExecutor");
|
||||
const Bukkit = Java.type("org.bukkit.Bukkit");
|
||||
const Event = Java.type("org.bukkit.event.Event");
|
||||
const Modifier = Java.type("java.lang.reflect.Modifier");
|
||||
const Listener = Java.type("org.bukkit.event.Listener");
|
||||
const EventPriority = Java.type("org.bukkit.event.EventPriority");
|
||||
const EventExecutor = Java.type("org.bukkit.plugin.EventExecutor");
|
||||
|
||||
@injectable()
|
||||
@provideSingleton(event.Event)
|
||||
export class BukkitEvent extends event.Event {
|
||||
@inject(plugin.PluginInstance)
|
||||
private pluginInstance: any
|
||||
@@ -18,6 +18,9 @@ export class BukkitEvent extends event.Event {
|
||||
super('org/bukkit/event');
|
||||
}
|
||||
|
||||
getJarFile(resource: string) {
|
||||
return super.getJarFile('org/bukkit/Bukkit.class', Bukkit.class.classLoader)
|
||||
}
|
||||
isValidEvent(clazz: any): boolean {
|
||||
// 继承于 org.bukkit.event.Event
|
||||
return Event.class.isAssignableFrom(clazz) &&
|
||||
@@ -26,8 +29,8 @@ export class BukkitEvent extends event.Event {
|
||||
// 不是抽象类
|
||||
!Modifier.isAbstract(clazz.getModifiers());
|
||||
}
|
||||
register(eventCls: any, exec: Function, priority: any, ignoreCancel: boolean) {
|
||||
var listener = new Listener({});
|
||||
register(eventCls: any, exec: Function, priority: event.EventPriority, ignoreCancel: boolean) {
|
||||
let listener = new Listener({});
|
||||
Bukkit.pluginManager.registerEvent(
|
||||
eventCls,
|
||||
listener,
|
||||
|
||||
@@ -1,22 +1,15 @@
|
||||
/// <reference path="./typings/index.ts" />
|
||||
/// <reference types="@ccms/types/dist/typings/bukkit" />
|
||||
|
||||
import { server, plugin, command, event, task } from '@ms/api'
|
||||
import { DefaultContainer as container } from '@ms/container'
|
||||
import { server } from '@ccms/api'
|
||||
import { Container } from '@ccms/container'
|
||||
|
||||
import { BukkitConsole } from './console';
|
||||
import { BukkitEvent } from './event';
|
||||
import { BukkitCommand } from './command';
|
||||
import { BukkitTaskManager } from './task';
|
||||
|
||||
let BukkitServerType = 'bukkit';
|
||||
let Bukkit = Java.type("org.bukkit.Bukkit");
|
||||
import './event';
|
||||
import './server';
|
||||
import './command';
|
||||
import './channel';
|
||||
import './task';
|
||||
|
||||
export default function BukkitImpl(container: Container) {
|
||||
container.bind(server.Console).toConstantValue(BukkitConsole);
|
||||
container.bind(server.ServerType).toConstantValue(BukkitServerType);
|
||||
container.bind(plugin.PluginInstance).toConstantValue(Bukkit.pluginManager.getPlugin('MiaoScript'));
|
||||
|
||||
container.bind(event.Event).to(BukkitEvent).inSingletonScope();
|
||||
container.bind(command.Command).to(BukkitCommand).inSingletonScope();
|
||||
container.bind(task.TaskManager).to(BukkitTaskManager).inSingletonScope();
|
||||
|
||||
console.debug(`Detect Bukkit Compatible set ServerType to ${BukkitServerType} ...`)
|
||||
}
|
||||
|
||||
66
packages/bukkit/src/server.ts
Normal file
66
packages/bukkit/src/server.ts
Normal file
@@ -0,0 +1,66 @@
|
||||
import { server, constants } from '@ccms/api'
|
||||
import { provideSingleton } from '@ccms/container';
|
||||
|
||||
import * as reflect from '@ccms/common/dist/reflect'
|
||||
import chat from './enhance/chat'
|
||||
|
||||
let Bukkit = org.bukkit.Bukkit;
|
||||
|
||||
@provideSingleton(server.Server)
|
||||
export class BukkitServer extends server.ReflectServer {
|
||||
private pluginsFolder: string;
|
||||
|
||||
constructor() {
|
||||
super();
|
||||
this.pluginsFolder = Bukkit.getUpdateFolderFile().getParentFile().getCanonicalPath();
|
||||
}
|
||||
|
||||
getPlayer(name: string) {
|
||||
return Bukkit.getPlayer(name)
|
||||
}
|
||||
getVersion(): string {
|
||||
return Bukkit.getVersion()
|
||||
}
|
||||
getOnlinePlayers() {
|
||||
return Bukkit.getOnlinePlayers() as unknown as any[]
|
||||
}
|
||||
getConsoleSender() {
|
||||
return Bukkit.getConsoleSender()
|
||||
}
|
||||
getService(service: string) {
|
||||
return Bukkit.getServicesManager().getRegistration(base.getClass(service))?.getProvider()
|
||||
}
|
||||
dispatchCommand(sender: string | any, command: string): boolean {
|
||||
if (typeof sender === 'string') {
|
||||
sender = this.getPlayer(sender)
|
||||
}
|
||||
return Bukkit.dispatchCommand(sender, command)
|
||||
}
|
||||
dispatchConsoleCommand(command: string): boolean {
|
||||
return Bukkit.dispatchCommand(Bukkit.getConsoleSender(), command)
|
||||
}
|
||||
getPluginsFolder(): string {
|
||||
return this.pluginsFolder;
|
||||
}
|
||||
getNativePluginManager() {
|
||||
return Bukkit.getPluginManager() as any;
|
||||
}
|
||||
getDedicatedServer() {
|
||||
return reflect.on(Bukkit.getServer()).get('console').get()
|
||||
}
|
||||
getNettyPipeline() {
|
||||
return this.pipeline;
|
||||
}
|
||||
getRootLogger() {
|
||||
return this.rootLogger;
|
||||
}
|
||||
sendJson(sender: string | any, json: object | string): void {
|
||||
if (typeof sender === "string") {
|
||||
sender = this.getPlayer(sender)
|
||||
}
|
||||
let result = chat.json(sender, json)
|
||||
if (result !== false) {
|
||||
this.dispatchConsoleCommand(result)
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,9 +1,11 @@
|
||||
import { task, plugin } from '@ms/api'
|
||||
import { injectable, inject } from '@ms/container';
|
||||
import { task, plugin } from '@ccms/api'
|
||||
import { inject, provideSingleton } from '@ccms/container';
|
||||
|
||||
let BukkitRunnable = Java.type('org.bukkit.scheduler.BukkitRunnable');
|
||||
const Bukkit = Java.type('org.bukkit.Bukkit');
|
||||
const BukkitRunnable = Java.type('org.bukkit.scheduler.BukkitRunnable');
|
||||
const Callable = Java.type('java.util.concurrent.Callable')
|
||||
|
||||
@injectable()
|
||||
@provideSingleton(task.TaskManager)
|
||||
export class BukkitTaskManager implements task.TaskManager {
|
||||
@inject(plugin.PluginInstance)
|
||||
private pluginInstance: any;
|
||||
@@ -12,13 +14,17 @@ export class BukkitTaskManager implements task.TaskManager {
|
||||
if (Object.prototype.toString.call(func) !== "[object Function]") { throw TypeError('第一个参数 Task 必须为 function !'); };
|
||||
return new BukkitTask(this.pluginInstance, func);
|
||||
}
|
||||
callSyncMethod(func: Function): any {
|
||||
return Bukkit.getScheduler().callSyncMethod(this.pluginInstance, new Callable({ call: () => func() })).get()
|
||||
}
|
||||
disable() {
|
||||
Bukkit.getScheduler().cancelTasks(this.pluginInstance);
|
||||
}
|
||||
}
|
||||
|
||||
export class BukkitTask extends task.Task {
|
||||
submit(): task.Cancelable {
|
||||
let run = new BukkitRunnable({
|
||||
run: () => this.run()
|
||||
})
|
||||
submit(...args: any[]): task.Cancelable {
|
||||
let run = new BukkitRunnable({ run: () => this.run(...args) })
|
||||
let funcName = `runTask${this.interval ? 'Timer' : 'Later'}${this.isAsync ? 'Asynchronously' : ''}`
|
||||
if (this.interval) {
|
||||
return run[funcName](this.plugin, this.laterTime, this.interval)
|
||||
|
||||
@@ -1,958 +0,0 @@
|
||||
/// <reference path="./org.bukkit.Achievement.ts" />
|
||||
/// <reference path="./org.bukkit.Art.ts" />
|
||||
/// <reference path="./org.bukkit.Axis.ts" />
|
||||
/// <reference path="./org.bukkit.BanEntry.ts" />
|
||||
/// <reference path="./org.bukkit.BanList.Type.ts" />
|
||||
/// <reference path="./org.bukkit.BanList.ts" />
|
||||
/// <reference path="./org.bukkit.BlockChangeDelegate.ts" />
|
||||
/// <reference path="./org.bukkit.Bukkit.ts" />
|
||||
/// <reference path="./org.bukkit.ChatColor.ts" />
|
||||
/// <reference path="./org.bukkit.Chunk.ts" />
|
||||
/// <reference path="./org.bukkit.ChunkSnapshot.ts" />
|
||||
/// <reference path="./org.bukkit.CoalType.ts" />
|
||||
/// <reference path="./org.bukkit.Color.ts" />
|
||||
/// <reference path="./org.bukkit.CropState.ts" />
|
||||
/// <reference path="./org.bukkit.Difficulty.ts" />
|
||||
/// <reference path="./org.bukkit.DyeColor.ts" />
|
||||
/// <reference path="./org.bukkit.Effect.Type.ts" />
|
||||
/// <reference path="./org.bukkit.Effect.ts" />
|
||||
/// <reference path="./org.bukkit.EntityEffect.ts" />
|
||||
/// <reference path="./org.bukkit.FireworkEffect.Builder.ts" />
|
||||
/// <reference path="./org.bukkit.FireworkEffect.Type.ts" />
|
||||
/// <reference path="./org.bukkit.FireworkEffect.ts" />
|
||||
/// <reference path="./org.bukkit.FluidCollisionMode.ts" />
|
||||
/// <reference path="./org.bukkit.GameMode.ts" />
|
||||
/// <reference path="./org.bukkit.GameRule.ts" />
|
||||
/// <reference path="./org.bukkit.GrassSpecies.ts" />
|
||||
/// <reference path="./org.bukkit.Instrument.ts" />
|
||||
/// <reference path="./org.bukkit.Keyed.ts" />
|
||||
/// <reference path="./org.bukkit.Location.ts" />
|
||||
/// <reference path="./org.bukkit.Material.ts" />
|
||||
/// <reference path="./org.bukkit.Nameable.ts" />
|
||||
/// <reference path="./org.bukkit.NamespacedKey.ts" />
|
||||
/// <reference path="./org.bukkit.NetherWartsState.ts" />
|
||||
/// <reference path="./org.bukkit.Note.Tone.ts" />
|
||||
/// <reference path="./org.bukkit.Note.ts" />
|
||||
/// <reference path="./org.bukkit.OfflinePlayer.ts" />
|
||||
/// <reference path="./org.bukkit.Particle.DustOptions.ts" />
|
||||
/// <reference path="./org.bukkit.Particle.ts" />
|
||||
/// <reference path="./org.bukkit.PortalType.ts" />
|
||||
/// <reference path="./org.bukkit.Registry.SimpleRegistry.ts" />
|
||||
/// <reference path="./org.bukkit.Registry.ts" />
|
||||
/// <reference path="./org.bukkit.Rotation.ts" />
|
||||
/// <reference path="./org.bukkit.SandstoneType.ts" />
|
||||
/// <reference path="./org.bukkit.Server.ts" />
|
||||
/// <reference path="./org.bukkit.SkullType.ts" />
|
||||
/// <reference path="./org.bukkit.Sound.ts" />
|
||||
/// <reference path="./org.bukkit.SoundCategory.ts" />
|
||||
/// <reference path="./org.bukkit.Statistic.Type.ts" />
|
||||
/// <reference path="./org.bukkit.Statistic.ts" />
|
||||
/// <reference path="./org.bukkit.StructureType.ts" />
|
||||
/// <reference path="./org.bukkit.Tag.ts" />
|
||||
/// <reference path="./org.bukkit.TreeSpecies.ts" />
|
||||
/// <reference path="./org.bukkit.TreeType.ts" />
|
||||
/// <reference path="./org.bukkit.UndefinedNullability.ts" />
|
||||
/// <reference path="./org.bukkit.UnsafeValues.ts" />
|
||||
/// <reference path="./org.bukkit.Utility.ts" />
|
||||
/// <reference path="./org.bukkit.Warning.WarningState.ts" />
|
||||
/// <reference path="./org.bukkit.Warning.ts" />
|
||||
/// <reference path="./org.bukkit.WeatherType.ts" />
|
||||
/// <reference path="./org.bukkit.World.Environment.ts" />
|
||||
/// <reference path="./org.bukkit.World.ts" />
|
||||
/// <reference path="./org.bukkit.WorldBorder.ts" />
|
||||
/// <reference path="./org.bukkit.WorldCreator.ts" />
|
||||
/// <reference path="./org.bukkit.WorldType.ts" />
|
||||
/// <reference path="./org.bukkit.advancement.Advancement.ts" />
|
||||
/// <reference path="./org.bukkit.advancement.AdvancementProgress.ts" />
|
||||
/// <reference path="./org.bukkit.attribute.Attributable.ts" />
|
||||
/// <reference path="./org.bukkit.attribute.Attribute.ts" />
|
||||
/// <reference path="./org.bukkit.attribute.AttributeInstance.ts" />
|
||||
/// <reference path="./org.bukkit.attribute.AttributeModifier.Operation.ts" />
|
||||
/// <reference path="./org.bukkit.attribute.AttributeModifier.ts" />
|
||||
/// <reference path="./org.bukkit.block.Banner.ts" />
|
||||
/// <reference path="./org.bukkit.block.Barrel.ts" />
|
||||
/// <reference path="./org.bukkit.block.Beacon.ts" />
|
||||
/// <reference path="./org.bukkit.block.Bed.ts" />
|
||||
/// <reference path="./org.bukkit.block.Bell.ts" />
|
||||
/// <reference path="./org.bukkit.block.Biome.ts" />
|
||||
/// <reference path="./org.bukkit.block.BlastFurnace.ts" />
|
||||
/// <reference path="./org.bukkit.block.Block.ts" />
|
||||
/// <reference path="./org.bukkit.block.BlockFace.ts" />
|
||||
/// <reference path="./org.bukkit.block.BlockState.ts" />
|
||||
/// <reference path="./org.bukkit.block.BrewingStand.ts" />
|
||||
/// <reference path="./org.bukkit.block.Campfire.ts" />
|
||||
/// <reference path="./org.bukkit.block.Chest.ts" />
|
||||
/// <reference path="./org.bukkit.block.CommandBlock.ts" />
|
||||
/// <reference path="./org.bukkit.block.Comparator.ts" />
|
||||
/// <reference path="./org.bukkit.block.Conduit.ts" />
|
||||
/// <reference path="./org.bukkit.block.Container.ts" />
|
||||
/// <reference path="./org.bukkit.block.CreatureSpawner.ts" />
|
||||
/// <reference path="./org.bukkit.block.DaylightDetector.ts" />
|
||||
/// <reference path="./org.bukkit.block.Dispenser.ts" />
|
||||
/// <reference path="./org.bukkit.block.DoubleChest.ts" />
|
||||
/// <reference path="./org.bukkit.block.Dropper.ts" />
|
||||
/// <reference path="./org.bukkit.block.EnchantingTable.ts" />
|
||||
/// <reference path="./org.bukkit.block.EndGateway.ts" />
|
||||
/// <reference path="./org.bukkit.block.EnderChest.ts" />
|
||||
/// <reference path="./org.bukkit.block.FlowerPot.ts" />
|
||||
/// <reference path="./org.bukkit.block.Furnace.ts" />
|
||||
/// <reference path="./org.bukkit.block.Hopper.ts" />
|
||||
/// <reference path="./org.bukkit.block.Jigsaw.ts" />
|
||||
/// <reference path="./org.bukkit.block.Jukebox.ts" />
|
||||
/// <reference path="./org.bukkit.block.Lectern.ts" />
|
||||
/// <reference path="./org.bukkit.block.Lockable.ts" />
|
||||
/// <reference path="./org.bukkit.block.NoteBlock.ts" />
|
||||
/// <reference path="./org.bukkit.block.PistonMoveReaction.ts" />
|
||||
/// <reference path="./org.bukkit.block.ShulkerBox.ts" />
|
||||
/// <reference path="./org.bukkit.block.Sign.ts" />
|
||||
/// <reference path="./org.bukkit.block.Skull.ts" />
|
||||
/// <reference path="./org.bukkit.block.Smoker.ts" />
|
||||
/// <reference path="./org.bukkit.block.Structure.ts" />
|
||||
/// <reference path="./org.bukkit.block.TileState.ts" />
|
||||
/// <reference path="./org.bukkit.block.banner.Pattern.ts" />
|
||||
/// <reference path="./org.bukkit.block.banner.PatternType.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.Ageable.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.AnaloguePowerable.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.Attachable.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.Bisected.Half.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.Bisected.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.BlockData.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.Directional.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.Levelled.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.Lightable.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.MultipleFacing.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.Openable.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.Orientable.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.Powerable.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.Rail.Shape.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.Rail.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.Rotatable.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.Snowable.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.Waterlogged.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.Bamboo.Leaves.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.Bamboo.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.Bed.Part.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.Bed.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.Bell.Attachment.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.Bell.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.BrewingStand.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.BubbleColumn.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.Cake.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.Campfire.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.Chest.Type.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.Chest.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.Cocoa.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.CommandBlock.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.Comparator.Mode.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.Comparator.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.CoralWallFan.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.DaylightDetector.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.Dispenser.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.Door.Hinge.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.Door.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.EndPortalFrame.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.EnderChest.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.Farmland.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.Fence.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.Fire.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.Furnace.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.Gate.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.GlassPane.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.Hopper.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.Jukebox.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.Ladder.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.Lantern.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.Leaves.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.Lectern.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.NoteBlock.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.Observer.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.Piston.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.PistonHead.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.RedstoneRail.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.RedstoneWallTorch.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.RedstoneWire.Connection.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.RedstoneWire.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.Repeater.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.Sapling.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.Scaffolding.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.SeaPickle.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.Sign.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.Slab.Type.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.Slab.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.Snow.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.Stairs.Shape.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.Stairs.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.StructureBlock.Mode.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.StructureBlock.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.Switch.Face.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.Switch.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.TNT.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.TechnicalPiston.Type.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.TechnicalPiston.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.TrapDoor.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.Tripwire.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.TripwireHook.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.TurtleEgg.ts" />
|
||||
/// <reference path="./org.bukkit.block.data.type.WallSign.ts" />
|
||||
/// <reference path="./org.bukkit.block.structure.Mirror.ts" />
|
||||
/// <reference path="./org.bukkit.block.structure.StructureRotation.ts" />
|
||||
/// <reference path="./org.bukkit.block.structure.UsageMode.ts" />
|
||||
/// <reference path="./org.bukkit.boss.BarColor.ts" />
|
||||
/// <reference path="./org.bukkit.boss.BarFlag.ts" />
|
||||
/// <reference path="./org.bukkit.boss.BarStyle.ts" />
|
||||
/// <reference path="./org.bukkit.boss.BossBar.ts" />
|
||||
/// <reference path="./org.bukkit.boss.KeyedBossBar.ts" />
|
||||
/// <reference path="./org.bukkit.command.BlockCommandSender.ts" />
|
||||
/// <reference path="./org.bukkit.command.Command.ts" />
|
||||
/// <reference path="./org.bukkit.command.CommandException.ts" />
|
||||
/// <reference path="./org.bukkit.command.CommandExecutor.ts" />
|
||||
/// <reference path="./org.bukkit.command.CommandMap.ts" />
|
||||
/// <reference path="./org.bukkit.command.CommandSender.ts" />
|
||||
/// <reference path="./org.bukkit.command.ConsoleCommandSender.ts" />
|
||||
/// <reference path="./org.bukkit.command.FormattedCommandAlias.ts" />
|
||||
/// <reference path="./org.bukkit.command.MultipleCommandAlias.ts" />
|
||||
/// <reference path="./org.bukkit.command.PluginCommand.ts" />
|
||||
/// <reference path="./org.bukkit.command.PluginCommandYamlParser.ts" />
|
||||
/// <reference path="./org.bukkit.command.PluginIdentifiableCommand.ts" />
|
||||
/// <reference path="./org.bukkit.command.ProxiedCommandSender.ts" />
|
||||
/// <reference path="./org.bukkit.command.RemoteConsoleCommandSender.ts" />
|
||||
/// <reference path="./org.bukkit.command.SimpleCommandMap.ts" />
|
||||
/// <reference path="./org.bukkit.command.TabCompleter.ts" />
|
||||
/// <reference path="./org.bukkit.command.TabExecutor.ts" />
|
||||
/// <reference path="./org.bukkit.command.defaults.BukkitCommand.ts" />
|
||||
/// <reference path="./org.bukkit.command.defaults.HelpCommand.ts" />
|
||||
/// <reference path="./org.bukkit.command.defaults.PluginsCommand.ts" />
|
||||
/// <reference path="./org.bukkit.command.defaults.ReloadCommand.ts" />
|
||||
/// <reference path="./org.bukkit.command.defaults.TimingsCommand.ts" />
|
||||
/// <reference path="./org.bukkit.command.defaults.VersionCommand.ts" />
|
||||
/// <reference path="./org.bukkit.configuration.Configuration.ts" />
|
||||
/// <reference path="./org.bukkit.configuration.ConfigurationOptions.ts" />
|
||||
/// <reference path="./org.bukkit.configuration.ConfigurationSection.ts" />
|
||||
/// <reference path="./org.bukkit.configuration.InvalidConfigurationException.ts" />
|
||||
/// <reference path="./org.bukkit.configuration.MemoryConfiguration.ts" />
|
||||
/// <reference path="./org.bukkit.configuration.MemoryConfigurationOptions.ts" />
|
||||
/// <reference path="./org.bukkit.configuration.MemorySection.ts" />
|
||||
/// <reference path="./org.bukkit.configuration.file.FileConfiguration.ts" />
|
||||
/// <reference path="./org.bukkit.configuration.file.FileConfigurationOptions.ts" />
|
||||
/// <reference path="./org.bukkit.configuration.file.YamlConfiguration.ts" />
|
||||
/// <reference path="./org.bukkit.configuration.file.YamlConfigurationOptions.ts" />
|
||||
/// <reference path="./org.bukkit.configuration.file.YamlConstructor.ts" />
|
||||
/// <reference path="./org.bukkit.configuration.file.YamlRepresenter.ts" />
|
||||
/// <reference path="./org.bukkit.configuration.serialization.ConfigurationSerializable.ts" />
|
||||
/// <reference path="./org.bukkit.configuration.serialization.ConfigurationSerialization.ts" />
|
||||
/// <reference path="./org.bukkit.configuration.serialization.DelegateDeserialization.ts" />
|
||||
/// <reference path="./org.bukkit.configuration.serialization.SerializableAs.ts" />
|
||||
/// <reference path="./org.bukkit.conversations.BooleanPrompt.ts" />
|
||||
/// <reference path="./org.bukkit.conversations.Conversable.ts" />
|
||||
/// <reference path="./org.bukkit.conversations.Conversation.ConversationState.ts" />
|
||||
/// <reference path="./org.bukkit.conversations.Conversation.ts" />
|
||||
/// <reference path="./org.bukkit.conversations.ConversationAbandonedEvent.ts" />
|
||||
/// <reference path="./org.bukkit.conversations.ConversationAbandonedListener.ts" />
|
||||
/// <reference path="./org.bukkit.conversations.ConversationCanceller.ts" />
|
||||
/// <reference path="./org.bukkit.conversations.ConversationContext.ts" />
|
||||
/// <reference path="./org.bukkit.conversations.ConversationFactory.ts" />
|
||||
/// <reference path="./org.bukkit.conversations.ConversationPrefix.ts" />
|
||||
/// <reference path="./org.bukkit.conversations.ExactMatchConversationCanceller.ts" />
|
||||
/// <reference path="./org.bukkit.conversations.FixedSetPrompt.ts" />
|
||||
/// <reference path="./org.bukkit.conversations.InactivityConversationCanceller.ts" />
|
||||
/// <reference path="./org.bukkit.conversations.ManuallyAbandonedConversationCanceller.ts" />
|
||||
/// <reference path="./org.bukkit.conversations.MessagePrompt.ts" />
|
||||
/// <reference path="./org.bukkit.conversations.NullConversationPrefix.ts" />
|
||||
/// <reference path="./org.bukkit.conversations.NumericPrompt.ts" />
|
||||
/// <reference path="./org.bukkit.conversations.PlayerNamePrompt.ts" />
|
||||
/// <reference path="./org.bukkit.conversations.PluginNameConversationPrefix.ts" />
|
||||
/// <reference path="./org.bukkit.conversations.Prompt.ts" />
|
||||
/// <reference path="./org.bukkit.conversations.RegexPrompt.ts" />
|
||||
/// <reference path="./org.bukkit.conversations.StringPrompt.ts" />
|
||||
/// <reference path="./org.bukkit.conversations.ValidatingPrompt.ts" />
|
||||
/// <reference path="./org.bukkit.enchantments.Enchantment.ts" />
|
||||
/// <reference path="./org.bukkit.enchantments.EnchantmentOffer.ts" />
|
||||
/// <reference path="./org.bukkit.enchantments.EnchantmentTarget.ts" />
|
||||
/// <reference path="./org.bukkit.enchantments.EnchantmentWrapper.ts" />
|
||||
/// <reference path="./org.bukkit.entity.AbstractArrow.PickupStatus.ts" />
|
||||
/// <reference path="./org.bukkit.entity.AbstractArrow.ts" />
|
||||
/// <reference path="./org.bukkit.entity.AbstractHorse.ts" />
|
||||
/// <reference path="./org.bukkit.entity.AbstractVillager.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Ageable.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Ambient.ts" />
|
||||
/// <reference path="./org.bukkit.entity.AnimalTamer.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Animals.ts" />
|
||||
/// <reference path="./org.bukkit.entity.AreaEffectCloud.ts" />
|
||||
/// <reference path="./org.bukkit.entity.ArmorStand.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Arrow.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Bat.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Blaze.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Boat.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Boss.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Cat.Type.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Cat.ts" />
|
||||
/// <reference path="./org.bukkit.entity.CaveSpider.ts" />
|
||||
/// <reference path="./org.bukkit.entity.ChestedHorse.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Chicken.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Cod.ts" />
|
||||
/// <reference path="./org.bukkit.entity.ComplexEntityPart.ts" />
|
||||
/// <reference path="./org.bukkit.entity.ComplexLivingEntity.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Cow.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Creature.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Creeper.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Damageable.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Dolphin.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Donkey.ts" />
|
||||
/// <reference path="./org.bukkit.entity.DragonFireball.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Drowned.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Egg.ts" />
|
||||
/// <reference path="./org.bukkit.entity.ElderGuardian.ts" />
|
||||
/// <reference path="./org.bukkit.entity.EnderCrystal.ts" />
|
||||
/// <reference path="./org.bukkit.entity.EnderDragon.Phase.ts" />
|
||||
/// <reference path="./org.bukkit.entity.EnderDragon.ts" />
|
||||
/// <reference path="./org.bukkit.entity.EnderDragonPart.ts" />
|
||||
/// <reference path="./org.bukkit.entity.EnderPearl.ts" />
|
||||
/// <reference path="./org.bukkit.entity.EnderSignal.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Enderman.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Endermite.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Entity.ts" />
|
||||
/// <reference path="./org.bukkit.entity.EntityType.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Evoker.Spell.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Evoker.ts" />
|
||||
/// <reference path="./org.bukkit.entity.EvokerFangs.ts" />
|
||||
/// <reference path="./org.bukkit.entity.ExperienceOrb.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Explosive.ts" />
|
||||
/// <reference path="./org.bukkit.entity.FallingBlock.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Fireball.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Firework.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Fish.ts" />
|
||||
/// <reference path="./org.bukkit.entity.FishHook.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Flying.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Fox.Type.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Fox.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Ghast.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Giant.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Golem.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Guardian.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Hanging.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Horse.Color.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Horse.Style.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Horse.Variant.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Horse.ts" />
|
||||
/// <reference path="./org.bukkit.entity.HumanEntity.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Husk.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Illager.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Illusioner.ts" />
|
||||
/// <reference path="./org.bukkit.entity.IronGolem.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Item.ts" />
|
||||
/// <reference path="./org.bukkit.entity.ItemFrame.ts" />
|
||||
/// <reference path="./org.bukkit.entity.LargeFireball.ts" />
|
||||
/// <reference path="./org.bukkit.entity.LeashHitch.ts" />
|
||||
/// <reference path="./org.bukkit.entity.LightningStrike.ts" />
|
||||
/// <reference path="./org.bukkit.entity.LingeringPotion.ts" />
|
||||
/// <reference path="./org.bukkit.entity.LivingEntity.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Llama.Color.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Llama.ts" />
|
||||
/// <reference path="./org.bukkit.entity.LlamaSpit.ts" />
|
||||
/// <reference path="./org.bukkit.entity.MagmaCube.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Minecart.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Mob.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Monster.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Mule.ts" />
|
||||
/// <reference path="./org.bukkit.entity.MushroomCow.Variant.ts" />
|
||||
/// <reference path="./org.bukkit.entity.MushroomCow.ts" />
|
||||
/// <reference path="./org.bukkit.entity.NPC.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Ocelot.Type.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Ocelot.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Painting.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Panda.Gene.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Panda.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Parrot.Variant.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Parrot.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Phantom.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Pig.ts" />
|
||||
/// <reference path="./org.bukkit.entity.PigZombie.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Pillager.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Player.ts" />
|
||||
/// <reference path="./org.bukkit.entity.PolarBear.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Pose.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Projectile.ts" />
|
||||
/// <reference path="./org.bukkit.entity.PufferFish.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Rabbit.Type.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Rabbit.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Raider.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Ravager.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Salmon.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Sheep.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Shulker.ts" />
|
||||
/// <reference path="./org.bukkit.entity.ShulkerBullet.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Silverfish.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Sittable.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Skeleton.SkeletonType.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Skeleton.ts" />
|
||||
/// <reference path="./org.bukkit.entity.SkeletonHorse.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Slime.ts" />
|
||||
/// <reference path="./org.bukkit.entity.SmallFireball.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Snowball.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Snowman.ts" />
|
||||
/// <reference path="./org.bukkit.entity.SpectralArrow.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Spellcaster.Spell.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Spellcaster.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Spider.ts" />
|
||||
/// <reference path="./org.bukkit.entity.SplashPotion.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Squid.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Stray.ts" />
|
||||
/// <reference path="./org.bukkit.entity.TNTPrimed.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Tameable.ts" />
|
||||
/// <reference path="./org.bukkit.entity.ThrownExpBottle.ts" />
|
||||
/// <reference path="./org.bukkit.entity.ThrownPotion.ts" />
|
||||
/// <reference path="./org.bukkit.entity.TippedArrow.ts" />
|
||||
/// <reference path="./org.bukkit.entity.TraderLlama.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Trident.ts" />
|
||||
/// <reference path="./org.bukkit.entity.TropicalFish.Pattern.ts" />
|
||||
/// <reference path="./org.bukkit.entity.TropicalFish.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Turtle.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Vehicle.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Vex.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Villager.Profession.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Villager.Type.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Villager.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Vindicator.ts" />
|
||||
/// <reference path="./org.bukkit.entity.WanderingTrader.ts" />
|
||||
/// <reference path="./org.bukkit.entity.WaterMob.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Witch.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Wither.ts" />
|
||||
/// <reference path="./org.bukkit.entity.WitherSkeleton.ts" />
|
||||
/// <reference path="./org.bukkit.entity.WitherSkull.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Wolf.ts" />
|
||||
/// <reference path="./org.bukkit.entity.Zombie.ts" />
|
||||
/// <reference path="./org.bukkit.entity.ZombieHorse.ts" />
|
||||
/// <reference path="./org.bukkit.entity.ZombieVillager.ts" />
|
||||
/// <reference path="./org.bukkit.entity.memory.MemoryKey.ts" />
|
||||
/// <reference path="./org.bukkit.entity.minecart.CommandMinecart.ts" />
|
||||
/// <reference path="./org.bukkit.entity.minecart.ExplosiveMinecart.ts" />
|
||||
/// <reference path="./org.bukkit.entity.minecart.HopperMinecart.ts" />
|
||||
/// <reference path="./org.bukkit.entity.minecart.PoweredMinecart.ts" />
|
||||
/// <reference path="./org.bukkit.entity.minecart.RideableMinecart.ts" />
|
||||
/// <reference path="./org.bukkit.entity.minecart.SpawnerMinecart.ts" />
|
||||
/// <reference path="./org.bukkit.entity.minecart.StorageMinecart.ts" />
|
||||
/// <reference path="./org.bukkit.event.Cancellable.ts" />
|
||||
/// <reference path="./org.bukkit.event.Event.Result.ts" />
|
||||
/// <reference path="./org.bukkit.event.Event.ts" />
|
||||
/// <reference path="./org.bukkit.event.EventException.ts" />
|
||||
/// <reference path="./org.bukkit.event.EventHandler.ts" />
|
||||
/// <reference path="./org.bukkit.event.EventPriority.ts" />
|
||||
/// <reference path="./org.bukkit.event.HandlerList.ts" />
|
||||
/// <reference path="./org.bukkit.event.Listener.ts" />
|
||||
/// <reference path="./org.bukkit.event.block.Action.ts" />
|
||||
/// <reference path="./org.bukkit.event.block.BlockBreakEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.block.BlockBurnEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.block.BlockCanBuildEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.block.BlockCookEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.block.BlockDamageEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.block.BlockDispenseArmorEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.block.BlockDispenseEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.block.BlockDropItemEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.block.BlockEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.block.BlockExpEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.block.BlockExplodeEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.block.BlockFadeEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.block.BlockFertilizeEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.block.BlockFormEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.block.BlockFromToEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.block.BlockGrowEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.block.BlockIgniteEvent.IgniteCause.ts" />
|
||||
/// <reference path="./org.bukkit.event.block.BlockIgniteEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.block.BlockMultiPlaceEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.block.BlockPhysicsEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.block.BlockPistonEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.block.BlockPistonExtendEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.block.BlockPistonRetractEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.block.BlockPlaceEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.block.BlockRedstoneEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.block.BlockShearEntityEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.block.BlockSpreadEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.block.CauldronLevelChangeEvent.ChangeReason.ts" />
|
||||
/// <reference path="./org.bukkit.event.block.CauldronLevelChangeEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.block.EntityBlockFormEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.block.FluidLevelChangeEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.block.LeavesDecayEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.block.MoistureChangeEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.block.NotePlayEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.block.SignChangeEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.block.SpongeAbsorbEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.enchantment.EnchantItemEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.enchantment.PrepareItemEnchantEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.AreaEffectCloudApplyEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.BatToggleSleepEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.CreatureSpawnEvent.SpawnReason.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.CreatureSpawnEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.CreeperPowerEvent.PowerCause.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.CreeperPowerEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.EnderDragonChangePhaseEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.EntityAirChangeEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.EntityBreakDoorEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.EntityBreedEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.EntityChangeBlockEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.EntityCombustByBlockEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.EntityCombustByEntityEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.EntityCombustEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.EntityCreatePortalEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.EntityDamageByBlockEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.EntityDamageByEntityEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.EntityDamageEvent.DamageCause.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.EntityDamageEvent.DamageModifier.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.EntityDamageEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.EntityDeathEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.EntityDropItemEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.EntityEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.EntityExplodeEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.EntityInteractEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.EntityPickupItemEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.EntityPlaceEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.EntityPortalEnterEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.EntityPortalEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.EntityPortalExitEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.EntityPoseChangeEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.EntityPotionEffectEvent.Action.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.EntityPotionEffectEvent.Cause.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.EntityPotionEffectEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.EntityRegainHealthEvent.RegainReason.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.EntityRegainHealthEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.EntityResurrectEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.EntityShootBowEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.EntitySpawnEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.EntityTameEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.EntityTargetEvent.TargetReason.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.EntityTargetEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.EntityTargetLivingEntityEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.EntityTeleportEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.EntityToggleGlideEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.EntityToggleSwimEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.EntityTransformEvent.TransformReason.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.EntityTransformEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.EntityUnleashEvent.UnleashReason.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.EntityUnleashEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.ExpBottleEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.ExplosionPrimeEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.FireworkExplodeEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.FoodLevelChangeEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.HorseJumpEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.ItemDespawnEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.ItemMergeEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.ItemSpawnEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.LingeringPotionSplashEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.PigZapEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.PigZombieAngerEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.PlayerDeathEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.PlayerLeashEntityEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.PotionSplashEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.ProjectileHitEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.ProjectileLaunchEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.SheepDyeWoolEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.SheepRegrowWoolEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.SlimeSplitEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.VillagerAcquireTradeEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.VillagerCareerChangeEvent.ChangeReason.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.VillagerCareerChangeEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.entity.VillagerReplenishTradeEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.hanging.HangingBreakByEntityEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.hanging.HangingBreakEvent.RemoveCause.ts" />
|
||||
/// <reference path="./org.bukkit.event.hanging.HangingBreakEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.hanging.HangingEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.hanging.HangingPlaceEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.inventory.BrewEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.inventory.BrewingStandFuelEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.inventory.ClickType.ts" />
|
||||
/// <reference path="./org.bukkit.event.inventory.CraftItemEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.inventory.DragType.ts" />
|
||||
/// <reference path="./org.bukkit.event.inventory.FurnaceBurnEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.inventory.FurnaceExtractEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.inventory.FurnaceSmeltEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.inventory.InventoryAction.ts" />
|
||||
/// <reference path="./org.bukkit.event.inventory.InventoryClickEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.inventory.InventoryCloseEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.inventory.InventoryCreativeEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.inventory.InventoryDragEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.inventory.InventoryEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.inventory.InventoryInteractEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.inventory.InventoryMoveItemEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.inventory.InventoryOpenEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.inventory.InventoryPickupItemEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.inventory.InventoryType.SlotType.ts" />
|
||||
/// <reference path="./org.bukkit.event.inventory.InventoryType.ts" />
|
||||
/// <reference path="./org.bukkit.event.inventory.PrepareAnvilEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.inventory.PrepareItemCraftEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.inventory.TradeSelectEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.AsyncPlayerChatEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.AsyncPlayerPreLoginEvent.Result.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.AsyncPlayerPreLoginEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerAchievementAwardedEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerAdvancementDoneEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerAnimationEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerAnimationType.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerArmorStandManipulateEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerBedEnterEvent.BedEnterResult.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerBedEnterEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerBedLeaveEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerBucketEmptyEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerBucketEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerBucketFillEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerChangedMainHandEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerChangedWorldEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerChannelEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerChatEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerChatTabCompleteEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerCommandPreprocessEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerCommandSendEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerDropItemEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerEditBookEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerEggThrowEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerExpChangeEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerFishEvent.State.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerFishEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerGameModeChangeEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerInteractAtEntityEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerInteractEntityEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerInteractEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerItemBreakEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerItemConsumeEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerItemDamageEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerItemHeldEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerItemMendEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerJoinEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerKickEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerLevelChangeEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerLocaleChangeEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerLoginEvent.Result.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerLoginEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerMoveEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerPickupArrowEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerPickupItemEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerPortalEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerPreLoginEvent.Result.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerPreLoginEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerQuitEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerRecipeDiscoverEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerRegisterChannelEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerResourcePackStatusEvent.Status.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerResourcePackStatusEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerRespawnEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerRiptideEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerShearEntityEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerStatisticIncrementEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerSwapHandItemsEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerTakeLecternBookEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerTeleportEvent.TeleportCause.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerTeleportEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerToggleFlightEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerToggleSneakEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerToggleSprintEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerUnleashEntityEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerUnregisterChannelEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.player.PlayerVelocityEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.server.BroadcastMessageEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.server.MapInitializeEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.server.PluginDisableEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.server.PluginEnableEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.server.PluginEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.server.RemoteServerCommandEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.server.ServerCommandEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.server.ServerEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.server.ServerListPingEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.server.ServerLoadEvent.LoadType.ts" />
|
||||
/// <reference path="./org.bukkit.event.server.ServerLoadEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.server.ServiceEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.server.ServiceRegisterEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.server.ServiceUnregisterEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.server.TabCompleteEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.vehicle.VehicleBlockCollisionEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.vehicle.VehicleCollisionEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.vehicle.VehicleCreateEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.vehicle.VehicleDamageEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.vehicle.VehicleDestroyEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.vehicle.VehicleEnterEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.vehicle.VehicleEntityCollisionEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.vehicle.VehicleEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.vehicle.VehicleExitEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.vehicle.VehicleMoveEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.vehicle.VehicleUpdateEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.weather.LightningStrikeEvent.Cause.ts" />
|
||||
/// <reference path="./org.bukkit.event.weather.LightningStrikeEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.weather.ThunderChangeEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.weather.WeatherChangeEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.weather.WeatherEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.world.ChunkEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.world.ChunkLoadEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.world.ChunkPopulateEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.world.ChunkUnloadEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.world.PortalCreateEvent.CreateReason.ts" />
|
||||
/// <reference path="./org.bukkit.event.world.PortalCreateEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.world.SpawnChangeEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.world.StructureGrowEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.world.WorldEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.world.WorldInitEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.world.WorldLoadEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.world.WorldSaveEvent.ts" />
|
||||
/// <reference path="./org.bukkit.event.world.WorldUnloadEvent.ts" />
|
||||
/// <reference path="./org.bukkit.generator.BlockPopulator.ts" />
|
||||
/// <reference path="./org.bukkit.generator.ChunkGenerator.BiomeGrid.ts" />
|
||||
/// <reference path="./org.bukkit.generator.ChunkGenerator.ChunkData.ts" />
|
||||
/// <reference path="./org.bukkit.generator.ChunkGenerator.ts" />
|
||||
/// <reference path="./org.bukkit.help.GenericCommandHelpTopic.ts" />
|
||||
/// <reference path="./org.bukkit.help.HelpMap.ts" />
|
||||
/// <reference path="./org.bukkit.help.HelpTopic.ts" />
|
||||
/// <reference path="./org.bukkit.help.HelpTopicComparator.TopicNameComparator.ts" />
|
||||
/// <reference path="./org.bukkit.help.HelpTopicComparator.ts" />
|
||||
/// <reference path="./org.bukkit.help.HelpTopicFactory.ts" />
|
||||
/// <reference path="./org.bukkit.help.IndexHelpTopic.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.AbstractHorseInventory.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.AnvilInventory.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.BeaconInventory.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.BlastingRecipe.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.BlockInventoryHolder.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.BrewerInventory.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.CampfireRecipe.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.CartographyInventory.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.CookingRecipe.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.CraftingInventory.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.DoubleChestInventory.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.EnchantingInventory.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.EntityEquipment.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.EquipmentSlot.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.FurnaceInventory.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.FurnaceRecipe.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.GrindstoneInventory.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.HorseInventory.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.Inventory.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.InventoryHolder.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.InventoryView.Property.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.InventoryView.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.ItemFactory.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.ItemFlag.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.ItemStack.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.LecternInventory.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.LlamaInventory.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.LoomInventory.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.MainHand.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.Merchant.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.MerchantInventory.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.MerchantRecipe.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.PlayerInventory.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.Recipe.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.RecipeChoice.ExactChoice.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.RecipeChoice.MaterialChoice.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.RecipeChoice.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.ShapedRecipe.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.ShapelessRecipe.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.SmokingRecipe.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.StonecutterInventory.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.StonecuttingRecipe.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.meta.BannerMeta.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.meta.BlockDataMeta.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.meta.BlockStateMeta.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.meta.BookMeta.Generation.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.meta.BookMeta.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.meta.CrossbowMeta.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.meta.Damageable.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.meta.EnchantmentStorageMeta.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.meta.FireworkEffectMeta.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.meta.FireworkMeta.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.meta.ItemMeta.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.meta.KnowledgeBookMeta.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.meta.LeatherArmorMeta.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.meta.MapMeta.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.meta.PotionMeta.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.meta.Repairable.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.meta.SkullMeta.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.meta.SpawnEggMeta.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.meta.TropicalFishBucketMeta.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.meta.tags.CustomItemTagContainer.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.meta.tags.ItemTagAdapterContext.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.meta.tags.ItemTagType.PrimitiveTagType.ts" />
|
||||
/// <reference path="./org.bukkit.inventory.meta.tags.ItemTagType.ts" />
|
||||
/// <reference path="./org.bukkit.loot.LootContext.Builder.ts" />
|
||||
/// <reference path="./org.bukkit.loot.LootContext.ts" />
|
||||
/// <reference path="./org.bukkit.loot.LootTable.ts" />
|
||||
/// <reference path="./org.bukkit.loot.LootTables.ts" />
|
||||
/// <reference path="./org.bukkit.loot.Lootable.ts" />
|
||||
/// <reference path="./org.bukkit.map.MapCanvas.ts" />
|
||||
/// <reference path="./org.bukkit.map.MapCursor.Type.ts" />
|
||||
/// <reference path="./org.bukkit.map.MapCursor.ts" />
|
||||
/// <reference path="./org.bukkit.map.MapCursorCollection.ts" />
|
||||
/// <reference path="./org.bukkit.map.MapFont.CharacterSprite.ts" />
|
||||
/// <reference path="./org.bukkit.map.MapFont.ts" />
|
||||
/// <reference path="./org.bukkit.map.MapPalette.ts" />
|
||||
/// <reference path="./org.bukkit.map.MapRenderer.ts" />
|
||||
/// <reference path="./org.bukkit.map.MapView.Scale.ts" />
|
||||
/// <reference path="./org.bukkit.map.MapView.ts" />
|
||||
/// <reference path="./org.bukkit.map.MinecraftFont.ts" />
|
||||
/// <reference path="./org.bukkit.material.Attachable.ts" />
|
||||
/// <reference path="./org.bukkit.material.Banner.ts" />
|
||||
/// <reference path="./org.bukkit.material.Bed.ts" />
|
||||
/// <reference path="./org.bukkit.material.Button.ts" />
|
||||
/// <reference path="./org.bukkit.material.Cake.ts" />
|
||||
/// <reference path="./org.bukkit.material.Cauldron.ts" />
|
||||
/// <reference path="./org.bukkit.material.Chest.ts" />
|
||||
/// <reference path="./org.bukkit.material.Coal.ts" />
|
||||
/// <reference path="./org.bukkit.material.CocoaPlant.CocoaPlantSize.ts" />
|
||||
/// <reference path="./org.bukkit.material.CocoaPlant.ts" />
|
||||
/// <reference path="./org.bukkit.material.Colorable.ts" />
|
||||
/// <reference path="./org.bukkit.material.Command.ts" />
|
||||
/// <reference path="./org.bukkit.material.Comparator.ts" />
|
||||
/// <reference path="./org.bukkit.material.Crops.ts" />
|
||||
/// <reference path="./org.bukkit.material.DetectorRail.ts" />
|
||||
/// <reference path="./org.bukkit.material.Diode.ts" />
|
||||
/// <reference path="./org.bukkit.material.Directional.ts" />
|
||||
/// <reference path="./org.bukkit.material.DirectionalContainer.ts" />
|
||||
/// <reference path="./org.bukkit.material.Dispenser.ts" />
|
||||
/// <reference path="./org.bukkit.material.Door.ts" />
|
||||
/// <reference path="./org.bukkit.material.Dye.ts" />
|
||||
/// <reference path="./org.bukkit.material.EnderChest.ts" />
|
||||
/// <reference path="./org.bukkit.material.ExtendedRails.ts" />
|
||||
/// <reference path="./org.bukkit.material.FlowerPot.ts" />
|
||||
/// <reference path="./org.bukkit.material.Furnace.ts" />
|
||||
/// <reference path="./org.bukkit.material.FurnaceAndDispenser.ts" />
|
||||
/// <reference path="./org.bukkit.material.Gate.ts" />
|
||||
/// <reference path="./org.bukkit.material.Hopper.ts" />
|
||||
/// <reference path="./org.bukkit.material.Ladder.ts" />
|
||||
/// <reference path="./org.bukkit.material.Leaves.ts" />
|
||||
/// <reference path="./org.bukkit.material.Lever.ts" />
|
||||
/// <reference path="./org.bukkit.material.LongGrass.ts" />
|
||||
/// <reference path="./org.bukkit.material.MaterialData.ts" />
|
||||
/// <reference path="./org.bukkit.material.MonsterEggs.ts" />
|
||||
/// <reference path="./org.bukkit.material.Mushroom.ts" />
|
||||
/// <reference path="./org.bukkit.material.NetherWarts.ts" />
|
||||
/// <reference path="./org.bukkit.material.Observer.ts" />
|
||||
/// <reference path="./org.bukkit.material.Openable.ts" />
|
||||
/// <reference path="./org.bukkit.material.PistonBaseMaterial.ts" />
|
||||
/// <reference path="./org.bukkit.material.PistonExtensionMaterial.ts" />
|
||||
/// <reference path="./org.bukkit.material.PoweredRail.ts" />
|
||||
/// <reference path="./org.bukkit.material.PressurePlate.ts" />
|
||||
/// <reference path="./org.bukkit.material.PressureSensor.ts" />
|
||||
/// <reference path="./org.bukkit.material.Pumpkin.ts" />
|
||||
/// <reference path="./org.bukkit.material.Rails.ts" />
|
||||
/// <reference path="./org.bukkit.material.Redstone.ts" />
|
||||
/// <reference path="./org.bukkit.material.RedstoneTorch.ts" />
|
||||
/// <reference path="./org.bukkit.material.RedstoneWire.ts" />
|
||||
/// <reference path="./org.bukkit.material.Sandstone.ts" />
|
||||
/// <reference path="./org.bukkit.material.Sapling.ts" />
|
||||
/// <reference path="./org.bukkit.material.Sign.ts" />
|
||||
/// <reference path="./org.bukkit.material.SimpleAttachableMaterialData.ts" />
|
||||
/// <reference path="./org.bukkit.material.Skull.ts" />
|
||||
/// <reference path="./org.bukkit.material.SmoothBrick.ts" />
|
||||
/// <reference path="./org.bukkit.material.SpawnEgg.ts" />
|
||||
/// <reference path="./org.bukkit.material.Stairs.ts" />
|
||||
/// <reference path="./org.bukkit.material.Step.ts" />
|
||||
/// <reference path="./org.bukkit.material.TexturedMaterial.ts" />
|
||||
/// <reference path="./org.bukkit.material.Torch.ts" />
|
||||
/// <reference path="./org.bukkit.material.TrapDoor.ts" />
|
||||
/// <reference path="./org.bukkit.material.Tree.ts" />
|
||||
/// <reference path="./org.bukkit.material.Tripwire.ts" />
|
||||
/// <reference path="./org.bukkit.material.TripwireHook.ts" />
|
||||
/// <reference path="./org.bukkit.material.Vine.ts" />
|
||||
/// <reference path="./org.bukkit.material.Wood.ts" />
|
||||
/// <reference path="./org.bukkit.material.WoodenStep.ts" />
|
||||
/// <reference path="./org.bukkit.material.Wool.ts" />
|
||||
/// <reference path="./org.bukkit.material.types.MushroomBlockTexture.ts" />
|
||||
/// <reference path="./org.bukkit.metadata.FixedMetadataValue.ts" />
|
||||
/// <reference path="./org.bukkit.metadata.LazyMetadataValue.CacheStrategy.ts" />
|
||||
/// <reference path="./org.bukkit.metadata.LazyMetadataValue.ts" />
|
||||
/// <reference path="./org.bukkit.metadata.MetadataConversionException.ts" />
|
||||
/// <reference path="./org.bukkit.metadata.MetadataEvaluationException.ts" />
|
||||
/// <reference path="./org.bukkit.metadata.MetadataStore.ts" />
|
||||
/// <reference path="./org.bukkit.metadata.MetadataStoreBase.ts" />
|
||||
/// <reference path="./org.bukkit.metadata.MetadataValue.ts" />
|
||||
/// <reference path="./org.bukkit.metadata.MetadataValueAdapter.ts" />
|
||||
/// <reference path="./org.bukkit.metadata.Metadatable.ts" />
|
||||
/// <reference path="./org.bukkit.permissions.Permissible.ts" />
|
||||
/// <reference path="./org.bukkit.permissions.PermissibleBase.ts" />
|
||||
/// <reference path="./org.bukkit.permissions.Permission.ts" />
|
||||
/// <reference path="./org.bukkit.permissions.PermissionAttachment.ts" />
|
||||
/// <reference path="./org.bukkit.permissions.PermissionAttachmentInfo.ts" />
|
||||
/// <reference path="./org.bukkit.permissions.PermissionDefault.ts" />
|
||||
/// <reference path="./org.bukkit.permissions.PermissionRemovedExecutor.ts" />
|
||||
/// <reference path="./org.bukkit.permissions.ServerOperator.ts" />
|
||||
/// <reference path="./org.bukkit.persistence.PersistentDataAdapterContext.ts" />
|
||||
/// <reference path="./org.bukkit.persistence.PersistentDataContainer.ts" />
|
||||
/// <reference path="./org.bukkit.persistence.PersistentDataHolder.ts" />
|
||||
/// <reference path="./org.bukkit.persistence.PersistentDataType.PrimitivePersistentDataType.ts" />
|
||||
/// <reference path="./org.bukkit.persistence.PersistentDataType.ts" />
|
||||
/// <reference path="./org.bukkit.plugin.AuthorNagException.ts" />
|
||||
/// <reference path="./org.bukkit.plugin.EventExecutor.ts" />
|
||||
/// <reference path="./org.bukkit.plugin.IllegalPluginAccessException.ts" />
|
||||
/// <reference path="./org.bukkit.plugin.InvalidDescriptionException.ts" />
|
||||
/// <reference path="./org.bukkit.plugin.InvalidPluginException.ts" />
|
||||
/// <reference path="./org.bukkit.plugin.Plugin.ts" />
|
||||
/// <reference path="./org.bukkit.plugin.PluginAwareness.Flags.ts" />
|
||||
/// <reference path="./org.bukkit.plugin.PluginAwareness.ts" />
|
||||
/// <reference path="./org.bukkit.plugin.PluginBase.ts" />
|
||||
/// <reference path="./org.bukkit.plugin.PluginDescriptionFile.ts" />
|
||||
/// <reference path="./org.bukkit.plugin.PluginLoadOrder.ts" />
|
||||
/// <reference path="./org.bukkit.plugin.PluginLoader.ts" />
|
||||
/// <reference path="./org.bukkit.plugin.PluginLogger.ts" />
|
||||
/// <reference path="./org.bukkit.plugin.PluginManager.ts" />
|
||||
/// <reference path="./org.bukkit.plugin.RegisteredListener.ts" />
|
||||
/// <reference path="./org.bukkit.plugin.RegisteredServiceProvider.ts" />
|
||||
/// <reference path="./org.bukkit.plugin.ServicePriority.ts" />
|
||||
/// <reference path="./org.bukkit.plugin.ServicesManager.ts" />
|
||||
/// <reference path="./org.bukkit.plugin.SimplePluginManager.ts" />
|
||||
/// <reference path="./org.bukkit.plugin.SimpleServicesManager.ts" />
|
||||
/// <reference path="./org.bukkit.plugin.TimedRegisteredListener.ts" />
|
||||
/// <reference path="./org.bukkit.plugin.UnknownDependencyException.ts" />
|
||||
/// <reference path="./org.bukkit.plugin.java.JavaPlugin.ts" />
|
||||
/// <reference path="./org.bukkit.plugin.java.JavaPluginLoader.ts" />
|
||||
/// <reference path="./org.bukkit.plugin.messaging.ChannelNameTooLongException.ts" />
|
||||
/// <reference path="./org.bukkit.plugin.messaging.ChannelNotRegisteredException.ts" />
|
||||
/// <reference path="./org.bukkit.plugin.messaging.MessageTooLargeException.ts" />
|
||||
/// <reference path="./org.bukkit.plugin.messaging.Messenger.ts" />
|
||||
/// <reference path="./org.bukkit.plugin.messaging.PluginChannelDirection.ts" />
|
||||
/// <reference path="./org.bukkit.plugin.messaging.PluginMessageListener.ts" />
|
||||
/// <reference path="./org.bukkit.plugin.messaging.PluginMessageListenerRegistration.ts" />
|
||||
/// <reference path="./org.bukkit.plugin.messaging.PluginMessageRecipient.ts" />
|
||||
/// <reference path="./org.bukkit.plugin.messaging.ReservedChannelException.ts" />
|
||||
/// <reference path="./org.bukkit.plugin.messaging.StandardMessenger.ts" />
|
||||
/// <reference path="./org.bukkit.potion.Potion.ts" />
|
||||
/// <reference path="./org.bukkit.potion.PotionBrewer.ts" />
|
||||
/// <reference path="./org.bukkit.potion.PotionData.ts" />
|
||||
/// <reference path="./org.bukkit.potion.PotionEffect.ts" />
|
||||
/// <reference path="./org.bukkit.potion.PotionEffectType.ts" />
|
||||
/// <reference path="./org.bukkit.potion.PotionEffectTypeWrapper.ts" />
|
||||
/// <reference path="./org.bukkit.potion.PotionType.ts" />
|
||||
/// <reference path="./org.bukkit.projectiles.BlockProjectileSource.ts" />
|
||||
/// <reference path="./org.bukkit.projectiles.ProjectileSource.ts" />
|
||||
/// <reference path="./org.bukkit.scheduler.BukkitRunnable.ts" />
|
||||
/// <reference path="./org.bukkit.scheduler.BukkitScheduler.ts" />
|
||||
/// <reference path="./org.bukkit.scheduler.BukkitTask.ts" />
|
||||
/// <reference path="./org.bukkit.scheduler.BukkitWorker.ts" />
|
||||
/// <reference path="./org.bukkit.scoreboard.Criterias.ts" />
|
||||
/// <reference path="./org.bukkit.scoreboard.DisplaySlot.ts" />
|
||||
/// <reference path="./org.bukkit.scoreboard.NameTagVisibility.ts" />
|
||||
/// <reference path="./org.bukkit.scoreboard.Objective.ts" />
|
||||
/// <reference path="./org.bukkit.scoreboard.RenderType.ts" />
|
||||
/// <reference path="./org.bukkit.scoreboard.Score.ts" />
|
||||
/// <reference path="./org.bukkit.scoreboard.Scoreboard.ts" />
|
||||
/// <reference path="./org.bukkit.scoreboard.ScoreboardManager.ts" />
|
||||
/// <reference path="./org.bukkit.scoreboard.Team.Option.ts" />
|
||||
/// <reference path="./org.bukkit.scoreboard.Team.OptionStatus.ts" />
|
||||
/// <reference path="./org.bukkit.scoreboard.Team.ts" />
|
||||
/// <reference path="./org.bukkit.util.BlockIterator.ts" />
|
||||
/// <reference path="./org.bukkit.util.BlockVector.ts" />
|
||||
/// <reference path="./org.bukkit.util.BoundingBox.ts" />
|
||||
/// <reference path="./org.bukkit.util.CachedServerIcon.ts" />
|
||||
/// <reference path="./org.bukkit.util.ChatPaginator.ChatPage.ts" />
|
||||
/// <reference path="./org.bukkit.util.ChatPaginator.ts" />
|
||||
/// <reference path="./org.bukkit.util.Consumer.ts" />
|
||||
/// <reference path="./org.bukkit.util.EulerAngle.ts" />
|
||||
/// <reference path="./org.bukkit.util.FileUtil.ts" />
|
||||
/// <reference path="./org.bukkit.util.NumberConversions.ts" />
|
||||
/// <reference path="./org.bukkit.util.RayTraceResult.ts" />
|
||||
/// <reference path="./org.bukkit.util.StringUtil.ts" />
|
||||
/// <reference path="./org.bukkit.util.Vector.ts" />
|
||||
/// <reference path="./org.bukkit.util.io.BukkitObjectInputStream.ts" />
|
||||
/// <reference path="./org.bukkit.util.io.BukkitObjectOutputStream.ts" />
|
||||
/// <reference path="./org.bukkit.util.noise.NoiseGenerator.ts" />
|
||||
/// <reference path="./org.bukkit.util.noise.OctaveGenerator.ts" />
|
||||
/// <reference path="./org.bukkit.util.noise.PerlinNoiseGenerator.ts" />
|
||||
/// <reference path="./org.bukkit.util.noise.PerlinOctaveGenerator.ts" />
|
||||
/// <reference path="./org.bukkit.util.noise.SimplexNoiseGenerator.ts" />
|
||||
/// <reference path="./org.bukkit.util.noise.SimplexOctaveGenerator.ts" />
|
||||
/// <reference path="./org.bukkit.util.permissions.BroadcastPermissions.ts" />
|
||||
/// <reference path="./org.bukkit.util.permissions.CommandPermissions.ts" />
|
||||
/// <reference path="./org.bukkit.util.permissions.DefaultPermissions.ts" />
|
||||
@@ -1,50 +0,0 @@
|
||||
declare namespace org {
|
||||
namespace bukkit {
|
||||
class Achievement {
|
||||
public static OPEN_INVENTORY: org.bukkit.Achievement;
|
||||
public static MINE_WOOD: org.bukkit.Achievement;
|
||||
public static BUILD_WORKBENCH: org.bukkit.Achievement;
|
||||
public static BUILD_PICKAXE: org.bukkit.Achievement;
|
||||
public static BUILD_FURNACE: org.bukkit.Achievement;
|
||||
public static ACQUIRE_IRON: org.bukkit.Achievement;
|
||||
public static BUILD_HOE: org.bukkit.Achievement;
|
||||
public static MAKE_BREAD: org.bukkit.Achievement;
|
||||
public static BAKE_CAKE: org.bukkit.Achievement;
|
||||
public static BUILD_BETTER_PICKAXE: org.bukkit.Achievement;
|
||||
public static COOK_FISH: org.bukkit.Achievement;
|
||||
public static ON_A_RAIL: org.bukkit.Achievement;
|
||||
public static BUILD_SWORD: org.bukkit.Achievement;
|
||||
public static KILL_ENEMY: org.bukkit.Achievement;
|
||||
public static KILL_COW: org.bukkit.Achievement;
|
||||
public static FLY_PIG: org.bukkit.Achievement;
|
||||
public static SNIPE_SKELETON: org.bukkit.Achievement;
|
||||
public static GET_DIAMONDS: org.bukkit.Achievement;
|
||||
public static NETHER_PORTAL: org.bukkit.Achievement;
|
||||
public static GHAST_RETURN: org.bukkit.Achievement;
|
||||
public static GET_BLAZE_ROD: org.bukkit.Achievement;
|
||||
public static BREW_POTION: org.bukkit.Achievement;
|
||||
public static END_PORTAL: org.bukkit.Achievement;
|
||||
public static THE_END: org.bukkit.Achievement;
|
||||
public static ENCHANTMENTS: org.bukkit.Achievement;
|
||||
public static OVERKILL: org.bukkit.Achievement;
|
||||
public static BOOKCASE: org.bukkit.Achievement;
|
||||
public static EXPLORE_ALL_BIOMES: org.bukkit.Achievement;
|
||||
public static SPAWN_WITHER: org.bukkit.Achievement;
|
||||
public static KILL_WITHER: org.bukkit.Achievement;
|
||||
public static FULL_BEACON: org.bukkit.Achievement;
|
||||
public static BREED_COW: org.bukkit.Achievement;
|
||||
public static DIAMONDS_TO_YOU: org.bukkit.Achievement;
|
||||
public static OVERPOWERED: org.bukkit.Achievement;
|
||||
public static values(): org.bukkit.Achievement[];
|
||||
public static valueOf(name: string): org.bukkit.Achievement;
|
||||
/**
|
||||
* Returns whether or not this achievement has a parent achievement.
|
||||
*/
|
||||
public hasParent(): boolean;
|
||||
/**
|
||||
* Returns the parent achievement of this achievement, or null if none.
|
||||
*/
|
||||
public getParent(): org.bukkit.Achievement;
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,57 +0,0 @@
|
||||
declare namespace org {
|
||||
namespace bukkit {
|
||||
class Art {
|
||||
public static KEBAB: org.bukkit.Art;
|
||||
public static AZTEC: org.bukkit.Art;
|
||||
public static ALBAN: org.bukkit.Art;
|
||||
public static AZTEC2: org.bukkit.Art;
|
||||
public static BOMB: org.bukkit.Art;
|
||||
public static PLANT: org.bukkit.Art;
|
||||
public static WASTELAND: org.bukkit.Art;
|
||||
public static POOL: org.bukkit.Art;
|
||||
public static COURBET: org.bukkit.Art;
|
||||
public static SEA: org.bukkit.Art;
|
||||
public static SUNSET: org.bukkit.Art;
|
||||
public static CREEBET: org.bukkit.Art;
|
||||
public static WANDERER: org.bukkit.Art;
|
||||
public static GRAHAM: org.bukkit.Art;
|
||||
public static MATCH: org.bukkit.Art;
|
||||
public static BUST: org.bukkit.Art;
|
||||
public static STAGE: org.bukkit.Art;
|
||||
public static VOID: org.bukkit.Art;
|
||||
public static SKULL_AND_ROSES: org.bukkit.Art;
|
||||
public static WITHER: org.bukkit.Art;
|
||||
public static FIGHTERS: org.bukkit.Art;
|
||||
public static POINTER: org.bukkit.Art;
|
||||
public static PIGSCENE: org.bukkit.Art;
|
||||
public static BURNING_SKULL: org.bukkit.Art;
|
||||
public static SKELETON: org.bukkit.Art;
|
||||
public static DONKEY_KONG: org.bukkit.Art;
|
||||
public static values(): org.bukkit.Art[];
|
||||
public static valueOf(name: string): org.bukkit.Art;
|
||||
/**
|
||||
* Gets the width of the painting, in blocks
|
||||
*/
|
||||
public getBlockWidth(): number;
|
||||
/**
|
||||
* Gets the height of the painting, in blocks
|
||||
*/
|
||||
public getBlockHeight(): number;
|
||||
/**
|
||||
* Get the ID of this painting.
|
||||
*/
|
||||
public getId(): number;
|
||||
public getKey(): org.bukkit.NamespacedKey;
|
||||
/**
|
||||
* Get a painting by its numeric ID
|
||||
*/
|
||||
public static getById(id: number): org.bukkit.Art;
|
||||
/**
|
||||
* Get a painting by its unique name
|
||||
* <p>
|
||||
* This ignores underscores and capitalization
|
||||
*/
|
||||
public static getByName(name: string): org.bukkit.Art;
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,11 +0,0 @@
|
||||
declare namespace org {
|
||||
namespace bukkit {
|
||||
class Axis {
|
||||
public static X: org.bukkit.Axis;
|
||||
public static Y: org.bukkit.Axis;
|
||||
public static Z: org.bukkit.Axis;
|
||||
public static values(): org.bukkit.Axis[];
|
||||
public static valueOf(name: string): org.bukkit.Axis;
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,57 +0,0 @@
|
||||
declare namespace org {
|
||||
namespace bukkit {
|
||||
class BanEntry {
|
||||
/**
|
||||
* Gets the target involved. This may be in the form of an IP or a player
|
||||
* name.
|
||||
*/
|
||||
public getTarget(): string;
|
||||
/**
|
||||
* Gets the date this ban entry was created.
|
||||
*/
|
||||
public getCreated(): any /*java.util.Date*/;
|
||||
/**
|
||||
* Sets the date this ban entry was created.
|
||||
*/
|
||||
public setCreated(created: any /*java.util.Date*/): void;
|
||||
/**
|
||||
* Gets the source of this ban.
|
||||
* <p>
|
||||
* Note: A source is considered any String, although this is generally a
|
||||
* player name.
|
||||
*/
|
||||
public getSource(): string;
|
||||
/**
|
||||
* Sets the source of this ban.
|
||||
* <p>
|
||||
* Note: A source is considered any String, although this is generally a
|
||||
* player name.
|
||||
*/
|
||||
public setSource(source: string): void;
|
||||
/**
|
||||
* Gets the date this ban expires on, or null for no defined end date.
|
||||
*/
|
||||
public getExpiration(): any /*java.util.Date*/;
|
||||
/**
|
||||
* Sets the date this ban expires on. Null values are considered
|
||||
* "infinite" bans.
|
||||
*/
|
||||
public setExpiration(expiration: any /*java.util.Date*/): void;
|
||||
/**
|
||||
* Gets the reason for this ban.
|
||||
*/
|
||||
public getReason(): string;
|
||||
/**
|
||||
* Sets the reason for this ban. Reasons must not be null.
|
||||
*/
|
||||
public setReason(reason: string): void;
|
||||
/**
|
||||
* Saves the ban entry, overwriting any previous data in the ban list.
|
||||
* <p>
|
||||
* Saving the ban entry of an unbanned player will cause the player to be
|
||||
* banned once again.
|
||||
*/
|
||||
public save(): void;
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,12 +0,0 @@
|
||||
declare namespace org {
|
||||
namespace bukkit {
|
||||
namespace BanList {
|
||||
class Type {
|
||||
public static NAME: org.bukkit.BanList.Type;
|
||||
public static IP: org.bukkit.BanList.Type;
|
||||
public static values(): org.bukkit.BanList.Type[];
|
||||
public static valueOf(name: string): org.bukkit.BanList.Type;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,29 +0,0 @@
|
||||
declare namespace org {
|
||||
namespace bukkit {
|
||||
class BanList {
|
||||
/**
|
||||
* Gets a {@link BanEntry} by target.
|
||||
*/
|
||||
public getBanEntry(target: string): org.bukkit.BanEntry;
|
||||
/**
|
||||
* Adds a ban to the this list. If a previous ban exists, this will
|
||||
* update the previous entry.
|
||||
*/
|
||||
public addBan(target: string, reason: string, expires: any /*java.util.Date*/, source: string): org.bukkit.BanEntry;
|
||||
/**
|
||||
* Gets a set containing every {@link BanEntry} in this list.
|
||||
*/
|
||||
public getBanEntries(): any[] /*java.util.Set*/;
|
||||
/**
|
||||
* Gets if a {@link BanEntry} exists for the target, indicating an active
|
||||
* ban status.
|
||||
*/
|
||||
public isBanned(target: string): boolean;
|
||||
/**
|
||||
* Removes the specified target from this list, therefore indicating a
|
||||
* "not banned" status.
|
||||
*/
|
||||
public pardon(target: string): void;
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,22 +0,0 @@
|
||||
declare namespace org {
|
||||
namespace bukkit {
|
||||
class BlockChangeDelegate {
|
||||
/**
|
||||
* Set a block data at the specified coordinates.
|
||||
*/
|
||||
public setBlockData(x: number, y: number, z: number, blockData: org.bukkit.block.data.BlockData): boolean;
|
||||
/**
|
||||
* Get the block data at the location.
|
||||
*/
|
||||
public getBlockData(x: number, y: number, z: number): org.bukkit.block.data.BlockData;
|
||||
/**
|
||||
* Gets the height of the world.
|
||||
*/
|
||||
public getHeight(): number;
|
||||
/**
|
||||
* Checks if the specified block is empty (air) or not.
|
||||
*/
|
||||
public isEmpty(x: number, y: number, z: number): boolean;
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,657 +0,0 @@
|
||||
declare namespace org {
|
||||
namespace bukkit {
|
||||
class Bukkit {
|
||||
/**
|
||||
* Gets the current {@link Server} singleton
|
||||
*/
|
||||
public static getServer(): org.bukkit.Server;
|
||||
/**
|
||||
* Attempts to set the {@link Server} singleton.
|
||||
* <p>
|
||||
* This cannot be done if the Server is already set.
|
||||
*/
|
||||
public static setServer(server: org.bukkit.Server): void;
|
||||
/**
|
||||
* Gets the name of this server implementation.
|
||||
*/
|
||||
public static getName(): string;
|
||||
/**
|
||||
* Gets the version string of this server implementation.
|
||||
*/
|
||||
public static getVersion(): string;
|
||||
/**
|
||||
* Gets the Bukkit version that this server is running.
|
||||
*/
|
||||
public static getBukkitVersion(): string;
|
||||
/**
|
||||
* Gets a view of all currently logged in players. This {@linkplain
|
||||
* Collections#unmodifiableCollection(Collection) view} is a reused
|
||||
* object, making some operations like {@link Collection#size()}
|
||||
* zero-allocation.
|
||||
* <p>
|
||||
* The collection is a view backed by the internal representation, such
|
||||
* that, changes to the internal state of the server will be reflected
|
||||
* immediately. However, the reuse of the returned collection (identity)
|
||||
* is not strictly guaranteed for future or all implementations. Casting
|
||||
* the collection, or relying on interface implementations (like {@link
|
||||
* Serializable} or {@link List}), is deprecated.
|
||||
* <p>
|
||||
* Iteration behavior is undefined outside of self-contained main-thread
|
||||
* uses. Normal and immediate iterator use without consequences that
|
||||
* affect the collection are fully supported. The effects following
|
||||
* (non-exhaustive) {@link Entity#teleport(Location) teleportation},
|
||||
* {@link Player#setHealth(double) death}, and {@link Player#kickPlayer(
|
||||
* String) kicking} are undefined. Any use of this collection from
|
||||
* asynchronous threads is unsafe.
|
||||
* <p>
|
||||
* For safe consequential iteration or mimicking the old array behavior,
|
||||
* using {@link Collection#toArray(Object[])} is recommended. For making
|
||||
* snapshots, {@link ImmutableList#copyOf(Collection)} is recommended.
|
||||
*/
|
||||
public static getOnlinePlayers(): any[] /*java.util.Collection*/;
|
||||
/**
|
||||
* Get the maximum amount of players which can login to this server.
|
||||
*/
|
||||
public static getMaxPlayers(): number;
|
||||
/**
|
||||
* Get the game port that the server runs on.
|
||||
*/
|
||||
public static getPort(): number;
|
||||
/**
|
||||
* Get the view distance from this server.
|
||||
*/
|
||||
public static getViewDistance(): number;
|
||||
/**
|
||||
* Get the IP that this server is bound to, or empty string if not
|
||||
* specified.
|
||||
*/
|
||||
public static getIp(): string;
|
||||
/**
|
||||
* Get world type (level-type setting) for default world.
|
||||
*/
|
||||
public static getWorldType(): string;
|
||||
/**
|
||||
* Get generate-structures setting.
|
||||
*/
|
||||
public static getGenerateStructures(): boolean;
|
||||
/**
|
||||
* Gets whether this server allows the End or not.
|
||||
*/
|
||||
public static getAllowEnd(): boolean;
|
||||
/**
|
||||
* Gets whether this server allows the Nether or not.
|
||||
*/
|
||||
public static getAllowNether(): boolean;
|
||||
/**
|
||||
* Gets whether this server has a whitelist or not.
|
||||
*/
|
||||
public static hasWhitelist(): boolean;
|
||||
/**
|
||||
* Sets if the server is whitelisted.
|
||||
*/
|
||||
public static setWhitelist(value: boolean): void;
|
||||
/**
|
||||
* Gets a list of whitelisted players.
|
||||
*/
|
||||
public static getWhitelistedPlayers(): any[] /*java.util.Set*/;
|
||||
/**
|
||||
* Reloads the whitelist from disk.
|
||||
*/
|
||||
public static reloadWhitelist(): void;
|
||||
/**
|
||||
* Broadcast a message to all players.
|
||||
* <p>
|
||||
* This is the same as calling {@link #broadcast(java.lang.String,
|
||||
* java.lang.String)} to {@link Server#BROADCAST_CHANNEL_USERS}
|
||||
*/
|
||||
public static broadcastMessage(message: string): number;
|
||||
/**
|
||||
* Gets the name of the update folder. The update folder is used to safely
|
||||
* update plugins at the right moment on a plugin load.
|
||||
* <p>
|
||||
* The update folder name is relative to the plugins folder.
|
||||
*/
|
||||
public static getUpdateFolder(): string;
|
||||
/**
|
||||
* Gets the update folder. The update folder is used to safely update
|
||||
* plugins at the right moment on a plugin load.
|
||||
*/
|
||||
public static getUpdateFolderFile(): any;
|
||||
/**
|
||||
* Gets the value of the connection throttle setting.
|
||||
*/
|
||||
public static getConnectionThrottle(): number;
|
||||
/**
|
||||
* Gets default ticks per animal spawns value.
|
||||
* <p>
|
||||
* <b>Example Usage:</b>
|
||||
* <ul>
|
||||
* <li>A value of 1 will mean the server will attempt to spawn monsters
|
||||
* every tick.
|
||||
* <li>A value of 400 will mean the server will attempt to spawn monsters
|
||||
* every 400th tick.
|
||||
* <li>A value below 0 will be reset back to Minecraft's default.
|
||||
* </ul>
|
||||
* <p>
|
||||
* <b>Note:</b> If set to 0, animal spawning will be disabled. We
|
||||
* recommend using spawn-animals to control this instead.
|
||||
* <p>
|
||||
* Minecraft default: 400.
|
||||
*/
|
||||
public static getTicksPerAnimalSpawns(): number;
|
||||
/**
|
||||
* Gets the default ticks per monster spawns value.
|
||||
* <p>
|
||||
* <b>Example Usage:</b>
|
||||
* <ul>
|
||||
* <li>A value of 1 will mean the server will attempt to spawn monsters
|
||||
* every tick.
|
||||
* <li>A value of 400 will mean the server will attempt to spawn monsters
|
||||
* every 400th tick.
|
||||
* <li>A value below 0 will be reset back to Minecraft's default.
|
||||
* </ul>
|
||||
* <p>
|
||||
* <b>Note:</b> If set to 0, monsters spawning will be disabled. We
|
||||
* recommend using spawn-monsters to control this instead.
|
||||
* <p>
|
||||
* Minecraft default: 1.
|
||||
*/
|
||||
public static getTicksPerMonsterSpawns(): number;
|
||||
/**
|
||||
* Gets a player object by the given username.
|
||||
* <p>
|
||||
* This method may not return objects for offline players.
|
||||
*/
|
||||
public static getPlayer(name: string): org.bukkit.entity.Player;
|
||||
/**
|
||||
* Gets the player with the exact given name, case insensitive.
|
||||
*/
|
||||
public static getPlayerExact(name: string): org.bukkit.entity.Player;
|
||||
/**
|
||||
* Attempts to match any players with the given name, and returns a list
|
||||
* of all possibly matches.
|
||||
* <p>
|
||||
* This list is not sorted in any particular order. If an exact match is
|
||||
* found, the returned list will only contain a single result.
|
||||
*/
|
||||
public static matchPlayer(name: string): any[] /*java.util.List*/;
|
||||
/**
|
||||
* Gets the player with the given UUID.
|
||||
*/
|
||||
public static getPlayer(id: any): org.bukkit.entity.Player;
|
||||
/**
|
||||
* Gets the plugin manager for interfacing with plugins.
|
||||
*/
|
||||
public static getPluginManager(): org.bukkit.plugin.PluginManager;
|
||||
/**
|
||||
* Gets the scheduler for managing scheduled events.
|
||||
*/
|
||||
public static getScheduler(): org.bukkit.scheduler.BukkitScheduler;
|
||||
/**
|
||||
* Gets a services manager.
|
||||
*/
|
||||
public static getServicesManager(): org.bukkit.plugin.ServicesManager;
|
||||
/**
|
||||
* Gets a list of all worlds on this server.
|
||||
*/
|
||||
public static getWorlds(): any[] /*java.util.List*/;
|
||||
/**
|
||||
* Creates or loads a world with the given name using the specified
|
||||
* options.
|
||||
* <p>
|
||||
* If the world is already loaded, it will just return the equivalent of
|
||||
* getWorld(creator.name()).
|
||||
*/
|
||||
public static createWorld(creator: org.bukkit.WorldCreator): org.bukkit.World;
|
||||
/**
|
||||
* Unloads a world with the given name.
|
||||
*/
|
||||
public static unloadWorld(name: string, save: boolean): boolean;
|
||||
/**
|
||||
* Unloads the given world.
|
||||
*/
|
||||
public static unloadWorld(world: org.bukkit.World, save: boolean): boolean;
|
||||
/**
|
||||
* Gets the world with the given name.
|
||||
*/
|
||||
public static getWorld(name: string): org.bukkit.World;
|
||||
/**
|
||||
* Gets the world from the given Unique ID.
|
||||
*/
|
||||
public static getWorld(uid: any): org.bukkit.World;
|
||||
/**
|
||||
* Gets the map from the given item ID.
|
||||
*/
|
||||
public static getMap(id: number): org.bukkit.map.MapView;
|
||||
/**
|
||||
* Create a new map with an automatically assigned ID.
|
||||
*/
|
||||
public static createMap(world: org.bukkit.World): org.bukkit.map.MapView;
|
||||
/**
|
||||
* Create a new explorer map targeting the closest nearby structure of a
|
||||
* given {@link StructureType}.
|
||||
* <br>
|
||||
* This method uses implementation default values for radius and
|
||||
* findUnexplored (usually 100, true).
|
||||
*/
|
||||
public static createExplorerMap(world: org.bukkit.World, location: org.bukkit.Location, structureType: org.bukkit.StructureType): org.bukkit.inventory.ItemStack;
|
||||
/**
|
||||
* Create a new explorer map targeting the closest nearby structure of a
|
||||
* given {@link StructureType}.
|
||||
* <br>
|
||||
* This method uses implementation default values for radius and
|
||||
* findUnexplored (usually 100, true).
|
||||
*/
|
||||
public static createExplorerMap(world: org.bukkit.World, location: org.bukkit.Location, structureType: org.bukkit.StructureType, radius: number, findUnexplored: boolean): org.bukkit.inventory.ItemStack;
|
||||
/**
|
||||
* Reloads the server, refreshing settings and plugin information.
|
||||
*/
|
||||
public static reload(): void;
|
||||
/**
|
||||
* Reload only the Minecraft data for the server. This includes custom
|
||||
* advancements and loot tables.
|
||||
*/
|
||||
public static reloadData(): void;
|
||||
/**
|
||||
* Returns the primary logger associated with this server instance.
|
||||
*/
|
||||
public static getLogger(): any;
|
||||
/**
|
||||
* Gets a {@link PluginCommand} with the given name or alias.
|
||||
*/
|
||||
public static getPluginCommand(name: string): org.bukkit.command.PluginCommand;
|
||||
/**
|
||||
* Writes loaded players to disk.
|
||||
*/
|
||||
public static savePlayers(): void;
|
||||
/**
|
||||
* Dispatches a command on this server, and executes it if found.
|
||||
*/
|
||||
public static dispatchCommand(sender: org.bukkit.command.CommandSender, commandLine: string): boolean;
|
||||
/**
|
||||
* Adds a recipe to the crafting manager.
|
||||
*/
|
||||
public static addRecipe(recipe: org.bukkit.inventory.Recipe): boolean;
|
||||
/**
|
||||
* Get a list of all recipes for a given item. The stack size is ignored
|
||||
* in comparisons. If the durability is -1, it will match any data value.
|
||||
*/
|
||||
public static getRecipesFor(result: org.bukkit.inventory.ItemStack): any[] /*java.util.List*/;
|
||||
/**
|
||||
* Get an iterator through the list of crafting recipes.
|
||||
*/
|
||||
public static recipeIterator(): any;
|
||||
/**
|
||||
* Clears the list of crafting recipes.
|
||||
*/
|
||||
public static clearRecipes(): void;
|
||||
/**
|
||||
* Resets the list of crafting recipes to the default.
|
||||
*/
|
||||
public static resetRecipes(): void;
|
||||
/**
|
||||
* Gets a list of command aliases defined in the server properties.
|
||||
*/
|
||||
public static getCommandAliases(): Map<any, any> /*java.util.Map*/;
|
||||
/**
|
||||
* Gets the radius, in blocks, around each worlds spawn point to protect.
|
||||
*/
|
||||
public static getSpawnRadius(): number;
|
||||
/**
|
||||
* Sets the radius, in blocks, around each worlds spawn point to protect.
|
||||
*/
|
||||
public static setSpawnRadius(value: number): void;
|
||||
/**
|
||||
* Gets whether the Server is in online mode or not.
|
||||
*/
|
||||
public static getOnlineMode(): boolean;
|
||||
/**
|
||||
* Gets whether this server allows flying or not.
|
||||
*/
|
||||
public static getAllowFlight(): boolean;
|
||||
/**
|
||||
* Gets whether the server is in hardcore mode or not.
|
||||
*/
|
||||
public static isHardcore(): boolean;
|
||||
/**
|
||||
* Shutdowns the server, stopping everything.
|
||||
*/
|
||||
public static shutdown(): void;
|
||||
/**
|
||||
* Broadcasts the specified message to every user with the given
|
||||
* permission name.
|
||||
*/
|
||||
public static broadcast(message: string, permission: string): number;
|
||||
/**
|
||||
* Gets the player by the given name, regardless if they are offline or
|
||||
* online.
|
||||
* <p>
|
||||
* This method may involve a blocking web request to get the UUID for the
|
||||
* given name.
|
||||
* <p>
|
||||
* This will return an object even if the player does not exist. To this
|
||||
* method, all players will exist.
|
||||
*/
|
||||
public static getOfflinePlayer(name: string): org.bukkit.OfflinePlayer;
|
||||
/**
|
||||
* Gets the player by the given UUID, regardless if they are offline or
|
||||
* online.
|
||||
* <p>
|
||||
* This will return an object even if the player does not exist. To this
|
||||
* method, all players will exist.
|
||||
*/
|
||||
public static getOfflinePlayer(id: any): org.bukkit.OfflinePlayer;
|
||||
/**
|
||||
* Gets a set containing all current IPs that are banned.
|
||||
*/
|
||||
public static getIPBans(): any[] /*java.util.Set*/;
|
||||
/**
|
||||
* Bans the specified address from the server.
|
||||
*/
|
||||
public static banIP(address: string): void;
|
||||
/**
|
||||
* Unbans the specified address from the server.
|
||||
*/
|
||||
public static unbanIP(address: string): void;
|
||||
/**
|
||||
* Gets a set containing all banned players.
|
||||
*/
|
||||
public static getBannedPlayers(): any[] /*java.util.Set*/;
|
||||
/**
|
||||
* Gets a ban list for the supplied type.
|
||||
* <p>
|
||||
* Bans by name are no longer supported and this method will return
|
||||
* null when trying to request them. The replacement is bans by UUID.
|
||||
*/
|
||||
public static getBanList(type: org.bukkit.BanList.Type): org.bukkit.BanList;
|
||||
/**
|
||||
* Gets a set containing all player operators.
|
||||
*/
|
||||
public static getOperators(): any[] /*java.util.Set*/;
|
||||
/**
|
||||
* Gets the default {@link GameMode} for new players.
|
||||
*/
|
||||
public static getDefaultGameMode(): org.bukkit.GameMode;
|
||||
/**
|
||||
* Sets the default {@link GameMode} for new players.
|
||||
*/
|
||||
public static setDefaultGameMode(mode: org.bukkit.GameMode): void;
|
||||
/**
|
||||
* Gets a {@link ConsoleCommandSender} that may be used as an input source
|
||||
* for this server.
|
||||
*/
|
||||
public static getConsoleSender(): org.bukkit.command.ConsoleCommandSender;
|
||||
/**
|
||||
* Gets the folder that contains all of the various {@link World}s.
|
||||
*/
|
||||
public static getWorldContainer(): any;
|
||||
/**
|
||||
* Gets every player that has ever played on this server.
|
||||
*/
|
||||
public static getOfflinePlayers(): org.bukkit.OfflinePlayer[];
|
||||
/**
|
||||
* Gets the {@link Messenger} responsible for this server.
|
||||
*/
|
||||
public static getMessenger(): org.bukkit.plugin.messaging.Messenger;
|
||||
/**
|
||||
* Gets the {@link HelpMap} providing help topics for this server.
|
||||
*/
|
||||
public static getHelpMap(): org.bukkit.help.HelpMap;
|
||||
/**
|
||||
* Creates an empty inventory with the specified type. If the type
|
||||
* is {@link InventoryType#CHEST}, the new inventory has a size of 27;
|
||||
* otherwise the new inventory has the normal size for its type.
|
||||
* <br>
|
||||
* {@link InventoryType#WORKBENCH} will not process crafting recipes if
|
||||
* created with this method. Use
|
||||
* {@link Player#openWorkbench(Location, boolean)} instead.
|
||||
* <br>
|
||||
* {@link InventoryType#ENCHANTING} will not process {@link ItemStack}s
|
||||
* for possible enchanting results. Use
|
||||
* {@link Player#openEnchanting(Location, boolean)} instead.
|
||||
*/
|
||||
public static createInventory(owner: org.bukkit.inventory.InventoryHolder, type: org.bukkit.event.inventory.InventoryType): org.bukkit.inventory.Inventory;
|
||||
/**
|
||||
* Creates an empty inventory with the specified type and title. If the type
|
||||
* is {@link InventoryType#CHEST}, the new inventory has a size of 27;
|
||||
* otherwise the new inventory has the normal size for its type.<br>
|
||||
* It should be noted that some inventory types do not support titles and
|
||||
* may not render with said titles on the Minecraft client.
|
||||
* <br>
|
||||
* {@link InventoryType#WORKBENCH} will not process crafting recipes if
|
||||
* created with this method. Use
|
||||
* {@link Player#openWorkbench(Location, boolean)} instead.
|
||||
* <br>
|
||||
* {@link InventoryType#ENCHANTING} will not process {@link ItemStack}s
|
||||
* for possible enchanting results. Use
|
||||
* {@link Player#openEnchanting(Location, boolean)} instead.
|
||||
*/
|
||||
public static createInventory(owner: org.bukkit.inventory.InventoryHolder, type: org.bukkit.event.inventory.InventoryType, title: string): org.bukkit.inventory.Inventory;
|
||||
/**
|
||||
* Creates an empty inventory of type {@link InventoryType#CHEST} with the
|
||||
* specified size.
|
||||
*/
|
||||
public static createInventory(owner: org.bukkit.inventory.InventoryHolder, size: number): org.bukkit.inventory.Inventory;
|
||||
/**
|
||||
* Creates an empty inventory of type {@link InventoryType#CHEST} with the
|
||||
* specified size and title.
|
||||
*/
|
||||
public static createInventory(owner: org.bukkit.inventory.InventoryHolder, size: number, title: string): org.bukkit.inventory.Inventory;
|
||||
/**
|
||||
* Creates an empty merchant.
|
||||
*/
|
||||
public static createMerchant(title: string): org.bukkit.inventory.Merchant;
|
||||
/**
|
||||
* Gets user-specified limit for number of monsters that can spawn in a
|
||||
* chunk.
|
||||
*/
|
||||
public static getMonsterSpawnLimit(): number;
|
||||
/**
|
||||
* Gets user-specified limit for number of animals that can spawn in a
|
||||
* chunk.
|
||||
*/
|
||||
public static getAnimalSpawnLimit(): number;
|
||||
/**
|
||||
* Gets user-specified limit for number of water animals that can spawn in
|
||||
* a chunk.
|
||||
*/
|
||||
public static getWaterAnimalSpawnLimit(): number;
|
||||
/**
|
||||
* Gets user-specified limit for number of ambient mobs that can spawn in
|
||||
* a chunk.
|
||||
*/
|
||||
public static getAmbientSpawnLimit(): number;
|
||||
/**
|
||||
* Checks the current thread against the expected primary thread for the
|
||||
* server.
|
||||
* <p>
|
||||
* <b>Note:</b> this method should not be used to indicate the current
|
||||
* synchronized state of the runtime. A current thread matching the main
|
||||
* thread indicates that it is synchronized, but a mismatch <b>does not
|
||||
* preclude</b> the same assumption.
|
||||
*/
|
||||
public static isPrimaryThread(): boolean;
|
||||
/**
|
||||
* Gets the message that is displayed on the server list.
|
||||
*/
|
||||
public static getMotd(): string;
|
||||
/**
|
||||
* Gets the default message that is displayed when the server is stopped.
|
||||
*/
|
||||
public static getShutdownMessage(): string;
|
||||
/**
|
||||
* Gets the current warning state for the server.
|
||||
*/
|
||||
public static getWarningState(): org.bukkit.Warning.WarningState;
|
||||
/**
|
||||
* Gets the instance of the item factory (for {@link ItemMeta}).
|
||||
*/
|
||||
public static getItemFactory(): org.bukkit.inventory.ItemFactory;
|
||||
/**
|
||||
* Gets the instance of the scoreboard manager.
|
||||
* <p>
|
||||
* This will only exist after the first world has loaded.
|
||||
*/
|
||||
public static getScoreboardManager(): org.bukkit.scoreboard.ScoreboardManager;
|
||||
/**
|
||||
* Gets an instance of the server's default server-icon.
|
||||
*/
|
||||
public static getServerIcon(): org.bukkit.util.CachedServerIcon;
|
||||
/**
|
||||
* Loads an image from a file, and returns a cached image for the specific
|
||||
* server-icon.
|
||||
* <p>
|
||||
* Size and type are implementation defined. An incompatible file is
|
||||
* guaranteed to throw an implementation-defined {@link Exception}.
|
||||
*/
|
||||
public static loadServerIcon(file: any): org.bukkit.util.CachedServerIcon;
|
||||
/**
|
||||
* Creates a cached server-icon for the specific image.
|
||||
* <p>
|
||||
* Size and type are implementation defined. An incompatible file is
|
||||
* guaranteed to throw an implementation-defined {@link Exception}.
|
||||
*/
|
||||
public static loadServerIcon(image: any): org.bukkit.util.CachedServerIcon;
|
||||
/**
|
||||
* Set the idle kick timeout. Any players idle for the specified amount of
|
||||
* time will be automatically kicked.
|
||||
* <p>
|
||||
* A value of 0 will disable the idle kick timeout.
|
||||
*/
|
||||
public static setIdleTimeout(threshold: number): void;
|
||||
/**
|
||||
* Gets the idle kick timeout.
|
||||
*/
|
||||
public static getIdleTimeout(): number;
|
||||
/**
|
||||
* Create a ChunkData for use in a generator.
|
||||
* See {@link ChunkGenerator#generateChunkData(org.bukkit.World, java.util.Random, int, int, org.bukkit.generator.ChunkGenerator.BiomeGrid)}
|
||||
*/
|
||||
public static createChunkData(world: org.bukkit.World): org.bukkit.generator.ChunkGenerator.ChunkData;
|
||||
/**
|
||||
* Creates a boss bar instance to display to players. The progress
|
||||
* defaults to 1.0
|
||||
*/
|
||||
public static createBossBar(title: string, color: org.bukkit.boss.BarColor, style: org.bukkit.boss.BarStyle, flags: org.bukkit.boss.BarFlag): org.bukkit.boss.BossBar;
|
||||
/**
|
||||
* Creates a boss bar instance to display to players. The progress defaults
|
||||
* to 1.0.
|
||||
* <br>
|
||||
* This instance is added to the persistent storage of the server and will
|
||||
* be editable by commands and restored after restart.
|
||||
*/
|
||||
public static createBossBar(key: org.bukkit.NamespacedKey, title: string, color: org.bukkit.boss.BarColor, style: org.bukkit.boss.BarStyle, flags: org.bukkit.boss.BarFlag): org.bukkit.boss.KeyedBossBar;
|
||||
/**
|
||||
* Gets an unmodifiable iterator through all persistent bossbars.
|
||||
* <ul>
|
||||
* <li><b>not</b> bound to a {@link org.bukkit.entity.Boss}</li>
|
||||
* <li>
|
||||
* <b>not</b> created using
|
||||
* {@link #createBossBar(String, BarColor, BarStyle, BarFlag...)}
|
||||
* </li>
|
||||
* </ul>
|
||||
* e.g. bossbars created using the bossbar command
|
||||
*/
|
||||
public static getBossBars(): any;
|
||||
/**
|
||||
* Gets the {@link KeyedBossBar} specified by this key.
|
||||
* <ul>
|
||||
* <li><b>not</b> bound to a {@link org.bukkit.entity.Boss}</li>
|
||||
* <li>
|
||||
* <b>not</b> created using
|
||||
* {@link #createBossBar(String, BarColor, BarStyle, BarFlag...)}
|
||||
* </li>
|
||||
* </ul>
|
||||
* e.g. bossbars created using the bossbar command
|
||||
*/
|
||||
public static getBossBar(key: org.bukkit.NamespacedKey): org.bukkit.boss.KeyedBossBar;
|
||||
/**
|
||||
* Removes a {@link KeyedBossBar} specified by this key.
|
||||
* <ul>
|
||||
* <li><b>not</b> bound to a {@link org.bukkit.entity.Boss}</li>
|
||||
* <li>
|
||||
* <b>not</b> created using
|
||||
* {@link #createBossBar(String, BarColor, BarStyle, BarFlag...)}
|
||||
* </li>
|
||||
* </ul>
|
||||
* e.g. bossbars created using the bossbar command
|
||||
*/
|
||||
public static removeBossBar(key: org.bukkit.NamespacedKey): boolean;
|
||||
/**
|
||||
* Gets an entity on the server by its UUID
|
||||
*/
|
||||
public static getEntity(uuid: any): org.bukkit.entity.Entity;
|
||||
/**
|
||||
* Get the advancement specified by this key.
|
||||
*/
|
||||
public static getAdvancement(key: org.bukkit.NamespacedKey): org.bukkit.advancement.Advancement;
|
||||
/**
|
||||
* Get an iterator through all advancements. Advancements cannot be removed
|
||||
* from this iterator,
|
||||
*/
|
||||
public static advancementIterator(): any;
|
||||
/**
|
||||
* Creates a new {@link BlockData} instance for the specified Material, with
|
||||
* all properties initialized to unspecified defaults.
|
||||
*/
|
||||
public static createBlockData(material: org.bukkit.Material): org.bukkit.block.data.BlockData;
|
||||
/**
|
||||
* Creates a new {@link BlockData} instance for the specified Material, with
|
||||
* all properties initialized to unspecified defaults.
|
||||
*/
|
||||
public static createBlockData(material: org.bukkit.Material, consumer: any): org.bukkit.block.data.BlockData;
|
||||
/**
|
||||
* Creates a new {@link BlockData} instance with material and properties
|
||||
* parsed from provided data.
|
||||
*/
|
||||
public static createBlockData(data: string): org.bukkit.block.data.BlockData;
|
||||
/**
|
||||
* Creates a new {@link BlockData} instance for the specified Material, with
|
||||
* all properties initialized to unspecified defaults, except for those
|
||||
* provided in data.
|
||||
*/
|
||||
public static createBlockData(material: org.bukkit.Material, data: string): org.bukkit.block.data.BlockData;
|
||||
/**
|
||||
* Gets a tag which has already been defined within the server. Plugins are
|
||||
* suggested to use the concrete tags in {@link Tag} rather than this method
|
||||
* which makes no guarantees about which tags are available, and may also be
|
||||
* less performant due to lack of caching.
|
||||
* <br>
|
||||
* Tags will be searched for in an implementation specific manner, but a
|
||||
* path consisting of namespace/tags/registry/key is expected.
|
||||
* <br>
|
||||
* Server implementations are allowed to handle only the registries
|
||||
* indicated in {@link Tag}.
|
||||
*/
|
||||
public static getTag(registry: string, tag: org.bukkit.NamespacedKey, clazz: any): org.bukkit.Tag;
|
||||
/**
|
||||
* Gets a all tags which have been defined within the server.
|
||||
* <br>
|
||||
* Server implementations are allowed to handle only the registries
|
||||
* indicated in {@link Tag}.
|
||||
* <br>
|
||||
* No guarantees are made about the mutability of the returned iterator.
|
||||
*/
|
||||
public static getTags(registry: string, clazz: any): any;
|
||||
/**
|
||||
* Gets the specified {@link LootTable}.
|
||||
*/
|
||||
public static getLootTable(key: org.bukkit.NamespacedKey): org.bukkit.loot.LootTable;
|
||||
/**
|
||||
* Selects entities using the given Vanilla selector.
|
||||
* <br>
|
||||
* No guarantees are made about the selector format, other than they match
|
||||
* the Vanilla format for the active Minecraft version.
|
||||
* <br>
|
||||
* Usually a selector will start with '@', unless selecting a Player in
|
||||
* which case it may simply be the Player's name or UUID.
|
||||
* <br>
|
||||
* Note that in Vanilla, elevated permissions are usually required to use
|
||||
* '@' selectors, but this method should not check such permissions from the
|
||||
* sender.
|
||||
*/
|
||||
public static selectEntities(sender: org.bukkit.command.CommandSender, selector: string): any[] /*java.util.List*/;
|
||||
public static getUnsafe(): org.bukkit.UnsafeValues;
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,67 +0,0 @@
|
||||
declare namespace org {
|
||||
namespace bukkit {
|
||||
class ChatColor {
|
||||
public static BLACK: org.bukkit.ChatColor;
|
||||
public static DARK_BLUE: org.bukkit.ChatColor;
|
||||
public static DARK_GREEN: org.bukkit.ChatColor;
|
||||
public static DARK_AQUA: org.bukkit.ChatColor;
|
||||
public static DARK_RED: org.bukkit.ChatColor;
|
||||
public static DARK_PURPLE: org.bukkit.ChatColor;
|
||||
public static GOLD: org.bukkit.ChatColor;
|
||||
public static GRAY: org.bukkit.ChatColor;
|
||||
public static DARK_GRAY: org.bukkit.ChatColor;
|
||||
public static BLUE: org.bukkit.ChatColor;
|
||||
public static GREEN: org.bukkit.ChatColor;
|
||||
public static AQUA: org.bukkit.ChatColor;
|
||||
public static RED: org.bukkit.ChatColor;
|
||||
public static LIGHT_PURPLE: org.bukkit.ChatColor;
|
||||
public static YELLOW: org.bukkit.ChatColor;
|
||||
public static WHITE: org.bukkit.ChatColor;
|
||||
public static MAGIC: org.bukkit.ChatColor;
|
||||
public static BOLD: org.bukkit.ChatColor;
|
||||
public static STRIKETHROUGH: org.bukkit.ChatColor;
|
||||
public static UNDERLINE: org.bukkit.ChatColor;
|
||||
public static ITALIC: org.bukkit.ChatColor;
|
||||
public static RESET: org.bukkit.ChatColor;
|
||||
public static COLOR_CHAR: string;
|
||||
public static values(): org.bukkit.ChatColor[];
|
||||
public static valueOf(name: string): org.bukkit.ChatColor;
|
||||
/**
|
||||
* Gets the char value associated with this color
|
||||
*/
|
||||
public getChar(): string;
|
||||
public toString(): string;
|
||||
/**
|
||||
* Checks if this code is a format code as opposed to a color code.
|
||||
*/
|
||||
public isFormat(): boolean;
|
||||
/**
|
||||
* Checks if this code is a color code as opposed to a format code.
|
||||
*/
|
||||
public isColor(): boolean;
|
||||
/**
|
||||
* Gets the color represented by the specified color code
|
||||
*/
|
||||
public static getByChar(code: string): org.bukkit.ChatColor;
|
||||
/**
|
||||
* Gets the color represented by the specified color code
|
||||
*/
|
||||
public static getByChar(code: string): org.bukkit.ChatColor;
|
||||
/**
|
||||
* Strips the given message of all color codes
|
||||
*/
|
||||
public static stripColor(input: string): string;
|
||||
/**
|
||||
* Translates a string using an alternate color code character into a
|
||||
* string that uses the internal ChatColor.COLOR_CODE color code
|
||||
* character. The alternate color code character will only be replaced if
|
||||
* it is immediately followed by 0-9, A-F, a-f, K-O, k-o, R or r.
|
||||
*/
|
||||
public static translateAlternateColorCodes(altColorChar: string, textToTranslate: string): string;
|
||||
/**
|
||||
* Gets the ChatColors used at the end of the given input string.
|
||||
*/
|
||||
public static getLastColors(input: string): string;
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,106 +0,0 @@
|
||||
declare namespace org {
|
||||
namespace bukkit {
|
||||
class Chunk {
|
||||
/**
|
||||
* Gets the X-coordinate of this chunk
|
||||
*/
|
||||
public getX(): number;
|
||||
/**
|
||||
* Gets the Z-coordinate of this chunk
|
||||
*/
|
||||
public getZ(): number;
|
||||
/**
|
||||
* Gets the world containing this chunk
|
||||
*/
|
||||
public getWorld(): org.bukkit.World;
|
||||
/**
|
||||
* Gets a block from this chunk
|
||||
*/
|
||||
public getBlock(x: number, y: number, z: number): org.bukkit.block.Block;
|
||||
/**
|
||||
* Capture thread-safe read-only snapshot of chunk data
|
||||
*/
|
||||
public getChunkSnapshot(): org.bukkit.ChunkSnapshot;
|
||||
/**
|
||||
* Capture thread-safe read-only snapshot of chunk data
|
||||
*/
|
||||
public getChunkSnapshot(includeMaxblocky: boolean, includeBiome: boolean, includeBiomeTempRain: boolean): org.bukkit.ChunkSnapshot;
|
||||
/**
|
||||
* Get a list of all entities in the chunk.
|
||||
*/
|
||||
public getEntities(): org.bukkit.entity.Entity[];
|
||||
/**
|
||||
* Get a list of all tile entities in the chunk.
|
||||
*/
|
||||
public getTileEntities(): org.bukkit.block.BlockState[];
|
||||
/**
|
||||
* Checks if the chunk is loaded.
|
||||
*/
|
||||
public isLoaded(): boolean;
|
||||
/**
|
||||
* Loads the chunk.
|
||||
*/
|
||||
public load(generate: boolean): boolean;
|
||||
/**
|
||||
* Loads the chunk.
|
||||
*/
|
||||
public load(): boolean;
|
||||
/**
|
||||
* Unloads and optionally saves the Chunk
|
||||
*/
|
||||
public unload(save: boolean): boolean;
|
||||
/**
|
||||
* Unloads and optionally saves the Chunk
|
||||
*/
|
||||
public unload(): boolean;
|
||||
/**
|
||||
* Checks if this chunk can spawn slimes without being a swamp biome.
|
||||
*/
|
||||
public isSlimeChunk(): boolean;
|
||||
/**
|
||||
* Gets whether the chunk at the specified chunk coordinates is force
|
||||
* loaded.
|
||||
* <p>
|
||||
* A force loaded chunk will not be unloaded due to lack of player activity.
|
||||
*/
|
||||
public isForceLoaded(): boolean;
|
||||
/**
|
||||
* Sets whether the chunk at the specified chunk coordinates is force
|
||||
* loaded.
|
||||
* <p>
|
||||
* A force loaded chunk will not be unloaded due to lack of player activity.
|
||||
*/
|
||||
public setForceLoaded(forced: boolean): void;
|
||||
/**
|
||||
* Adds a plugin ticket for this chunk, loading this chunk if it is not
|
||||
* already loaded.
|
||||
* <p>
|
||||
* A plugin ticket will prevent a chunk from unloading until it is
|
||||
* explicitly removed. A plugin instance may only have one ticket per chunk,
|
||||
* but each chunk can have multiple plugin tickets.
|
||||
* </p>
|
||||
*/
|
||||
public addPluginChunkTicket(plugin: org.bukkit.plugin.Plugin): boolean;
|
||||
/**
|
||||
* Removes the specified plugin's ticket for this chunk
|
||||
* <p>
|
||||
* A plugin ticket will prevent a chunk from unloading until it is
|
||||
* explicitly removed. A plugin instance may only have one ticket per chunk,
|
||||
* but each chunk can have multiple plugin tickets.
|
||||
* </p>
|
||||
*/
|
||||
public removePluginChunkTicket(plugin: org.bukkit.plugin.Plugin): boolean;
|
||||
/**
|
||||
* Retrieves a collection specifying which plugins have tickets for this
|
||||
* chunk. This collection is not updated when plugin tickets are added or
|
||||
* removed to this chunk.
|
||||
* <p>
|
||||
* A plugin ticket will prevent a chunk from unloading until it is
|
||||
* explicitly removed. A plugin instance may only have one ticket per chunk,
|
||||
* but each chunk can have multiple plugin tickets.
|
||||
* </p>
|
||||
*/
|
||||
public getPluginChunkTickets(): any[] /*java.util.Collection*/;
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,59 +0,0 @@
|
||||
declare namespace org {
|
||||
namespace bukkit {
|
||||
class ChunkSnapshot {
|
||||
/**
|
||||
* Gets the X-coordinate of this chunk
|
||||
*/
|
||||
public getX(): number;
|
||||
/**
|
||||
* Gets the Z-coordinate of this chunk
|
||||
*/
|
||||
public getZ(): number;
|
||||
/**
|
||||
* Gets name of the world containing this chunk
|
||||
*/
|
||||
public getWorldName(): string;
|
||||
/**
|
||||
* Get block type for block at corresponding coordinate in the chunk
|
||||
*/
|
||||
public getBlockType(x: number, y: number, z: number): org.bukkit.Material;
|
||||
/**
|
||||
* Get block data for block at corresponding coordinate in the chunk
|
||||
*/
|
||||
public getBlockData(x: number, y: number, z: number): org.bukkit.block.data.BlockData;
|
||||
/**
|
||||
* Get block data for block at corresponding coordinate in the chunk
|
||||
*/
|
||||
public getData(x: number, y: number, z: number): number;
|
||||
/**
|
||||
* Get sky light level for block at corresponding coordinate in the chunk
|
||||
*/
|
||||
public getBlockSkyLight(x: number, y: number, z: number): number;
|
||||
/**
|
||||
* Get light level emitted by block at corresponding coordinate in the
|
||||
* chunk
|
||||
*/
|
||||
public getBlockEmittedLight(x: number, y: number, z: number): number;
|
||||
/**
|
||||
* Gets the highest non-air coordinate at the given coordinates
|
||||
*/
|
||||
public getHighestBlockYAt(x: number, z: number): number;
|
||||
/**
|
||||
* Get biome at given coordinates
|
||||
*/
|
||||
public getBiome(x: number, z: number): org.bukkit.block.Biome;
|
||||
/**
|
||||
* Get raw biome temperature (0.0-1.0) at given coordinate
|
||||
*/
|
||||
public getRawBiomeTemperature(x: number, z: number): number;
|
||||
/**
|
||||
* Get world full time when chunk snapshot was captured
|
||||
*/
|
||||
public getCaptureFullTime(): number;
|
||||
/**
|
||||
* Test if section is empty
|
||||
*/
|
||||
public isSectionEmpty(sy: number): boolean;
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,18 +0,0 @@
|
||||
declare namespace org {
|
||||
namespace bukkit {
|
||||
class CoalType {
|
||||
public static COAL: org.bukkit.CoalType;
|
||||
public static CHARCOAL: org.bukkit.CoalType;
|
||||
public static values(): org.bukkit.CoalType[];
|
||||
public static valueOf(name: string): org.bukkit.CoalType;
|
||||
/**
|
||||
* Gets the associated data value representing this type of coal
|
||||
*/
|
||||
public getData(): number;
|
||||
/**
|
||||
* Gets the type of coal with the given data value
|
||||
*/
|
||||
public static getByData(data: number): org.bukkit.CoalType;
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,82 +0,0 @@
|
||||
declare namespace org {
|
||||
namespace bukkit {
|
||||
class Color {
|
||||
public static WHITE: org.bukkit.Color;
|
||||
public static SILVER: org.bukkit.Color;
|
||||
public static GRAY: org.bukkit.Color;
|
||||
public static BLACK: org.bukkit.Color;
|
||||
public static RED: org.bukkit.Color;
|
||||
public static MAROON: org.bukkit.Color;
|
||||
public static YELLOW: org.bukkit.Color;
|
||||
public static OLIVE: org.bukkit.Color;
|
||||
public static LIME: org.bukkit.Color;
|
||||
public static GREEN: org.bukkit.Color;
|
||||
public static AQUA: org.bukkit.Color;
|
||||
public static TEAL: org.bukkit.Color;
|
||||
public static BLUE: org.bukkit.Color;
|
||||
public static NAVY: org.bukkit.Color;
|
||||
public static FUCHSIA: org.bukkit.Color;
|
||||
public static PURPLE: org.bukkit.Color;
|
||||
public static ORANGE: org.bukkit.Color;
|
||||
/**
|
||||
* Creates a new Color object from a red, green, and blue
|
||||
*/
|
||||
public static fromRGB(red: number, green: number, blue: number): org.bukkit.Color;
|
||||
/**
|
||||
* Creates a new Color object from a blue, green, and red
|
||||
*/
|
||||
public static fromBGR(blue: number, green: number, red: number): org.bukkit.Color;
|
||||
/**
|
||||
* Creates a new color object from an integer that contains the red,
|
||||
* green, and blue bytes in the lowest order 24 bits.
|
||||
*/
|
||||
public static fromRGB(rgb: number): org.bukkit.Color;
|
||||
/**
|
||||
* Creates a new color object from an integer that contains the blue,
|
||||
* green, and red bytes in the lowest order 24 bits.
|
||||
*/
|
||||
public static fromBGR(bgr: number): org.bukkit.Color;
|
||||
/**
|
||||
* Gets the red component
|
||||
*/
|
||||
public getRed(): number;
|
||||
/**
|
||||
* Creates a new Color object with specified component
|
||||
*/
|
||||
public setRed(red: number): org.bukkit.Color;
|
||||
/**
|
||||
* Gets the green component
|
||||
*/
|
||||
public getGreen(): number;
|
||||
/**
|
||||
* Creates a new Color object with specified component
|
||||
*/
|
||||
public setGreen(green: number): org.bukkit.Color;
|
||||
/**
|
||||
* Gets the blue component
|
||||
*/
|
||||
public getBlue(): number;
|
||||
/**
|
||||
* Creates a new Color object with specified component
|
||||
*/
|
||||
public setBlue(blue: number): org.bukkit.Color;
|
||||
public asRGB(): number;
|
||||
public asBGR(): number;
|
||||
/**
|
||||
* Creates a new color with its RGB components changed as if it was dyed
|
||||
* with the colors passed in, replicating vanilla workbench dyeing
|
||||
*/
|
||||
public mixDyes(colors: org.bukkit.DyeColor): org.bukkit.Color;
|
||||
/**
|
||||
* Creates a new color with its RGB components changed as if it was dyed
|
||||
* with the colors passed in, replicating vanilla workbench dyeing
|
||||
*/
|
||||
public mixColors(colors: org.bukkit.Color): org.bukkit.Color;
|
||||
public equals(o: any): boolean;
|
||||
public hashCode(): number;
|
||||
public serialize(): Map<any, any> /*java.util.Map*/;
|
||||
public static deserialize(map: Map<any, any> /*java.util.Map*/): org.bukkit.Color;
|
||||
public toString(): string;
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,24 +0,0 @@
|
||||
declare namespace org {
|
||||
namespace bukkit {
|
||||
class CropState {
|
||||
public static SEEDED: org.bukkit.CropState;
|
||||
public static GERMINATED: org.bukkit.CropState;
|
||||
public static VERY_SMALL: org.bukkit.CropState;
|
||||
public static SMALL: org.bukkit.CropState;
|
||||
public static MEDIUM: org.bukkit.CropState;
|
||||
public static TALL: org.bukkit.CropState;
|
||||
public static VERY_TALL: org.bukkit.CropState;
|
||||
public static RIPE: org.bukkit.CropState;
|
||||
public static values(): org.bukkit.CropState[];
|
||||
public static valueOf(name: string): org.bukkit.CropState;
|
||||
/**
|
||||
* Gets the associated data value representing this growth state
|
||||
*/
|
||||
public getData(): number;
|
||||
/**
|
||||
* Gets the CropState with the given data value
|
||||
*/
|
||||
public static getByData(data: number): org.bukkit.CropState;
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,20 +0,0 @@
|
||||
declare namespace org {
|
||||
namespace bukkit {
|
||||
class Difficulty {
|
||||
public static PEACEFUL: org.bukkit.Difficulty;
|
||||
public static EASY: org.bukkit.Difficulty;
|
||||
public static NORMAL: org.bukkit.Difficulty;
|
||||
public static HARD: org.bukkit.Difficulty;
|
||||
public static values(): org.bukkit.Difficulty[];
|
||||
public static valueOf(name: string): org.bukkit.Difficulty;
|
||||
/**
|
||||
* Gets the difficulty value associated with this Difficulty.
|
||||
*/
|
||||
public getValue(): number;
|
||||
/**
|
||||
* Gets the Difficulty represented by the specified value
|
||||
*/
|
||||
public static getByValue(value: number): org.bukkit.Difficulty;
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,60 +0,0 @@
|
||||
declare namespace org {
|
||||
namespace bukkit {
|
||||
class DyeColor {
|
||||
public static WHITE: org.bukkit.DyeColor;
|
||||
public static ORANGE: org.bukkit.DyeColor;
|
||||
public static MAGENTA: org.bukkit.DyeColor;
|
||||
public static LIGHT_BLUE: org.bukkit.DyeColor;
|
||||
public static YELLOW: org.bukkit.DyeColor;
|
||||
public static LIME: org.bukkit.DyeColor;
|
||||
public static PINK: org.bukkit.DyeColor;
|
||||
public static GRAY: org.bukkit.DyeColor;
|
||||
public static LIGHT_GRAY: org.bukkit.DyeColor;
|
||||
public static CYAN: org.bukkit.DyeColor;
|
||||
public static PURPLE: org.bukkit.DyeColor;
|
||||
public static BLUE: org.bukkit.DyeColor;
|
||||
public static BROWN: org.bukkit.DyeColor;
|
||||
public static GREEN: org.bukkit.DyeColor;
|
||||
public static RED: org.bukkit.DyeColor;
|
||||
public static BLACK: org.bukkit.DyeColor;
|
||||
public static values(): org.bukkit.DyeColor[];
|
||||
public static valueOf(name: string): org.bukkit.DyeColor;
|
||||
/**
|
||||
* Gets the associated wool data value representing this color.
|
||||
*/
|
||||
public getWoolData(): number;
|
||||
/**
|
||||
* Gets the associated dye data value representing this color.
|
||||
*/
|
||||
public getDyeData(): number;
|
||||
/**
|
||||
* Gets the color that this dye represents.
|
||||
*/
|
||||
public getColor(): org.bukkit.Color;
|
||||
/**
|
||||
* Gets the firework color that this dye represents.
|
||||
*/
|
||||
public getFireworkColor(): org.bukkit.Color;
|
||||
/**
|
||||
* Gets the DyeColor with the given wool data value.
|
||||
*/
|
||||
public static getByWoolData(data: number): org.bukkit.DyeColor;
|
||||
/**
|
||||
* Gets the DyeColor with the given dye data value.
|
||||
*/
|
||||
public static getByDyeData(data: number): org.bukkit.DyeColor;
|
||||
/**
|
||||
* Gets the DyeColor with the given color value.
|
||||
*/
|
||||
public static getByColor(color: org.bukkit.Color): org.bukkit.DyeColor;
|
||||
/**
|
||||
* Gets the DyeColor with the given firework color value.
|
||||
*/
|
||||
public static getByFireworkColor(color: org.bukkit.Color): org.bukkit.DyeColor;
|
||||
/**
|
||||
* Gets the DyeColor for the given name, possibly doing legacy transformations.
|
||||
*/
|
||||
public static legacyValueOf(name: string): org.bukkit.DyeColor;
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,12 +0,0 @@
|
||||
declare namespace org {
|
||||
namespace bukkit {
|
||||
namespace Effect {
|
||||
class Type {
|
||||
public static SOUND: org.bukkit.Effect.Type;
|
||||
public static VISUAL: org.bukkit.Effect.Type;
|
||||
public static values(): org.bukkit.Effect.Type[];
|
||||
public static valueOf(name: string): org.bukkit.Effect.Type;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,63 +0,0 @@
|
||||
declare namespace org {
|
||||
namespace bukkit {
|
||||
class Effect {
|
||||
public static CLICK2: org.bukkit.Effect;
|
||||
public static CLICK1: org.bukkit.Effect;
|
||||
public static BOW_FIRE: org.bukkit.Effect;
|
||||
public static DOOR_TOGGLE: org.bukkit.Effect;
|
||||
public static IRON_DOOR_TOGGLE: org.bukkit.Effect;
|
||||
public static TRAPDOOR_TOGGLE: org.bukkit.Effect;
|
||||
public static IRON_TRAPDOOR_TOGGLE: org.bukkit.Effect;
|
||||
public static FENCE_GATE_TOGGLE: org.bukkit.Effect;
|
||||
public static DOOR_CLOSE: org.bukkit.Effect;
|
||||
public static IRON_DOOR_CLOSE: org.bukkit.Effect;
|
||||
public static TRAPDOOR_CLOSE: org.bukkit.Effect;
|
||||
public static IRON_TRAPDOOR_CLOSE: org.bukkit.Effect;
|
||||
public static FENCE_GATE_CLOSE: org.bukkit.Effect;
|
||||
public static EXTINGUISH: org.bukkit.Effect;
|
||||
public static RECORD_PLAY: org.bukkit.Effect;
|
||||
public static GHAST_SHRIEK: org.bukkit.Effect;
|
||||
public static GHAST_SHOOT: org.bukkit.Effect;
|
||||
public static BLAZE_SHOOT: org.bukkit.Effect;
|
||||
public static ZOMBIE_CHEW_WOODEN_DOOR: org.bukkit.Effect;
|
||||
public static ZOMBIE_CHEW_IRON_DOOR: org.bukkit.Effect;
|
||||
public static ZOMBIE_DESTROY_DOOR: org.bukkit.Effect;
|
||||
public static SMOKE: org.bukkit.Effect;
|
||||
public static STEP_SOUND: org.bukkit.Effect;
|
||||
public static POTION_BREAK: org.bukkit.Effect;
|
||||
public static ENDER_SIGNAL: org.bukkit.Effect;
|
||||
public static MOBSPAWNER_FLAMES: org.bukkit.Effect;
|
||||
public static BREWING_STAND_BREW: org.bukkit.Effect;
|
||||
public static CHORUS_FLOWER_GROW: org.bukkit.Effect;
|
||||
public static CHORUS_FLOWER_DEATH: org.bukkit.Effect;
|
||||
public static PORTAL_TRAVEL: org.bukkit.Effect;
|
||||
public static ENDEREYE_LAUNCH: org.bukkit.Effect;
|
||||
public static FIREWORK_SHOOT: org.bukkit.Effect;
|
||||
public static VILLAGER_PLANT_GROW: org.bukkit.Effect;
|
||||
public static DRAGON_BREATH: org.bukkit.Effect;
|
||||
public static ANVIL_BREAK: org.bukkit.Effect;
|
||||
public static ANVIL_USE: org.bukkit.Effect;
|
||||
public static ANVIL_LAND: org.bukkit.Effect;
|
||||
public static ENDERDRAGON_SHOOT: org.bukkit.Effect;
|
||||
public static WITHER_BREAK_BLOCK: org.bukkit.Effect;
|
||||
public static WITHER_SHOOT: org.bukkit.Effect;
|
||||
public static ZOMBIE_INFECT: org.bukkit.Effect;
|
||||
public static ZOMBIE_CONVERTED_VILLAGER: org.bukkit.Effect;
|
||||
public static BAT_TAKEOFF: org.bukkit.Effect;
|
||||
public static END_GATEWAY_SPAWN: org.bukkit.Effect;
|
||||
public static ENDERDRAGON_GROWL: org.bukkit.Effect;
|
||||
public static values(): org.bukkit.Effect[];
|
||||
public static valueOf(name: string): org.bukkit.Effect;
|
||||
/**
|
||||
* Gets the ID for this effect.
|
||||
*/
|
||||
public getId(): number;
|
||||
public getType(): org.bukkit.Effect.Type;
|
||||
public getData(): any;
|
||||
/**
|
||||
* Gets the Effect associated with the given ID.
|
||||
*/
|
||||
public static getById(id: number): org.bukkit.Effect;
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,47 +0,0 @@
|
||||
declare namespace org {
|
||||
namespace bukkit {
|
||||
class EntityEffect {
|
||||
public static ARROW_PARTICLES: org.bukkit.EntityEffect;
|
||||
public static RABBIT_JUMP: org.bukkit.EntityEffect;
|
||||
public static HURT: org.bukkit.EntityEffect;
|
||||
public static DEATH: org.bukkit.EntityEffect;
|
||||
public static WOLF_SMOKE: org.bukkit.EntityEffect;
|
||||
public static WOLF_HEARTS: org.bukkit.EntityEffect;
|
||||
public static WOLF_SHAKE: org.bukkit.EntityEffect;
|
||||
public static SHEEP_EAT: org.bukkit.EntityEffect;
|
||||
public static IRON_GOLEM_ROSE: org.bukkit.EntityEffect;
|
||||
public static VILLAGER_HEART: org.bukkit.EntityEffect;
|
||||
public static VILLAGER_ANGRY: org.bukkit.EntityEffect;
|
||||
public static VILLAGER_HAPPY: org.bukkit.EntityEffect;
|
||||
public static WITCH_MAGIC: org.bukkit.EntityEffect;
|
||||
public static ZOMBIE_TRANSFORM: org.bukkit.EntityEffect;
|
||||
public static FIREWORK_EXPLODE: org.bukkit.EntityEffect;
|
||||
public static LOVE_HEARTS: org.bukkit.EntityEffect;
|
||||
public static SQUID_ROTATE: org.bukkit.EntityEffect;
|
||||
public static ENTITY_POOF: org.bukkit.EntityEffect;
|
||||
public static GUARDIAN_TARGET: org.bukkit.EntityEffect;
|
||||
public static SHIELD_BLOCK: org.bukkit.EntityEffect;
|
||||
public static SHIELD_BREAK: org.bukkit.EntityEffect;
|
||||
public static ARMOR_STAND_HIT: org.bukkit.EntityEffect;
|
||||
public static THORNS_HURT: org.bukkit.EntityEffect;
|
||||
public static IRON_GOLEM_SHEATH: org.bukkit.EntityEffect;
|
||||
public static TOTEM_RESURRECT: org.bukkit.EntityEffect;
|
||||
public static HURT_DROWN: org.bukkit.EntityEffect;
|
||||
public static HURT_EXPLOSION: org.bukkit.EntityEffect;
|
||||
public static values(): org.bukkit.EntityEffect[];
|
||||
public static valueOf(name: string): org.bukkit.EntityEffect;
|
||||
/**
|
||||
* Gets the data value of this EntityEffect
|
||||
*/
|
||||
public getData(): number;
|
||||
/**
|
||||
* Gets entity superclass which this affect is applicable to.
|
||||
*/
|
||||
public getApplicable(): any;
|
||||
/**
|
||||
* Gets the EntityEffect with the given data value
|
||||
*/
|
||||
public static getByData(data: number): org.bukkit.EntityEffect;
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,59 +0,0 @@
|
||||
declare namespace org {
|
||||
namespace bukkit {
|
||||
namespace FireworkEffect {
|
||||
class Builder {
|
||||
/**
|
||||
* Specify the type of the firework effect.
|
||||
*/
|
||||
public with(type: org.bukkit.FireworkEffect.Type): org.bukkit.FireworkEffect.Builder;
|
||||
/**
|
||||
* Add a flicker to the firework effect.
|
||||
*/
|
||||
public withFlicker(): org.bukkit.FireworkEffect.Builder;
|
||||
/**
|
||||
* Set whether the firework effect should flicker.
|
||||
*/
|
||||
public flicker(flicker: boolean): org.bukkit.FireworkEffect.Builder;
|
||||
/**
|
||||
* Add a trail to the firework effect.
|
||||
*/
|
||||
public withTrail(): org.bukkit.FireworkEffect.Builder;
|
||||
/**
|
||||
* Set whether the firework effect should have a trail.
|
||||
*/
|
||||
public trail(trail: boolean): org.bukkit.FireworkEffect.Builder;
|
||||
/**
|
||||
* Add a primary color to the firework effect.
|
||||
*/
|
||||
public withColor(color: org.bukkit.Color): org.bukkit.FireworkEffect.Builder;
|
||||
/**
|
||||
* Add several primary colors to the firework effect.
|
||||
*/
|
||||
public withColor(colors: org.bukkit.Color): org.bukkit.FireworkEffect.Builder;
|
||||
/**
|
||||
* Add several primary colors to the firework effect.
|
||||
*/
|
||||
public withColor(colors: any): org.bukkit.FireworkEffect.Builder;
|
||||
/**
|
||||
* Add a fade color to the firework effect.
|
||||
*/
|
||||
public withFade(color: org.bukkit.Color): org.bukkit.FireworkEffect.Builder;
|
||||
/**
|
||||
* Add several fade colors to the firework effect.
|
||||
*/
|
||||
public withFade(colors: org.bukkit.Color): org.bukkit.FireworkEffect.Builder;
|
||||
/**
|
||||
* Add several fade colors to the firework effect.
|
||||
*/
|
||||
public withFade(colors: any): org.bukkit.FireworkEffect.Builder;
|
||||
/**
|
||||
* Create a {@link FireworkEffect} from the current contents of this
|
||||
* builder.
|
||||
* <p>
|
||||
* To successfully build, you must have specified at least one color.
|
||||
*/
|
||||
public build(): org.bukkit.FireworkEffect;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,15 +0,0 @@
|
||||
declare namespace org {
|
||||
namespace bukkit {
|
||||
namespace FireworkEffect {
|
||||
class Type {
|
||||
public static BALL: org.bukkit.FireworkEffect.Type;
|
||||
public static BALL_LARGE: org.bukkit.FireworkEffect.Type;
|
||||
public static STAR: org.bukkit.FireworkEffect.Type;
|
||||
public static BURST: org.bukkit.FireworkEffect.Type;
|
||||
public static CREEPER: org.bukkit.FireworkEffect.Type;
|
||||
public static values(): org.bukkit.FireworkEffect.Type[];
|
||||
public static valueOf(name: string): org.bukkit.FireworkEffect.Type;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,35 +0,0 @@
|
||||
declare namespace org {
|
||||
namespace bukkit {
|
||||
class FireworkEffect {
|
||||
/**
|
||||
* Construct a firework effect.
|
||||
*/
|
||||
public static builder(): org.bukkit.FireworkEffect.Builder;
|
||||
/**
|
||||
* Get whether the firework effect flickers.
|
||||
*/
|
||||
public hasFlicker(): boolean;
|
||||
/**
|
||||
* Get whether the firework effect has a trail.
|
||||
*/
|
||||
public hasTrail(): boolean;
|
||||
/**
|
||||
* Get the primary colors of the firework effect.
|
||||
*/
|
||||
public getColors(): any[] /*java.util.List*/;
|
||||
/**
|
||||
* Get the fade colors of the firework effect.
|
||||
*/
|
||||
public getFadeColors(): any[] /*java.util.List*/;
|
||||
/**
|
||||
* Get the type of the firework effect.
|
||||
*/
|
||||
public getType(): org.bukkit.FireworkEffect.Type;
|
||||
public static deserialize(map: Map<any, any> /*java.util.Map*/): org.bukkit.configuration.serialization.ConfigurationSerializable;
|
||||
public serialize(): Map<any, any> /*java.util.Map*/;
|
||||
public toString(): string;
|
||||
public hashCode(): number;
|
||||
public equals(obj: any): boolean;
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,11 +0,0 @@
|
||||
declare namespace org {
|
||||
namespace bukkit {
|
||||
class FluidCollisionMode {
|
||||
public static NEVER: org.bukkit.FluidCollisionMode;
|
||||
public static SOURCE_ONLY: org.bukkit.FluidCollisionMode;
|
||||
public static ALWAYS: org.bukkit.FluidCollisionMode;
|
||||
public static values(): org.bukkit.FluidCollisionMode[];
|
||||
public static valueOf(name: string): org.bukkit.FluidCollisionMode;
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,20 +0,0 @@
|
||||
declare namespace org {
|
||||
namespace bukkit {
|
||||
class GameMode {
|
||||
public static CREATIVE: org.bukkit.GameMode;
|
||||
public static SURVIVAL: org.bukkit.GameMode;
|
||||
public static ADVENTURE: org.bukkit.GameMode;
|
||||
public static SPECTATOR: org.bukkit.GameMode;
|
||||
public static values(): org.bukkit.GameMode[];
|
||||
public static valueOf(name: string): org.bukkit.GameMode;
|
||||
/**
|
||||
* Gets the mode value associated with this GameMode
|
||||
*/
|
||||
public getValue(): number;
|
||||
/**
|
||||
* Gets the GameMode represented by the specified value
|
||||
*/
|
||||
public static getByValue(value: number): org.bukkit.GameMode;
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,48 +0,0 @@
|
||||
declare namespace org {
|
||||
namespace bukkit {
|
||||
class GameRule {
|
||||
public static ANNOUNCE_ADVANCEMENTS: org.bukkit.GameRule;
|
||||
public static COMMAND_BLOCK_OUTPUT: org.bukkit.GameRule;
|
||||
public static DISABLE_ELYTRA_MOVEMENT_CHECK: org.bukkit.GameRule;
|
||||
public static DO_DAYLIGHT_CYCLE: org.bukkit.GameRule;
|
||||
public static DO_ENTITY_DROPS: org.bukkit.GameRule;
|
||||
public static DO_FIRE_TICK: org.bukkit.GameRule;
|
||||
public static DO_LIMITED_CRAFTING: org.bukkit.GameRule;
|
||||
public static DO_MOB_LOOT: org.bukkit.GameRule;
|
||||
public static DO_MOB_SPAWNING: org.bukkit.GameRule;
|
||||
public static DO_TILE_DROPS: org.bukkit.GameRule;
|
||||
public static DO_WEATHER_CYCLE: org.bukkit.GameRule;
|
||||
public static KEEP_INVENTORY: org.bukkit.GameRule;
|
||||
public static LOG_ADMIN_COMMANDS: org.bukkit.GameRule;
|
||||
public static MOB_GRIEFING: org.bukkit.GameRule;
|
||||
public static NATURAL_REGENERATION: org.bukkit.GameRule;
|
||||
public static REDUCED_DEBUG_INFO: org.bukkit.GameRule;
|
||||
public static SEND_COMMAND_FEEDBACK: org.bukkit.GameRule;
|
||||
public static SHOW_DEATH_MESSAGES: org.bukkit.GameRule;
|
||||
public static SPECTATORS_GENERATE_CHUNKS: org.bukkit.GameRule;
|
||||
public static DISABLE_RAIDS: org.bukkit.GameRule;
|
||||
public static RANDOM_TICK_SPEED: org.bukkit.GameRule;
|
||||
public static SPAWN_RADIUS: org.bukkit.GameRule;
|
||||
public static MAX_ENTITY_CRAMMING: org.bukkit.GameRule;
|
||||
public static MAX_COMMAND_CHAIN_LENGTH: org.bukkit.GameRule;
|
||||
/**
|
||||
* Get the name of this GameRule.
|
||||
*/
|
||||
public getName(): string;
|
||||
/**
|
||||
* Get the type of this rule.
|
||||
*/
|
||||
public getType(): any;
|
||||
public equals(obj: any): boolean;
|
||||
public toString(): string;
|
||||
/**
|
||||
* Get a {@link GameRule} by its name.
|
||||
*/
|
||||
public static getByName(rule: string): org.bukkit.GameRule;
|
||||
/**
|
||||
* Get an immutable collection of {@link GameRule}s.
|
||||
*/
|
||||
public static values(): org.bukkit.GameRule[];
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,19 +0,0 @@
|
||||
declare namespace org {
|
||||
namespace bukkit {
|
||||
class GrassSpecies {
|
||||
public static DEAD: org.bukkit.GrassSpecies;
|
||||
public static NORMAL: org.bukkit.GrassSpecies;
|
||||
public static FERN_LIKE: org.bukkit.GrassSpecies;
|
||||
public static values(): org.bukkit.GrassSpecies[];
|
||||
public static valueOf(name: string): org.bukkit.GrassSpecies;
|
||||
/**
|
||||
* Gets the associated data value representing this species
|
||||
*/
|
||||
public getData(): number;
|
||||
/**
|
||||
* Gets the GrassSpecies with the given data value
|
||||
*/
|
||||
public static getByData(data: number): org.bukkit.GrassSpecies;
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,29 +0,0 @@
|
||||
declare namespace org {
|
||||
namespace bukkit {
|
||||
class Instrument {
|
||||
public static PIANO: org.bukkit.Instrument;
|
||||
public static BASS_DRUM: org.bukkit.Instrument;
|
||||
public static SNARE_DRUM: org.bukkit.Instrument;
|
||||
public static STICKS: org.bukkit.Instrument;
|
||||
public static BASS_GUITAR: org.bukkit.Instrument;
|
||||
public static FLUTE: org.bukkit.Instrument;
|
||||
public static BELL: org.bukkit.Instrument;
|
||||
public static GUITAR: org.bukkit.Instrument;
|
||||
public static CHIME: org.bukkit.Instrument;
|
||||
public static XYLOPHONE: org.bukkit.Instrument;
|
||||
public static IRON_XYLOPHONE: org.bukkit.Instrument;
|
||||
public static COW_BELL: org.bukkit.Instrument;
|
||||
public static DIDGERIDOO: org.bukkit.Instrument;
|
||||
public static BIT: org.bukkit.Instrument;
|
||||
public static BANJO: org.bukkit.Instrument;
|
||||
public static PLING: org.bukkit.Instrument;
|
||||
public static values(): org.bukkit.Instrument[];
|
||||
public static valueOf(name: string): org.bukkit.Instrument;
|
||||
public getType(): number;
|
||||
/**
|
||||
* Get an instrument by its type ID.
|
||||
*/
|
||||
public static getByType(type: number): org.bukkit.Instrument;
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,10 +0,0 @@
|
||||
declare namespace org {
|
||||
namespace bukkit {
|
||||
class Keyed {
|
||||
/**
|
||||
* Return the namespaced identifier for this object.
|
||||
*/
|
||||
public getKey(): org.bukkit.NamespacedKey;
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,223 +0,0 @@
|
||||
declare namespace org {
|
||||
namespace bukkit {
|
||||
class Location {
|
||||
/**
|
||||
* Constructs a new Location with the given coordinates
|
||||
*/
|
||||
constructor(world: org.bukkit.World, x: number, y: number, z: number)
|
||||
/**
|
||||
* Constructs a new Location with the given coordinates and direction
|
||||
*/
|
||||
constructor(world: org.bukkit.World, x: number, y: number, z: number, yaw: number, pitch: number)
|
||||
/**
|
||||
* Sets the world that this location resides in
|
||||
*/
|
||||
public setWorld(world: org.bukkit.World): void;
|
||||
/**
|
||||
* Checks if world in this location is present and loaded.
|
||||
*/
|
||||
public isWorldLoaded(): boolean;
|
||||
/**
|
||||
* Gets the world that this location resides in
|
||||
*/
|
||||
public getWorld(): org.bukkit.World;
|
||||
/**
|
||||
* Gets the chunk at the represented location
|
||||
*/
|
||||
public getChunk(): org.bukkit.Chunk;
|
||||
/**
|
||||
* Gets the block at the represented location
|
||||
*/
|
||||
public getBlock(): org.bukkit.block.Block;
|
||||
/**
|
||||
* Sets the x-coordinate of this location
|
||||
*/
|
||||
public setX(x: number): void;
|
||||
/**
|
||||
* Gets the x-coordinate of this location
|
||||
*/
|
||||
public getX(): number;
|
||||
/**
|
||||
* Gets the floored value of the X component, indicating the block that
|
||||
* this location is contained with.
|
||||
*/
|
||||
public getBlockX(): number;
|
||||
/**
|
||||
* Sets the y-coordinate of this location
|
||||
*/
|
||||
public setY(y: number): void;
|
||||
/**
|
||||
* Gets the y-coordinate of this location
|
||||
*/
|
||||
public getY(): number;
|
||||
/**
|
||||
* Gets the floored value of the Y component, indicating the block that
|
||||
* this location is contained with.
|
||||
*/
|
||||
public getBlockY(): number;
|
||||
/**
|
||||
* Sets the z-coordinate of this location
|
||||
*/
|
||||
public setZ(z: number): void;
|
||||
/**
|
||||
* Gets the z-coordinate of this location
|
||||
*/
|
||||
public getZ(): number;
|
||||
/**
|
||||
* Gets the floored value of the Z component, indicating the block that
|
||||
* this location is contained with.
|
||||
*/
|
||||
public getBlockZ(): number;
|
||||
/**
|
||||
* Sets the yaw of this location, measured in degrees.
|
||||
* <ul>
|
||||
* <li>A yaw of 0 or 360 represents the positive z direction.
|
||||
* <li>A yaw of 180 represents the negative z direction.
|
||||
* <li>A yaw of 90 represents the negative x direction.
|
||||
* <li>A yaw of 270 represents the positive x direction.
|
||||
* </ul>
|
||||
* Increasing yaw values are the equivalent of turning to your
|
||||
* right-facing, increasing the scale of the next respective axis, and
|
||||
* decreasing the scale of the previous axis.
|
||||
*/
|
||||
public setYaw(yaw: number): void;
|
||||
/**
|
||||
* Gets the yaw of this location, measured in degrees.
|
||||
* <ul>
|
||||
* <li>A yaw of 0 or 360 represents the positive z direction.
|
||||
* <li>A yaw of 180 represents the negative z direction.
|
||||
* <li>A yaw of 90 represents the negative x direction.
|
||||
* <li>A yaw of 270 represents the positive x direction.
|
||||
* </ul>
|
||||
* Increasing yaw values are the equivalent of turning to your
|
||||
* right-facing, increasing the scale of the next respective axis, and
|
||||
* decreasing the scale of the previous axis.
|
||||
*/
|
||||
public getYaw(): number;
|
||||
/**
|
||||
* Sets the pitch of this location, measured in degrees.
|
||||
* <ul>
|
||||
* <li>A pitch of 0 represents level forward facing.
|
||||
* <li>A pitch of 90 represents downward facing, or negative y
|
||||
* direction.
|
||||
* <li>A pitch of -90 represents upward facing, or positive y direction.
|
||||
* </ul>
|
||||
* Increasing pitch values the equivalent of looking down.
|
||||
*/
|
||||
public setPitch(pitch: number): void;
|
||||
/**
|
||||
* Gets the pitch of this location, measured in degrees.
|
||||
* <ul>
|
||||
* <li>A pitch of 0 represents level forward facing.
|
||||
* <li>A pitch of 90 represents downward facing, or negative y
|
||||
* direction.
|
||||
* <li>A pitch of -90 represents upward facing, or positive y direction.
|
||||
* </ul>
|
||||
* Increasing pitch values the equivalent of looking down.
|
||||
*/
|
||||
public getPitch(): number;
|
||||
/**
|
||||
* Gets a unit-vector pointing in the direction that this Location is
|
||||
* facing.
|
||||
*/
|
||||
public getDirection(): org.bukkit.util.Vector;
|
||||
/**
|
||||
* Sets the {@link #getYaw() yaw} and {@link #getPitch() pitch} to point
|
||||
* in the direction of the vector.
|
||||
*/
|
||||
public setDirection(vector: org.bukkit.util.Vector): org.bukkit.Location;
|
||||
/**
|
||||
* Adds the location by another.
|
||||
*/
|
||||
public add(vec: org.bukkit.Location): org.bukkit.Location;
|
||||
/**
|
||||
* Adds the location by a vector.
|
||||
*/
|
||||
public add(vec: org.bukkit.util.Vector): org.bukkit.Location;
|
||||
/**
|
||||
* Adds the location by another. Not world-aware.
|
||||
*/
|
||||
public add(x: number, y: number, z: number): org.bukkit.Location;
|
||||
/**
|
||||
* Subtracts the location by another.
|
||||
*/
|
||||
public subtract(vec: org.bukkit.Location): org.bukkit.Location;
|
||||
/**
|
||||
* Subtracts the location by a vector.
|
||||
*/
|
||||
public subtract(vec: org.bukkit.util.Vector): org.bukkit.Location;
|
||||
/**
|
||||
* Subtracts the location by another. Not world-aware and
|
||||
* orientation independent.
|
||||
*/
|
||||
public subtract(x: number, y: number, z: number): org.bukkit.Location;
|
||||
/**
|
||||
* Gets the magnitude of the location, defined as sqrt(x^2+y^2+z^2). The
|
||||
* value of this method is not cached and uses a costly square-root
|
||||
* function, so do not repeatedly call this method to get the location's
|
||||
* magnitude. NaN will be returned if the inner result of the sqrt()
|
||||
* function overflows, which will be caused if the length is too long. Not
|
||||
* world-aware and orientation independent.
|
||||
*/
|
||||
public length(): number;
|
||||
/**
|
||||
* Gets the magnitude of the location squared. Not world-aware and
|
||||
* orientation independent.
|
||||
*/
|
||||
public lengthSquared(): number;
|
||||
/**
|
||||
* Get the distance between this location and another. The value of this
|
||||
* method is not cached and uses a costly square-root function, so do not
|
||||
* repeatedly call this method to get the location's magnitude. NaN will
|
||||
* be returned if the inner result of the sqrt() function overflows, which
|
||||
* will be caused if the distance is too long.
|
||||
*/
|
||||
public distance(o: org.bukkit.Location): number;
|
||||
/**
|
||||
* Get the squared distance between this location and another.
|
||||
*/
|
||||
public distanceSquared(o: org.bukkit.Location): number;
|
||||
/**
|
||||
* Performs scalar multiplication, multiplying all components with a
|
||||
* scalar. Not world-aware.
|
||||
*/
|
||||
public multiply(m: number): org.bukkit.Location;
|
||||
/**
|
||||
* Zero this location's components. Not world-aware.
|
||||
*/
|
||||
public zero(): org.bukkit.Location;
|
||||
public equals(obj: any): boolean;
|
||||
public hashCode(): number;
|
||||
public toString(): string;
|
||||
/**
|
||||
* Constructs a new {@link Vector} based on this Location
|
||||
*/
|
||||
public toVector(): org.bukkit.util.Vector;
|
||||
public clone(): org.bukkit.Location;
|
||||
/**
|
||||
* Check if each component of this Location is finite.
|
||||
*/
|
||||
public checkFinite(): void;
|
||||
/**
|
||||
* Safely converts a double (location coordinate) to an int (block
|
||||
* coordinate)
|
||||
*/
|
||||
public static locToBlock(loc: number): number;
|
||||
public serialize(): Map<any, any> /*java.util.Map*/;
|
||||
/**
|
||||
* Required method for deserialization
|
||||
*/
|
||||
public static deserialize(args: Map<any, any> /*java.util.Map*/): org.bukkit.Location;
|
||||
/**
|
||||
* Normalizes the given yaw angle to a value between <code>+/-180</code>
|
||||
* degrees.
|
||||
*/
|
||||
public static normalizeYaw(yaw: number): number;
|
||||
/**
|
||||
* Normalizes the given pitch angle to a value between <code>+/-90</code>
|
||||
* degrees.
|
||||
*/
|
||||
public static normalizePitch(pitch: number): number;
|
||||
}
|
||||
}
|
||||
}
|
||||
File diff suppressed because it is too large
Load Diff
@@ -1,24 +0,0 @@
|
||||
declare namespace org {
|
||||
namespace bukkit {
|
||||
class Nameable {
|
||||
/**
|
||||
* Gets the custom name on a mob or block. If there is no name this method
|
||||
* will return null.
|
||||
* <p>
|
||||
* This value has no effect on players, they will always use their real
|
||||
* name.
|
||||
*/
|
||||
public getCustomName(): string;
|
||||
/**
|
||||
* Sets a custom name on a mob or block. This name will be used in death
|
||||
* messages and can be sent to the client as a nameplate over the mob.
|
||||
* <p>
|
||||
* Setting the name to null or an empty string will clear it.
|
||||
* <p>
|
||||
* This value has no effect on players, they will always use their real
|
||||
* name.
|
||||
*/
|
||||
public setCustomName(name: string): void;
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,35 +0,0 @@
|
||||
declare namespace org {
|
||||
namespace bukkit {
|
||||
class NamespacedKey {
|
||||
/**
|
||||
* Create a key in a specific namespace.
|
||||
*/
|
||||
constructor(namespace: string, key: string)
|
||||
/**
|
||||
* Create a key in the plugin's namespace.
|
||||
* <p>
|
||||
* Namespaces may only contain lowercase alphanumeric characters, periods,
|
||||
* underscores, and hyphens.
|
||||
* <p>
|
||||
* Keys may only contain lowercase alphanumeric characters, periods,
|
||||
* underscores, hyphens, and forward slashes.
|
||||
*/
|
||||
constructor(plugin: org.bukkit.plugin.Plugin, key: string)
|
||||
public static MINECRAFT: string;
|
||||
public static BUKKIT: string;
|
||||
public getNamespace(): string;
|
||||
public getKey(): string;
|
||||
public hashCode(): number;
|
||||
public equals(obj: any): boolean;
|
||||
public toString(): string;
|
||||
/**
|
||||
* Return a new random key in the {@link #BUKKIT} namespace.
|
||||
*/
|
||||
public static randomKey(): org.bukkit.NamespacedKey;
|
||||
/**
|
||||
* Get a key in the Minecraft namespace.
|
||||
*/
|
||||
public static minecraft(key: string): org.bukkit.NamespacedKey;
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,12 +0,0 @@
|
||||
declare namespace org {
|
||||
namespace bukkit {
|
||||
class NetherWartsState {
|
||||
public static SEEDED: org.bukkit.NetherWartsState;
|
||||
public static STAGE_ONE: org.bukkit.NetherWartsState;
|
||||
public static STAGE_TWO: org.bukkit.NetherWartsState;
|
||||
public static RIPE: org.bukkit.NetherWartsState;
|
||||
public static values(): org.bukkit.NetherWartsState[];
|
||||
public static valueOf(name: string): org.bukkit.NetherWartsState;
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,40 +0,0 @@
|
||||
declare namespace org {
|
||||
namespace bukkit {
|
||||
namespace Note {
|
||||
class Tone {
|
||||
public static G: org.bukkit.Note.Tone;
|
||||
public static A: org.bukkit.Note.Tone;
|
||||
public static B: org.bukkit.Note.Tone;
|
||||
public static C: org.bukkit.Note.Tone;
|
||||
public static D: org.bukkit.Note.Tone;
|
||||
public static E: org.bukkit.Note.Tone;
|
||||
public static F: org.bukkit.Note.Tone;
|
||||
public static TONES_COUNT: number;
|
||||
public static values(): org.bukkit.Note.Tone[];
|
||||
public static valueOf(name: string): org.bukkit.Note.Tone;
|
||||
/**
|
||||
* Returns the not sharped id of this tone.
|
||||
*/
|
||||
public getId(): number;
|
||||
/**
|
||||
* Returns the id of this tone. These method allows to return the
|
||||
* sharped id of the tone. If the tone couldn't be sharped it always
|
||||
* return the not sharped id of this tone.
|
||||
*/
|
||||
public getId(sharped: boolean): number;
|
||||
/**
|
||||
* Returns if this tone could be sharped.
|
||||
*/
|
||||
public isSharpable(): boolean;
|
||||
/**
|
||||
* Returns if this tone id is the sharped id of the tone.
|
||||
*/
|
||||
public isSharped(id: number): boolean;
|
||||
/**
|
||||
* Returns the tone to id. Also returning the semitones.
|
||||
*/
|
||||
public static getById(id: number): org.bukkit.Note.Tone;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,47 +0,0 @@
|
||||
declare namespace org {
|
||||
namespace bukkit {
|
||||
class Note {
|
||||
/**
|
||||
* Creates a new note.
|
||||
*/
|
||||
constructor(note: number)
|
||||
/**
|
||||
* Creates a new note.
|
||||
*/
|
||||
constructor(octave: number, tone: org.bukkit.Note.Tone, sharped: boolean)
|
||||
/**
|
||||
* Creates a new note for a flat tone, such as A-flat.
|
||||
*/
|
||||
public static flat(octave: number, tone: org.bukkit.Note.Tone): org.bukkit.Note;
|
||||
/**
|
||||
* Creates a new note for a sharp tone, such as A-sharp.
|
||||
*/
|
||||
public static sharp(octave: number, tone: org.bukkit.Note.Tone): org.bukkit.Note;
|
||||
/**
|
||||
* Creates a new note for a natural tone, such as A-natural.
|
||||
*/
|
||||
public static natural(octave: number, tone: org.bukkit.Note.Tone): org.bukkit.Note;
|
||||
public sharped(): org.bukkit.Note;
|
||||
public flattened(): org.bukkit.Note;
|
||||
/**
|
||||
* Returns the internal id of this note.
|
||||
*/
|
||||
public getId(): number;
|
||||
/**
|
||||
* Returns the octave of this note.
|
||||
*/
|
||||
public getOctave(): number;
|
||||
/**
|
||||
* Returns the tone of this note.
|
||||
*/
|
||||
public getTone(): org.bukkit.Note.Tone;
|
||||
/**
|
||||
* Returns if this note is sharped.
|
||||
*/
|
||||
public isSharped(): boolean;
|
||||
public hashCode(): number;
|
||||
public equals(obj: any): boolean;
|
||||
public toString(): string;
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,67 +0,0 @@
|
||||
declare namespace org {
|
||||
namespace bukkit {
|
||||
class OfflinePlayer {
|
||||
/**
|
||||
* Checks if this player is currently online
|
||||
*/
|
||||
public isOnline(): boolean;
|
||||
/**
|
||||
* Returns the name of this player
|
||||
* <p>
|
||||
* Names are no longer unique past a single game session. For persistent storage
|
||||
* it is recommended that you use {@link #getUniqueId()} instead.
|
||||
*/
|
||||
public getName(): string;
|
||||
/**
|
||||
* Returns the UUID of this player
|
||||
*/
|
||||
public getUniqueId(): any;
|
||||
/**
|
||||
* Checks if this player is banned or not
|
||||
*/
|
||||
public isBanned(): boolean;
|
||||
/**
|
||||
* Checks if this player is whitelisted or not
|
||||
*/
|
||||
public isWhitelisted(): boolean;
|
||||
/**
|
||||
* Sets if this player is whitelisted or not
|
||||
*/
|
||||
public setWhitelisted(value: boolean): void;
|
||||
/**
|
||||
* Gets a {@link Player} object that this represents, if there is one
|
||||
* <p>
|
||||
* If the player is online, this will return that player. Otherwise,
|
||||
* it will return null.
|
||||
*/
|
||||
public getPlayer(): org.bukkit.entity.Player;
|
||||
/**
|
||||
* Gets the first date and time that this player was witnessed on this
|
||||
* server.
|
||||
* <p>
|
||||
* If the player has never played before, this will return 0. Otherwise,
|
||||
* it will be the amount of milliseconds since midnight, January 1, 1970
|
||||
* UTC.
|
||||
*/
|
||||
public getFirstPlayed(): number;
|
||||
/**
|
||||
* Gets the last date and time that this player was witnessed on this
|
||||
* server.
|
||||
* <p>
|
||||
* If the player has never played before, this will return 0. Otherwise,
|
||||
* it will be the amount of milliseconds since midnight, January 1, 1970
|
||||
* UTC.
|
||||
*/
|
||||
public getLastPlayed(): number;
|
||||
/**
|
||||
* Checks if this player has played on this server before.
|
||||
*/
|
||||
public hasPlayedBefore(): boolean;
|
||||
/**
|
||||
* Gets the Location where the player will spawn at their bed, null if
|
||||
* they have not slept in one or their current bed spawn is invalid.
|
||||
*/
|
||||
public getBedSpawnLocation(): org.bukkit.Location;
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,17 +0,0 @@
|
||||
declare namespace org {
|
||||
namespace bukkit {
|
||||
namespace Particle {
|
||||
class DustOptions {
|
||||
constructor(color: org.bukkit.Color, size: number)
|
||||
/**
|
||||
* The color of the particles to be displayed.
|
||||
*/
|
||||
public getColor(): org.bukkit.Color;
|
||||
/**
|
||||
* Relative size of the particle.
|
||||
*/
|
||||
public getSize(): number;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,76 +0,0 @@
|
||||
declare namespace org {
|
||||
namespace bukkit {
|
||||
class Particle {
|
||||
public static EXPLOSION_NORMAL: org.bukkit.Particle;
|
||||
public static EXPLOSION_LARGE: org.bukkit.Particle;
|
||||
public static EXPLOSION_HUGE: org.bukkit.Particle;
|
||||
public static FIREWORKS_SPARK: org.bukkit.Particle;
|
||||
public static WATER_BUBBLE: org.bukkit.Particle;
|
||||
public static WATER_SPLASH: org.bukkit.Particle;
|
||||
public static WATER_WAKE: org.bukkit.Particle;
|
||||
public static SUSPENDED: org.bukkit.Particle;
|
||||
public static SUSPENDED_DEPTH: org.bukkit.Particle;
|
||||
public static CRIT: org.bukkit.Particle;
|
||||
public static CRIT_MAGIC: org.bukkit.Particle;
|
||||
public static SMOKE_NORMAL: org.bukkit.Particle;
|
||||
public static SMOKE_LARGE: org.bukkit.Particle;
|
||||
public static SPELL: org.bukkit.Particle;
|
||||
public static SPELL_INSTANT: org.bukkit.Particle;
|
||||
public static SPELL_MOB: org.bukkit.Particle;
|
||||
public static SPELL_MOB_AMBIENT: org.bukkit.Particle;
|
||||
public static SPELL_WITCH: org.bukkit.Particle;
|
||||
public static DRIP_WATER: org.bukkit.Particle;
|
||||
public static DRIP_LAVA: org.bukkit.Particle;
|
||||
public static VILLAGER_ANGRY: org.bukkit.Particle;
|
||||
public static VILLAGER_HAPPY: org.bukkit.Particle;
|
||||
public static TOWN_AURA: org.bukkit.Particle;
|
||||
public static NOTE: org.bukkit.Particle;
|
||||
public static PORTAL: org.bukkit.Particle;
|
||||
public static ENCHANTMENT_TABLE: org.bukkit.Particle;
|
||||
public static FLAME: org.bukkit.Particle;
|
||||
public static LAVA: org.bukkit.Particle;
|
||||
public static CLOUD: org.bukkit.Particle;
|
||||
public static REDSTONE: org.bukkit.Particle;
|
||||
public static SNOWBALL: org.bukkit.Particle;
|
||||
public static SNOW_SHOVEL: org.bukkit.Particle;
|
||||
public static SLIME: org.bukkit.Particle;
|
||||
public static HEART: org.bukkit.Particle;
|
||||
public static BARRIER: org.bukkit.Particle;
|
||||
public static ITEM_CRACK: org.bukkit.Particle;
|
||||
public static BLOCK_CRACK: org.bukkit.Particle;
|
||||
public static BLOCK_DUST: org.bukkit.Particle;
|
||||
public static WATER_DROP: org.bukkit.Particle;
|
||||
public static MOB_APPEARANCE: org.bukkit.Particle;
|
||||
public static DRAGON_BREATH: org.bukkit.Particle;
|
||||
public static END_ROD: org.bukkit.Particle;
|
||||
public static DAMAGE_INDICATOR: org.bukkit.Particle;
|
||||
public static SWEEP_ATTACK: org.bukkit.Particle;
|
||||
public static FALLING_DUST: org.bukkit.Particle;
|
||||
public static TOTEM: org.bukkit.Particle;
|
||||
public static SPIT: org.bukkit.Particle;
|
||||
public static SQUID_INK: org.bukkit.Particle;
|
||||
public static BUBBLE_POP: org.bukkit.Particle;
|
||||
public static CURRENT_DOWN: org.bukkit.Particle;
|
||||
public static BUBBLE_COLUMN_UP: org.bukkit.Particle;
|
||||
public static NAUTILUS: org.bukkit.Particle;
|
||||
public static DOLPHIN: org.bukkit.Particle;
|
||||
public static SNEEZE: org.bukkit.Particle;
|
||||
public static CAMPFIRE_COSY_SMOKE: org.bukkit.Particle;
|
||||
public static CAMPFIRE_SIGNAL_SMOKE: org.bukkit.Particle;
|
||||
public static COMPOSTER: org.bukkit.Particle;
|
||||
public static FLASH: org.bukkit.Particle;
|
||||
public static FALLING_LAVA: org.bukkit.Particle;
|
||||
public static LANDING_LAVA: org.bukkit.Particle;
|
||||
public static FALLING_WATER: org.bukkit.Particle;
|
||||
public static LEGACY_BLOCK_CRACK: org.bukkit.Particle;
|
||||
public static LEGACY_BLOCK_DUST: org.bukkit.Particle;
|
||||
public static LEGACY_FALLING_DUST: org.bukkit.Particle;
|
||||
public static values(): org.bukkit.Particle[];
|
||||
public static valueOf(name: string): org.bukkit.Particle;
|
||||
/**
|
||||
* Returns the required data type for the particle
|
||||
*/
|
||||
public getDataType(): any;
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,11 +0,0 @@
|
||||
declare namespace org {
|
||||
namespace bukkit {
|
||||
class PortalType {
|
||||
public static NETHER: org.bukkit.PortalType;
|
||||
public static ENDER: org.bukkit.PortalType;
|
||||
public static CUSTOM: org.bukkit.PortalType;
|
||||
public static values(): org.bukkit.PortalType[];
|
||||
public static valueOf(name: string): org.bukkit.PortalType;
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,12 +0,0 @@
|
||||
declare namespace org {
|
||||
namespace bukkit {
|
||||
namespace Registry {
|
||||
class SimpleRegistry {
|
||||
constructor(type: any)
|
||||
constructor(type: any, predicate: any)
|
||||
public get(key: org.bukkit.NamespacedKey): any;
|
||||
public iterator(): any;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,22 +0,0 @@
|
||||
declare namespace org {
|
||||
namespace bukkit {
|
||||
class Registry {
|
||||
public static ADVANCEMENT: org.bukkit.Registry;
|
||||
public static ART: org.bukkit.Registry;
|
||||
public static BIOME: org.bukkit.Registry;
|
||||
public static BOSS_BARS: org.bukkit.Registry;
|
||||
public static ENCHANTMENT: org.bukkit.Registry;
|
||||
public static ENTITY_TYPE: org.bukkit.Registry;
|
||||
public static LOOT_TABLES: org.bukkit.Registry;
|
||||
public static MATERIAL: org.bukkit.Registry;
|
||||
public static STATISTIC: org.bukkit.Registry;
|
||||
public static VILLAGER_PROFESSION: org.bukkit.Registry;
|
||||
public static VILLAGER_TYPE: org.bukkit.Registry;
|
||||
public static MEMORY_MODULE_TYPE: org.bukkit.Registry;
|
||||
/**
|
||||
* Get the object by its key.
|
||||
*/
|
||||
public get(key: org.bukkit.NamespacedKey): org.bukkit.Keyed;
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,24 +0,0 @@
|
||||
declare namespace org {
|
||||
namespace bukkit {
|
||||
class Rotation {
|
||||
public static NONE: org.bukkit.Rotation;
|
||||
public static CLOCKWISE_45: org.bukkit.Rotation;
|
||||
public static CLOCKWISE: org.bukkit.Rotation;
|
||||
public static CLOCKWISE_135: org.bukkit.Rotation;
|
||||
public static FLIPPED: org.bukkit.Rotation;
|
||||
public static FLIPPED_45: org.bukkit.Rotation;
|
||||
public static COUNTER_CLOCKWISE: org.bukkit.Rotation;
|
||||
public static COUNTER_CLOCKWISE_45: org.bukkit.Rotation;
|
||||
public static values(): org.bukkit.Rotation[];
|
||||
public static valueOf(name: string): org.bukkit.Rotation;
|
||||
/**
|
||||
* Rotate clockwise by 90 degrees.
|
||||
*/
|
||||
public rotateClockwise(): org.bukkit.Rotation;
|
||||
/**
|
||||
* Rotate counter-clockwise by 90 degrees.
|
||||
*/
|
||||
public rotateCounterClockwise(): org.bukkit.Rotation;
|
||||
}
|
||||
}
|
||||
}
|
||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user