Upgrade structure of code base

This commit is contained in:
h z
2024-07-03 12:20:08 +08:00
parent d382481cd4
commit 42e06a0d0c
82 changed files with 864 additions and 116 deletions

View File

@@ -0,0 +1,17 @@
using Nocturnis.DataStructures;
using Nocturnis.Enigmos.Ports.DataPorts.Directions;
using Skeleton.DataStructure;
namespace Nocturnis.Enigmos.Modules.ComputationalModules;
public static class EBinaryComputationalModule
{
public static IData X(this IBinaryComputationalModule p, CacheItem x) => p.DataInPorts[0].GetData.GetFrom(x)!;
public static IData Y(this IBinaryComputationalModule p, CacheItem x) => p.DataInPorts[1].GetData.GetFrom(x)!;
public static void BinaryInit(this IBinaryComputationalModule p)
{
p.DataInPorts = new IDataInPort[2];
p.DataInInit("Input", 2);
}
}

View File

@@ -0,0 +1,13 @@
using Nocturnis.Enigmos.Ports.DataPorts.Directions;
namespace Nocturnis.Enigmos.Modules.ComputationalModules;
public static class EComputationalModule
{
public static void DataOutInit(this IComputationalModule a, string prefix, int dI)
{
a.DataOutPorts = new IDataOutPort[dI];
for (int i = 1; i <= dI; i++)
a.DataOutPorts[i - 1] = a.GetPort<IDataOutPort>($"{prefix}{i}");
}
}

View File

@@ -0,0 +1,20 @@
using Godot;
using Nocturnis.Enigmos.Ports.DataPorts.Directions;
using Skeleton.DataStructure;
namespace Nocturnis.Enigmos.Modules.ComputationalModules;
public static class EDuplicateOutputModule
{
public static void Define(this IDuplicateOutputModule m, Func<CacheItem, (object, StringName)> define)
{
foreach (IDataOutPort op in m.DataOutPorts)
op.OutData.UpdateCalculation(define);
}
public static void SetOutputType(this IDuplicateOutputModule m, StringName type)
{
foreach (IDataOutPort op in m.DataOutPorts)
op.SetDataType(type);
}
}

View File

@@ -0,0 +1,15 @@
using Nocturnis.Enigmos.Ports.DataPorts.Directions;
using Nocturnis.GlobalManagement.Constants;
namespace Nocturnis.Enigmos.Modules.ComputationalModules;
public static class ELogicModule
{
public static void LogicModuleInit(this ILogicModule lm)
{
foreach (IDataOutPort op in lm.DataOutPorts)
op.SetDataType(EnigmosConstant.DataPortTypes.Bit);
foreach (IDataInPort ip in lm.DataInPorts)
ip.SetDataType(EnigmosConstant.DataPortTypes.Bit);
}
}

View File

@@ -0,0 +1,13 @@
using Godot;
using Nocturnis.Enigmos.Ports.DataPorts.Directions;
namespace Nocturnis.Enigmos.Modules.ComputationalModules;
public static class EOperationModule
{
public static void SetInputType(this IOperationModule m, StringName type)
{
foreach (IDataInPort ip in m.DataInPorts)
ip.SetDataType(type);
}
}

View File

@@ -0,0 +1,14 @@
using Nocturnis.DataStructures;
using Skeleton.DataStructure;
namespace Nocturnis.Enigmos.Modules.ComputationalModules;
public static class ETernaryComputationalModule
{
public static IData X(this ITernaryComputationalModule m, CacheItem cache) =>
m.DataOutPorts[0].OutData.GetFrom(cache)!;
public static IData Y(this ITernaryComputationalModule m, CacheItem cache) =>
m.DataOutPorts[1].OutData.GetFrom(cache)!;
public static IData Z(this ITernaryComputationalModule m, CacheItem cache) =>
m.DataOutPorts[2].OutData.GetFrom(cache)!;
}

View File

@@ -0,0 +1,10 @@
using Nocturnis.DataStructures;
using Skeleton.DataStructure;
namespace Nocturnis.Enigmos.Modules.ComputationalModules;
public static class EUnaryComputationalModule
{
public static IData X(this IUnaryComputationalModule m, CacheItem cache) =>
m.DataOutPorts[0].OutData.GetFrom(cache)!;
}

View File

@@ -0,0 +1,6 @@
namespace Nocturnis.Enigmos.Modules.ComputationalModules;
public interface IBinaryComputationalModule : IComputationalModule, IParameterModule
{
}

View File

@@ -0,0 +1,9 @@
using Nocturnis.Enigmos.Ports.DataPorts.Directions;
namespace Nocturnis.Enigmos.Modules.ComputationalModules;
public interface IComputationalModule : IBaseModule
{
IDataOutPort[] DataOutPorts { get; set; }
void Define();
}

