X-Git-Url: http://4ch.mooo.com/gitweb/?a=blobdiff_plain;f=src%2Flib%2F16_head.h;h=0a71c965a040b9a467d81f3b1023f977f19220bc;hb=d48c3f2da3fb828320dc2817d5ab0e5848d07905;hp=5634fa39b9025ad74480309b3b8ad09e797bed81;hpb=95d9a86ba9df7b1cdfe3b990b1e52298c56ce23f;p=16.git diff --git a/src/lib/16_head.h b/src/lib/16_head.h index 5634fa39..0a71c965 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,46 @@ * */ -#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__ /* Control codes for all keys on the keyboard */ //here temperarly @@ -142,57 +153,70 @@ #define KEY_MENU (0x75) */ -static dword far* clockdw= (dword 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 +#define _DI CPURegs.x.di -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 _CFLAG CPURegs.x.cflag + +#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; - word far* 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); - -#endif/*_LIBHEAD_H_*/ +byte dirchar(byte in); +void print_mem(void const *vp, size_t n); +void hres (void); +void regidump(); + +//from https://stackoverflow.com/questions/111928/is-there-a-printf-converter-to-print-in-binary-format +//printf("Leading text "BYTE_TO_BINARY_PATTERN, BYTE_TO_BINARY(byte)); +//For multi-byte types +//printf("m: "BYTE_TO_BINARY_PATTERN" "BYTE_TO_BINARY_PATTERN"\n", BYTE_TO_BINARY(m>>8), BYTE_TO_BINARY(m)); +#define BYTE_TO_BINARY_PATTERN "%c%c%c%c%c%c%c%c" +#define BYTE_TO_BINARY(byte) \ + (byte & 0x80 ? '1' : '0'), \ + (byte & 0x40 ? '1' : '0'), \ + (byte & 0x20 ? '1' : '0'), \ + (byte & 0x10 ? '1' : '0'), \ + (byte & 0x08 ? '1' : '0'), \ + (byte & 0x04 ? '1' : '0'), \ + (byte & 0x02 ? '1' : '0'), \ + (byte & 0x01 ? '1' : '0') + +#define PRINT_OPAQUE_STRUCT(p) print_mem((p), sizeof(*(p))) + +#endif/*__16_HEAD_H__*/