summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/industry.h4
-rw-r--r--src/saveload/industry_sl.cpp52
2 files changed, 53 insertions, 3 deletions
diff --git a/src/industry.h b/src/industry.h
index 9ff0e5403..c65c65b48 100644
--- a/src/industry.h
+++ b/src/industry.h
@@ -146,7 +146,10 @@ void ReleaseDisastersTargetingIndustry(IndustryID);
/** Data for managing the number of industries of a single industry type. */
struct IndustryTypeBuildData {
uint32 probability; ///< Relative probability of building this industry.
+ byte min_number; ///< Smallest number of industries that should exist (either \c 0 or \c 1).
uint16 target_count; ///< Desired number of industries of this type.
+ uint16 max_wait; ///< Starting number of turns to wait (copied to #wait_count).
+ uint16 wait_count; ///< Number of turns to wait before trying to build again.
void GetIndustryTypeData(IndustryType it);
};
@@ -156,6 +159,7 @@ struct IndustryTypeBuildData {
*/
struct IndustryBuildData {
IndustryTypeBuildData builddata[NUM_INDUSTRYTYPES]; ///< Industry build data for every industry type.
+ uint32 wanted_inds; ///< Number of wanted industries (bits 31-16), and a fraction (bits 15-0).
void SetupTargetCount();
void TryBuildNewIndustry();
diff --git a/src/saveload/industry_sl.cpp b/src/saveload/industry_sl.cpp
index e3c9ff438..2ba07a1a6 100644
--- a/src/saveload/industry_sl.cpp
+++ b/src/saveload/industry_sl.cpp
@@ -113,8 +113,54 @@ static void Ptrs_INDY()
}
}
+/** Description of the data to save and load in #IndustryBuildData. */
+static const SaveLoad _industry_builder_desc[] = {
+ SLEG_VAR(_industry_builder.wanted_inds, SLE_UINT32),
+ SLEG_END()
+};
+
+/** Load/save industry builder. */
+static void LoadSave_IBLD()
+{
+ SlGlobList(_industry_builder_desc);
+}
+
+/** Description of the data to save and load in #IndustryTypeBuildData. */
+static const SaveLoad _industrytype_builder_desc[] = {
+ SLE_VAR(IndustryTypeBuildData, probability, SLE_UINT32),
+ SLE_VAR(IndustryTypeBuildData, min_number, SLE_UINT8),
+ SLE_VAR(IndustryTypeBuildData, target_count, SLE_UINT16),
+ SLE_VAR(IndustryTypeBuildData, max_wait, SLE_UINT16),
+ SLE_VAR(IndustryTypeBuildData, wait_count, SLE_UINT16),
+ SLE_END()
+};
+
+/** Save industry-type build data. */
+static void Save_ITBL()
+{
+ for (int i = 0; i < NUM_INDUSTRYTYPES; i++) {
+ SlSetArrayIndex(i);
+ SlObject(_industry_builder.builddata + i, _industrytype_builder_desc);
+ }
+}
+
+/** Load industry-type build data. */
+static void Load_ITBL()
+{
+ int index;
+ for (int i = 0; i < NUM_INDUSTRYTYPES; i++) {
+ index = SlIterateArray();
+ assert(index == i);
+ SlObject(_industry_builder.builddata + i, _industrytype_builder_desc);
+ }
+ index = SlIterateArray();
+ assert(index == -1);
+}
+
extern const ChunkHandler _industry_chunk_handlers[] = {
- { 'INDY', Save_INDY, Load_INDY, Ptrs_INDY, NULL, CH_ARRAY},
- { 'IIDS', Save_IIDS, Load_IIDS, NULL, NULL, CH_ARRAY},
- { 'TIDS', Save_TIDS, Load_TIDS, NULL, NULL, CH_ARRAY | CH_LAST},
+ { 'INDY', Save_INDY, Load_INDY, Ptrs_INDY, NULL, CH_ARRAY},
+ { 'IIDS', Save_IIDS, Load_IIDS, NULL, NULL, CH_ARRAY},
+ { 'TIDS', Save_TIDS, Load_TIDS, NULL, NULL, CH_ARRAY},
+ { 'IBLD', LoadSave_IBLD, LoadSave_IBLD, NULL, NULL, CH_RIFF},
+ { 'ITBL', Save_ITBL, Load_ITBL, NULL, NULL, CH_ARRAY | CH_LAST},
};