diff options
| author | Jörg Frings-Fürst <debian@jff-webhosting.net> | 2022-02-06 16:04:38 +0100 | 
|---|---|---|
| committer | Jörg Frings-Fürst <debian@jff-webhosting.net> | 2022-02-06 16:04:38 +0100 | 
| commit | d0ca838c7ab297036b4a7c45351761a48fe05efd (patch) | |
| tree | f0f3cc006e8157d6bd699bd644b7dd7b35387ac2 /app/bin/common.h | |
| parent | fd6639655b399a79fb72f494786a4f57da9c90e7 (diff) | |
| parent | 5d2c2b27a6323e2666378b986129b2a7c2c39e5c (diff) | |
Update upstream source from tag 'upstream/5.2.2GA'
Update to upstream version '5.2.2GA'
with Debian dir 9c80045d0b4f9e463647bc8af8c090a673df4132
Diffstat (limited to 'app/bin/common.h')
| -rw-r--r-- | app/bin/common.h | 140 | 
1 files changed, 122 insertions, 18 deletions
| diff --git a/app/bin/common.h b/app/bin/common.h index 2db961f..92620f2 100644 --- a/app/bin/common.h +++ b/app/bin/common.h @@ -1,5 +1,5 @@  /** \file common.h - * Defnitions of basic types  + * Defnitions of basic types   */  /*  XTrkCad - Model Railroad CAD @@ -23,16 +23,98 @@  #ifndef COMMON_H  #define COMMON_H -#include <stdlib.h> +// INCLUDES +#include <assert.h> +#include <ctype.h> +#include <errno.h> +#include <locale.h> +#include <math.h> +#include <stdarg.h>  #include <stdint.h> +#include <stdio.h> +#include <stdlib.h> +#include <string.h> +#include <sys/stat.h> +#include <sys/types.h> +#include <time.h> + +#ifdef HAVE_MALLOC_H +#include <malloc.h> +#endif + +#include "wlib.h" + +#ifndef WINDOWS +// Unix/Mac +#include <dirent.h> +#include <unistd.h> + +#define PATH_SEPARATOR "/" + +#else +// Windows +#include <io.h> +#include <process.h> +#include "include/dirent.h" +#include "direct.h" +#include "getopt.h" + +// DEFINES +#define UTFCONVERT +#define M_PI 3.14159265358979323846 + +#define F_OK (00) +#define W_OK (02) +#define R_OK (04) +#define PATH_SEPARATOR "\\" + +// ALIASES for WINDOWS +#define access _access +#define unlink(a) _unlink((a)) +#define rmdir(a) _rmdir((a)) +#define open(name, flag, mode) _open((name), (flag), (mode)) +#define close(file) _close((file)) +#define getpid() _getpid() +#define strcasecmp _stricmp +#define strncasecmp _strnicmp +#define mkdir( DIR, MODE ) _mkdir( (DIR) ) +#if _MSC_VER >1300 +#define strnicmp _strnicmp +#define stricmp _stricmp +#define strdup _strdup +#endif +// starting from Visual Studio 2015 round is in the runtime library, fake otherwise +#if ( _MSC_VER < 1900 ) +#define round(x) floor((x)+0.5) +#endif + +/* suppress warning from *.bmp about conversion of int to char */ +#pragma warning( disable : 4305 ) +/* suppress warning about array references */ +#pragma warning( disable : 6385 ) +#endif + +// We need to pass integer values via void* objects +// typically context vars (declared as void*) which sometimes pass pointers and some times integers +// For example see paramData_t.context. +// Also some wlib calls take a generic parameter, declared as void* but somethings used to pass integers +// These are used in logical pairs; VP=I2VP(INTEGER); ...a lot of code...; INTEGER=VP2L(VP); +// Note: we never use VP2L to manipulate integer-ized values of a pointer and all integer values we use fit in a long +#define I2VP(VAL) ((void*)(intptr_t)(VAL)) +#define VP2L(VAL) ((long)(intptr_t)(VAL)) +  #ifndef TRUE  #define TRUE	(1)  #define FALSE	(0)  #endif +#define DIST_INF 2.0E9 +  #define NUM_LAYERS		(99) +// TYPEDEFS +  typedef double FLOAT_T;  typedef double POS_T;  typedef double DIST_T; @@ -72,19 +154,15 @@ enum paramFileState { PARAMFILE_UNLOADED = 0, PARAMFILE_NOTUSABLE, PARAMFILE_COM  #define SCALE_ANY	(-2)  #define SCALE_DEMO	(-1) +// DYNARRAY +  typedef struct {  		int cnt;  		int max;  		void * ptr;  		} dynArr_t; -#if defined(WINDOWS) && ! defined(WIN32) -#define CHECK_SIZE(T,DA) \ -		if ( (long)((DA).max) * (long)(sizeof *(T*)NULL) > 65500L ) \ -			AbortProg( "Dynamic array too large at %s:%d", __FILE__, __LINE__ ); -#else  #define CHECK_SIZE(T,DA) -#endif  #define DYNARR_APPEND(T,DA,INCR) \  		{ if ((DA).cnt >= (DA).max) { \ @@ -130,16 +208,42 @@ typedef struct {  		if ((DA.cnt)>=I) (DA).cnt--; \  		} - -#ifdef WINDOWS -#define M_PI 3.14159 -#define strcasecmp _stricmp -#define strncasecmp _strnicmp -#endif - -#if _MSC_VER >1300 -	#define strdup _strdup -#endif +// Base DotsPerInch +#define BASE_DPI	(75.0) + +// FILE VERSIONS - non-backward file format changes +// Descriptions added for Bezier, Cornu, Joint +#define VERSION_DESCRIPTION2	(12) +// Inline quoted text replaces multiline text in Notes and Cars +#define VERSION_INLINENOTE	(12) +// END is replaced by END$SEGS, END$TRK, ... +#define VERSION_NONAKEDENDS	(12) + + +// FORWARD TYPE DECLS +typedef struct drawCmd_t * drawCmd_p; +typedef struct track_t * track_p; +typedef struct trkSeg_t * trkSeg_p; +typedef struct traverseTrack_t * traverseTrack_p; +typedef struct trkEndPt_t * trkEndPt_p; + +// base class for extraData*_t: each of which must include this struct as the first element +typedef struct extraDataBase_t { +		TRKTYP_T trkType; +	} extraDataBase_t; +// We check if TRKTYP_T in trk, trk->extraDataBase and the code context (TRKTYP) match. +// If TRKTYP is T_NOTRACK then we are dealing with T_TURNOUT/T_STRUCTURE or T_BEZIER/T_BEZLIN which +// share a log of code and have the same extraData*_t structure. +#define GET_EXTRA_DATA(TRK,TRKTYP,TYPE) \ +	((TYPE*)GetTrkExtraData( (TRK), (TRKTYP) )) +extraDataBase_t * GetTrkExtraData( track_p, TRKTYP_T ); + +// COMMON INCLUDES +// If you add includes here, please remove them elsewhere + +#include "i18n.h" +#include "utility.h" +#include "misc.h"  #endif | 
