From 958f2fb2968e4f1a0520e719cd43a5f21a796215 Mon Sep 17 00:00:00 2001 From: medsouz Date: Mon, 17 Aug 2015 23:05:46 -0400 Subject: [PATCH 1/3] Document some scenery memory addresses --- src/addresses.h | 7 +++ src/windows/scenery.c | 12 +++--- src/windows/top_toolbar.c | 90 +++++++++++++++++++-------------------- src/world/scenery.c | 37 ++++++++-------- 4 files changed, 75 insertions(+), 71 deletions(-) diff --git a/src/addresses.h b/src/addresses.h index f1dc347c96..8421dce109 100644 --- a/src/addresses.h +++ b/src/addresses.h @@ -349,6 +349,13 @@ #define RCT2_ADDRESS_TRACK_LIST 0x00F441EC +#define RCT2_ADDRESS_SCENERY_COST 0x00F64EB4 + +#define RCT2_ADDRESS_GHOST_SCENERY_X 0x00F64EC4 +#define RCT2_ADDRESS_GHOST_SCENERY_Y 0x00F64EC6 +#define RCT2_ADDRESS_GHOST_SCENERY_Z 0x00F64F09 +#define RCT2_ADDRESS_GHOST_SCENERY_TYPE 0x00F64F0D + #define RCT2_ADDRESS_CTRL_PRESS_Z_COORDINATE 0x00F64ECC #define RCT2_ADDRESS_SHIFT_PRESS_X_COORDINATE 0x00F64ECE #define RCT2_ADDRESS_SHIFT_PRESS_Y_COORDINATE 0x00F64ED0 diff --git a/src/windows/scenery.c b/src/windows/scenery.c index 3deb35e692..ea6a4388a2 100644 --- a/src/windows/scenery.c +++ b/src/windows/scenery.c @@ -470,8 +470,8 @@ void window_scenery_open() window->scenery.selected_scenery_id = -1; window->scenery.hover_counter = 0; window_push_others_below(window); - RCT2_GLOBAL(0x00F64F0D, uint8) = 0; - RCT2_GLOBAL(0x00F64EB4, uint32) = MONEY32_UNDEFINED; + RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_TYPE, uint8) = 0; + RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_COST, uint32) = MONEY32_UNDEFINED; RCT2_GLOBAL(0x00F64EC0, uint16) = 0; window_scenery_is_repaint_scenery_tool_on = 0; // repaint colored scenery tool state window_scenery_is_build_cluster_tool_on = 0; // build cluster tool state @@ -639,7 +639,7 @@ static void window_scenery_mousedown(int widgetIndex, rct_window* w, rct_widget* if (widgetIndex >= WIDX_SCENERY_TAB_1 && widgetIndex <= WIDX_SCENERY_TAB_20) { window_scenery_active_tab_index = widgetIndex - WIDX_SCENERY_TAB_1; window_invalidate(w); - RCT2_GLOBAL(0x00F64EB4, uint32) = MONEY32_UNDEFINED; + RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_COST, uint32) = MONEY32_UNDEFINED; window_scenery_update_scroll(w); } } @@ -797,7 +797,7 @@ void window_scenery_scrollmousedown(rct_window *w, int scrollIndex, int x, int y window_scenery_is_repaint_scenery_tool_on &= 0xFE; sound_play_panned(4, (w->width >> 1) + w->x, 0, 0, 0); w->scenery.hover_counter = -16; - RCT2_GLOBAL(0x00F64EB4, uint32) = MONEY32_UNDEFINED; + RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_COST, uint32) = MONEY32_UNDEFINED; window_invalidate(w); } @@ -1021,8 +1021,8 @@ void window_scenery_paint(rct_window *w, rct_drawpixelinfo *dpi) price = sceneryEntry->small_scenery.price * 10; } - if (w->scenery.selected_scenery_id == -1 && RCT2_GLOBAL(0x00F64EB4, uint32) != MONEY32_UNDEFINED) { - price = RCT2_GLOBAL(0x00F64EB4, uint32); + if (w->scenery.selected_scenery_id == -1 && RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_COST, uint32) != MONEY32_UNDEFINED) { + price = RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_COST, uint32); } RCT2_GLOBAL(0x013CE952, uint32) = price; diff --git a/src/windows/top_toolbar.c b/src/windows/top_toolbar.c index f1b94142f5..b4c634c9ba 100644 --- a/src/windows/top_toolbar.c +++ b/src/windows/top_toolbar.c @@ -2083,18 +2083,18 @@ money32 try_place_ghost_scenery(rct_xy16 map_tile, uint32 parameter_1, uint32 pa parameter_2, GAME_COMMAND_PLACE_SCENERY, parameter_3, - RCT2_GLOBAL(0x00F64ED4, sint16)); + RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_Z_COORDINATE, sint16)); if (cost == MONEY32_UNDEFINED) return cost; - RCT2_GLOBAL(0x00F64EC4, sint16) = map_tile.x; - RCT2_GLOBAL(0x00F64EC6, sint16) = map_tile.y; + RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_X, sint16) = map_tile.x; + RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_Y, sint16) = map_tile.y; RCT2_GLOBAL(0x00F64EC0, uint16) = (uint16)(parameter_3 & 0xFFFF); RCT2_GLOBAL(0x00F64EDA, sint16) = selected_tab; mapElement = RCT2_GLOBAL(0x00F64EBC, rct_map_element*); - RCT2_GLOBAL(0x00F64F09, uint8) = mapElement->base_height; + RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_Z, uint8) = mapElement->base_height; RCT2_GLOBAL(0x00F64F0C, uint8) = mapElement->type; if (RCT2_GLOBAL(0x00F64F14, uint8) & (1 << 1)){ viewport_set_visibility(4); @@ -2103,7 +2103,7 @@ money32 try_place_ghost_scenery(rct_xy16 map_tile, uint32 parameter_1, uint32 pa viewport_set_visibility(5); } - RCT2_GLOBAL(0x00F64F0D, uint8) |= (1 << 0); + RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_TYPE, uint8) |= (1 << 0); break; case 1: // Path Bits @@ -2120,14 +2120,14 @@ money32 try_place_ghost_scenery(rct_xy16 map_tile, uint32 parameter_1, uint32 pa if (cost == MONEY32_UNDEFINED) return cost; - RCT2_GLOBAL(0x00F64EC4, sint16) = map_tile.x; - RCT2_GLOBAL(0x00F64EC6, sint16) = map_tile.y; - RCT2_GLOBAL(0x00F64F09, uint8) = (parameter_2 & 0xFF); + RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_X, sint16) = map_tile.x; + RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_Y, sint16) = map_tile.y; + RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_Z, uint8) = (parameter_2 & 0xFF); RCT2_GLOBAL(0x00F64F0F, uint8) = ((parameter_1 >> 8) & 0xFF); RCT2_GLOBAL(0x00F64F10, uint8) = ((parameter_2 >> 8) & 0xFF); RCT2_GLOBAL(0x00F64EAC, uint32) = parameter_3; - RCT2_GLOBAL(0x00F64F0D, uint8) |= (1 << 1); + RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_TYPE, uint8) |= (1 << 1); break; case 2: // Walls @@ -2138,20 +2138,20 @@ money32 try_place_ghost_scenery(rct_xy16 map_tile, uint32 parameter_1, uint32 pa map_tile.y, parameter_2, GAME_COMMAND_PLACE_FENCE, - RCT2_GLOBAL(0x00F64ED4, uint16), + RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_Z_COORDINATE, uint16), RCT2_GLOBAL(0x00F64F15, uint16)); if (cost == MONEY32_UNDEFINED) return cost; - RCT2_GLOBAL(0x00F64EC4, sint16) = map_tile.x; - RCT2_GLOBAL(0x00F64EC6, sint16) = map_tile.y; + RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_X, sint16) = map_tile.x; + RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_Y, sint16) = map_tile.y; RCT2_GLOBAL(0x00F64F11, uint8) = (parameter_2 & 0xFF); mapElement = RCT2_GLOBAL(0x00F64EBC, rct_map_element*); - RCT2_GLOBAL(0x00F64F09, uint8) = mapElement->base_height; + RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_Z, uint8) = mapElement->base_height; - RCT2_GLOBAL(0x00F64F0D, uint8) |= (1 << 2); + RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_TYPE, uint8) |= (1 << 2); break; case 3: // Large Scenery @@ -2163,17 +2163,17 @@ money32 try_place_ghost_scenery(rct_xy16 map_tile, uint32 parameter_1, uint32 pa parameter_2, GAME_COMMAND_PLACE_LARGE_SCENERY, parameter_3, - RCT2_GLOBAL(0x00F64ED4, uint16)); + RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_Z_COORDINATE, uint16)); if (cost == MONEY32_UNDEFINED) return cost; - RCT2_GLOBAL(0x00F64EC4, sint16) = map_tile.x; - RCT2_GLOBAL(0x00F64EC6, sint16) = map_tile.y; + RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_X, sint16) = map_tile.x; + RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_Y, sint16) = map_tile.y; RCT2_GLOBAL(0x00F64EC0, uint8) = ((parameter_1 >> 8) & 0xFF); mapElement = RCT2_GLOBAL(0x00F64EBC, rct_map_element*); - RCT2_GLOBAL(0x00F64F09, uint8) = mapElement->base_height; + RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_Z, uint8) = mapElement->base_height; if (RCT2_GLOBAL(0x00F64F14, uint8) & (1 << 1)){ viewport_set_visibility(4); @@ -2182,7 +2182,7 @@ money32 try_place_ghost_scenery(rct_xy16 map_tile, uint32 parameter_1, uint32 pa viewport_set_visibility(5); } - RCT2_GLOBAL(0x00F64F0D, uint8) |= (1 << 3); + RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_TYPE, uint8) |= (1 << 3); break; case 4: // Banners @@ -2199,11 +2199,11 @@ money32 try_place_ghost_scenery(rct_xy16 map_tile, uint32 parameter_1, uint32 pa if (cost == MONEY32_UNDEFINED) return cost; - RCT2_GLOBAL(0x00F64EC4, sint16) = map_tile.x; - RCT2_GLOBAL(0x00F64EC6, sint16) = map_tile.y; - RCT2_GLOBAL(0x00F64F09, uint8) = (parameter_2 & 0xFF); + RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_X, sint16) = map_tile.x; + RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_Y, sint16) = map_tile.y; + RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_Z, uint8) = (parameter_2 & 0xFF); RCT2_GLOBAL(0x00F64EC0, uint8) = ((parameter_2 >> 8) & 0xFF); - RCT2_GLOBAL(0x00F64F0D, uint8) |= (1 << 4); + RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_TYPE, uint8) |= (1 << 4); break; } @@ -2264,9 +2264,9 @@ void top_toolbar_tool_update_scenery(sint16 x, sint16 y){ map_invalidate_selection_rect(); // If no change in ghost placement - if ((RCT2_GLOBAL(0x00F64F0D, uint8) & (1 << 0)) && - mapTile.x == RCT2_GLOBAL(0x00F64EC4, sint16) && - mapTile.y == RCT2_GLOBAL(0x00F64EC6, sint16) && + if ((RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_TYPE, uint8) & (1 << 0)) && + mapTile.x == RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_X, sint16) && + mapTile.y == RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_Y, sint16) && (parameter2 & 0xFF) == RCT2_GLOBAL(0x00F64F0E, uint8)&& RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_Z_COORDINATE, sint16) == RCT2_GLOBAL(0x00F64F0A, sint16) && RCT2_GLOBAL(0x00F64EDA, uint16) == selected_tab){ @@ -2297,7 +2297,7 @@ void top_toolbar_tool_update_scenery(sint16 x, sint16 y){ RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_Z_COORDINATE, sint16) += 8; } - RCT2_GLOBAL(0x00F64EB4, money32) = cost; + RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_COST, money32) = cost; break; case 1: RCT2_GLOBAL(RCT2_ADDRESS_MAP_SELECTION_FLAGS, uint16) |= (1 << 0); @@ -2310,10 +2310,10 @@ void top_toolbar_tool_update_scenery(sint16 x, sint16 y){ map_invalidate_selection_rect(); // If no change in ghost placement - if ((RCT2_GLOBAL(0x00F64F0D, uint8) & (1 << 1)) && - mapTile.x == RCT2_GLOBAL(0x00F64EC4, sint16) && - mapTile.y == RCT2_GLOBAL(0x00F64EC6, sint16) && - (parameter2 & 0xFF) == RCT2_GLOBAL(0x00F64F09, uint8)){ + if ((RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_TYPE, uint8) & (1 << 1)) && + mapTile.x == RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_X, sint16) && + mapTile.y == RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_Y, sint16) && + (parameter2 & 0xFF) == RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_Z, uint8)){ return; } @@ -2326,7 +2326,7 @@ void top_toolbar_tool_update_scenery(sint16 x, sint16 y){ parameter3, selected_tab); - RCT2_GLOBAL(0x00F64EB4, money32) = cost; + RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_COST, money32) = cost; break; case 2: RCT2_GLOBAL(RCT2_ADDRESS_MAP_SELECTION_FLAGS, uint16) |= (1 << 0); @@ -2339,9 +2339,9 @@ void top_toolbar_tool_update_scenery(sint16 x, sint16 y){ map_invalidate_selection_rect(); // If no change in ghost placement - if ((RCT2_GLOBAL(0x00F64F0D, uint8) & (1 << 2)) && - mapTile.x == RCT2_GLOBAL(0x00F64EC4, sint16) && - mapTile.y == RCT2_GLOBAL(0x00F64EC6, sint16) && + if ((RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_TYPE, uint8) & (1 << 2)) && + mapTile.x == RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_X, sint16) && + mapTile.y == RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_Y, sint16) && (parameter2 & 0xFF) == RCT2_GLOBAL(0x00F64F11, uint8) && RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_Z_COORDINATE, sint16) == RCT2_GLOBAL(0x00F64F0A, sint16) ){ @@ -2373,7 +2373,7 @@ void top_toolbar_tool_update_scenery(sint16 x, sint16 y){ RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_Z_COORDINATE, sint16) += 8; } - RCT2_GLOBAL(0x00F64EB4, money32) = cost; + RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_COST, money32) = cost; break; case 3: scenery = g_largeSceneryEntries[selected_scenery]; @@ -2400,9 +2400,9 @@ void top_toolbar_tool_update_scenery(sint16 x, sint16 y){ map_invalidate_map_selection_tiles(); // If no change in ghost placement - if ((RCT2_GLOBAL(0x00F64F0D, uint8) & (1 << 3)) && - mapTile.x == RCT2_GLOBAL(0x00F64EC4, sint16) && - mapTile.y == RCT2_GLOBAL(0x00F64EC6, sint16) && + if ((RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_TYPE, uint8) & (1 << 3)) && + mapTile.x == RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_X, sint16) && + mapTile.y == RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_Y, sint16) && RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_Z_COORDINATE, sint16) == RCT2_GLOBAL(0x00F64F0A, sint16) && (parameter3 & 0xFFFF) == RCT2_GLOBAL(0x00F64EDA, uint16)){ return; @@ -2433,7 +2433,7 @@ void top_toolbar_tool_update_scenery(sint16 x, sint16 y){ RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_Z_COORDINATE, sint16) += 8; } - RCT2_GLOBAL(0x00F64EB4, money32) = cost; + RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_COST, money32) = cost; break; case 4: RCT2_GLOBAL(RCT2_ADDRESS_MAP_SELECTION_FLAGS, uint16) |= (1 << 0); @@ -2446,10 +2446,10 @@ void top_toolbar_tool_update_scenery(sint16 x, sint16 y){ map_invalidate_selection_rect(); // If no change in ghost placement - if ((RCT2_GLOBAL(0x00F64F0D, uint8) & (1 << 4)) && - mapTile.x == RCT2_GLOBAL(0x00F64EC4, sint16) && - mapTile.y == RCT2_GLOBAL(0x00F64EC6, sint16) && - (parameter2 & 0xFF) == RCT2_GLOBAL(0x00F64F09, uint8) && + if ((RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_TYPE, uint8) & (1 << 4)) && + mapTile.x == RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_X, sint16) && + mapTile.y == RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_Y, sint16) && + (parameter2 & 0xFF) == RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_Z, uint8) && ((parameter2 >> 8) & 0xFF) == RCT2_GLOBAL(0x00F64EC0, uint8)){ return; } @@ -2463,7 +2463,7 @@ void top_toolbar_tool_update_scenery(sint16 x, sint16 y){ parameter3, selected_tab); - RCT2_GLOBAL(0x00F64EB4, money32) = cost; + RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_COST, money32) = cost; break; } } diff --git a/src/world/scenery.c b/src/world/scenery.c index cbf9bf3ca3..fabf42ff24 100644 --- a/src/world/scenery.c +++ b/src/world/scenery.c @@ -111,18 +111,19 @@ void scenery_increase_age(int x, int y, rct_map_element *mapElement) } } - -/* 0x006E2712 */ +/* + * + * rct2: 0x006E2712 + */ void scenery_remove_ghost_tool_placement(){ sint16 x, y, z; - x = RCT2_GLOBAL(0x00F64EC4, sint16); - y = RCT2_GLOBAL(0x00F64EC6, sint16); - z = RCT2_GLOBAL(0x00F64F09, uint8); - - if (RCT2_GLOBAL(0x00F64F0D, uint8) & (1 << 0)){ - RCT2_GLOBAL(0x00F64F0D, uint8) &= ~(1 << 0); + x = RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_X, sint16); + y = RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_Y, sint16); + z = RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_Z, uint8); + if (RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_TYPE, uint8) & (1 << 0)){ + RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_TYPE, uint8) &= ~(1 << 0); game_do_command( x, 105 | (RCT2_GLOBAL(0x00F64F0C, uint8) << 8), @@ -133,9 +134,8 @@ void scenery_remove_ghost_tool_placement(){ 0); } - if (RCT2_GLOBAL(0x00F64F0D, uint8) & (1 << 1)){ - RCT2_GLOBAL(0x00F64F0D, uint8) &= ~(1 << 1); - + if (RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_TYPE, uint8) & (1 << 1)){ + RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_TYPE, uint8) &= ~(1 << 1); rct_map_element* map_element = map_get_first_element_at(x / 32, y / 32); do{ @@ -157,9 +157,8 @@ void scenery_remove_ghost_tool_placement(){ } while (!map_element_is_last_for_tile(map_element++)); } - if (RCT2_GLOBAL(0x00F64F0D, uint8) & (1 << 2)){ - RCT2_GLOBAL(0x00F64F0D, uint8) &= ~(1 << 2); - + if (RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_TYPE, uint8) & (1 << 2)){ + RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_TYPE, uint8) &= ~(1 << 2); game_do_command( x, 105 | (RCT2_GLOBAL(0x00F64F0C, uint8) << 8), @@ -170,9 +169,8 @@ void scenery_remove_ghost_tool_placement(){ 0); } - if (RCT2_GLOBAL(0x00F64F0D, uint8) & (1 << 3)){ - RCT2_GLOBAL(0x00F64F0D, uint8) &= ~(1 << 3); - + if (RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_TYPE, uint8) & (1 << 3)){ + RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_TYPE, uint8) &= ~(1 << 3); game_do_command( x, 105 | (RCT2_GLOBAL(0x00F64EC0, uint8) << 8), @@ -183,9 +181,8 @@ void scenery_remove_ghost_tool_placement(){ 0); } - if (RCT2_GLOBAL(0x00F64F0D, uint8) & (1 << 4)){ - RCT2_GLOBAL(0x00F64F0D, uint8) &= ~(1 << 4); - + if (RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_TYPE, uint8) & (1 << 4)){ + RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_TYPE, uint8) &= ~(1 << 4); game_do_command( x, 105, From 4207b41855a13d2f099a5d13cab16121dbaa7b87 Mon Sep 17 00:00:00 2001 From: medsouz Date: Tue, 18 Aug 2015 23:53:24 -0400 Subject: [PATCH 2/3] Name more addresses --- src/addresses.h | 4 +++- src/windows/top_toolbar.c | 18 +++++++++--------- src/world/map.c | 6 +++--- src/world/scenery.c | 8 ++++---- 4 files changed, 19 insertions(+), 17 deletions(-) diff --git a/src/addresses.h b/src/addresses.h index 8421dce109..3c96cec4e4 100644 --- a/src/addresses.h +++ b/src/addresses.h @@ -350,10 +350,11 @@ #define RCT2_ADDRESS_TRACK_LIST 0x00F441EC #define RCT2_ADDRESS_SCENERY_COST 0x00F64EB4 - +#define RCT2_ADDRESS_SCENERY_MAP_ELEMENT 0x00F64EBC #define RCT2_ADDRESS_GHOST_SCENERY_X 0x00F64EC4 #define RCT2_ADDRESS_GHOST_SCENERY_Y 0x00F64EC6 #define RCT2_ADDRESS_GHOST_SCENERY_Z 0x00F64F09 +#define RCT2_ADDRESS_SCENERY_MAP_ELEMENT_TYPE 0x00F64F0C #define RCT2_ADDRESS_GHOST_SCENERY_TYPE 0x00F64F0D #define RCT2_ADDRESS_CTRL_PRESS_Z_COORDINATE 0x00F64ECC @@ -361,6 +362,7 @@ #define RCT2_ADDRESS_SHIFT_PRESS_Y_COORDINATE 0x00F64ED0 #define RCT2_ADDRESS_SHIFT_PRESS_Z_VECTOR 0x00F64ED2 #define RCT2_ADDRESS_SCENERY_Z_COORDINATE 0x00F64ED4 +#define RCT2_ADDRESS_SCENERY_SELECTED_OBJECT 0x00F64EDA #define RCT2_ADDRESS_SCENERY_TOOL_CTRL_PRESSED 0x00F64F12 #define RCT2_ADDRESS_SCENERY_TOOL_SHIFT_PRESSED 0x00F64F13 diff --git a/src/windows/top_toolbar.c b/src/windows/top_toolbar.c index b4c634c9ba..9aa804c3b6 100644 --- a/src/windows/top_toolbar.c +++ b/src/windows/top_toolbar.c @@ -2091,11 +2091,11 @@ money32 try_place_ghost_scenery(rct_xy16 map_tile, uint32 parameter_1, uint32 pa RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_X, sint16) = map_tile.x; RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_Y, sint16) = map_tile.y; RCT2_GLOBAL(0x00F64EC0, uint16) = (uint16)(parameter_3 & 0xFFFF); - RCT2_GLOBAL(0x00F64EDA, sint16) = selected_tab; - - mapElement = RCT2_GLOBAL(0x00F64EBC, rct_map_element*); + RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_SELECTED_OBJECT, sint16) = selected_tab; + + mapElement = RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_MAP_ELEMENT, rct_map_element*); RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_Z, uint8) = mapElement->base_height; - RCT2_GLOBAL(0x00F64F0C, uint8) = mapElement->type; + RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_MAP_ELEMENT_TYPE, uint8) = mapElement->type; if (RCT2_GLOBAL(0x00F64F14, uint8) & (1 << 1)){ viewport_set_visibility(4); } @@ -2148,7 +2148,7 @@ money32 try_place_ghost_scenery(rct_xy16 map_tile, uint32 parameter_1, uint32 pa RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_Y, sint16) = map_tile.y; RCT2_GLOBAL(0x00F64F11, uint8) = (parameter_2 & 0xFF); - mapElement = RCT2_GLOBAL(0x00F64EBC, rct_map_element*); + mapElement = RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_MAP_ELEMENT, rct_map_element*); RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_Z, uint8) = mapElement->base_height; RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_TYPE, uint8) |= (1 << 2); @@ -2172,7 +2172,7 @@ money32 try_place_ghost_scenery(rct_xy16 map_tile, uint32 parameter_1, uint32 pa RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_Y, sint16) = map_tile.y; RCT2_GLOBAL(0x00F64EC0, uint8) = ((parameter_1 >> 8) & 0xFF); - mapElement = RCT2_GLOBAL(0x00F64EBC, rct_map_element*); + mapElement = RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_MAP_ELEMENT, rct_map_element*); RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_Z, uint8) = mapElement->base_height; if (RCT2_GLOBAL(0x00F64F14, uint8) & (1 << 1)){ @@ -2269,7 +2269,7 @@ void top_toolbar_tool_update_scenery(sint16 x, sint16 y){ mapTile.y == RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_Y, sint16) && (parameter2 & 0xFF) == RCT2_GLOBAL(0x00F64F0E, uint8)&& RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_Z_COORDINATE, sint16) == RCT2_GLOBAL(0x00F64F0A, sint16) && - RCT2_GLOBAL(0x00F64EDA, uint16) == selected_tab){ + RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_SELECTED_OBJECT, uint16) == selected_tab){ return; } @@ -2404,13 +2404,13 @@ void top_toolbar_tool_update_scenery(sint16 x, sint16 y){ mapTile.x == RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_X, sint16) && mapTile.y == RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_Y, sint16) && RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_Z_COORDINATE, sint16) == RCT2_GLOBAL(0x00F64F0A, sint16) && - (parameter3 & 0xFFFF) == RCT2_GLOBAL(0x00F64EDA, uint16)){ + (parameter3 & 0xFFFF) == RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_SELECTED_OBJECT, uint16)){ return; } scenery_remove_ghost_tool_placement(); - RCT2_GLOBAL(0x00F64EDA, uint16) = (parameter3 & 0xFFFF); + RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_SELECTED_OBJECT, uint16) = (parameter3 & 0xFFFF); RCT2_GLOBAL(0x00F64F0A, sint16) = RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_Z_COORDINATE, sint16); bl = 1; diff --git a/src/world/map.c b/src/world/map.c index f144dda8d7..ad481c3e00 100644 --- a/src/world/map.c +++ b/src/world/map.c @@ -2383,7 +2383,7 @@ void game_command_place_scenery(int* eax, int* ebx, int* ecx, int* edx, int* esi if(*ebx & GAME_COMMAND_FLAG_APPLY){ int flags = (bl & 0xf); rct_map_element* new_map_element = map_element_insert(x / 32, y / 32, zLow, flags); - RCT2_GLOBAL(0x00F64EBC, rct_map_element*) = new_map_element; + RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_MAP_ELEMENT, rct_map_element*) = new_map_element; uint8 type = quadrant << 6; type |= MAP_ELEMENT_TYPE_SCENERY; type |= rotation; @@ -2681,7 +2681,7 @@ void game_command_place_fence(int* eax, int* ebx, int* ecx, int* edx, int* esi, map_element->flags |= MAP_ELEMENT_FLAG_GHOST; } - RCT2_GLOBAL(0x00F64EBC, rct_map_element*) = map_element; + RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_MAP_ELEMENT, rct_map_element*) = map_element; map_invalidate_tile_zoom1(position.x, position.y, map_element->base_height * 8, map_element->base_height * 8 + 72); } @@ -2897,7 +2897,7 @@ void game_command_place_large_scenery(int* eax, int* ebx, int* ecx, int* edx, in new_map_element->flags |= MAP_ELEMENT_FLAG_GHOST; } if(tile_num == 0){ - RCT2_GLOBAL(0x00F64EBC, rct_map_element*) = new_map_element; + RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_MAP_ELEMENT, rct_map_element*) = new_map_element; } map_invalidate_tile_full(x2, y2); } diff --git a/src/world/scenery.c b/src/world/scenery.c index fabf42ff24..dae85db385 100644 --- a/src/world/scenery.c +++ b/src/world/scenery.c @@ -126,9 +126,9 @@ void scenery_remove_ghost_tool_placement(){ RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_TYPE, uint8) &= ~(1 << 0); game_do_command( x, - 105 | (RCT2_GLOBAL(0x00F64F0C, uint8) << 8), + 105 | (RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_MAP_ELEMENT_TYPE, uint8) << 8), y, - z | (RCT2_GLOBAL(0x00F64EDA, uint8) << 8), + z | (RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_SELECTED_OBJECT, uint8) << 8), GAME_COMMAND_REMOVE_SCENERY, 0, 0); @@ -161,7 +161,7 @@ void scenery_remove_ghost_tool_placement(){ RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_TYPE, uint8) &= ~(1 << 2); game_do_command( x, - 105 | (RCT2_GLOBAL(0x00F64F0C, uint8) << 8), + 105 | (RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_MAP_ELEMENT_TYPE, uint8) << 8), y, RCT2_GLOBAL(0x00F64F11, uint8) |(z << 8), GAME_COMMAND_REMOVE_FENCE, @@ -173,7 +173,7 @@ void scenery_remove_ghost_tool_placement(){ RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_TYPE, uint8) &= ~(1 << 3); game_do_command( x, - 105 | (RCT2_GLOBAL(0x00F64EC0, uint8) << 8), + 105 | (RCT2_GLOBAL(0x00F64EC0 /* rotation? */, uint8) << 8), y, z, GAME_COMMAND_REMOVE_LARGE_SCENERY, From e9269cb882cb864baf250a14f21fe8ffe7ec8b48 Mon Sep 17 00:00:00 2001 From: medsouz Date: Sat, 22 Aug 2015 12:03:40 -0400 Subject: [PATCH 3/3] Finish naming scenery.c addresses --- src/addresses.h | 7 +++++-- src/windows/scenery.c | 2 +- src/windows/top_toolbar.c | 26 +++++++++++++------------- src/world/scenery.c | 12 ++++++------ 4 files changed, 25 insertions(+), 22 deletions(-) diff --git a/src/addresses.h b/src/addresses.h index 3c96cec4e4..5533ef5ce3 100644 --- a/src/addresses.h +++ b/src/addresses.h @@ -351,19 +351,22 @@ #define RCT2_ADDRESS_SCENERY_COST 0x00F64EB4 #define RCT2_ADDRESS_SCENERY_MAP_ELEMENT 0x00F64EBC +#define RCT2_ADDRESS_SCENERY_ROTATION 0x00F64EC0 #define RCT2_ADDRESS_GHOST_SCENERY_X 0x00F64EC4 #define RCT2_ADDRESS_GHOST_SCENERY_Y 0x00F64EC6 #define RCT2_ADDRESS_GHOST_SCENERY_Z 0x00F64F09 #define RCT2_ADDRESS_SCENERY_MAP_ELEMENT_TYPE 0x00F64F0C #define RCT2_ADDRESS_GHOST_SCENERY_TYPE 0x00F64F0D - +#define RCT2_ADDRESS_SCENERY_TARGET_PATH_INCLINE 0x00F64F0F +#define RCT2_ADDRESS_GHOST_SCENERY_PATH_OBJECT_TYPE 0x00F64EAC #define RCT2_ADDRESS_CTRL_PRESS_Z_COORDINATE 0x00F64ECC #define RCT2_ADDRESS_SHIFT_PRESS_X_COORDINATE 0x00F64ECE #define RCT2_ADDRESS_SHIFT_PRESS_Y_COORDINATE 0x00F64ED0 #define RCT2_ADDRESS_SHIFT_PRESS_Z_VECTOR 0x00F64ED2 #define RCT2_ADDRESS_SCENERY_Z_COORDINATE 0x00F64ED4 #define RCT2_ADDRESS_SCENERY_SELECTED_OBJECT 0x00F64EDA - +#define RCT2_ADDRESS_SCENERY_TARGET_PATH_TYPE 0x00F64F10 +#define RCT2_ADDRESS_GHOST_SCENERY_WALL_ROTATION 0x00F64F11 #define RCT2_ADDRESS_SCENERY_TOOL_CTRL_PRESSED 0x00F64F12 #define RCT2_ADDRESS_SCENERY_TOOL_SHIFT_PRESSED 0x00F64F13 diff --git a/src/windows/scenery.c b/src/windows/scenery.c index ea6a4388a2..b7c132a489 100644 --- a/src/windows/scenery.c +++ b/src/windows/scenery.c @@ -472,7 +472,7 @@ void window_scenery_open() window_push_others_below(window); RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_TYPE, uint8) = 0; RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_COST, uint32) = MONEY32_UNDEFINED; - RCT2_GLOBAL(0x00F64EC0, uint16) = 0; + RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_ROTATION, uint16) = 0; window_scenery_is_repaint_scenery_tool_on = 0; // repaint colored scenery tool state window_scenery_is_build_cluster_tool_on = 0; // build cluster tool state diff --git a/src/windows/top_toolbar.c b/src/windows/top_toolbar.c index 9aa804c3b6..16d838b2c2 100644 --- a/src/windows/top_toolbar.c +++ b/src/windows/top_toolbar.c @@ -1434,8 +1434,8 @@ static void window_top_toolbar_scenery_tool_down(short x, short y, rct_window* w cur_grid_y += ((scenario_rand() % 16) - 8) * 32; if (!(scenery->small_scenery.flags & SMALL_SCENERY_FLAG4)){ - RCT2_GLOBAL(0x00F64EC0, uint16)++; - RCT2_GLOBAL(0x00F64EC0, uint16) &= 3; + RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_ROTATION, uint16)++; + RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_ROTATION, uint16) &= 3; } } @@ -1460,7 +1460,7 @@ static void window_top_toolbar_scenery_tool_down(short x, short y, rct_window* w RCT2_GLOBAL(RCT2_ADDRESS_GAME_COMMAND_ERROR_STRING_ID, rct_string_id) = 1161; - int cost = game_do_command(cur_grid_x, ebx, cur_grid_y, parameter_2, GAME_COMMAND_PLACE_SCENERY, RCT2_GLOBAL(0x00F64EC0, uint8) | (parameter_3 & 0xFFFF0000), RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_Z_COORDINATE, sint16)); + int cost = game_do_command(cur_grid_x, ebx, cur_grid_y, parameter_2, GAME_COMMAND_PLACE_SCENERY, RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_ROTATION, uint8) | (parameter_3 & 0xFFFF0000), RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_Z_COORDINATE, sint16)); RCT2_GLOBAL(0x009A8C29, uint8) &= ~1; @@ -2090,7 +2090,7 @@ money32 try_place_ghost_scenery(rct_xy16 map_tile, uint32 parameter_1, uint32 pa RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_X, sint16) = map_tile.x; RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_Y, sint16) = map_tile.y; - RCT2_GLOBAL(0x00F64EC0, uint16) = (uint16)(parameter_3 & 0xFFFF); + RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_ROTATION, uint16) = (uint16)(parameter_3 & 0xFFFF); RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_SELECTED_OBJECT, sint16) = selected_tab; mapElement = RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_MAP_ELEMENT, rct_map_element*); @@ -2123,9 +2123,9 @@ money32 try_place_ghost_scenery(rct_xy16 map_tile, uint32 parameter_1, uint32 pa RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_X, sint16) = map_tile.x; RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_Y, sint16) = map_tile.y; RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_Z, uint8) = (parameter_2 & 0xFF); - RCT2_GLOBAL(0x00F64F0F, uint8) = ((parameter_1 >> 8) & 0xFF); - RCT2_GLOBAL(0x00F64F10, uint8) = ((parameter_2 >> 8) & 0xFF); - RCT2_GLOBAL(0x00F64EAC, uint32) = parameter_3; + RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_TARGET_PATH_INCLINE, uint8) = ((parameter_1 >> 8) & 0xFF); + RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_TARGET_PATH_TYPE, uint8) = ((parameter_2 >> 8) & 0xFF); + RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_PATH_OBJECT_TYPE, uint32) = parameter_3; RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_TYPE, uint8) |= (1 << 1); break; @@ -2146,7 +2146,7 @@ money32 try_place_ghost_scenery(rct_xy16 map_tile, uint32 parameter_1, uint32 pa RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_X, sint16) = map_tile.x; RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_Y, sint16) = map_tile.y; - RCT2_GLOBAL(0x00F64F11, uint8) = (parameter_2 & 0xFF); + RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_WALL_ROTATION, uint8) = (parameter_2 & 0xFF); mapElement = RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_MAP_ELEMENT, rct_map_element*); RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_Z, uint8) = mapElement->base_height; @@ -2170,7 +2170,7 @@ money32 try_place_ghost_scenery(rct_xy16 map_tile, uint32 parameter_1, uint32 pa RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_X, sint16) = map_tile.x; RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_Y, sint16) = map_tile.y; - RCT2_GLOBAL(0x00F64EC0, uint8) = ((parameter_1 >> 8) & 0xFF); + RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_ROTATION, uint8) = ((parameter_1 >> 8) & 0xFF); mapElement = RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_MAP_ELEMENT, rct_map_element*); RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_Z, uint8) = mapElement->base_height; @@ -2202,7 +2202,7 @@ money32 try_place_ghost_scenery(rct_xy16 map_tile, uint32 parameter_1, uint32 pa RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_X, sint16) = map_tile.x; RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_Y, sint16) = map_tile.y; RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_Z, uint8) = (parameter_2 & 0xFF); - RCT2_GLOBAL(0x00F64EC0, uint8) = ((parameter_2 >> 8) & 0xFF); + RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_ROTATION, uint8) = ((parameter_2 >> 8) & 0xFF); RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_TYPE, uint8) |= (1 << 4); break; } @@ -2342,7 +2342,7 @@ void top_toolbar_tool_update_scenery(sint16 x, sint16 y){ if ((RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_TYPE, uint8) & (1 << 2)) && mapTile.x == RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_X, sint16) && mapTile.y == RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_Y, sint16) && - (parameter2 & 0xFF) == RCT2_GLOBAL(0x00F64F11, uint8) && + (parameter2 & 0xFF) == RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_WALL_ROTATION, uint8) && RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_Z_COORDINATE, sint16) == RCT2_GLOBAL(0x00F64F0A, sint16) ){ return; @@ -2350,7 +2350,7 @@ void top_toolbar_tool_update_scenery(sint16 x, sint16 y){ scenery_remove_ghost_tool_placement(); - RCT2_GLOBAL(0x00F64F11, uint8) = (parameter2 & 0xFF); + RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_WALL_ROTATION, uint8) = (parameter2 & 0xFF); RCT2_GLOBAL(0x00F64F0A, sint16) = RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_Z_COORDINATE, sint16); bl = 1; @@ -2450,7 +2450,7 @@ void top_toolbar_tool_update_scenery(sint16 x, sint16 y){ mapTile.x == RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_X, sint16) && mapTile.y == RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_Y, sint16) && (parameter2 & 0xFF) == RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_Z, uint8) && - ((parameter2 >> 8) & 0xFF) == RCT2_GLOBAL(0x00F64EC0, uint8)){ + ((parameter2 >> 8) & 0xFF) == RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_ROTATION, uint8)){ return; } diff --git a/src/world/scenery.c b/src/world/scenery.c index dae85db385..5075173d7f 100644 --- a/src/world/scenery.c +++ b/src/world/scenery.c @@ -147,11 +147,11 @@ void scenery_remove_ghost_tool_placement(){ game_do_command( x, - 233 | (RCT2_GLOBAL(0x00F64F0F, uint8) << 8), + 233 | (RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_TARGET_PATH_INCLINE, uint8) << 8), y, - z | (RCT2_GLOBAL(0x00F64F10, uint8) << 8), + z | (RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_TARGET_PATH_TYPE, uint8) << 8), GAME_COMMAND_PLACE_PATH, - RCT2_GLOBAL(0x00F64EAC, uint32) & 0xFFFF0000, + RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_PATH_OBJECT_TYPE, uint32) & 0xFFFF0000, 0); break; } while (!map_element_is_last_for_tile(map_element++)); @@ -163,7 +163,7 @@ void scenery_remove_ghost_tool_placement(){ x, 105 | (RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_MAP_ELEMENT_TYPE, uint8) << 8), y, - RCT2_GLOBAL(0x00F64F11, uint8) |(z << 8), + RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_WALL_ROTATION, uint8) |(z << 8), GAME_COMMAND_REMOVE_FENCE, 0, 0); @@ -173,7 +173,7 @@ void scenery_remove_ghost_tool_placement(){ RCT2_GLOBAL(RCT2_ADDRESS_GHOST_SCENERY_TYPE, uint8) &= ~(1 << 3); game_do_command( x, - 105 | (RCT2_GLOBAL(0x00F64EC0 /* rotation? */, uint8) << 8), + 105 | (RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_ROTATION, uint8) << 8), y, z, GAME_COMMAND_REMOVE_LARGE_SCENERY, @@ -187,7 +187,7 @@ void scenery_remove_ghost_tool_placement(){ x, 105, y, - z | (RCT2_GLOBAL(0x00F64EC0, uint8) << 8), + z | (RCT2_GLOBAL(RCT2_ADDRESS_SCENERY_ROTATION, uint8) << 8), GAME_COMMAND_REMOVE_BANNER, 0, 0);