X-Git-Url: http://4ch.mooo.com/gitweb/?a=blobdiff_plain;f=src%2Flib%2F16_head.h;h=274722303b73d393709ee8d71f358669ad9034f4;hb=6021fc3f27b895d382fbd30488ead35657e39196;hp=f4774012d2b8d07e183ea20f330009816edc006b;hpb=707c5310d94a386646727cafad91f93cc65052ad;p=16.git diff --git a/src/lib/16_head.h b/src/lib/16_head.h index f4774012..27472230 100755 --- a/src/lib/16_head.h +++ b/src/lib/16_head.h @@ -1,5 +1,5 @@ /* Project 16 Source Code~ - * Copyright (C) 2012-2015 sparky4 & pngwen & andrius4669 + * Copyright (C) 2012-2018 sparky4 & pngwen & andrius4669 & joncampbell123 & yakui-lover * * This file is part of Project 16. * @@ -20,35 +20,44 @@ * */ -#if !defined(__LARGE__) && !defined(__COMPACT__) && !defined(__HUGE__) -#error Invalid memory model for compiling project 16 -#endif +//#if !defined(__LARGE__) && !defined(__COMPACT__) && !defined(__HUGE__) +//#error Invalid memory model for compiling project 16 +//#endif #if !defined(__i86__) && defined(__i386__) #error i8088 only #endif -#ifndef _LIBHEAD_H_ -#define _LIBHEAD_H_ +#ifndef __16_HEAD_H__ +#define __16_HEAD_H__ #include #include #include -#include // just for wait +#include // this is where Open Watcom hides the outp() etc. functions // just for wait #include // just for wait -#include #include #include #include #include #include #include +#include +#include +#include #ifdef __WATCOMC__ #include #include #include +#include //16_vrs.h +#endif +#ifdef __BORLANDC__ +#include +#include +#define TILEWH 16 #endif +#include "src/lib/16_t.h" +#include "src/lib/16_tdef.h" #include "src/lib/nyan/kitten.h" -#include "src/lib/types.h" #define VERSION __DATE__ " " __TIME__ @@ -144,59 +153,51 @@ #define KEY_MENU (0x75) */ -static dword far* clockdw= (dword far*) 0x046C; /* 18.2hz clock */ -//static word far* hwclockw= (word far*) 0x046C; /* 18.2hz clock */ +//static word far* clockw= (word far*) 0x046C; /* 18.2hz clock */ extern int profilehandle,debughandle; //make it into game global -#define __DEBUG__ +//#define OLD16_VL #define nil ((void *)0) -#ifdef __BORLANDC__ -#define _FCORELEFT 0x90000UL-16UL -#endif + #ifdef __WATCOMC__ -#define _FCORELEFT 0x90000UL+16UL +//----#define _FCORELEFT 0x90000UL+16UL +extern union REGS CPURegs; -#define peekb(segm,ofs) (*(byte far*)MK_FP((segm),(ofs))) -#define peekw(segm,ofs) (*(word far*)MK_FP((segm),(ofs))) -#define pokeb(segm,ofs,value) (peekb((segm),(ofs)) = (byte)(value)) -#define pokew(segm,ofs,value) (peekw((segm),(ofs)) = (word)(value)) +#define _AX CPURegs.x.ax +#define _BX CPURegs.x.bx +#define _CX CPURegs.x.cx +#define _DX CPURegs.x.dx -typedef union REGPACK regs_t; -#endif +#define _SI CPURegs.x.si -typedef enum {false,true} boolean; +#define _AH CPURegs.h.ah +#define _AL CPURegs.h.al +#define _BH CPURegs.h.bh +#define _BL CPURegs.h.bl +#define _CH CPURegs.h.ch +#define _CL CPURegs.h.cl +#define _DH CPURegs.h.dh +#define _DL CPURegs.h.dl -#ifdef __WATCOMC__ -typedef void __based(__self) * memptr; -#endif -#ifdef __BORLANDC__ -typedef void _seg * memptr; -#endif +#define geninterrupt(n) int86(n,&CPURegs,&CPURegs); -typedef struct -{ -// int showmemhandle; - int profilehandle,debughandle; - int heaphandle; -} handle_t; - -typedef struct -{ - int old_mode; //old video mode before game! - word frames_per_second; - //clock_t t; - dword tiku; //frames passed - word clock_start; //timer start - //word clock; //current time on clock - handle_t handle; //handles for file logging -} global_game_variables_t; - -/* local function */ -void wait(clock_t wait); +typedef union REGPACK regs_t; +#endif + +// local function // long int filesize(FILE *fp); +void clrstdin(); +char *remove_ext(char* mystr, char dot, char sep); +void rotateR(byte arr[], byte n); +void rotateL(byte arr[], byte n); void printmeminfoline(byte *strc, const byte *pee, size_t h_total, size_t h_used, size_t h_free); int US_CheckParm(char *parm,char **strings); +byte dirchar(byte in); +void print_mem(void const *vp, size_t n); +void hres (void); + +#define PRINT_OPAQUE_STRUCT(p) print_mem((p), sizeof(*(p))) -#endif/*_LIBHEAD_H_*/ +#endif/*__16_HEAD_H__*/