Skip to main content

A Pythonic, structured data engine for Twilight Imperium 4th Edition

Project description

TI4 Rules Engine

A Pythonic, structured data engine for Twilight Imperium 4th Edition. Tracks game state, provides rule references, and calculates player options from a live AsyncTI4 Discord bot game.

Analyse a game in one command

No installation required — just uvx:

uvx --from ti4-rules-engine ti4-analyze <game_name>

Replace <game_name> with the name of your AsyncTI4 game (the identifier shown by the bot, e.g. pbd22295):

uvx --from ti4-rules-engine ti4-analyze pbd22295

The command fetches the live game snapshot from the AsyncTI4 API and prints:

  • Current round, phase, and active player
  • Per-player summary: faction, VP, resources, planets, technologies, and leaders
  • Every legal action available to each player under TI4 rules right now
  • Reachable systems for each fleet (movement + anomaly rules applied)

Note: uvx --from ti4-rules-engine requires the package to be published on PyPI. Until then, clone the repo and use the local install instead:

git clone --recurse-submodules https://github.com/adam133/ti4-rules-engine
cd ti4-rules-engine
uv tool install .
ti4-analyze pbd22295

Development note: this repository reads game data from a git submodule (data/TI4_map_generator_bot), so local development requires cloning with submodules (or running git submodule update --init --recursive in an existing clone).

What it shows

============================================================
Game:   pbd22295   Round: 3   Phase: action
Active: sargun
============================================================

  sargun [ACTIVE]
    Faction:  Nekro Virus
    VP:       5
    TG:       3  |  Commodities: 0
    Tokens:   3 tactical / 5 fleet / 2 strategy
    Planets:  8 controlled, 2 exhausted
    ...
    Actions available:
      • tactical_action
      • component_action
      • strategic_action

Further reading

  • docs/implementation.md — module reference and API examples (game session setup, modifier system, combat simulation, scoring, movement, opponent public info)
  • docs/contributing.md — local dev setup, running tests, and project roadmap

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ti4_rules_engine-0.2.1.tar.gz (604.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

ti4_rules_engine-0.2.1-py3-none-any.whl (1.4 MB view details)

Uploaded Python 3

File details

Details for the file ti4_rules_engine-0.2.1.tar.gz.

File metadata

  • Download URL: ti4_rules_engine-0.2.1.tar.gz
  • Upload date:
  • Size: 604.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for ti4_rules_engine-0.2.1.tar.gz
Algorithm Hash digest
SHA256 d2f5b1ecc5dc939a96f051102a312126385497a9b7fbe2ec324bf32dc7994d23
MD5 881d36b36d04749e263c9ae68a560244
BLAKE2b-256 ad9e66186e5ce60407f8362d53814649f89ec1e9a54494665ba45549d479397e

See more details on using hashes here.

Provenance

The following attestation bundles were made for ti4_rules_engine-0.2.1.tar.gz:

Publisher: publish.yml on adam133/ti4-rules-engine

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file ti4_rules_engine-0.2.1-py3-none-any.whl.

File metadata

File hashes

Hashes for ti4_rules_engine-0.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 b80d246ffe6b9665e494318af7ee1a2f53e5b860ce2822a05c61582272b73636
MD5 52d4439983a702a24d9b90a8ac0c08d7
BLAKE2b-256 c7aca685d845f29d583a4f5935cac64ca9c96b94c2b910cb352e6d08959602a2

See more details on using hashes here.

Provenance

The following attestation bundles were made for ti4_rules_engine-0.2.1-py3-none-any.whl:

Publisher: publish.yml on adam133/ti4-rules-engine

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page