|
|
|
@ -1,3 +1,4 @@
|
|
|
|
|
|
|
|
using System.Diagnostics;
|
|
|
|
using Godot;
|
|
|
|
using Godot;
|
|
|
|
using Godot.Collections;
|
|
|
|
using Godot.Collections;
|
|
|
|
|
|
|
|
|
|
|
|
@ -6,32 +7,41 @@ namespace Babushka.scripts.CSharp.Common.Farming;
|
|
|
|
[GlobalClass]
|
|
|
|
[GlobalClass]
|
|
|
|
public partial class FieldService : Node3D
|
|
|
|
public partial class FieldService : Node3D
|
|
|
|
{
|
|
|
|
{
|
|
|
|
[Export] private Dictionary<Vector2I, FieldState> fields = new Dictionary<Vector2I, FieldState>();
|
|
|
|
[Export] private Dictionary<Vector2I, FieldBehaviour> fields = new Dictionary<Vector2I, FieldBehaviour>();
|
|
|
|
|
|
|
|
|
|
|
|
//Create
|
|
|
|
//Create
|
|
|
|
|
|
|
|
public bool TryAddEntry(Vector2I key, FieldBehaviour field)
|
|
|
|
public void AddEntry(Vector2I key, FieldState state)
|
|
|
|
|
|
|
|
{
|
|
|
|
{
|
|
|
|
fields.Add(key, state);
|
|
|
|
if (!fields.ContainsKey(key))
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
fields.Add(key, field);
|
|
|
|
|
|
|
|
return true;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
Debug.Print("Added entry: " + key);
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// Read
|
|
|
|
// Read
|
|
|
|
|
|
|
|
public FieldBehaviour Get(Vector2I key)
|
|
|
|
public FieldState Get(Vector2I key)
|
|
|
|
|
|
|
|
{
|
|
|
|
{
|
|
|
|
return fields[key];
|
|
|
|
Debug.Print($"Getting field at {key}. Found: {fields.ContainsKey(key)}.");
|
|
|
|
|
|
|
|
if(fields.TryGetValue(key, out FieldBehaviour field))
|
|
|
|
|
|
|
|
return field;
|
|
|
|
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
//Update
|
|
|
|
//Update
|
|
|
|
public void UpdateEntry(Vector2I fieldPosition, FieldState state)
|
|
|
|
public void UpdateEntry(Vector2I fieldPosition, FieldBehaviour state)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Debug.Print("Updating entry: " + fieldPosition);
|
|
|
|
if (fields.ContainsKey(fieldPosition))
|
|
|
|
if (fields.ContainsKey(fieldPosition))
|
|
|
|
{
|
|
|
|
{
|
|
|
|
fields[fieldPosition] = state;
|
|
|
|
fields[fieldPosition] = state;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
else
|
|
|
|
{
|
|
|
|
{
|
|
|
|
AddEntry(fieldPosition, state);
|
|
|
|
TryAddEntry(fieldPosition, state);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
@ -39,6 +49,7 @@ public partial class FieldService : Node3D
|
|
|
|
|
|
|
|
|
|
|
|
public void RemoveEntry(Vector2I fieldPosition)
|
|
|
|
public void RemoveEntry(Vector2I fieldPosition)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
|
|
|
|
Debug.Print("Removing entry: " + fieldPosition);
|
|
|
|
if (fields.ContainsKey(fieldPosition))
|
|
|
|
if (fields.ContainsKey(fieldPosition))
|
|
|
|
{
|
|
|
|
{
|
|
|
|
fields.Remove(fieldPosition);
|
|
|
|
fields.Remove(fieldPosition);
|
|
|
|
|