mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-26 00:40:56 +00:00
Use XXH64 functions for editor undo/redo when building for 64-bit.
git-svn-id: https://svn.eduke32.com/eduke32@5546 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
ea1f6dc476
commit
e27eb7a7e5
2 changed files with 18 additions and 8 deletions
|
@ -147,7 +147,7 @@ typedef struct mapundo_
|
||||||
// most of the time. +4 bytes refcount at the beginning.
|
// most of the time. +4 bytes refcount at the beginning.
|
||||||
char *sws[3]; // sector, wall, sprite
|
char *sws[3]; // sector, wall, sprite
|
||||||
|
|
||||||
uint32_t crc[3];
|
uintptr_t crc[3];
|
||||||
|
|
||||||
struct mapundo_ *next; // 'redo' loads this
|
struct mapundo_ *next; // 'redo' loads this
|
||||||
struct mapundo_ *prev; // 'undo' loads this
|
struct mapundo_ *prev; // 'undo' loads this
|
||||||
|
|
|
@ -337,7 +337,7 @@ mapundo_t *mapstate = NULL;
|
||||||
|
|
||||||
int32_t map_revision = 1;
|
int32_t map_revision = 1;
|
||||||
|
|
||||||
static int32_t try_match_with_prev(int32_t idx, int32_t numsthgs, uint32_t crc)
|
static int32_t try_match_with_prev(int32_t idx, int32_t numsthgs, uintptr_t crc)
|
||||||
{
|
{
|
||||||
if (mapstate->prev && mapstate->prev->num[idx]==numsthgs && mapstate->prev->crc[idx]==crc)
|
if (mapstate->prev && mapstate->prev->num[idx]==numsthgs && mapstate->prev->crc[idx]==crc)
|
||||||
{
|
{
|
||||||
|
@ -351,7 +351,7 @@ static int32_t try_match_with_prev(int32_t idx, int32_t numsthgs, uint32_t crc)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void create_compressed_block(int32_t idx, const void *srcdata, uint32_t size, uint32_t crc)
|
static void create_compressed_block(int32_t idx, const void *srcdata, uint32_t size, uintptr_t crc)
|
||||||
{
|
{
|
||||||
uint32_t j;
|
uint32_t j;
|
||||||
|
|
||||||
|
@ -442,15 +442,24 @@ void create_map_snapshot(void)
|
||||||
|
|
||||||
if (numsectors)
|
if (numsectors)
|
||||||
{
|
{
|
||||||
int32_t j;
|
#if !defined UINTPTR_MAX
|
||||||
uint32_t temphash = XXH32((uint8_t *)sector, numsectors*sizeof(sectortype), numsectors*sizeof(sectortype));
|
# error Need UINTPTR_MAX define to select between 32- and 64-bit functions
|
||||||
|
#endif
|
||||||
|
#if UINTPTR_MAX == 0xffffffff
|
||||||
|
/* 32-bit */
|
||||||
|
#define XXH__ XXH32
|
||||||
|
#else
|
||||||
|
/* 64-bit */
|
||||||
|
#define XXH__ XXH64
|
||||||
|
#endif
|
||||||
|
uintptr_t temphash = XXH__((uint8_t *)sector, numsectors*sizeof(sectortype), numsectors*sizeof(sectortype));
|
||||||
|
|
||||||
if (!try_match_with_prev(0, numsectors, temphash))
|
if (!try_match_with_prev(0, numsectors, temphash))
|
||||||
create_compressed_block(0, sector, numsectors*sizeof(sectortype), temphash);
|
create_compressed_block(0, sector, numsectors*sizeof(sectortype), temphash);
|
||||||
|
|
||||||
if (numwalls)
|
if (numwalls)
|
||||||
{
|
{
|
||||||
temphash = XXH32((uint8_t *)wall, numwalls*sizeof(walltype), numwalls*sizeof(walltype));
|
temphash = XXH__((uint8_t *)wall, numwalls*sizeof(walltype), numwalls*sizeof(walltype));
|
||||||
|
|
||||||
if (!try_match_with_prev(1, numwalls, temphash))
|
if (!try_match_with_prev(1, numwalls, temphash))
|
||||||
create_compressed_block(1, wall, numwalls*sizeof(walltype), temphash);
|
create_compressed_block(1, wall, numwalls*sizeof(walltype), temphash);
|
||||||
|
@ -458,7 +467,7 @@ void create_map_snapshot(void)
|
||||||
|
|
||||||
if (Numsprites)
|
if (Numsprites)
|
||||||
{
|
{
|
||||||
temphash = XXH32((uint8_t *)sprite, MAXSPRITES*sizeof(spritetype), MAXSPRITES*sizeof(spritetype));
|
temphash = XXH__((uint8_t *)sprite, MAXSPRITES*sizeof(spritetype), MAXSPRITES*sizeof(spritetype));
|
||||||
|
|
||||||
if (!try_match_with_prev(2, Numsprites, temphash))
|
if (!try_match_with_prev(2, Numsprites, temphash))
|
||||||
{
|
{
|
||||||
|
@ -466,7 +475,7 @@ void create_map_snapshot(void)
|
||||||
spritetype *const tspri = (spritetype *)Xmalloc(Numsprites*sizeof(spritetype) + 4);
|
spritetype *const tspri = (spritetype *)Xmalloc(Numsprites*sizeof(spritetype) + 4);
|
||||||
spritetype *spri = tspri;
|
spritetype *spri = tspri;
|
||||||
|
|
||||||
for (j=0; j<MAXSPRITES && i < Numsprites; j++)
|
for (int j=0; j<MAXSPRITES && i < Numsprites; j++)
|
||||||
if (sprite[j].statnum != MAXSTATUS)
|
if (sprite[j].statnum != MAXSTATUS)
|
||||||
{
|
{
|
||||||
Bmemcpy(spri++, &sprite[j], sizeof(spritetype));
|
Bmemcpy(spri++, &sprite[j], sizeof(spritetype));
|
||||||
|
@ -477,6 +486,7 @@ void create_map_snapshot(void)
|
||||||
Bfree(tspri);
|
Bfree(tspri);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#undef XXH__
|
||||||
}
|
}
|
||||||
|
|
||||||
CheckMapCorruption(5, 0);
|
CheckMapCorruption(5, 0);
|
||||||
|
|
Loading…
Reference in a new issue