Skip to content
forked from BSData/phalanx

Project Phalanx is a roster editor handling BattleScribe datafiles

License

Notifications You must be signed in to change notification settings

Samsquonch/phalanx

Repository files navigation

phalanx

Project Phalanx

This is a project to create an alternative roster editor that uses BattleScribe-format datafiles.

Our main communication channel beside Issues, PRs and Discussions on GitHub is the #project-phalanx channel on BSData Discord server. BSData Discord link

Please see Wiki for more information.

Technical description

The following stack of app layers is currently (at least partially) implemented:

  • DTO to (de)serialize XML content into typed objects (WarHub.ArmouryModel.Source.*Core types). This layer is a tree where children don't have a reference to their parent.
  • SourceNode layer, lazy-initialized immutable wrappers for DTOs (WarHub.ArmouryModel.Source.*Node types). This layer is a tree where children have a reference to their parent.
  • Symbol layer, immutable object graph. Internal implementation of upper ISymbol layer, which builds an actual object graph, by resolving references (e.g. link targetId is resolved to an actual symbol for the target entry) - this operation is called binding. This layer also generates diagnostics (e.g. bad links, invalid enum values, etc).
  • ISymbol layer is an interface view of the Symbol layer, creating a fully bound object graph.
  • Compilation is a container for a set of data roots (gamesystem, catalogues, rosters), in which a binding happends.
  • RosterEditor and RosterState (from RosterServices namespace) is a heavily WIP layer that manages actual editing of roster, via IRosterOperations which encapsulate roster edit actions.

Development

You need one of the following setups:

  • Visual Studio 2022 (latest) - open the Phalanx.sln with it.
  • VSCode and .NET 6 SDK (latest) - open the repository folder in it.

The main app to run is in src/Phalanx.App - select this project as startup project in Visual Studio. VSCode has a defined debug configuration.

TODO

  • test default group entry binding - how it works in BattleScribe (allowed selections), does it work same in Phalanx
  • consider removing "deeper" types than IResourceDefinition/IResourceEntry/IContainerEntry
    • simpler usage
    • requires moving their "custom" properties somewhere: "ContentFields" collection of custom name-value wrappers, maybe strongly typed?
  • symbol layer:
    • symbolinfo that might be an error
    • implementation for: constraints, logic (conditions, modifiers)
    • binder factory
    • binders for sub-catalogue levels
  • add default subselections:
    • for entries with constraints min > 0 (constraints need symbols?)
    • entry groups
    • should that be in a separate "RosterEditor" module?
  • implement Logic symbols

Symbols

The symbols are the basis of semantic model object graph.

Symbol notes

  • ISymbol is the root type.
  • Links (BS EntryLink/InfoLink/CategoryLink) are represented as the symbol type that the link points to, its IsReference is true and ReferencedEntry points to the link target.

Symbol list

  • ICatalogueSymbol (+ catalogue links?)
  • ICatalogueItemSymbol // has catalogue ref
    • ICatalogueReferenceSymbol // catalogue link
    • IResourceDefinitionSymbol
      • ICharacteristicTypeSymbol
      • ICostTypeSymbol
      • IProfileTypeSymbol
      • IPublicationSymbol
    • IEntrySymbol // contains effects
      • IResourceEntrySymbol
        • ICharacteristicSymbol
        • ICostSymbol
        • IProfileSymbol (can be a link)
        • IRuleSymbol (can be a link)
        • IResourceGroupSymbol (can be a link)
      • IContainerEntrySymbol // contains constraints, resources
        • ICategoryEntry (can be a link)
        • IForceEntry
        • ISelectionEntryContainerSymbol // contains other SelectionEntry-like stuff
          • ISelectionEntrySymbol (can be a link)
          • ISelectionEntryGroupSymbol (can be a link)
    • ILogicSymbol
      • IConstraintSymbol // contains effects
      • IEffectSymbol
        • IConditionalEffectSymbol
        • ILoopEffectSymbol
        • IModifyingEffectSymbol
      • IConditionSymbol
        • IQueryConditionSymbol // condition/constaint/repeat "query" part
        • ITupleOperationConditionSymbol // condition groups
      • IQuerySymbol
  • IRosterSymbol
  • IRosterCostSymbol // both value and limit (if set)
  • IRosterEntrySymbol // has SourceEntry
    • ICategorySymbol
    • IRosterSelectionTreeElementSymbol // has selections
      • IForceSymbol
      • ISelectionSymbol

Implementation notes

BattleScribe has some unnatural or unexpected, or just unobvious behavior. Here we try to gather such cases:

  • Editing a roster results in Categories having new IDs, even if they/selections didn't change.

About

Project Phalanx is a roster editor handling BattleScribe datafiles

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C# 91.9%
  • HTML 6.1%
  • CSS 1.3%
  • Other 0.7%