A small utility to manipulate data related to Factorio.
The main feature at this point is to export prototype definitions from Factorio
using factorio-exporter
.
See crate page on crates.io
sh
$ fct --factorio-dir ~/tmp/factorio-full -f json | jq '.recipe_prototypes["iron-plate"]'
Output:
json
{
"allow_as_intermediate": true,
"allow_decomposition": true,
"allow_inserter_overload": true,
"allow_intermediates": true,
"always_show_made_in": false,
"always_show_products": false,
"category": "smelting",
"emissions_multiplier": 1,
"enabled": true,
"energy": 3.2,
"hidden": false,
"hidden_from_flow_stats": false,
"hidden_from_player_crafting": false,
"ingredients": [
{
"amount": 1,
"name": "iron-ore",
"type": "item"
}
],
"localised_description": "Unknown key: \"recipe-description.iron-plate\"",
"localised_name": "Iron plate",
"name": "iron-plate",
"object_name": "LuaRecipePrototype",
"order": "b[iron-plate]",
"overload_multiplier": 0,
"products": [
{
"amount": 1,
"name": "iron-plate",
"probability": 1,
"type": "item"
}
],
"request_paste_multiplier": 30,
"show_amount_in_title": true,
"unlock_results": true,
"valid": true
}
```sh $ fct --help Exports prototypes from Factorio in JSON or YAML format
Usage: fct [OPTIONS] [MODS]...
Arguments: [MODS]... Mods to install before exporting the prototypes
Options:
--factorio-dir --factorio-api-spec
and --factorio-binary
are specified
--factorio-api-spec <FACTORIO_API_SPEC>
Location of the `runtime-api.json` file. Defaults to `<FACTORIO_DIR>/doc-html/runtime-api.json`
The spec can be found in the `doc-html` directory of a full Factorio installation, or [online](https://lua-api.factorio.com/latest/runtime-api.json).
--factorio-binary <FACTORIO_BINARY>
Location of the factorio binary. Defaults to `<FACTORIO_DIR>/bin/x64/factorio(.exe)`. This can be any Factorio binary (full, headless, demo)
-d, --destination
-f, --format
[default: json]
[possible values: json, yaml]
-i, --icons Export icon paths
-h, --help
Print help information (use -h
for a summary)
-V, --version Print version information ```
This is still very much in the prototype phase. The output will be incomplete and have bugs. Please try it out anyway and report any issues that you run into!
See the change log for progress.
This tool is intended to be platform-independent, but it's currently only tested on Linux.
Contributions are welcome! Feel free to send pull requests, but if you want to make large-scale changes it would make sense to discuss them first.