X-Git-Url: http://4ch.mooo.com/gitweb/?a=blobdiff_plain;f=src%2Flib%2F16_head.h;h=0a71c965a040b9a467d81f3b1023f977f19220bc;hb=d48c3f2da3fb828320dc2817d5ab0e5848d07905;hp=b840043d4fd149606472f7f4ae2d00d84c585642;hpb=b19573f9753bcfdfa5d73535e500bc27dd96839f;p=16.git diff --git a/src/lib/16_head.h b/src/lib/16_head.h index b840043d..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-2016 sparky4 & pngwen & andrius4669 & joncampbell123 & yakui-lover + * Copyright (C) 2012-2018 sparky4 & pngwen & andrius4669 & joncampbell123 & yakui-lover * * This file is part of Project 16. * @@ -20,38 +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" -#include "src/lib/typdefst.h" -#include "src/lib/16_in.h" #define VERSION __DATE__ " " __TIME__ @@ -147,18 +153,15 @@ #define KEY_MENU (0x75) */ -static word far* clockw= (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 -#define sprite -#endif + #ifdef __WATCOMC__ -#define _FCORELEFT 0x90000UL+16UL +//----#define _FCORELEFT 0x90000UL+16UL extern union REGS CPURegs; #define _AX CPURegs.x.ax @@ -166,6 +169,9 @@ extern union REGS CPURegs; #define _CX CPURegs.x.cx #define _DX CPURegs.x.dx +#define _SI CPURegs.x.si +#define _DI CPURegs.x.di + #define _AH CPURegs.h.ah #define _AL CPURegs.h.al #define _BH CPURegs.h.bh @@ -175,26 +181,42 @@ extern union REGS CPURegs; #define _DH CPURegs.h.dh #define _DL CPURegs.h.dl +#define _CFLAG CPURegs.x.cflag + #define geninterrupt(n) int86(n,&CPURegs,&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)) + typedef union REGPACK regs_t; #endif -#define INPUT_STATUS_1 0x03da - -/* local function */ -void wait(clock_t wait); - +// 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); -#ifdef __BORLANDC__ -void Quit (char *error); -#endif byte dirchar(byte in); - -#endif/*_LIBHEAD_H_*/ +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__*/