Python API and CLI tool to read Mindustry's campaign global stats.
Project description
Mindustry Campaign Stats
Python API and CLI tool to read Mindustry's campaign global stats.
PyPI - Documentation - Source code - Issue tracker - Changelog
Prerequisites
- Python >= 3.10
Installation
From PyPi
pip install mindustry-campaign-stats
Locally
After cloning/downloading the repo:
pip install .
Usage
API
The API consists of:
- A
load()function, which reads data from the given binary file-like object and returns the raw parsed data as a dictionary - A
compute()function, which transforms the above dictionary to aStatsinstance - A
Planetenum (Serpulo,Erekir) to be used withcompute()
import mindustry_campaign_stats
from pprint import pprint
try:
with open('settings.bin', 'rb') as fp: # Note it's opened in binary mode
raw_settings = mindustry_campaign_stats.load(fp)
pprint(raw_settings)
computed = mindustry_campaign_stats.compute(
raw_settings,
mindustry_campaign_stats.Planet.Erekir
)
print(computed.totals.storage.capacity)
pprint(
computed.to_dict()
)
except Exception as e:
print(e)
CLI
In its simplest form, the CLI reads data from the given settings.bin filename, then writes a human-readable ASCII table
of computed stats to stdout. Note you must choose between the serpulo or erekir campaign.
mindustry-campaign-stats settings.bin erekir
When the --refresh option is set, the CLI is running indefinitely, listening for modification in the given settings.bin
file until it's terminated. This feature allows the table to be automatically updated in your terminal (screen is cleared
before any update happens).
The --json option switches output format to JSON, specifically JSON Lines. The --pretty
option may be used to pretty-print the outputted JSON. When --refresh is set as well, the CLI will sequentially write
a stream of JSON Lines. Note that --pretty is ignored in that case as it would break JSON Lines formatting.
settings.bin format
This file is designed much like a persistent key-value store. It is used to store both user settings and campaigns-related data. It is formatted as follows (everything is big-endian):
- 4 bytes (int32) - Number of fields to read (
fields_count) - Fields sequence (based on
fields_count):- 2 bytes (uint16) - Length of the field name (
field_name_length) field_name_lengthbytes - MUTF-8-encoded field name- 1 byte (int8) - Field type ID (
field_type_id) field_type_idvalue determines how to read the next bytes:0:- 1 byte (boolean) - A boolean value
1:- 4 bytes (int32) - A 32 bits integer
2:- 8 bytes (int64) - A 64 bits integer
3:- 4 bytes (float) - A single-precision floating-point number
4:- 2 bytes (uint16) - Length of the field value (
field_value_length) field_value_lengthbytes - An MUTF-8-encoded string
- 2 bytes (uint16) - Length of the field value (
5:- 4 bytes (int32) - Length of the field value (
field_value_length) field_value_lengthbytes - A binary value. Most likely UBJSON data
- 4 bytes (int32) - Length of the field value (
- 2 bytes (uint16) - Length of the field name (
References
Development
Getting source code and installing the package with dev dependencies
- Clone the repository
- From the root directory, run:
pip install -e ".[dev]"
Releasing the package
From the root directory, run python setup.py upload. This will build the package, create a git tag and publish on PyPI.
__version__ in mindustry_campaign_stats/__version__.py must be updated beforehand. It should adhere to Semantic Versioning.
An associated GitHub release must be created following the Keep a Changelog format.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file mindustry_campaign_stats-2.1.0.tar.gz.
File metadata
- Download URL: mindustry_campaign_stats-2.1.0.tar.gz
- Upload date:
- Size: 13.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.10
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
566b30a13724cba098b9de128fd9582b79c901238f097fca7150919db1b2f1e5
|
|
| MD5 |
1229362a6bfaf9e86e3a7f39541ae330
|
|
| BLAKE2b-256 |
d237be16c680f7f2b71a4d4c8e64850452925ea875b6106ecd1788c058891f70
|
File details
Details for the file mindustry_campaign_stats-2.1.0-py3-none-any.whl.
File metadata
- Download URL: mindustry_campaign_stats-2.1.0-py3-none-any.whl
- Upload date:
- Size: 11.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.10
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
7a3637358a538817d012865f05882f9092c82824c265d505aac0965f61157600
|
|
| MD5 |
1df587362250f49e6f0aa9fc750f6ff4
|
|
| BLAKE2b-256 |
2f7b180d12968a9abc7e52ccb3e4a8e1ddb7f4ff03e9c61855a0bbd0995c1fb5
|