Upgrade structure of code base
This commit is contained in:
@@ -1,32 +1,13 @@
|
||||
using Enigmos.Exceptions;
|
||||
using Enigmos.Modules.ControllingModules;
|
||||
using Enigmos.Ports.DataPorts;
|
||||
using Nocturnis.Enigmos.Modules;
|
||||
using Nocturnis.Enigmos.Modules.ComputationalModules;
|
||||
using Nocturnis.Enigmos.Ports.DataPorts.Directions;
|
||||
|
||||
namespace Enigmos.Modules.ComputationalModules;
|
||||
|
||||
public abstract partial class ComputationalModule : BaseModule
|
||||
public abstract partial class ComputationalModule : BaseModule, IComputationalModule
|
||||
{
|
||||
protected override void TimeoutHandler(ModuleExecutionTimeout timeout)
|
||||
{
|
||||
foreach (DataOutPort port in Ports.OfType<DataOutPort>())
|
||||
port.DataUpdated = false;
|
||||
base.TimeoutHandler(timeout);
|
||||
}
|
||||
public IDataOutPort[] DataOutPorts { get; set; } = Array.Empty<IDataOutPort>();
|
||||
public abstract void Define();
|
||||
|
||||
protected abstract void Compute(IRootModule root);
|
||||
public void ComputeWithTimeoutHandle(IRootModule root)
|
||||
{
|
||||
foreach (DataOutPort port in Ports.OfType<DataOutPort>())
|
||||
port.DataUpdated = true;
|
||||
try
|
||||
{
|
||||
Compute(root);
|
||||
}
|
||||
catch (ModuleExecutionTimeout timeOut)
|
||||
{
|
||||
TimeoutHandler(timeOut);
|
||||
}
|
||||
TimeoutCheck(root);
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user