Merge branch 'pre-release-0.0.2' into develop

Conflicts:
	src/util/util.c
This commit is contained in:
IntelOrca 2015-06-15 19:04:10 +01:00
commit 2eb39d4a31
10 changed files with 119 additions and 15 deletions

View File

@ -74,11 +74,17 @@ typedef utf16* utf16string;
#endif
#define OPENRCT2_NAME "OpenRCT2"
#define OPENRCT2_VERSION "develop"
#define OPENRCT2_VERSION "0.0.3"
#define OPENRCT2_ARCHITECTURE "x86"
#define OPENRCT2_PLATFORM "Windows"
#define OPENRCT2_TIMESTAMP __DATE__ " " __TIME__
// The following constants are for automated build servers
#define OPENRCT2_BUILD_SERVER ""
#define OPENRCT2_BRANCH "develop"
#define OPENRCT2_COMMIT_SHA1 ""
#define OPENRCT2_COMMIT_SHA1_SHORT ""
// Represent fixed point numbers. dp = decimal point
typedef sint16 fixed16_1dp;
typedef sint16 fixed16_2dp;

View File

@ -4472,3 +4472,39 @@ bool ride_is_powered_launched(rct_ride *ride)
ride->mode == RIDE_MODE_POWERED_LAUNCH ||
ride->mode == RIDE_MODE_POWERED_LAUNCH_BLOCK_SECTIONED;
}
bool ride_has_any_track_elements(int rideIndex)
{
map_element_iterator it;
map_element_iterator_begin(&it);
while (map_element_iterator_next(&it)) {
if (map_element_get_type(it.element) != MAP_ELEMENT_TYPE_TRACK)
continue;
if (it.element->properties.track.ride_index != rideIndex)
continue;
if (it.element->flags & MAP_ELEMENT_FLAG_GHOST)
continue;
return true;
}
return false;
}
void ride_all_has_any_track_elements(bool *rideIndexArray)
{
map_element_iterator it;
memset(rideIndexArray, 0, MAX_RIDES * sizeof(bool));
map_element_iterator_begin(&it);
while (map_element_iterator_next(&it)) {
if (map_element_get_type(it.element) != MAP_ELEMENT_TYPE_TRACK)
continue;
if (it.element->flags & MAP_ELEMENT_FLAG_GHOST)
continue;
rideIndexArray[it.element->properties.track.ride_index] = true;
}
}

View File

@ -837,5 +837,7 @@ bool ride_has_whirlpool(rct_ride *ride);
bool ride_type_has_flag(int rideType, int flag);
bool ride_is_powered_launched(rct_ride *ride);
bool ride_has_any_track_elements(int rideIndex);
void ride_all_has_any_track_elements(bool *rideIndexArray);
#endif

View File

