Allow cancelling an activity without aborting the entire queue
This commit is contained in:
committed by
Paul Chote
parent
3111b2cf9b
commit
f9951f76ca
@@ -201,7 +201,7 @@ namespace OpenRA.Activities
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
protected virtual void OnLastRun(Actor self) { }
|
protected virtual void OnLastRun(Actor self) { }
|
||||||
|
|
||||||
public virtual bool Cancel(Actor self)
|
public virtual bool Cancel(Actor self, bool keepQueue = false)
|
||||||
{
|
{
|
||||||
if (!IsInterruptible)
|
if (!IsInterruptible)
|
||||||
return false;
|
return false;
|
||||||
@@ -209,9 +209,11 @@ namespace OpenRA.Activities
|
|||||||
if (ChildActivity != null && !ChildActivity.Cancel(self))
|
if (ChildActivity != null && !ChildActivity.Cancel(self))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
State = ActivityState.Canceled;
|
if (!keepQueue)
|
||||||
NextActivity = null;
|
NextActivity = null;
|
||||||
|
|
||||||
ChildActivity = null;
|
ChildActivity = null;
|
||||||
|
State = ActivityState.Canceled;
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -207,7 +207,7 @@ namespace OpenRA.Mods.Common.Activities
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
public override bool Cancel(Actor self)
|
public override bool Cancel(Actor self, bool keepQueue = false)
|
||||||
{
|
{
|
||||||
if (!IsCanceled && innerActivity != null && !innerActivity.Cancel(self))
|
if (!IsCanceled && innerActivity != null && !innerActivity.Cancel(self))
|
||||||
return false;
|
return false;
|
||||||
|
|||||||
@@ -112,7 +112,7 @@ namespace OpenRA.Mods.Common.Activities
|
|||||||
inner.Cancel(self);
|
inner.Cancel(self);
|
||||||
}
|
}
|
||||||
|
|
||||||
public override bool Cancel(Actor self)
|
public override bool Cancel(Actor self, bool keepQueue = false)
|
||||||
{
|
{
|
||||||
AbortOrExit(self);
|
AbortOrExit(self);
|
||||||
if (nextState < EnterState.Exiting)
|
if (nextState < EnterState.Exiting)
|
||||||
|
|||||||
@@ -81,7 +81,7 @@ namespace OpenRA.Mods.Common.Activities
|
|||||||
throw new InvalidOperationException("Invalid harvester dock state");
|
throw new InvalidOperationException("Invalid harvester dock state");
|
||||||
}
|
}
|
||||||
|
|
||||||
public override bool Cancel(Actor self)
|
public override bool Cancel(Actor self, bool keepQueue = false)
|
||||||
{
|
{
|
||||||
dockingState = DockingState.Undock;
|
dockingState = DockingState.Undock;
|
||||||
return base.Cancel(self);
|
return base.Cancel(self);
|
||||||
|
|||||||
@@ -46,12 +46,12 @@ namespace OpenRA.Mods.Common.Activities
|
|||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public override bool Cancel(Actor self)
|
public override bool Cancel(Actor self, bool keepQueue = false)
|
||||||
{
|
{
|
||||||
if (!IsCanceled && inner != null && !inner.Cancel(self))
|
if (!IsCanceled && inner != null && !inner.Cancel(self))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
return base.Cancel(self);
|
return base.Cancel(self, keepQueue);
|
||||||
}
|
}
|
||||||
|
|
||||||
public override IEnumerable<Target> GetTargets(Actor self)
|
public override IEnumerable<Target> GetTargets(Actor self)
|
||||||
|
|||||||
@@ -334,9 +334,9 @@ namespace OpenRA.Mods.Common.Activities
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public override bool Cancel(Actor self)
|
public override bool Cancel(Actor self, bool keepQueue = false)
|
||||||
{
|
{
|
||||||
Move.Cancel(self);
|
Move.Cancel(self, keepQueue);
|
||||||
return base.Cancel(self);
|
return base.Cancel(self);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -161,7 +161,7 @@ namespace OpenRA.Mods.Common.Activities
|
|||||||
return Target.None;
|
return Target.None;
|
||||||
}
|
}
|
||||||
|
|
||||||
public override bool Cancel(Actor self)
|
public override bool Cancel(Actor self, bool keepQueue = false)
|
||||||
{
|
{
|
||||||
if (!IsCanceled && inner != null && !inner.Cancel(self))
|
if (!IsCanceled && inner != null && !inner.Cancel(self))
|
||||||
return false;
|
return false;
|
||||||
|
|||||||
@@ -157,12 +157,12 @@ namespace OpenRA.Mods.Common.Activities
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
public override bool Cancel(Actor self)
|
public override bool Cancel(Actor self, bool keepQueue = false)
|
||||||
{
|
{
|
||||||
if (!IsCanceled && innerActivity != null && !innerActivity.Cancel(self))
|
if (!IsCanceled && innerActivity != null && !innerActivity.Cancel(self))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
return base.Cancel(self);
|
return base.Cancel(self, keepQueue);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -30,9 +30,9 @@ namespace OpenRA.Mods.Common.Activities
|
|||||||
return (remainingTicks-- == 0) ? NextActivity : this;
|
return (remainingTicks-- == 0) ? NextActivity : this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public override bool Cancel(Actor self)
|
public override bool Cancel(Actor self, bool keepQueue = false)
|
||||||
{
|
{
|
||||||
if (!base.Cancel(self))
|
if (!base.Cancel(self, keepQueue))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
remainingTicks = 0;
|
remainingTicks = 0;
|
||||||
@@ -56,9 +56,9 @@ namespace OpenRA.Mods.Common.Activities
|
|||||||
return (f == null || f()) ? NextActivity : this;
|
return (f == null || f()) ? NextActivity : this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public override bool Cancel(Actor self)
|
public override bool Cancel(Actor self, bool keepQueue = false)
|
||||||
{
|
{
|
||||||
if (!base.Cancel(self))
|
if (!base.Cancel(self, keepQueue))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
f = null;
|
f = null;
|
||||||
|
|||||||
@@ -41,12 +41,12 @@ namespace OpenRA.Mods.Common.Activities
|
|||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public override bool Cancel(Actor self)
|
public override bool Cancel(Actor self, bool keepQueue = false)
|
||||||
{
|
{
|
||||||
if (!IsCanceled && inner != null && !inner.Cancel(self))
|
if (!IsCanceled && inner != null && !inner.Cancel(self))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
return base.Cancel(self);
|
return base.Cancel(self, keepQueue);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -43,9 +43,9 @@ namespace OpenRA.Mods.Common.Activities
|
|||||||
return NextActivity;
|
return NextActivity;
|
||||||
}
|
}
|
||||||
|
|
||||||
public override bool Cancel(Actor self)
|
public override bool Cancel(Actor self, bool keepQueue = false)
|
||||||
{
|
{
|
||||||
if (!base.Cancel(self))
|
if (!base.Cancel(self, keepQueue))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
Dispose();
|
Dispose();
|
||||||
|
|||||||
Reference in New Issue
Block a user