mirror of
https://github.com/subsurface/subsurface.git
synced 2024-11-28 13:10:19 +00:00
4c0156e3d5
And adapt a new CMakeLists.txt file for it. On the way I've also found out that we where double-compilling a few files. I've also set the subsurface-core as a include_path but that was just to reduce the noise on this commit, since I plan to remove it from the include path to make it obligatory to specify something like include "subsurface-core/dive.h" for the header files. Since the app is growing quite a bit we ended up having a few different files with almost same name that did similar things, I want to kill that (for instance Dive.h, dive.h, PrintDive.h and such). Signed-off-by: Tomaz Canabrava <tomaz.canabrava@intel.com> Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
41 lines
1.1 KiB
C
41 lines
1.1 KiB
C
#ifndef DATATRAK_HEADER_H
|
|
#define DATATRAK_HEADER_H
|
|
|
|
#include <string.h>
|
|
|
|
typedef struct dtrakheader_ {
|
|
int header; //Must be 0xA100;
|
|
int divesNum;
|
|
int dc_serial_1;
|
|
int dc_serial_2;
|
|
} dtrakheader;
|
|
|
|
#define read_bytes(_n) \
|
|
switch (_n) { \
|
|
case 1: \
|
|
if (fread (&lector_bytes, sizeof(char), _n, archivo) != _n) \
|
|
goto bail; \
|
|
tmp_1byte = lector_bytes[0]; \
|
|
break; \
|
|
case 2: \
|
|
if (fread (&lector_bytes, sizeof(char), _n, archivo) != _n) \
|
|
goto bail; \
|
|
tmp_2bytes = two_bytes_to_int (lector_bytes[1], lector_bytes[0]); \
|
|
break; \
|
|
default: \
|
|
if (fread (&lector_word, sizeof(char), _n, archivo) != _n) \
|
|
goto bail; \
|
|
tmp_4bytes = four_bytes_to_long(lector_word[3], lector_word[2], lector_word[1], lector_word[0]); \
|
|
break; \
|
|
}
|
|
|
|
#define read_string(_property) \
|
|
unsigned char *_property##tmp = (unsigned char *)calloc(tmp_1byte + 1, 1); \
|
|
if (fread((char *)_property##tmp, 1, tmp_1byte, archivo) != tmp_1byte) { \
|
|
free(_property##tmp); \
|
|
goto bail; \
|
|
} \
|
|
_property = (unsigned char *)strcat(to_utf8(_property##tmp), ""); \
|
|
free(_property##tmp);
|
|
|
|
#endif // DATATRAK_HEADER_H
|