View File

@@ -0,0 +1,6 @@
namespace Nocturnis.Enigmos.Modules.ComputationalModules;
public interface IDuplicateOutputModule : IComputationalModule
{
}

View File

@@ -0,0 +1,6 @@
namespace Nocturnis.Enigmos.Modules.ComputationalModules;
public interface IOperationModule : IParameterModule
{
}

View File

@@ -0,0 +1,6 @@
namespace Nocturnis.Enigmos.Modules.ComputationalModules;
public interface ITernaryComputationalModule: IParameterModule, IComputationalModule
{
}

View File

@@ -0,0 +1,6 @@
namespace Nocturnis.Enigmos.Modules.ComputationalModules;
public interface IUnaryComputationalModule: IComputationalModule, IOperationModule
{
}

View File

@@ -0,0 +1,19 @@
using Godot;
using Nocturnis.Enigmos.Ports;
namespace Nocturnis.Enigmos.Modules;
public static class EBaseModule
{
public static TPort GetPort<TPort>(this IBaseModule m, NodePath path)
where TPort : IBasePort
{
if (m.GetNode(path) is TPort port)
{
port.Init();
return port;
}
throw new Exception("NOT A PORT");
}
}

View File

@@ -0,0 +1,62 @@
using Nocturnis.Communicators;
using Nocturnis.GlobalManagement.Constants;
using Nocturnis.GlobalManagement.Controls;
using Nocturnis.GlobalManagement.Providers;
namespace Nocturnis.Enigmos.Modules;
public static class ECommunicateModule
{
public static bool Paired(this ICommunicateModule module) => module.PairedCommunicator != null;
/// <summary>
/// Determine if the module can be paired with given communicator
/// </summary>
public static bool IsMatch(this ICommunicateModule module, IBaseCommunicator communicator) =>
module.CommunicationDataType == communicator.CommunicationDataType &&
GlobalProvider.EnigmosProvider!.CommunicationDirectionCompatible(
module.CommunicationDirection,
communicator.CommunicationDirection
);
/// <summary>
/// Pair the module with given communicator
/// </summary>
public static void Pair(this ICommunicateModule module, IBaseCommunicator communicator)
{
if(module.Paired())
module.Unpair();
module.PairedCommunicator = communicator;
communicator.PairedModule = module;
}
/// <summary>
/// Unpair the module with its paired communicator
/// </summary>
public static void Unpair(this ICommunicateModule module)
{
if (!module.Paired())
return;
module.PairedCommunicator!.PairedModule = null;
module.PairedCommunicator = null;
}
public static void SendData(this ICommunicateModule module)
{
if (!module.Paired() || module.CommunicationDirection == EnigmosConstant.CommunicationDirections.Receive)
return;
module.PairedCommunicator!.DataBuffer.Assign(module.DataBuffer, module.CommunicationDataType);
}
public static void ReceiveData(this ICommunicateModule module)
{
if (!module.Paired() || module.CommunicationDirection == EnigmosConstant.CommunicationDirections.Send)
return;
module.DataBuffer.Assign(module.PairedCommunicator!.DataBuffer, module.CommunicationDataType);
}
public static IBaseCommunicator[] CompatibleCommunicators(this ICommunicateModule module) =>
CreatureControl.Instance.CurrentCharacter!.DashboardTab.AllCommunicators
.Where(module.IsMatch)
.ToArray();
}

View File

@@ -0,0 +1,13 @@
using Nocturnis.Enigmos.Ports.SignalPorts.Directions;
namespace Nocturnis.Enigmos.Modules;
public static class EControllingModule
{
public static void SignalInInit(this IControllingModule m, string prefix, int sI)
{
m.SignalInPorts = new ISignalInPort[sI];
for (int i = 1; i <= sI; i++)
m.SignalInPorts[i - 1] = m.GetPort<ISignalInPort>($"{prefix}{i}");
}
}

View File

@@ -0,0 +1,13 @@
using Nocturnis.Enigmos.Ports.DataPorts.Directions;
namespace Nocturnis.Enigmos.Modules;
public static class EParameterModule
{
public static void DataInInit(this IParameterModule m, string prefix, int dI)
{
m.DataInPorts = new IDataInPort[dI];
for (int i = 1; i <= dI; i++)
m.DataInPorts[i - 1] = m.GetPort<IDataInPort>($"{prefix}{i}");
}
}

View File

