mirror of
https://github.com/Minestom/Minestom.git
synced 2025-01-20 07:02:32 +01:00
Merge Task#scheduleForShutdown
into Task#schedule
This commit is contained in:
parent
1c92414cad
commit
75964f87b4
@ -100,19 +100,7 @@ public class Task implements Runnable {
|
|||||||
* Sets up the task for correct execution.
|
* Sets up the task for correct execution.
|
||||||
*/
|
*/
|
||||||
public void schedule() {
|
public void schedule() {
|
||||||
Int2ObjectMap<Task> tasks = this.schedulerManager.tasks;
|
if(this.shutdown) {
|
||||||
synchronized (tasks) {
|
|
||||||
tasks.put(getId(), this);
|
|
||||||
}
|
|
||||||
if(owningExtension != null) {
|
|
||||||
this.schedulerManager.onScheduleFromExtension(owningExtension, this);
|
|
||||||
}
|
|
||||||
this.future = this.repeat == 0L ?
|
|
||||||
this.schedulerManager.getTimerExecutionService().schedule(this, this.delay, TimeUnit.MILLISECONDS) :
|
|
||||||
this.schedulerManager.getTimerExecutionService().scheduleAtFixedRate(this, this.delay, this.repeat, TimeUnit.MILLISECONDS);
|
|
||||||
}
|
|
||||||
|
|
||||||
public void scheduleForShutdown() {
|
|
||||||
Int2ObjectMap<Task> shutdownTasks = this.schedulerManager.shutdownTasks;
|
Int2ObjectMap<Task> shutdownTasks = this.schedulerManager.shutdownTasks;
|
||||||
synchronized (shutdownTasks) {
|
synchronized (shutdownTasks) {
|
||||||
shutdownTasks.put(getId(), this);
|
shutdownTasks.put(getId(), this);
|
||||||
@ -120,6 +108,18 @@ public class Task implements Runnable {
|
|||||||
if (owningExtension != null) {
|
if (owningExtension != null) {
|
||||||
this.schedulerManager.onScheduleShutdownFromExtension(owningExtension, this);
|
this.schedulerManager.onScheduleShutdownFromExtension(owningExtension, this);
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
Int2ObjectMap<Task> tasks = this.schedulerManager.tasks;
|
||||||
|
synchronized (tasks) {
|
||||||
|
tasks.put(getId(), this);
|
||||||
|
}
|
||||||
|
if (owningExtension != null) {
|
||||||
|
this.schedulerManager.onScheduleFromExtension(owningExtension, this);
|
||||||
|
}
|
||||||
|
this.future = this.repeat == 0L ?
|
||||||
|
this.schedulerManager.getTimerExecutionService().schedule(this, this.delay, TimeUnit.MILLISECONDS) :
|
||||||
|
this.schedulerManager.getTimerExecutionService().scheduleAtFixedRate(this, this.delay, this.repeat, TimeUnit.MILLISECONDS);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -162,11 +162,7 @@ public class TaskBuilder {
|
|||||||
@NotNull
|
@NotNull
|
||||||
public Task schedule() {
|
public Task schedule() {
|
||||||
Task task = build();
|
Task task = build();
|
||||||
if (this.shutdown) {
|
|
||||||
task.scheduleForShutdown();
|
|
||||||
} else {
|
|
||||||
task.schedule();
|
task.schedule();
|
||||||
}
|
|
||||||
return task;
|
return task;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user