@ -830,6 +830,26 @@ static void sub_674BCF()
}
}
static void get_map_elements_without_ghost(rct_map_element *resultElements)
{
size_t mapElementTotalSize = MAX_MAP_ELEMENTS * sizeof(rct_map_element);
rct_map_element *destinationElement = resultElements;
for (int y = 0; y < 256; y++) {
for (int x = 0; x < 256; x++) {
rct_map_element *originalElement = map_get_first_element_at(x, y);
do {
if (!(originalElement->flags & MAP_ELEMENT_FLAG_GHOST)) {
*destinationElement++ = *originalElement;
}
} while (!map_element_is_last_for_tile(originalElement++));
// Set last element flag in case the original last element was never added
(destinationElement - 1)->flags |= MAP_ELEMENT_FLAG_LAST_TILE;
}
}
}
/**
*
* rct2: 0x006754F5
@ -944,11 +964,17 @@ int scenario_save(char *path, int flags)
fwrite(buffer, encodedLength, 1, file);
// Write map elements
uint8 *chunkData = malloc(0x4A85EC);
get_map_elements_without_ghost((rct_map_element*)chunkData);
memcpy(chunkData + 0x180000, (uint8*)(RCT2_ADDRESS_MAP_ELEMENTS + 0x180000), 0x4A85EC - 0x180000);
chunkHeader.encoding = CHUNK_ENCODING_RLECOMPRESSED;
chunkHeader.length = 0x4A85EC;
encodedLength = sawyercoding_write_chunk_buffer(buffer, (uint8*)0x00F663B8, chunkHeader);
encodedLength = sawyercoding_write_chunk_buffer(buffer, chunkData, chunkHeader);
fwrite(buffer, encodedLength, 1, file);
free(chunkData);
if (flags & 2) {
// Write chunk
chunkHeader.encoding = CHUNK_ENCODING_RLECOMPRESSED;
@ -992,16 +1018,38 @@ int scenario_save(char *path, int flags)
encodedLength = sawyercoding_write_chunk_buffer(buffer, (uint8*)0x0135853C, chunkHeader);
fwrite(buffer, encodedLength, 1, file);
// Write chunk
// Write chunk (don't save rides which have no track pieces)
uint8 *chunkData = malloc(0x761E8);
memcpy(chunkData, (void*)0x01358740, 0x761E8);
bool rideHasTrack[MAX_RIDES];
rct_ride *rides = (rct_ride*)(chunkData + (0x013628F8 - 0x01358740));
ride_all_has_any_track_elements(rideHasTrack);
for (int i = 0; i < MAX_RIDES; i++) {
if (!rideHasTrack[i])
rides[i].type = RIDE_TYPE_NULL;
}
chunkHeader.encoding = CHUNK_ENCODING_RLECOMPRESSED;
chunkHeader.length = 0x761E8;
encodedLength = sawyercoding_write_chunk_buffer(buffer, (uint8*)0x01358740, chunkHeader);
fwrite(buffer, encodedLength, 1, file);
free(chunkData);
} else {
// Write chunk
// Write chunk (don't save rides which have no track pieces)
uint8 *chunkData = malloc(0x2E8570);
memcpy(chunkData, (void*)0x010E63B8, 0x2E8570);
bool rideHasTrack[MAX_RIDES];
rct_ride *rides = (rct_ride*)(chunkData + (0x013628F8 - 0x010E63B8));
ride_all_has_any_track_elements(rideHasTrack);
for (int i = 0; i < MAX_RIDES; i++) {
if (!rideHasTrack[i])
rides[i].type = RIDE_TYPE_NULL;
}
chunkHeader.encoding = CHUNK_ENCODING_RLECOMPRESSED;
chunkHeader.length = 0x2E8570;
encodedLength = sawyercoding_write_chunk_buffer(buffer, (uint8*)0x010E63B8, chunkHeader);
encodedLength = sawyercoding_write_chunk_buffer(buffer, chunkData, chunkHeader);
fwrite(buffer, encodedLength, 1, file);
}

View File

@ -374,6 +374,12 @@ static void DrawOpenRCT2(int x, int y)
// Format text (name and version)
sprintf(buffer, "%c%c%c%s, v%s", FORMAT_MEDIUMFONT, FORMAT_OUTLINE, FORMAT_WHITE, OPENRCT2_NAME, OPENRCT2_VERSION);
if (!str_is_null_or_empty(OPENRCT2_BRANCH))
sprintf(strchr(buffer, 0), "-%s", OPENRCT2_BRANCH);
if (!str_is_null_or_empty(OPENRCT2_COMMIT_SHA1_SHORT))
sprintf(strchr(buffer, 0), " (%s)", OPENRCT2_COMMIT_SHA1_SHORT);
if (!str_is_null_or_empty(OPENRCT2_BUILD_SERVER))
sprintf(strchr(buffer, 0), " provided by %s", OPENRCT2_BUILD_SERVER);
// Draw Text
gfx_draw_string(dpi, buffer, 0, x + 5, y + 5);

View File

@ -159,3 +159,8 @@ bool utf8_is_bom(const char *str)
{
return str[0] == 0xEF && str[1] == 0xBB && str[2] == 0xBF;
}
bool str_is_null_or_empty(const char *str)
{
return str == NULL || str[0] == 0;
}

View File

@ -39,5 +39,6 @@ bool strequals(const char *a, const char *b, int length, bool caseInsensitive);
int strcicmp(char const *a, char const *b);
bool utf8_is_bom(const char *str);
bool str_is_null_or_empty(const char *str);
#endif

View File

@ -679,7 +679,7 @@ void game_command_remove_scenery(int* eax, int* ebx, int* ecx, int* edx, int* es
while(map_element->type != map_element_type ||
map_element->base_height != base_height ||
map_element->properties.scenery.type != scenery_type ||
(*ebx & 0x40) && !(map_element->flags & MAP_ELEMENT_FLAG_5)){
(*ebx & 0x40) && !(map_element->flags & MAP_ELEMENT_FLAG_GHOST)){
map_element++;
if((map_element - 1)->flags & MAP_ELEMENT_FLAG_LAST_TILE){
*ebx = 0;
@ -742,7 +742,7 @@ void game_command_remove_large_scenery(int* eax, int* ebx, int* ecx, int* edx, i
return;
}
if((*ebx & 0x40) && !(map_element->flags & MAP_ELEMENT_FLAG_5)){
if((*ebx & 0x40) && !(map_element->flags & MAP_ELEMENT_FLAG_GHOST)){
*ebx = 0;
return;
}
@ -913,7 +913,7 @@ void game_command_set_scenery_colour(int* eax, int* ebx, int* ecx, int* edx, int
return;
}
}
if((*ebx & 0x40) && !(map_element->flags & MAP_ELEMENT_FLAG_5)){
if((*ebx & 0x40) && !(map_element->flags & MAP_ELEMENT_FLAG_GHOST)){
*ebx = 0;
return;
}
@ -955,14 +955,14 @@ void game_command_set_fence_colour(int* eax, int* ebx, int* ecx, int* edx, int*
while(map_element_get_type(map_element) != MAP_ELEMENT_TYPE_FENCE ||
map_element->base_height != base_height ||
(map_element->type & MAP_ELEMENT_DIRECTION_MASK) != map_element_direction||
((*ebx & 0x40) && !(map_element->flags & MAP_ELEMENT_FLAG_5))){
((*ebx & 0x40) && !(map_element->flags & MAP_ELEMENT_FLAG_GHOST))){
map_element++;
if((map_element - 1)->flags & MAP_ELEMENT_FLAG_LAST_TILE){
*ebx = 0;
return;
}
}
if((*ebx & 0x40) && !(map_element->flags & MAP_ELEMENT_FLAG_5)){
if((*ebx & 0x40) && !(map_element->flags & MAP_ELEMENT_FLAG_GHOST)){
*ebx = 0;
return;
}
@ -1014,7 +1014,7 @@ void game_command_set_large_scenery_colour(int* eax, int* ebx, int* ecx, int* ed
return;
}
}
if((*ebx & 0x40) && !(map_element->flags & MAP_ELEMENT_FLAG_5)){
if((*ebx & 0x40) && !(map_element->flags & MAP_ELEMENT_FLAG_GHOST)){
*ebx = 0;
return;
}
@ -1823,7 +1823,7 @@ void game_command_remove_fence(int* eax, int* ebx, int* ecx, int* edx, int* esi,
while(map_element_get_type(map_element) != MAP_ELEMENT_TYPE_FENCE ||
map_element->base_height != base_height ||
(map_element->type & MAP_ELEMENT_DIRECTION_MASK) != direction ||
((*ebx & 0x40) && !(map_element->flags & MAP_ELEMENT_FLAG_5))){
((*ebx & 0x40) && !(map_element->flags & MAP_ELEMENT_FLAG_GHOST))){
map_element++;
if((map_element - 1)->flags & MAP_ELEMENT_FLAG_LAST_TILE){
*ebx = 0;
@ -2305,7 +2305,7 @@ void game_command_place_large_scenery(int* eax, int* ebx, int* ecx, int* edx, in
}
if(*ebx & 0x40){
new_map_element->flags |= MAP_ELEMENT_FLAG_5;
new_map_element->flags |= MAP_ELEMENT_FLAG_GHOST;
}
if(tile_num == 0){
RCT2_GLOBAL(0x00F64EBC, rct_map_element*) = new_map_element;

View File

@ -129,7 +129,7 @@ enum {
};
enum {
MAP_ELEMENT_FLAG_5 = (1 << 4),
MAP_ELEMENT_FLAG_GHOST = (1 << 4),
MAP_ELEMENT_FLAG_BROKEN = (1 << 5),
MAP_ELEMENT_FLAG_LAST_TILE = (1 << 7)
};

View File

@ -766,7 +766,7 @@ void update_park_fences(int x, int y)
if (mapElement->properties.entrance.type != ENTRANCE_TYPE_PARK_ENTRANCE)
continue;
if (!(mapElement->flags & MAP_ELEMENT_FLAG_5)){
if (!(mapElement->flags & MAP_ELEMENT_FLAG_GHOST)) {
fence_required = 0;
break;
}