mirror of
https://github.com/OpenTTD/OpenTTD.git
synced 2025-01-27 17:32:06 +00:00
dcca3cf80b
-Codechange: removed next_in_chain_old, and saved ->next for Vehicles (and bumped savegame revision for that to version 4.4) -Codechange: Added _sl.full_version, which has both major and minor version
178 lines
4.2 KiB
C
178 lines
4.2 KiB
C
#ifndef SAVELOAD_H
|
|
#define SAVELOAD_H
|
|
|
|
#include <setjmp.h>
|
|
|
|
typedef void ChunkSaveLoadProc();
|
|
typedef void AutolengthProc(void *arg);
|
|
|
|
typedef struct SaveLoadGlobVarList {
|
|
void *address;
|
|
byte conv;
|
|
byte from_version;
|
|
byte to_version;
|
|
} SaveLoadGlobVarList;
|
|
|
|
|
|
typedef struct {
|
|
uint32 id;
|
|
ChunkSaveLoadProc *save_proc;
|
|
ChunkSaveLoadProc *load_proc;
|
|
uint32 flags;
|
|
} ChunkHandler;
|
|
|
|
typedef struct {
|
|
byte null;
|
|
} NullStruct;
|
|
|
|
typedef void WriterProc(uint len);
|
|
typedef uint ReaderProc();
|
|
|
|
typedef uint ReferenceToIntProc(void *v, uint t);
|
|
typedef void *IntToReferenceProc(uint r, uint t);
|
|
|
|
typedef struct {
|
|
bool save;
|
|
byte need_length;
|
|
byte block_mode;
|
|
bool error;
|
|
byte version;
|
|
uint16 full_version;
|
|
|
|
int obj_len;
|
|
int array_index, last_array_index;
|
|
|
|
uint32 offs_base;
|
|
|
|
WriterProc *write_bytes;
|
|
ReaderProc *read_bytes;
|
|
|
|
ReferenceToIntProc *ref_to_int_proc;
|
|
IntToReferenceProc *int_to_ref_proc;
|
|
|
|
const ChunkHandler * const * chs;
|
|
const byte * const *includes;
|
|
|
|
byte *bufp, *bufe;
|
|
|
|
int tmp;
|
|
|
|
// these 3 may be used by compressor/decompressors.
|
|
byte *buf; // pointer and size to read/write, initialized by init
|
|
uint bufsize;
|
|
FILE *fh;
|
|
|
|
void (*excpt_uninit)();
|
|
const char *excpt_msg;
|
|
jmp_buf excpt; // used to jump to "exception handler"
|
|
} SaverLoader;
|
|
|
|
extern SaverLoader _sl;
|
|
|
|
enum {
|
|
REF_SCHEDULE = 0,
|
|
REF_VEHICLE = 1,
|
|
REF_STATION = 2,
|
|
REF_TOWN = 3,
|
|
REF_VEHICLE_OLD = 4,
|
|
};
|
|
|
|
|
|
enum {
|
|
INC_VEHICLE_COMMON = 0,
|
|
};
|
|
|
|
|
|
enum {
|
|
CH_RIFF = 0,
|
|
CH_ARRAY = 1,
|
|
CH_SPARSE_ARRAY = 2,
|
|
CH_TYPE_MASK = 3,
|
|
CH_LAST = 8,
|
|
CH_AUTO_LENGTH = 16,
|
|
CH_PRI_0 = 0 << 4,
|
|
CH_PRI_1 = 1 << 4,
|
|
CH_PRI_2 = 2 << 4,
|
|
CH_PRI_3 = 3 << 4,
|
|
CH_PRI_SHL = 4,
|
|
CH_NUM_PRI_LEVELS = 4,
|
|
};
|
|
|
|
enum {
|
|
SLE_FILE_I8 = 0,
|
|
SLE_FILE_U8 = 1,
|
|
SLE_FILE_I16 = 2,
|
|
SLE_FILE_U16 = 3,
|
|
SLE_FILE_I32 = 4,
|
|
SLE_FILE_U32 = 5,
|
|
SLE_FILE_I64 = 6,
|
|
SLE_FILE_U64 = 7,
|
|
|
|
SLE_FILE_STRINGID = 8,
|
|
// SLE_FILE_IVAR = 8,
|
|
// SLE_FILE_UVAR = 9,
|
|
|
|
SLE_VAR_I8 = 0 << 4,
|
|
SLE_VAR_U8 = 1 << 4,
|
|
SLE_VAR_I16 = 2 << 4,
|
|
SLE_VAR_U16 = 3 << 4,
|
|
SLE_VAR_I32 = 4 << 4,
|
|
SLE_VAR_U32 = 5 << 4,
|
|
SLE_VAR_I64 = 6 << 4,
|
|
SLE_VAR_U64 = 7 << 4,
|
|
|
|
SLE_VAR_NULL = 8 << 4, // useful to write zeros in savegame.
|
|
|
|
SLE_VAR_INT = SLE_VAR_I32,
|
|
SLE_VAR_UINT = SLE_VAR_U32,
|
|
|
|
SLE_INT8 = SLE_FILE_I8 | SLE_VAR_I8,
|
|
SLE_UINT8 = SLE_FILE_U8 | SLE_VAR_U8,
|
|
SLE_INT16 = SLE_FILE_I16 | SLE_VAR_I16,
|
|
SLE_UINT16 = SLE_FILE_U16 | SLE_VAR_U16,
|
|
SLE_INT32 = SLE_FILE_I32 | SLE_VAR_I32,
|
|
SLE_UINT32 = SLE_FILE_U32 | SLE_VAR_U32,
|
|
SLE_INT64 = SLE_FILE_I64 | SLE_VAR_I64,
|
|
SLE_UINT64 = SLE_FILE_U64 | SLE_VAR_U64,
|
|
|
|
SLE_STRINGID = SLE_FILE_STRINGID | SLE_VAR_U16,
|
|
};
|
|
|
|
#define SLE_VAR(t,i,c) 0 | (offsetof(t,i) & 0xF), offsetof(t,i) >> 4, c
|
|
#if _MSC_VER == 1200 /* XXX workaround for MSVC6 */
|
|
#define SLE_VAR2(t0,i0, t1, i1, c) 0 | ((offsetof(t0, i0) + offsetof(t1, i1)) & 0xF), (offsetof(t0, i0) + offsetof(t1, i1)) >> 4, c
|
|
#endif
|
|
#define SLE_REF(t,i,c) 0x10 | (offsetof(t,i) & 0xF), offsetof(t,i) >> 4, c
|
|
#define SLE_ARR(t,i,c,l) 0x20 | (offsetof(t,i) & 0xF), offsetof(t,i) >> 4, c, l
|
|
#define SLE_CONDVAR(t,i,c,from,to) 0x40 | (offsetof(t,i) & 0xF), offsetof(t,i) >> 4, c, from, to
|
|
#define SLE_CONDREF(t,i,c,from,to) 0x50 | (offsetof(t,i) & 0xF), offsetof(t,i) >> 4, c, from, to
|
|
#define SLE_CONDARR(t,i,c,l,from,to) 0x60 | (offsetof(t,i) & 0xF), offsetof(t,i) >> 4, c, from,to, l
|
|
#define SLE_WRITEBYTE(t,i,b,c) 0x80 | (offsetof(t,i) & 0xF), offsetof(t,i) >> 4, b, c
|
|
#define SLE_INCLUDE(t,i,c) 0x90 | (offsetof(t,i) & 0xF), offsetof(t,i) >> 4, c
|
|
|
|
|
|
#define SLE_VARX(t,c) 0x00 | ((t) & 0xF), (t) >> 4, c
|
|
#define SLE_REFX(t,c) 0x10 | ((t) & 0xF), (t) >> 4, c
|
|
#define SLE_CONDVARX(t,c,from,to) 0x40 | ((t) & 0xF), (t) >> 4, c, from, to
|
|
#define SLE_CONDREFX(t,c,co) 0x50 | ((t) & 0xF), (t) >> 4, c, co
|
|
#define SLE_WRITEBYTEX(t,b) 0x80 | ((t) & 0xF), (t) >> 4, b
|
|
#define SLE_INCLUDEX(t,c) 0x90 | ((t) & 0xF), (t) >> 4, c
|
|
|
|
#define SLE_END() 0xF0
|
|
|
|
|
|
void SlSetArrayIndex(uint index);
|
|
int SlIterateArray();
|
|
void SlArray(void *array, uint length, uint conv);
|
|
void SlObject(void *object, const void *desc);
|
|
void SlAutolength(AutolengthProc *proc, void *arg);
|
|
uint SlGetFieldLength();
|
|
int SlReadByte();
|
|
void SlSetLength(uint length);
|
|
void SlWriteByte(byte v);
|
|
void SlGlobList(const SaveLoadGlobVarList *desc);
|
|
|
|
//int GetSavegameType(char *file);
|
|
|
|
#endif /* SAVELOAD_H */
|