Achievement file format: Difference between revisions
m (→File Format: fix redirect) |
|||
(12 intermediate revisions by 4 users not shown) | |||
Line 2: | Line 2: | ||
This is a technical description of the achievement file format, used by Factorio to store player's achievement progress in the files "achievements.dat" and "achievements-modded.dat". | This is a technical description of the achievement file format, used by Factorio to store player's achievement progress in the files "achievements.dat" and "achievements-modded.dat". | ||
Yes - this information can be used to "cheat" Factorio by simply writing to the achievement file(s) in such a way as if you had met all the achievement requirements, open up Factorio, and then suddenly have all achievements unlocked | Yes - this information can be used to "cheat" Factorio by simply writing to the achievement file(s) in such a way as if you had met all the achievement requirements, open up Factorio, and then suddenly have all achievements unlocked. The goal of this document is to share how to _read_ the achievement file(s) - so that third party applications can do new and interesting things with that information. Enjoy! | ||
See the page on [[Data_Types|data types]] for an explanation of the different types of data used in this document. | See the page on [[Data_Types|data types]] for an explanation of the different types of data used in this document. | ||
Line 14: | Line 14: | ||
|- | |- | ||
| [[Data_Types#short|short]][4] | | [[Data_Types#short|short]][4] | ||
| The [[ | | The [[Version_string_format|version string]] of Factorio that generated this file. | ||
|- | |- | ||
| [[Data_Types#array|array]]<[[#Achievement Header Info|bytes]]> | | [[Data_Types#array|array]]<[[#Achievement Header Info|bytes]]> | ||
Line 21: | Line 21: | ||
| [[Data_Types#array|array]]<[[#Achievement Content Info|bytes]]> | | [[Data_Types#array|array]]<[[#Achievement Content Info|bytes]]> | ||
| [[#Achievement Content Info|Achievement content info]]. Variable length. See the section for more information. | | [[#Achievement Content Info|Achievement content info]]. Variable length. See the section for more information. | ||
|- | |- | ||
| [[Data_Types#short|short]][*] | | [[Data_Types#short|short]][*] | ||
Line 44: | Line 41: | ||
|- | |- | ||
| [[Data_Types#short|short]] | | [[Data_Types#short|short]] | ||
| Achievement index number. This number is used to map achievements between this header info array, the content info array, and the tracked achievements list in this file. These index numbers are non-normative, so they won't always match up with the same achievement.<br> Note: the mapping of index numbers to achievement ids are continuous, but start at index 1 (there is no index 0). | | Achievement index number. This number is used to map achievements between this header info array, the content info array, and the tracked achievements list in this file. These index numbers are non-normative, so they won't always match up with the same achievement.<br> Note: the mapping of index numbers to achievement ids are continuous, but start at index 1 (there is no index 0) - because LUA tables start at 1. | ||
|} | |} | ||
Line 50: | Line 47: | ||
This contains the actual data of each achievement. It's important to note that not every achievement listed in the header has a matching content section here. | This contains the actual data of each achievement. It's important to note that not every achievement listed in the header has a matching content section here. | ||
Also note that this array always ends with an index number of 0. When reading, either ignore this, or manually add in a blank achievement into your meta table at index zero with no fields. | |||
{| class="wikitable" | {| class="wikitable" | ||
Line 64: | Line 63: | ||
If new achievement types are added in the future, the achievement files will be unparse-able. Please add any new types you find here, thanks! | If new achievement types are added in the future, the achievement files will be unparse-able. Please add any new types you find here, thanks! | ||
See the [[Prototype/Achievement]] base prototype page for more information about achievement structure. | |||
{| class="wikitable" | {| class="wikitable" | ||
! Achievement<br>Type !! | ! Achievement<br>Type !! Binary<br>Fields(s) !! Field(s) Description | ||
|- | |- | ||
| build-entity-achievement | | [[Prototype/BuildEntityAchievement|build-entity-achievement]] | ||
| | | | ||
* byte[4] | * byte[4] | ||
Line 74: | Line 75: | ||
* Unknown format, 4 bytes long. | * Unknown format, 4 bytes long. | ||
|- | |- | ||
| combat-robot-count | | [[Prototype/CombatRobotCountAchievement|combat-robot-count]] | ||
| | | | ||
* [[Data_Types#int|int]] | * [[Data_Types#int|int]] | ||
Line 80: | Line 81: | ||
* The greatest number of combat robots you've had following you. | * The greatest number of combat robots you've had following you. | ||
|- | |- | ||
| construct-with-robots-achievement | | [[Prototype/ConstructWithRobotsAchievement|construct-with-robots-achievement]] | ||
| | | | ||
* [[Data_Types#int|int]] | * [[Data_Types#int|int]] | ||
Line 88: | Line 89: | ||
* Unknown format, 4 bytes long. | * Unknown format, 4 bytes long. | ||
|- | |- | ||
| deconstruct-with-robots-achievement | | [[Prototype/DeconstructWithRobotsAchievement|deconstruct-with-robots-achievement]] | ||
| | | | ||
* [[Data_Types#int|int]] | * [[Data_Types#int|int]] | ||
Line 94: | Line 95: | ||
* Total number of objects deconstructed using robots. | * Total number of objects deconstructed using robots. | ||
|- | |- | ||
| deliver-by-robots-achievement | | [[Prototype/DeliverByRobotsAchievement|deliver-by-robots-achievement]] | ||
| | | | ||
* byte[8] | * byte[8] | ||
Line 100: | Line 101: | ||
* Unknown format, 8 bytes long. | * Unknown format, 8 bytes long. | ||
|- | |- | ||
| dont-use-entity-in-energy-production-achievement | | [[Prototype/DontBuildEntityAchievement|dont-build-entity-achievement]] | ||
| | |||
''TODO'' | |||
| | |||
''TODO'' | |||
|- | |||
| [[Prototype/DontCraftManuallyAchievement|dont-craft-manually-achievement]] | |||
| | |||
''TODO'' | |||
| | |||
''TODO'' | |||
|- | |||
| [[Prototype/DontUseEntityInEnergyProductionAchievement|dont-use-entity-in-energy-production-achievement]] | |||
| | | | ||
* [[Data_Types#double|double]] | * [[Data_Types#double|double]] | ||
| | | | ||
* Maximum number of Joules produced per hour, only including power produced from entities listed under "included", and excluding those listed under "excluded". | * Maximum number of Joules produced per hour, only including power produced from entities listed under "[[Prototype/DontUseEntityInEnergyProductionAchievement#included|included]]", and excluding those listed under "[[Prototype/DontUseEntityInEnergyProductionAchievement#excluded|excluded]]". | ||
|- | |||
| [[Prototype/FinishTheGameAchievement|finish-the-game-achievement]] | |||
| | |||
''TODO'' | |||
| | |||
''TODO'' | |||
|- | |- | ||
| group-attack-achievement | | [[Prototype/GroupAttackAchievement|group-attack-achievement]] | ||
| | | | ||
* byte[4] | * byte[4] | ||
Line 112: | Line 131: | ||
* Unknown format, 4 bytes long. | * Unknown format, 4 bytes long. | ||
|- | |- | ||
| kill-achievement | | [[Prototype/KillAchievement|kill-achievement]] | ||
| | | | ||
* [[Data_Types#double|double]] | * [[Data_Types#double|double]] | ||
Line 118: | Line 137: | ||
* The greatest number of an entity killed (e.g. trees, spawners). | * The greatest number of an entity killed (e.g. trees, spawners). | ||
|- | |- | ||
| player-damaged-achievement | | [[Prototype/PlayerDamagedAchievement|player-damaged-achievement]] | ||
| | | | ||
* [[Data_Types#float|float]] | * [[Data_Types#float|float]] | ||
Line 126: | Line 145: | ||
* True if the you survived that hit, False if you died. | * True if the you survived that hit, False if you died. | ||
|- | |- | ||
| produce-achievement | | [[Prototype/ProduceAchievement|produce-achievement]] | ||
| | | | ||
* [[Data_Types#double|double]] | * [[Data_Types#double|double]] | ||
Line 132: | Line 151: | ||
* The total number of the item you've produced. | * The total number of the item you've produced. | ||
|- | |- | ||
| produce-per-hour-achievement | | [[Prototype/ProducePerHourAchievement|produce-per-hour-achievement]] | ||
| | | | ||
* [[Data_Types#double|double]] | * [[Data_Types#double|double]] | ||
Line 138: | Line 157: | ||
* The maximum amount of the item produced per hour. | * The maximum amount of the item produced per hour. | ||
|- | |- | ||
| research-achievement | | [[Prototype/ResearchAchievement|research-achievement]] | ||
| | | | ||
* byte[4] | * byte[4] | ||
Line 144: | Line 163: | ||
* Unknown format, 4 bytes long. | * Unknown format, 4 bytes long. | ||
|- | |- | ||
| train-path-achievement | | [[Prototype/TrainPathAchievement|train-path-achievement]] | ||
| | | | ||
* [[Data_Types#double|double]] | * [[Data_Types#double|double]] |
Latest revision as of 04:08, 29 April 2020
This is a technical description of the achievement file format, used by Factorio to store player's achievement progress in the files "achievements.dat" and "achievements-modded.dat".
Yes - this information can be used to "cheat" Factorio by simply writing to the achievement file(s) in such a way as if you had met all the achievement requirements, open up Factorio, and then suddenly have all achievements unlocked. The goal of this document is to share how to _read_ the achievement file(s) - so that third party applications can do new and interesting things with that information. Enjoy!
See the page on data types for an explanation of the different types of data used in this document.
File Format
The overall file format is as follows. Note that in this file, array length is stored as a short, not an int!
Type | Description |
---|---|
short[4] | The version string of Factorio that generated this file. |
array<bytes> | Achievement header info. Variable length. See the section for more information. |
array<bytes> | Achievement content info. Variable length. See the section for more information. |
short[*] | Currently tracked achievements, given as a series of shorts up until the end of the file, with each representing the index number of an achievement. The order of achievements in this series matches the order of which the player has them tracked in game. |
This format has been valid since at least version 0.14.x.
Achievement Header Info
The header contains information about what type of data fields each achievement has.
Type | Description |
---|---|
string | Achievement type. This determines what kind of data fields this achievement contains in the content array. |
string | Achievement string id - the one used internally by Factorio. |
short | Achievement index number. This number is used to map achievements between this header info array, the content info array, and the tracked achievements list in this file. These index numbers are non-normative, so they won't always match up with the same achievement. Note: the mapping of index numbers to achievement ids are continuous, but start at index 1 (there is no index 0) - because LUA tables start at 1. |
Achievement Content Info
This contains the actual data of each achievement. It's important to note that not every achievement listed in the header has a matching content section here.
Also note that this array always ends with an index number of 0. When reading, either ignore this, or manually add in a blank achievement into your meta table at index zero with no fields.
Type | Description |
---|---|
short | Achievement index number. This matches up with the index number in the Achievement header info. |
byte[*] | The achievement's progress information. The structure and length of this is determined by the achievement's type. See the table below for a list of achievement types. |
Achievement Types
If new achievement types are added in the future, the achievement files will be unparse-able. Please add any new types you find here, thanks!
See the Prototype/Achievement base prototype page for more information about achievement structure.
Achievement Type |
Binary Fields(s) |
Field(s) Description |
---|---|---|
build-entity-achievement |
|
|
combat-robot-count |
| |
construct-with-robots-achievement |
|
|
deconstruct-with-robots-achievement |
| |
deliver-by-robots-achievement |
|
|
dont-build-entity-achievement |
TODO |
TODO |
dont-craft-manually-achievement |
TODO |
TODO |
dont-use-entity-in-energy-production-achievement | ||
finish-the-game-achievement |
TODO |
TODO |
group-attack-achievement |
|
|
kill-achievement |
| |
player-damaged-achievement |
| |
produce-achievement |
| |
produce-per-hour-achievement |
| |
research-achievement |
|
|
train-path-achievement |
|
"combat-robot-count" is currently the only achievement type that doesn't end in "-achievement". This is not an error.