feat: add callSyncMethod
Signed-off-by: MiaoWoo <admin@yumc.pw>
This commit is contained in:
parent
94ebbf3cba
commit
9546881691
@ -4,6 +4,7 @@ export namespace task {
|
|||||||
export const TaskManager = Symbol('TaskManager')
|
export const TaskManager = Symbol('TaskManager')
|
||||||
export interface TaskManager {
|
export interface TaskManager {
|
||||||
create(func: Function): task.Task;
|
create(func: Function): task.Task;
|
||||||
|
callSyncMethod(func: Function): any;
|
||||||
}
|
}
|
||||||
/**
|
/**
|
||||||
* 任务抽象
|
* 任务抽象
|
||||||
|
@ -1,7 +1,9 @@
|
|||||||
import { task, plugin } from '@ms/api'
|
import { task, plugin } from '@ms/api'
|
||||||
import { injectable, inject } from '@ms/container';
|
import { injectable, inject } from '@ms/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()
|
@injectable()
|
||||||
export class BukkitTaskManager implements task.TaskManager {
|
export class BukkitTaskManager implements task.TaskManager {
|
||||||
@ -12,6 +14,9 @@ export class BukkitTaskManager implements task.TaskManager {
|
|||||||
if (Object.prototype.toString.call(func) !== "[object Function]") { throw TypeError('第一个参数 Task 必须为 function !'); };
|
if (Object.prototype.toString.call(func) !== "[object Function]") { throw TypeError('第一个参数 Task 必须为 function !'); };
|
||||||
return new BukkitTask(this.pluginInstance, func);
|
return new BukkitTask(this.pluginInstance, func);
|
||||||
}
|
}
|
||||||
|
callSyncMethod(func: Function): any {
|
||||||
|
return Bukkit.getScheduler().callSyncMethod(this.pluginInstance, new Callable({ call: () => func() })).get()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
export class BukkitTask extends task.Task {
|
export class BukkitTask extends task.Task {
|
||||||
|
@ -13,6 +13,9 @@ export class BungeeTaskManager implements task.TaskManager {
|
|||||||
if (Object.prototype.toString.call(func) !== "[object Function]") { throw TypeError('第一个参数 Task 必须为 function !'); };
|
if (Object.prototype.toString.call(func) !== "[object Function]") { throw TypeError('第一个参数 Task 必须为 function !'); };
|
||||||
return new BungeeTask(this.pluginInstance, func);
|
return new BungeeTask(this.pluginInstance, func);
|
||||||
}
|
}
|
||||||
|
callSyncMethod(func: Function): any {
|
||||||
|
return func();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
export class BungeeTask extends task.Task {
|
export class BungeeTask extends task.Task {
|
||||||
|
@ -1,8 +1,11 @@
|
|||||||
import { task, plugin } from '@ms/api'
|
import { task, plugin } from '@ms/api'
|
||||||
import { injectable, inject } from '@ms/container';
|
import { injectable, inject } from '@ms/container';
|
||||||
|
|
||||||
var Consumer = Java.type('java.util.function.Consumer');
|
const Sponge = Java.type("org.spongepowered.api.Sponge");
|
||||||
var Task = Java.type("org.spongepowered.api.scheduler.Task");
|
const Task = Java.type("org.spongepowered.api.scheduler.Task");
|
||||||
|
const Consumer = Java.type('java.util.function.Consumer');
|
||||||
|
const Callable = Java.type('java.util.concurrent.Callable');
|
||||||
|
const TimeUnit = Java.type('java.util.concurrent.TimeUnit');
|
||||||
|
|
||||||
@injectable()
|
@injectable()
|
||||||
export class SpongeTaskManager implements task.TaskManager {
|
export class SpongeTaskManager implements task.TaskManager {
|
||||||
@ -13,6 +16,9 @@ export class SpongeTaskManager implements task.TaskManager {
|
|||||||
if (Object.prototype.toString.call(func) !== "[object Function]") { throw TypeError('第一个参数 Task 必须为 function !'); };
|
if (Object.prototype.toString.call(func) !== "[object Function]") { throw TypeError('第一个参数 Task 必须为 function !'); };
|
||||||
return new SpongeTask(this.pluginInstance, func);
|
return new SpongeTask(this.pluginInstance, func);
|
||||||
}
|
}
|
||||||
|
callSyncMethod(func: Function): any {
|
||||||
|
return Sponge.getScheduler().createSyncExecutor(this.pluginInstance).schedule(new Callable({ call: () => func() }), 0, TimeUnit.NANOSECONDS).get()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
export class SpongeTask extends task.Task {
|
export class SpongeTask extends task.Task {
|
||||||
|
Loading…
Reference in New Issue
Block a user