@@ -0,0 +1,13 @@
using Nocturnis.Enigmos.Ports.SignalPorts.Directions;
namespace Nocturnis.Enigmos.Modules;
public static class ERoutingModule
{
public static void SignalOutInit(this IRoutingModule m, string prefix, int sO)
{
m.SignalOutPorts = new ISignalOutPort[sO];
for (int i = 1; i <= sO; i++)
m.SignalOutPorts[i - 1] = m.GetPort<ISignalOutPort>($"{prefix}{i}");
}
}

View File

@@ -0,0 +1,12 @@
using Nocturnis.Enigmos.Ports.DataPorts.Directions;
namespace Nocturnis.Enigmos.Modules;
public static class ESourceModule
{
public static void Reset(this ISourceModule m)
{
foreach (IDataOutPort port in m.DataOutPorts)
port.OutData.Expire();
}
}

View File

@@ -0,0 +1,14 @@
using Nocturnis.Enigmos.Ports.DataPorts.Directions;
namespace Nocturnis.Enigmos.Modules;
public static class ETerminalModule
{
public static void Consume(this ITerminalModule m)
{
foreach (IDataInPort ip in m.DataInPorts)
if(ip.GetData.Expired)
_ = ip.GetData.Get;
}
}

View File

@@ -0,0 +1,6 @@
namespace Nocturnis.Enigmos.Modules;
public interface IActionModule : IControllingModule
{
void Act();
}

View File

@@ -8,16 +8,19 @@ namespace Nocturnis.Enigmos.Modules;
public interface IBaseModule
{
IEnumerable<IBasePort> Ports { get; }
IBaseBoard Board { get; set; }
IBaseBoard? Board { get; set; }
Vector2 PositionToBoard { get; }
Vector2 Size { get; set; }
double MaintenanceAlpha { get; }
double MaintenanceBeta { get; }
string GetDescription { get; }
ISimpleLabel Label { get; }
ISimpleLabel? Label { get; }
Node AsNode { get; }
Vector2 Position { get; set; }
string LabelString { get; set; }
void UpdateCables();
}
//T GetPort<T>(NodePath path);
Node GetNode(NodePath path);
void Init();
}

View File

@@ -4,10 +4,10 @@ using Nocturnis.DataStructures;
namespace Nocturnis.Enigmos.Modules;
public interface ICommunicateModule
public interface ICommunicateModule : IBaseModule
{
IBaseCommunicator PairedCommunicator { get; set; }
IBaseCommunicator? PairedCommunicator { get; set; }
StringName CommunicationDataType { get; }
StringName CommunicationDirection { get; }
IDataPackage DataBuffer { get; set; }
IData DataBuffer { get; set; }
}

View File

@@ -4,6 +4,5 @@ namespace Nocturnis.Enigmos.Modules;
public interface IComputationalCompositeModule : ICompositeModule
{
void Compute(IRootModule root);
Vector2 PositionToBoard { get; }
}

View File

@@ -1,6 +1,10 @@
using Nocturnis.Enigmos.Ports.SignalPorts.Directions;
namespace Nocturnis.Enigmos.Modules;
public interface IControllingModule : IBaseModule
{
void RouteWithTimeoutHandle(IRootModule root);
}
ISignalInPort[] SignalInPorts { get; set; }
void Execute();
bool Visited { get; set; }
}

View File

@@ -1,6 +1,10 @@
using Nocturnis.DataStructures;
namespace Nocturnis.Enigmos.Modules;
public interface IFilterModule : IProgrammableModule
{
void FilterWithTimeoutHandle(IRootModule root);
}
void Filter();
IData[] CachedResult { get; set; }
}

View File

@@ -1,9 +0,0 @@
using Nocturnis.Enigmos.Ports;
namespace Nocturnis.Enigmos.Modules;
public interface IInterlayerDataInModule : IInterlayerModule
{
IInterlayerDataOutModule? DualModule { get; set; }
IDataInPort? DataIn { get; set; }
}

View File

@@ -1,9 +0,0 @@
using Nocturnis.Enigmos.Ports;
namespace Nocturnis.Enigmos.Modules;
public interface IInterlayerDataOutModule : IInterlayerModule
{
IInterlayerDataInModule? DualModule { get; set; }
IDataOutPort? DataOut { get; set; }
}

View File

@@ -1,9 +0,0 @@
using Nocturnis.Enigmos.Ports;
namespace Nocturnis.Enigmos.Modules;
public interface IInterlayerSignalInModule : IInterlayerModule
{
IInterlayerSignalOutModule? DualModule { get; set; }
ISignalInPort? SignalIn { get; set; }
}

View File

@@ -1,9 +0,0 @@
using Nocturnis.Enigmos.Ports;
namespace Nocturnis.Enigmos.Modules;
public interface IInterlayerSignalOutModule : IInterlayerModule
{
IInterlayerSignalInModule? DualModule { get; set; }
ISignalOutPort? SignalOut { get; set; }
}

