2024-06-07 04:57:34 +00:00
|
|
|
|
using System;
|
|
|
|
|
using System.Collections.Generic;
|
2020-01-31 02:37:27 +00:00
|
|
|
|
using System.Linq;
|
|
|
|
|
using Restock.Constraints;
|
|
|
|
|
|
|
|
|
|
namespace Restock
|
|
|
|
|
{
|
|
|
|
|
public class ModuleRestockConstraints : PartModule
|
|
|
|
|
{
|
2024-06-07 04:57:34 +00:00
|
|
|
|
private List<IConstraint> _constraints;
|
2020-01-31 02:37:27 +00:00
|
|
|
|
|
|
|
|
|
public override void OnLoad(ConfigNode node)
|
|
|
|
|
{
|
|
|
|
|
base.OnLoad(node);
|
|
|
|
|
|
2024-06-07 04:57:34 +00:00
|
|
|
|
_constraints = new List<IConstraint>();
|
2020-01-31 02:37:27 +00:00
|
|
|
|
var cnodes = node.GetNodes();
|
|
|
|
|
this.Log($"Loading {cnodes.Length} constraints");
|
|
|
|
|
|
|
|
|
|
foreach (var cnode in cnodes)
|
|
|
|
|
{
|
2024-06-07 04:57:34 +00:00
|
|
|
|
try
|
2020-01-31 02:37:27 +00:00
|
|
|
|
{
|
2024-06-07 04:57:34 +00:00
|
|
|
|
switch (cnode.name)
|
|
|
|
|
{
|
|
|
|
|
//LookAtConstraint
|
|
|
|
|
case "CONSTRAINLOOKFX":
|
|
|
|
|
case "LOOKATCONSTRAINT":
|
|
|
|
|
_constraints.Add(new LookAtConstraint(cnode, this.part));
|
|
|
|
|
break;
|
2020-01-31 02:37:27 +00:00
|
|
|
|
|
2024-06-07 04:57:34 +00:00
|
|
|
|
//CopyPositionConstraint
|
|
|
|
|
case "COPYPOSITIONCONSTRAINT":
|
|
|
|
|
_constraints.Add(new CopyPositionConstraint(cnode, this.part));
|
|
|
|
|
break;
|
2020-01-31 02:37:27 +00:00
|
|
|
|
|
2024-06-07 04:57:34 +00:00
|
|
|
|
//CopyRotationConstraint
|
|
|
|
|
case "COPYROTATIONCONSTRAINT":
|
|
|
|
|
_constraints.Add(new CopyRotationConstraint(cnode, this.part));
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
catch(Exception e)
|
|
|
|
|
{
|
|
|
|
|
this.LogError($"Exception while loading {cnode.name} Node: {e}");
|
2020-01-31 02:37:27 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2024-06-07 04:57:34 +00:00
|
|
|
|
this.Log($"Loaded {_constraints.Count} constraints");
|
2020-01-31 02:37:27 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public override void OnStart(StartState state)
|
|
|
|
|
{
|
2024-06-07 04:57:34 +00:00
|
|
|
|
if (!HighLogic.LoadedSceneIsFlight && !HighLogic.LoadedSceneIsEditor) return;
|
|
|
|
|
if (_constraints != null && _constraints.Count != 0) return;
|
|
|
|
|
|
|
|
|
|
// I have no idea why this is here but I'm scared to remove it
|
|
|
|
|
foreach (var pNode in GameDatabase.Instance.GetConfigs("PART"))
|
2020-01-31 02:37:27 +00:00
|
|
|
|
{
|
2024-06-07 04:57:34 +00:00
|
|
|
|
if (pNode.name.Replace("_", ".") != part.partInfo.name) continue;
|
|
|
|
|
var cfg = pNode.config;
|
|
|
|
|
var node = cfg.GetNodes("MODULE").Single(n => n.GetValue("name") == moduleName);
|
|
|
|
|
OnLoad(node);
|
2020-01-31 02:37:27 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2020-06-27 03:58:17 +00:00
|
|
|
|
private void LateUpdate()
|
2020-01-31 02:37:27 +00:00
|
|
|
|
{
|
2024-06-07 04:57:34 +00:00
|
|
|
|
for (var i = 0; i < _constraints.Count; i++)
|
2020-01-31 02:37:27 +00:00
|
|
|
|
{
|
2024-06-07 04:57:34 +00:00
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
_constraints[i].Update();
|
|
|
|
|
}
|
|
|
|
|
catch (Exception e)
|
|
|
|
|
{
|
|
|
|
|
this.LogError($"Encountered exception in constraint. Removing the constraint to prevent further errors\n {e}");
|
|
|
|
|
_constraints.RemoveAt(i--);
|
|
|
|
|
}
|
|
|
|
|
|
2020-01-31 02:37:27 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|