68c4abace3
Replace the entire static, enum-based modifier pipeline with a composition-based, data-driven architecture using ScriptableObject polymorphism. New modifiers can now be created by assembling SO building blocks (Conditions + Effects + Behaviors) — no core code edits needed. New architecture: - Core/: TriggerType, ModifierPhase, ModifierContext, ICondition, IEffect - Definition/: ModifierDefinitionSO, ModifierBehaviorSO, ConditionSO, EffectSO, ModifierCatalogSO - Conditions/: DieValueCondition, CategoryCondition, MinScoreCondition, DiceCountCondition - Effects/: AddFlat, AddPerDie, Multiply, MultiplyPerDie, PostMultiply, AddCurrency, ConsumeCharge - Runtime/: ModifierInstance, ModifierRegistry (non-static service) - Pipeline/: async ModifierPipeline with phase ordering, tracing, anti-recursion - Editor/: ModifierDefinitionValidator with menu items - Events/: GameEventBus (non-static typed dispatcher) - DI/: GameLifetimeScope (VContainer composition root) Deleted old system: ModifierData, ModifierEffect, ModifierEnums, ModifierPipeline (static), ModifierRuntime, ModifierTarget, ShopCatalog, ModifierAssetCreator. Updated: ScoringSystem (VContainer + async), InventoryModel (delegates to ModifierRegistry), ShopModel (uses ModifierDefinitionSO), GameController (VContainer injection), SaveData (uses Runtime.ModifierSaveEntry), all views/controllers, and all test files. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
49 lines
1.7 KiB
C#
49 lines
1.7 KiB
C#
using System;
|
|
using System.Collections.Generic;
|
|
using YachtDice.Modifiers.Definition;
|
|
using YachtDice.Modifiers.Runtime;
|
|
|
|
namespace YachtDice.Inventory
|
|
{
|
|
public class InventoryModel
|
|
{
|
|
private readonly ModifierRegistry registry;
|
|
|
|
public event Action OnInventoryChanged;
|
|
public event Action<IReadOnlyList<ModifierInstance>> OnActiveModifiersChanged;
|
|
|
|
public InventoryModel(ModifierRegistry registry)
|
|
{
|
|
this.registry = registry;
|
|
|
|
registry.OnChanged += () => OnInventoryChanged?.Invoke();
|
|
registry.OnActiveModifiersChanged += list => OnActiveModifiersChanged?.Invoke(list);
|
|
}
|
|
|
|
public IReadOnlyList<ModifierInstance> OwnedModifiers => registry.All;
|
|
public int MaxActiveSlots => registry.MaxActiveSlots;
|
|
public int ActiveCount => registry.ActiveCount;
|
|
|
|
public void SetMaxActiveSlots(int slots) => registry.SetMaxActiveSlots(slots);
|
|
|
|
public void AddModifier(ModifierDefinitionSO definition) => registry.Add(definition);
|
|
|
|
public void RemoveModifier(ModifierInstance instance) => registry.Remove(instance);
|
|
|
|
public bool TryActivate(ModifierInstance instance) => registry.TryActivate(instance);
|
|
|
|
public void Deactivate(ModifierInstance instance) => registry.Deactivate(instance);
|
|
|
|
public void ConsumeUseOnActive() => registry.ConsumeChargesOnActive();
|
|
|
|
public List<ModifierDefinitionSO> GetActiveModifierDefinitions()
|
|
{
|
|
var result = new List<ModifierDefinitionSO>();
|
|
var active = registry.Active;
|
|
for (int i = 0; i < active.Count; i++)
|
|
result.Add(active[i].Definition);
|
|
return result;
|
|
}
|
|
}
|
|
}
|