View File

@@ -0,0 +1,8 @@
using Nocturnis.Enigmos.Modules.ComputationalModules;
namespace Nocturnis.Enigmos.Modules;
public interface ILogicModule : IComputationalModule, IParameterModule
{
}

View File

@@ -1,6 +1,10 @@
using Nocturnis.DataStructures;
namespace Nocturnis.Enigmos.Modules;
public interface IOptimizationModule : IProgrammableModule
{
void OptimizeWithTimeoutHandle(IRootModule root);
}
IData CachedResult { get; set; }
bool Calculated { get; set; }
void Optimize();
}

View File

@@ -0,0 +1,8 @@
using Nocturnis.Enigmos.Ports.DataPorts.Directions;
namespace Nocturnis.Enigmos.Modules;
public interface IParameterModule : IBaseModule
{
IDataInPort[] DataInPorts { get; set; }
}

View File

@@ -1,4 +1,3 @@
using Nocturnis.DataStructures;
using Nocturnis.DataStructures.ConfigurableParameters;
namespace Nocturnis.Enigmos.Modules;

View File

@@ -1,4 +1,4 @@
using Nocturnis.DataStructures;
using Nocturnis.DataStructures.DataPortGroups;
namespace Nocturnis.Enigmos.Modules;

View File

@@ -1,5 +1,3 @@
using Godot;
namespace Nocturnis.Enigmos.Modules;
public interface IProgrammableModule : IBaseModule

View File

@@ -3,10 +3,11 @@ using Nocturnis.Creatures;
namespace Nocturnis.Enigmos.Modules;
public interface IRootModule : IControllingModule
public interface IRootModule : IRoutingModule
{
Stopwatch? Timer { get; set; }
bool ActionFinished { get; set; }
IBaseCreature ManagedBy { get; set; }
IBaseCreature? ManagedBy { get; set; }
void Start();
}

View File

@@ -0,0 +1,9 @@
using Nocturnis.Enigmos.Ports.SignalPorts.Directions;
namespace Nocturnis.Enigmos.Modules;
public interface IRoutingModule : IBaseModule
{
ISignalOutPort[] SignalOutPorts { get; set; }
}

View File

@@ -0,0 +1,8 @@
using Nocturnis.Enigmos.Modules.ComputationalModules;
namespace Nocturnis.Enigmos.Modules;
public interface ISourceModule : IComputationalModule
{
}

View File

@@ -0,0 +1,7 @@
namespace Nocturnis.Enigmos.Modules;
public interface ITerminalModule : IParameterModule
{
void Drain();
}

View File

@@ -0,0 +1,11 @@
using Nocturnis.Enigmos.Ports.DataPorts.Directions;
namespace Nocturnis.Enigmos.Modules.InterlayerModules;
public interface IInterlayerDataInModule : IInterlayerModule, IParameterModule
{
new IInterlayerDataOutModule? DualModule { get; set; }
IDataInPort? DataIn { get; set; }
}

View File

@@ -0,0 +1,11 @@
using Nocturnis.Enigmos.Modules.ComputationalModules;
using Nocturnis.Enigmos.Ports.DataPorts.Directions;
namespace Nocturnis.Enigmos.Modules.InterlayerModules;
public interface IInterlayerDataOutModule : IInterlayerModule, IComputationalModule
{
new IInterlayerDataInModule? DualModule { get; set; }
IDataOutPort? DataOut { get; set; }
}

View File

@@ -1,10 +1,11 @@
using Nocturnis.Enigmos.Ports;
namespace Nocturnis.Enigmos.Modules;
namespace Nocturnis.Enigmos.Modules.InterlayerModules;
public interface IInterlayerModule
{
IBasePort? UnderlyingPort { get; }
IProgrammableModule? ParentModule { get; set; }
}

View File

@@ -0,0 +1,9 @@
using Nocturnis.Enigmos.Ports.SignalPorts.Directions;
namespace Nocturnis.Enigmos.Modules.InterlayerModules;
public interface IInterlayerSignalInModule : IInterlayerModule, IControllingModule
{
new IInterlayerSignalOutModule? DualModule { get; set; }
ISignalInPort? SignalIn { get; set; }
}

View File

@@ -0,0 +1,9 @@
using Nocturnis.Enigmos.Ports.SignalPorts.Directions;
namespace Nocturnis.Enigmos.Modules.InterlayerModules;
public interface IInterlayerSignalOutModule : IInterlayerModule, IRoutingModule
{
new IInterlayerSignalInModule? DualModule { get; set; }
ISignalOutPort? SignalOut { get; set; }
}