summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--intro_gui.c16
-rw-r--r--settings.c2
2 files changed, 11 insertions, 7 deletions
diff --git a/intro_gui.c b/intro_gui.c
index bd0bbdef6..b3206efa0 100644
--- a/intro_gui.c
+++ b/intro_gui.c
@@ -54,6 +54,7 @@ static void SelectGameWndProc(Window *w, WindowEvent *e)
{
/* We do +/- 6 for the map_xy because 64 is 2^6, but it is the lowest available element */
static const StringID mapsizes[] = {STR_64, STR_128, STR_256, STR_512, STR_1024, STR_2048, INVALID_STRING_ID};
+ extern Patches _patches_newgame;
switch (e->event) {
case WE_PAINT:
@@ -62,9 +63,9 @@ static void SelectGameWndProc(Window *w, WindowEvent *e)
DrawWindowWidgets(w);
DrawStringRightAligned(216, 121, STR_MAPSIZE, 0);
- DrawString(223, 121, mapsizes[_patches.map_x - 6], 0x10);
+ DrawString(223, 121, mapsizes[_patches_newgame.map_x - 6], 0x10);
DrawString(270, 121, STR_BY, 0);
- DrawString(283, 121, mapsizes[_patches.map_y - 6], 0x10);
+ DrawString(283, 121, mapsizes[_patches_newgame.map_y - 6], 0x10);
break;
case WE_CLICK:
@@ -77,10 +78,10 @@ static void SelectGameWndProc(Window *w, WindowEvent *e)
SetNewLandscapeType(e->click.widget - 6);
break;
case 10: case 11: /* Mapsize X */
- ShowDropDownMenu(w, mapsizes, _patches.map_x - 6, 11, 0, 0);
+ ShowDropDownMenu(w, mapsizes, _patches_newgame.map_x - 6, 11, 0, 0);
break;
case 12: case 13: /* Mapsize Y */
- ShowDropDownMenu(w, mapsizes, _patches.map_y - 6, 13, 0, 0);
+ ShowDropDownMenu(w, mapsizes, _patches_newgame.map_y - 6, 13, 0, 0);
break;
case 15:
#ifdef ENABLE_NETWORK
@@ -104,8 +105,11 @@ static void SelectGameWndProc(Window *w, WindowEvent *e)
case WE_DROPDOWN_SELECT: /* Mapsize selection */
switch (e->dropdown.button) {
- case 11: _patches.map_x = e->dropdown.index + 6; break;
- case 13: _patches.map_y = e->dropdown.index + 6; break;
+ /* We need a *hacky* here because generateworld is called with _patches
+ * but it only gets the new value INSIDE generateworld so not setting it would
+ * break generating a new game on the run (eg MP) */
+ case 11: _patches.map_x = _patches_newgame.map_x = e->dropdown.index + 6; break;
+ case 13: _patches.map_y = _patches_newgame.map_y = e->dropdown.index + 6; break;
}
SetWindowDirty(w);
break;
diff --git a/settings.c b/settings.c
index 0dde5c2a9..350dd4041 100644
--- a/settings.c
+++ b/settings.c
@@ -1420,7 +1420,7 @@ static const SettingDesc *GetPatchFromName(const char *name, uint *i)
const SettingDesc *sd;
for (*i = 0, sd = _patch_settings; sd->save.cmd != SL_END; sd++, (*i)++) {
- if (strncmp(sd->desc.name, name, sizeof(sd->desc.name)) == 0) return sd;
+ if (strncmp(sd->desc.name, name, strlen(sd->desc.name)) == 0) return sd;
}
return NULL;