2016-06-13 04:07:22 +02:00
# define _TOKA_
# include "tok.h"
# pragma option -w-pin
# ifdef _WIN32_
# include <windows.h>
# endif
# include <unistd.h>
# include <sys/stat.h>
# include "dirlist.h"
# include "id.h"
# include "resname.h"
struct idrec * treestart = NULL ;
struct idrec * definestart = NULL ;
UNDEFOFF * undefoffstart = NULL ;
DLLLIST * listdll = NULL ;
struct structteg * tegtree = NULL ; //<2F> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> ᮪ ⥣<> <E2A5A3>
struct structteg * ltegtree = NULL ; //<2F> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> ᮪ ⥣<> <E2A5A3>
//struct idrec *lstructlist=NULL; //ᯨ᮪ <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD>
SINFO strinf = { NULL } ;
static int notdef = TRUE ;
static char precha ;
int scanalltoks = TRUE ;
static volatile idrec * * DynamicList = NULL ;
static int sizeDL ; //ࠧ<> <E0A0A7> <EFBFBD> ᯨ᪠
static volatile int countDP ; //<2F> <> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> ᪨<EFBFBD> <20> <> <EFBFBD> 楤<EFBFBD> <E6A5A4> <20> ᯨ᪥
static int findofset = FALSE ;
# define STEPDL 128; //蠣 㢥<> <E3A2A5> 祭<EFBFBD> <E7A5AD> ࠧ<> <E0A0A7> <EFBFBD> <EFBFBD> ᯨ᪠
ITOK structadr ;
char id2 [ ID2S ] [ 9 ] = {
" ESCHAR " , " ESBYTE " , " ESINT " , " ESWORD " , " ESLONG " , " ESDWORD " , " ESFLOAT " , " ESQWORD " , " ESDOUBLE " ,
" CSCHAR " , " CSBYTE " , " CSINT " , " CSWORD " , " CSLONG " , " CSDWORD " , " CSFLOAT " , " CSQWORD " , " CSDOUBLE " ,
" SSCHAR " , " SSBYTE " , " SSINT " , " SSWORD " , " SSLONG " , " SSDWORD " , " SSFLOAT " , " SSQWORD " , " SSDOUBLE " ,
" DSCHAR " , " DSBYTE " , " DSINT " , " DSWORD " , " DSLONG " , " DSDWORD " , " DSFLOAT " , " DSQWORD " , " DSDOUBLE " ,
" FSCHAR " , " FSBYTE " , " FSINT " , " FSWORD " , " FSLONG " , " FSDWORD " , " FSFLOAT " , " FSQWORD " , " FSDOUBLE " ,
" GSCHAR " , " GSBYTE " , " GSINT " , " GSWORD " , " GSLONG " , " GSDWORD " , " GSFLOAT " , " GSQWORD " , " GSDOUBLE " , } ;
char regs [ 2 ] [ 8 ] [ 4 ] = { " AX " , " CX " , " DX " , " BX " , " SP " , " BP " , " SI " , " DI " ,
" EAX " , " ECX " , " EDX " , " EBX " , " ESP " , " EBP " , " ESI " , " EDI " } ;
char begs [ 8 ] [ 3 ] = { " AL " , " CL " , " DL " , " BL " , " AH " , " CH " , " DH " , " BH " } ;
char segs [ 6 ] [ 3 ] = { " ES " , " CS " , " SS " , " DS " , " FS " , " GS " } ;
char mon [ 12 ] [ 4 ] = { " Jan " , " Feb " , " Mar " , " Apr " , " May " , " Jun " , " Jul " , " Aug " ,
" Sep " , " Oct " , " Nov " , " Dec " } ;
unsigned char cha2 ;
char skipfind = FALSE ; /* <20> ய<EFBFBD> <E0AEAF> <EFBFBD> <20> <> <EFBFBD> ᪠ <20> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> 쭮<EFBFBD> <20> <> ॢ<EFBFBD> <20> <20> ।<EFBFBD>
<EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> ६ <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> */
static unsigned char savestring3 = FALSE ; //ࠧ<> <E0A0A7> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <20> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> string3
static int posstr3 ; //㪠<> <E3AAA0> ⥫<EFBFBD> <20> <> <EFBFBD> <EFBFBD> 樨 <20> string3
unsigned int inptr2 ;
unsigned int linenum2 = 0 ; //<2F> <20> <> <20> <> <EFBFBD> <EFBFBD> , <20> <> <20> <> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> ⪠
char displaytokerrors ; /* flag to display errors, 0 for tok2 scan */
char * bufrm = NULL ;
char * startline = NULL ;
char * endinput = NULL ;
unsigned char skiplocals = FALSE ;
int scanlexmode = STDLEX ;
unsigned char bytesize = TRUE ;
COM_MOD * cur_mod = NULL ;
void docals ( struct idrec * ptr ) ;
void dostructvar2 ( int * tok4 , ITOK * itok4 , struct structteg * tteg , unsigned char * string4 ) ; //ࠧ<> <E0A0A7> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <20> <> ६<EFBFBD> <E0A5AC> <EFBFBD> <EFBFBD> <EFBFBD> <20> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD>
void dosizeof ( ITOK * itok4 ) ; //<2F> <> <EFBFBD> <20> <> <EFBFBD> 祭<EFBFBD> <E7A5AD> sizeof
void ofsstr ( int * tok4 , ITOK * itok4 ) ;
int searchlocals ( ITOK * itok4 , int * tok4 , unsigned char * string4 ) ;
unsigned char convert_char ( ) ;
void tokscan ( int * tok4 , ITOK * itok4 , unsigned char * string4 ) ;
int calcnum ( int * ctok , ITOK * cstok , char * cstring , long * retval ) ;
int GetDirective ( char * str ) ;
int CheckAsmName ( char * name ) ;
void tag_massiv ( int * tok4 , ITOK * itok4 , unsigned char * string4 ) ;
int CheckResName ( char * name ) ;
void GetTypeVar ( int * tok4 ) ;
int RegToRM ( int number , int tok4 ) ;
elementteg * FindClassEl ( structteg * searcht , unsigned char * string4 , int * addofs ,
structteg * subteg ) ;
int AskUseDestr ( structteg * searcht ) ;
int SaveStruct ( int size , idrec * newrec ) ;
int CheckDefPar ( char * name ) ;
int searchtree2 ( idrec * fptr , ITOK * itok4 , int * tok4 , unsigned char * string4 ) ;
extern void blockerror ( ) ;
extern void block16_32error ( ) ;
extern void notstructname ( ) ;
extern void badtoken ( ) ;
extern void opb ( unsigned long num , unsigned int ofs , unsigned int size ) ;
extern void CorrectOfsBit ( int bitofs ) ;
extern int skipstring ( int pos , unsigned char term ) ;
extern int skipcomment ( int pos ) ;
void retoldscanmode ( int mode )
{
if ( mode = = STDLEX & & cha2 = = 13 & & tok ! = tk_endline ) {
cha2 = cha ;
}
scanlexmode = mode ;
}
void CheckConvertString ( char * string4 )
{
if ( cha = = ' o ' ) {
OemToChar ( string4 , string4 ) ;
nextchar ( ) ;
}
else if ( cha = = ' w ' ) {
CharToOem ( string4 , string4 ) ;
nextchar ( ) ;
}
}
void DateToStr ( char * buf )
{
// GetDateFormat(LOCALE_SYSTEM_DEFAULT,DATE_SHORTDATE|LOCALE_NOUSEROVERRIDE,NULL,NULL,buf,80);
sprintf ( buf , " %2d %s %d " , timeptr . tm_mday , mon [ timeptr . tm_mon ] , timeptr . tm_year + 1900 ) ;
}
void compressoffset ( ITOK * thetok )
{
if ( thetok - > sib = = CODE16 ) {
if ( thetok - > rm ! = rm_d16 ) {
thetok - > rm & = 7 ;
if ( thetok - > number = = 0 ) {
if ( thetok - > rm = = rm_BP ) thetok - > rm | = rm_mod01 ;
}
else if ( ( int ) thetok - > number < 128 & & ( int ) thetok - > number > = - 128 ) thetok - > rm | = rm_mod01 ;
else thetok - > rm | = rm_mod10 ;
}
}
else {
if ( thetok - > rm ! = rm_d32 & & thetok - > rm ! = rm_sib ) {
thetok - > rm & = 7 ;
if ( thetok - > number = = 0 ) {
if ( thetok - > rm = = 5 ) thetok - > rm | = rm_mod01 ;
if ( thetok - > rm = = 4 & & ( thetok - > sib & 7 ) = = 5 ) thetok - > rm | = rm_mod01 ;
}
else if ( thetok - > number < 128 & & thetok - > number > = - 128 ) thetok - > rm | = rm_mod01 ;
else thetok - > rm | = rm_mod10 ;
}
}
}
int CalcRm16 ( int base , int idx )
{
int rm ;
rm = 0 ;
switch ( base + idx ) {
case 2 : rm + + ;
case 4 : rm + + ;
case 6 : rm + + ;
case 5 : rm + + ;
case 12 : rm + + ;
case 11 : rm + + ;
case 10 : rm + + ;
}
return rm ;
}
void SRBackBuf ( int mode ) //save/restore BackTextBlock
{
static int size = 0 ;
static char * buf ;
if ( mode = = 0 ) {
if ( SizeBackBuf ) {
size = SizeBackBuf ;
SizeBackBuf = 0 ;
buf = BackTextBlock ;
}
}
else {
SizeBackBuf = size ;
size = 0 ;
BackTextBlock = buf ;
}
}
void ExpandRm ( int rm , int sib , int * zoom , int * base , int * idx )
{
int rm0 ;
int reg1 = - 1 , reg2 = - 1 ;
int z = 0 ;
rm0 = rm & 0x7 ;
if ( sib = = CODE16 | | sib = = ( CODE16 + 1 ) ) {
switch ( rm0 ) {
case 0 :
reg1 = BX ;
reg2 = SI ;
break ;
case 1 :
reg1 = BX ;
reg2 = DI ;
break ;
case 2 :
reg1 = BP ;
reg2 = SI ;
break ;
case 3 :
reg1 = BP ;
reg2 = DI ;
break ;
case 4 :
reg2 = SI ;
break ;
case 5 :
reg2 = DI ;
break ;
case 6 :
if ( ( rm & 0xC0 ) ! = 0 ) reg1 = BP ;
break ;
case 7 :
reg1 = BX ;
break ;
}
}
else {
if ( rm0 = = 4 ) {
reg1 = sib & 7 ;
reg2 = ( sib > > 3 ) & 7 ;
if ( reg1 = = 5 & & ( rm & 0xc0 ) = = 0 ) reg1 = - 1 ;
if ( reg2 = = 4 ) reg2 = - 1 ;
else z = sib > > 6 ;
}
else {
reg1 = rm0 ;
if ( reg1 = = 5 & & ( rm & 0xc0 ) = = 0 ) reg1 = - 1 ;
}
}
* base = reg1 ;
* idx = reg2 ;
* zoom = z ;
}
int CheckZoom ( int size )
{
int zoom = 0 ;
switch ( size ) {
case 8 : zoom + + ;
case 4 : zoom + + ;
case 2 : zoom + + ;
}
return zoom ;
}
void calcrm ( ITOK * itok4 , int ttok ) //<2F> <> ࠡ<EFBFBD> ⪠ <20> <> ࠦ<EFBFBD> <E0A0A6> <EFBFBD> <EFBFBD> <20> []
{
int idx , base , razr = 0 , zoom , rm = 0 ;
long numrm = 0 , cnum , ocnum ;
int nextscan ;
ITOK cstok , dstok ;
int ctok , sopenb ;
unsigned char * pstring ;
unsigned int flag ;
unsigned int sizevar = 1 ;
unsigned int prevtok = tk_number , operand = tk_plus ;
int dsword , dsword2 ;
nextchar ( ) ;
whitespace ( ) ; //<2F> ய<EFBFBD> <E0AEAF> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> ᨬ<> <E1A8AC> <EFBFBD> <EFBFBD> <EFBFBD>
if ( ! displaytokerrors ) {
for ( int i = 1 ; i ! = 0 ; ) {
FastTok ( 0 , & ctok , & cstok ) ;
switch ( ctok ) {
case tk_closeblock : i - - ; break ;
case tk_openblock : i + + ; break ;
case tk_eof : i = 0 ; break ;
}
}
return ;
}
dsword2 = dsword = itok4 - > post & POINTER ;
itok4 - > post & = NOTPOINTER ;
memcpy ( & dstok , itok4 , sizeof ( ITOK ) ) ;
ExpandRm ( dstok . rm , dstok . sib , & zoom , & base , & idx ) ;
if ( ( dstok . sib = = CODE16 | | dstok . sib = = ( CODE16 + 1 ) ) & & dstok . rm ! = rm_d16 ) razr = r16 ;
if ( am32 & & dstok . rm ! = rm_d32 ) {
rm = dstok . rm & 0xC0 ;
razr = r32 ;
}
// printf("in idx=%d base=%d zoom=%d\n",idx,base,zoom);
pstring = ( unsigned char * ) MALLOC ( STRLEN ) ;
sopenb = inptr ;
char bcha = cha ;
SRBackBuf ( 0 ) ;
flag = f_useidx ; //0;//cstok.flag;
if ( bytesize = = FALSE ) {
sizevar = GetVarSize ( ttok ) ;
if ( dsword ) sizevar = 1 ;
if ( am32 ) zoom = CheckZoom ( sizevar ) ;
}
if ( cha = = ' & ' ) {
nextchar ( ) ;
whitespace ( ) ; //<2F> ய<EFBFBD> <E0AEAF> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> ᨬ<> <E1A8AC> <EFBFBD> <EFBFBD> <EFBFBD>
sizevar = 1 ;
zoom = 0 ;
}
for ( ; ; ) {
nextscan = TRUE ;
if ( cha = = ' # ' & & dsword ) dsword = 1 ;
tokscan ( & ctok , & cstok , pstring ) ;
whitespace ( ) ; //<2F> ய<EFBFBD> <E0AEAF> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> ᨬ<> <E1A8AC> <EFBFBD> <EFBFBD> <EFBFBD>
if ( dsword = = 1 ) strcpy ( dstok . name , cstok . name ) ;
// printf("tok=%d num=%d %s\n",ctok,cstok.number,cstok.name);
loopsw :
switch ( ctok ) {
case tk_reg :
if ( razr = = 0 ) razr = r16 ;
else if ( razr = = r32 | | sizevar ! = 1 | | operand ! = tk_plus ) goto runblock ; //16.12.04 22:39
if ( cstok . number = = BP | | cstok . number = = BX ) {
if ( base = = - 1 ) base = cstok . number ;
else goto runblock ;
}
else if ( cstok . number = = SI | | cstok . number = = DI ) {
if ( idx = = - 1 ) idx = cstok . number ;
else goto runblock ;
}
else goto runblock ;
prevtok = tk_reg ;
break ;
case tk_minus :
if ( calcnum ( & ctok , & cstok , ( char * ) pstring , & cnum ) = = 0 ) goto runblock ;
prevtok = tk_number ;
ocnum = cstok . number ;
goto enumb ;
case tk_number :
if ( operand = = tk_mult & & prevtok = = tk_reg32 ) {
if ( zoom = = 0 ) {
prevtok = tk_number ;
if ( razr = = 0 ) razr = r32 ;
else if ( razr = = r16 ) goto runblock ;
zoom = CheckZoom ( cstok . number ) ;
if ( zoom ) break ;
}
else goto runblock ;
}
prevtok = tk_number ;
ocnum = cstok . number ;
if ( zoom = = 0 & & razr ! = r16 & & ( idx = = - 1 | | base = = - 1 ) ) {
if ( ( zoom = CheckZoom ( cstok . number ) ) ! = 0 ) {
if ( cha = = ' * ' ) {
nextchar ( ) ;
tokscan ( & ctok , & cstok , pstring ) ;
if ( ctok = = tk_reg32 ) {
if ( idx ! = - 1 ) base = idx ;
idx = cstok . number ;
prevtok = tk_reg32 ;
if ( razr = = 0 ) razr = r32 ;
break ;
}
if ( ctok = = tk_number ) {
calclongnumber ( & ocnum , cstok . number , tk_mult ) ;
numrm + = ocnum ;
zoom = 0 ;
break ;
}
goto runblock ;
}
zoom = 0 ;
}
}
if ( calcnum ( & ctok , & cstok , ( char * ) pstring , & cnum ) = = 0 ) goto runblock ;
enumb :
flag ^ = cstok . flag ;
whitespace ( ) ; //<2F> ய<EFBFBD> <E0AEAF> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> ᨬ<> <E1A8AC> <EFBFBD> <EFBFBD> <EFBFBD>
ocnum = cnum ;
numrm + = cnum ;
if ( cstok . type = = tp_opperand | | cstok . type = = tp_stopper ) nextscan = FALSE ;
else {
operand = tk_plus ;
goto loopsw ;
}
break ;
case tk_reg32 :
// printf("prevtok=%d operand=%d ocnum=%d idx=%d base=%d zoom=%d\n",prevtok,operand,ocnum,idx,base,zoom);
if ( razr = = 0 ) razr = r32 ;
if ( razr = = r16 | | ( operand ! = tk_plus & & operand ! = tk_mult ) | | ( idx ! = - 1 & & base ! = - 1 ) ) goto runblock ;
if ( sizevar ! = 1 ) {
if ( idx ! = - 1 ) goto runblock ;
idx = cstok . number ;
}
else if ( operand = = tk_mult ) {
if ( prevtok ! = tk_number ) goto runblock ;
zoom = CheckZoom ( ocnum ) ;
numrm - = ocnum ;
if ( idx ! = - 1 ) base = idx ;
idx = cstok . number ;
}
else if ( cha = = ' * ' ) {
if ( idx ! = - 1 ) base = idx ;
idx = cstok . number ;
}
else if ( base = = - 1 ) base = cstok . number ;
else if ( idx = = - 1 ) idx = cstok . number ;
// else goto runblock;
prevtok = tk_reg32 ;
break ;
case tk_postnumber :
if ( dsword = = 0 | | sizevar ! = 1 ) goto runblock ;
if ( ( cstok . post & USED_DIN_VAR ) = = USED_DIN_VAR ) { //<2F> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> ᪠<EFBFBD> <20> <> ६<EFBFBD> <E0A5AC> <EFBFBD> <EFBFBD> <EFBFBD>
if ( dstok . rec ! = NULL ) goto runblock ;
dstok . rec = cstok . rec ;
}
if ( operand = = tk_minus ) numrm - = cstok . number ;
else numrm + = cstok . number ;
dstok . post | = cstok . post ;
prevtok = tk_number ;
break ;
case tk_undefofs :
if ( dsword = = 0 | | sizevar ! = 1 ) goto runblock ;
if ( operand = = tk_minus ) numrm - = cstok . number ;
else numrm + = cstok . number ;
dstok . post | = UNDEF_OFSET ;
strcpy ( dstok . name , cstok . name ) ;
flag ^ = cstok . flag ;
prevtok = tk_number ;
break ;
case tk_rmnumber :
/* if(strinf.bufstr!=NULL){
free ( strinf . bufstr ) ;
strinf . bufstr = NULL ;
goto runblock ;
} */
if ( dsword = = 0 | | sizevar ! = 1 ) goto runblock ;
if ( operand = = tk_minus ) numrm - = cstok . number ;
else numrm + = cstok . number ;
dstok . post | = cstok . post ;
if ( dstok . sib = = CODE16 ) {
if ( cstok . rm ! = rm_d16 ) {
switch ( cstok . rm & 7 ) {
case 0 :
if ( base ! = - 1 | | idx ! = - 1 ) goto runblock ;
base = BX ; idx = SI ; break ;
case 1 :
if ( base ! = - 1 | | idx ! = - 1 ) goto runblock ;
base = BX ; idx = DI ; break ;
case 2 :
if ( base ! = - 1 | | idx ! = - 1 ) goto runblock ;
base = BP ; idx = SI ; break ;
case 3 :
if ( base ! = - 1 | | idx ! = - 1 ) goto runblock ;
base = BP ; idx = DI ; break ;
case 4 :
if ( idx ! = - 1 ) goto runblock ;
idx = SI ; break ;
case 5 :
if ( idx ! = - 1 ) goto runblock ;
idx = DI ; break ;
case 6 :
if ( idx ! = - 1 ) goto runblock ;
base = BP ; break ;
case 7 :
if ( idx ! = - 1 ) goto runblock ;
base = BX ; break ;
}
}
razr = r16 ;
}
else {
if ( cstok . rm ! = rm_d32 ) {
rm = cstok . rm & 0xC0 ;
cstok . rm & = 7 ;
if ( base = = - 1 ) base = cstok . rm ;
else if ( idx = = - 1 ) {
idx = base ;
base = cstok . rm ;
}
else goto runblock ;
if ( base = = 4 ) {
base = cstok . sib & 7 ;
idx = ( cstok . sib > > 3 ) & 7 ;
if ( base = = 5 & & rm = = 0 ) base = - 1 ;
if ( idx = = 4 ) idx = - 1 ;
}
}
else dstok . flag | = cstok . flag & f_reloc ;
razr = r32 ;
}
break ;
//-----------------28.07.98 13:59-------------------
// var[i]
//--------------------------------------------------
default :
runblock :
if ( dsword2 ) {
CharToBackBuf ( ' & ' ) ;
if ( strinf . bufstr ) {
free ( strinf . bufstr ) ;
strinf . bufstr = NULL ;
}
}
AddBackBuf ( sopenb , bcha ) ;
if ( bufrm ) {
if ( strcmp ( bufrm , " &this; " ) = = 0 ) {
free ( bufrm ) ;
CharToBackBuf ( 0 ) ;
sprintf ( ( char * ) string3 , " &%s*%d+this; " , BackTextBlock , GetVarSize ( ttok ) ) ;
bufrm = BackString ( ( char * ) string3 ) ;
// puts((char *)string3);
goto con1 ;
}
else free ( bufrm ) ;
}
CharToBackBuf ( ' ; ' ) ;
CharToBackBuf ( 0 ) ;
bufrm = ( char * ) REALLOC ( BackTextBlock , SizeBackBuf + 1 ) ;
con1 :
if ( cha ! = ' ] ' ) blockerror ( ) ;
tokscan ( & ctok , & cstok , pstring ) ;
if ( itok4 - > sib > = CODE16 ) itok4 - > sib + + ;
SRBackBuf ( 1 ) ;
// if(itok4->post&POINTER)itok4->post=0;//&=NOTPOINTER;
free ( pstring ) ;
itok4 - > flag | = flag ;
return ;
//-----------------28.07.98 13:59-------------------
// end
//--------------------------------------------------
}
if ( dsword = = 1 ) dsword = 0 ;
if ( nextscan ) {
tokscan ( & ctok , & cstok , pstring ) ;
whitespace ( ) ; //<2F> ய<EFBFBD> <E0AEAF> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> ᨬ<> <E1A8AC> <EFBFBD> <EFBFBD> <EFBFBD>
}
while ( ctok = = tk_minus ) {
if ( calcnum ( & ctok , & cstok , ( char * ) pstring , & cnum ) = = 0 ) goto runblock ;
whitespace ( ) ; //<2F> ய<EFBFBD> <E0AEAF> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> ᨬ<> <E1A8AC> <EFBFBD> <EFBFBD> <EFBFBD>
numrm + = cnum ;
flag ^ = cstok . flag ;
if ( cstok . type ! = tp_opperand & & cstok . type ! = tp_stopper ) {
operand = tk_plus ;
goto loopsw ;
}
}
operand = ctok ;
// printf("operand tok=%d flag=%08X %s\n",ctok,cstok.flag,cstok.name);
if ( ctok = = tk_closeblock | | ctok = = tokens | | ctok = = tk_eof ) break ;
if ( ctok ! = tk_plus & & ctok ! = tk_mult ) goto runblock ;
// flag|=cstok.flag;
}
// printf("out idx=%d base=%d zoom=%d\n",idx,base,zoom);
SRBackBuf ( 1 ) ;
if ( ctok ! = tk_closeblock ) expected ( ' ] ' ) ;
numrm * = sizevar ;
dstok . number + = numrm ;
if ( razr = = r16 ) {
if ( idx = = - 1 & & base = = - 1 ) cstok . rm = 6 ;
else {
cstok . rm = CalcRm16 ( base , idx ) | rm_mod10 ;
dstok . sib = CODE16 ;
}
}
else if ( razr = = 0 ) {
if ( dstok . number < 65536 & & dstok . number > - 65535 ) cstok . rm = 6 ;
else {
cstok . rm = 5 ;
dstok . sib = 0 ;
}
if ( am32 ) cstok . rm = 5 ;
}
else {
// printf("razr=%d sib=%08X %s\n",razr,dstok.sib,dstok.name);
if ( dstok . sib > CODE32 ) dstok . sib - = CODE32 ;
else dstok . sib = 0 ;
if ( idx ! = - 1 ) {
cstok . rm = 4 ;
if ( idx = = 4 ) preerror ( " ESP cannot be the index register " ) ;
if ( base ! = - 1 ) dstok . sib = ( zoom < < 6 ) + ( idx < < 3 ) + base ;
else {
dstok . sib = ( zoom < < 6 ) + ( idx < < 3 ) + 5 ;
rm = ( base = = 5 ? rm_mod10 : 0 ) ;
}
}
else {
if ( base = = 4 ) {
dstok . sib = ( 4 < < 3 ) + 4 ;
cstok . rm = 4 ;
}
else if ( base = = - 1 ) {
cstok . rm = rm_d32 ;
}
else cstok . rm = base ;
}
if ( base ! = - 1 | | rm ! = 0 ) cstok . rm | = rm_mod10 ; //<2F> <> ४<EFBFBD> <E0A5AA> <EFBFBD> MOD <20> 㤥<EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> , <20> ᥩ<> <E1A5A9> <EFBFBD> <20> <> <EFBFBD> ᨬ<EFBFBD> <E1A8AC>
}
dstok . rm = cstok . rm ;
dstok . flag | = flag ;
memcpy ( itok4 , & dstok , sizeof ( ITOK ) ) ;
free ( pstring ) ;
}
int calcnum ( int * ctok , ITOK * cstok , char * cstring , long * retval )
{
long value ;
unsigned int flag ;
if ( * ctok = = tk_minus ) {
tokscan ( ctok , cstok , ( unsigned char * ) cstring ) ;
if ( * ctok ! = tk_number ) return ( 0 ) ;
cstok - > number = - cstok - > number ;
}
else if ( * ctok ! = tk_number ) return ( 0 ) ;
value = cstok - > number ;
flag = cstok - > flag ;
for ( ; ; ) {
int otok ;
tokscan ( ctok , cstok , ( unsigned char * ) cstring ) ;
otok = * ctok ;
if ( otok = = tk_closeblock ) break ;
tokscan ( ctok , cstok , ( unsigned char * ) cstring ) ;
if ( * ctok ! = tk_number ) {
if ( * ctok = = tk_reg32 & & ( otok = = tk_mult | | otok = = tk_minus ) ) {
* ctok = ( unsigned int ) cstok - > number ;
* retval = value ;
cstok - > flag = flag ;
return 0 ;
}
break ;
}
if ( calclongnumber ( & value , cstok - > number , otok ) = = FALSE ) {
if ( displaytokerrors ) blockerror ( ) ;
break ;
}
/* switch(otok){
case tk_minus : value - = cstok - > number ; break ;
case tk_plus : value + = cstok - > number ; break ;
case tk_xor : value ^ = cstok - > number ; break ;
case tk_and : value & = cstok - > number ; break ;
case tk_or : value | = cstok - > number ; break ;
case tk_mod : value % = cstok - > number ; break ;
case tk_div : value / = cstok - > number ; break ;
case tk_mult : value * = cstok - > number ; break ;
case tk_rr : value > > = cstok - > number ; break ;
case tk_ll : value < < = cstok - > number ; break ;
case tk_xorminus : value ^ = - cstok - > number ; break ;
case tk_andminus : value & = - cstok - > number ; break ;
case tk_orminus : value | = - cstok - > number ; break ;
case tk_modminus : value % = - cstok - > number ; break ;
case tk_divminus : value / = - cstok - > number ; break ;
case tk_multminus : value * = - cstok - > number ; break ;
case tk_rrminus : value > > = - cstok - > number ; break ;
case tk_llminus : value < < = - cstok - > number ; break ;
default : if ( displaytokerrors ) blockerror ( ) ; goto end ;
} */
flag ^ = cstok - > flag ;
}
//end:
cstok - > flag = flag ;
* retval = value ;
return - 1 ;
}
void CheckReg ( int idx , int base , int * reg1 , int * reg2 , int razr )
{
if ( razr = = r32 ) {
unsigned char lreg [ 8 ] ;
int i ;
for ( i = 0 ; i < 8 ; i + + ) {
if ( i = = ESP | | i = = EBP ) lreg [ i ] = 1 ;
else {
if ( ( idx ! = - 1 & & idx = = i ) | | ( base ! = - 1 & & base = = i ) ) lreg [ i ] = 1 ;
else lreg [ i ] = 0 ;
}
// printf("%c",lreg[i]+'0');
}
if ( lreg [ * reg1 ] = = 0 ) lreg [ * reg1 ] = 1 ;
else {
2019-04-11 09:12:30 +02:00
for ( i = 7 ; i > = 0 ; i - - ) { // fix by cppcheck, side effect - enable EAX
2016-06-13 04:07:22 +02:00
if ( lreg [ i ] = = 0 ) {
lreg [ i ] = 1 ;
* reg1 = i ;
break ;
}
}
}
// printf("\nreg1=%d",*reg1);
if ( lreg [ * reg2 ] ! = 0 ) {
2019-04-11 09:12:30 +02:00
for ( i = 7 ; i > = 0 ; i - - ) { // fix by cppcheck, side effect - enable EAX
2016-06-13 04:07:22 +02:00
if ( lreg [ i ] = = 0 ) {
* reg2 = i ;
break ;
}
}
}
// printf(" reg2=%d\n",*reg2);
}
else {
if ( base ! = - 1 ) {
if ( base = = * reg1 ) * reg1 = SI ;
else if ( base = = * reg2 ) * reg2 = DI ;
if ( * reg1 = = * reg2 ) {
if ( * reg1 = = SI ) * reg2 = DI ;
else * reg2 = SI ;
}
}
if ( idx ! = - 1 ) {
if ( idx = = SI ) * reg1 = DI ;
else * reg1 = SI ;
* reg2 = CX ;
}
}
}
void CheckAllMassiv ( char * & buf , int sizeel , SINFO * strc , ITOK * ctok , int reg1 , int reg2 )
{
int zoom0 , idx0 , base0 , newreg ;
int zoom1 = 0 , zoom2 = 0 ;
char pv = FALSE ;
int razr = r32 ;
//printf("sib=%X\n",ctok->sib);
switch ( ctok - > sib ) {
case CODE16 + 2 :
case CODE32 + 2 : ctok - > sib - - ;
case CODE16 + 1 :
case CODE32 + 1 : ctok - > sib - - ;
}
if ( ctok - > sib = = CODE16 ) {
razr = r16 ;
if ( am32 ) block16_32error ( ) ;
}
if ( buf = = NULL & & strc - > bufstr = = NULL ) return ;
ExpandRm ( ctok - > rm , ctok - > sib , & zoom0 , & base0 , & idx0 ) ;
if ( base0 = = - 1 & & idx0 ! = - 1 & & zoom0 = = 0 ) {
base0 = idx0 ;
idx0 = - 1 ;
}
CheckReg ( idx0 , base0 , & reg1 , & reg2 , razr ) ;
// printf("reg1=%d reg2=%d idx0=%d base0=%d zoom0=%d\n",reg1,reg2,idx0,base0,zoom0);
if ( buf ! = NULL ) {
if ( * buf = = ' & ' ) {
sizeel = 1 ;
pv = TRUE ;
ctok - > flag & = ~ f_reloc ;
}
if ( ( newreg = CheckIDXReg ( buf , sizeel , reg1 ) ) ! = NOINREG ) {
if ( newreg ! = SKIPREG ) {
if ( razr = = r16 ) {
if ( newreg ! = BX & & newreg ! = DI & & newreg ! = SI & & newreg ! = BP ) goto noopt ;
if ( base0 ! = - 1 & & ( newreg = = BX | | newreg = = BP ) ) goto noopt ;
if ( idx0 ! = - 1 & & ( newreg = = DI | | newreg = = SI ) ) goto noopt ;
}
waralreadinitreg ( regs [ am32 ] [ reg1 ] , regs [ am32 ] [ newreg ] ) ;
reg1 = newreg ;
}
free ( buf ) ;
buf = NULL ;
}
else {
if ( razr = = r32 ) {
if ( ( zoom1 = CheckZoom ( sizeel ) ) ) {
sizeel = 1 ;
if ( ( newreg = CheckIDXReg ( buf , sizeel , reg1 ) ) ! = NOINREG ) {
if ( newreg ! = SKIPREG ) {
waralreadinitreg ( regs [ 1 ] [ reg1 ] , regs [ 1 ] [ newreg ] ) ;
reg2 = reg1 ;
reg1 = newreg ;
}
free ( buf ) ;
buf = NULL ;
goto cont1 ;
}
}
}
noopt :
if ( razr = = r32 & & idx0 = = - 1 & & base0 = = - 1 & & zoom1 = = 0 ) {
ITOK wtok ;
wtok = * ctok ;
newreg = CheckMassiv ( buf , sizeel , reg1 , & idx0 , & base0 , & wtok . number ) ;
* ctok = wtok ;
// newreg=CheckMassiv(buf,sizeel,reg1);
}
else newreg = CheckMassiv ( buf , sizeel , reg1 ) ;
if ( newreg ! = - 1 ) {
reg2 = reg1 ;
reg1 = newreg ;
}
}
}
else {
reg2 = reg1 ;
reg1 = - 1 ;
}
cont1 :
// printf("reg1=%d reg2=%d idx0=%d base0=%d zoom0=%d\n",reg1,reg2,idx0,base0,zoom0);
if ( strc - > bufstr ! = NULL ) {
sizeel = strc - > size ;
if ( ( newreg = CheckIDXReg ( strc - > bufstr , sizeel , reg2 ) ) ! = NOINREG ) {
if ( newreg ! = SKIPREG ) {
if ( razr = = r16 ) {
if ( newreg ! = BX & & newreg ! = DI & & newreg ! = SI & & newreg ! = BP ) goto noopt2 ;
if ( base0 ! = - 1 & & ( newreg = = BX | | newreg = = BP ) ) goto noopt2 ;
if ( idx0 ! = - 1 & & ( newreg = = DI | | newreg = = SI ) ) goto noopt2 ;
}
waralreadinitreg ( regs [ am32 ] [ reg2 ] , regs [ am32 ] [ newreg ] ) ;
reg2 = newreg ;
}
free ( strc - > bufstr ) ;
strc - > bufstr = NULL ;
}
else {
if ( razr = = r32 & & zoom1 = = 0 ) {
if ( ( zoom2 = CheckZoom ( sizeel ) ) ) {
sizeel = 1 ;
if ( ( newreg = CheckIDXReg ( strc - > bufstr , sizeel , reg2 ) ) ! = NOINREG ) {
if ( newreg ! = SKIPREG ) {
waralreadinitreg ( regs [ 2 ] [ reg1 ] , regs [ 2 ] [ newreg ] ) ;
reg2 = newreg ;
}
free ( strc - > bufstr ) ;
strc - > bufstr = NULL ;
goto cont2 ;
}
}
}
noopt2 :
if ( ( newreg = CheckMassiv ( strc - > bufstr , sizeel , reg2 ) ) ! = - 1 ) reg2 = newreg ;
}
cont2 :
if ( reg1 = = - 1 ) {
reg1 = reg2 ;
zoom1 = zoom2 ;
reg2 = - 1 ;
zoom2 = 0 ;
}
}
else reg2 = - 1 ;
// printf("reg1=%d reg2=%d idx0=%d base0=%d zoom0=%d\n",reg1,reg2,idx0,base0,zoom0);
if ( base0 = = - 1 ) {
if ( reg1 ! = - 1 & & zoom1 = = 0 ) {
base0 = reg1 ;
reg1 = reg2 ;
zoom1 = zoom2 ;
reg2 = - 1 ;
zoom2 = 0 ;
}
else if ( reg2 ! = - 1 & & zoom2 = = 0 ) {
base0 = reg2 ;
reg2 = - 1 ;
}
}
if ( idx0 = = - 1 ) {
if ( zoom1 ) {
zoom0 = zoom1 ;
zoom1 = 0 ; //zoom2;
idx0 = reg1 ;
reg1 = reg2 ;
reg2 = - 1 ;
}
else {
if ( reg1 ! = - 1 ) {
idx0 = reg1 ;
reg1 = reg2 ;
zoom1 = zoom2 ;
reg2 = - 1 ;
zoom2 = 0 ;
}
}
}
// printf("reg1=%d reg2=%d idx0=%d base0=%d zoom0=%d\n",reg1,reg2,idx0,base0,zoom0);
if ( reg2 ! = - 1 ) {
if ( zoom1 = = 0 & & zoom2 = = 0 ) {
op ( 3 ) ;
op ( 0xC0 + reg1 * 8 + reg2 ) ; //add reg1,reg2
}
else {
if ( zoom1 = = 0 ) {
op ( 0x8d ) ; //lea reg1,[reg1+reg2*zoom2]
op ( reg1 * 8 + 4 ) ;
op ( ( zoom2 < < 6 ) + ( reg2 < < 3 ) + reg1 ) ;
}
else {
op ( 0x8d ) ; //lea reg1,[reg2+reg1*zoom1]
op ( reg1 * 8 + 4 ) ;
op ( ( zoom1 < < 6 ) + ( reg1 < < 3 ) + reg2 ) ;
zoom1 = 0 ;
}
}
ClearReg ( reg1 ) ;
}
if ( reg1 ! = - 1 ) {
if ( base0 ! = - 1 ) {
if ( zoom1 = = 0 ) {
op ( 3 ) ;
op ( 0xC0 + reg1 * 8 + base0 ) ; //add reg1,base0
}
else {
op ( 0x8d ) ; //lea reg1,[base0+reg1*zoom1]
op ( reg1 * 8 + 4 ) ;
op ( ( zoom1 < < 6 ) + ( reg1 < < 3 ) + base0 ) ;
}
}
else if ( zoom1 ) {
op ( 0xC1 ) ;
op ( 0xE0 + reg1 ) ; //shl reg2,zoom2
op ( zoom1 ) ;
}
base0 = reg1 ;
}
if ( razr = = r32 ) {
ctok - > sib = CODE32 ;
if ( idx0 ! = - 1 ) {
ctok - > rm = 4 ;
if ( base0 ! = - 1 ) {
ctok - > sib = ( zoom0 < < 6 ) + ( idx0 < < 3 ) + base0 ;
ctok - > rm | = rm_mod10 ;
}
else ctok - > sib = ( zoom0 < < 6 ) + ( idx0 < < 3 ) + 5 ;
}
else {
ctok - > rm = base0 ;
if ( pv = = FALSE ) ctok - > rm | = rm_mod10 ;
}
}
else {
if ( base0 = = SI | | base0 = = DI ) {
if ( idx0 = = BX | | idx0 = = BP | | idx0 = = - 1 ) {
newreg = idx0 ;
idx0 = base0 ;
base0 = newreg ;
}
else {
op ( 3 ) ;
op ( 0xC0 + base0 * 8 + idx0 ) ; //add base0,idx0
idx0 = base0 ;
base0 = - 1 ;
}
}
if ( idx0 = = BX | | idx0 = = BP ) {
if ( base0 = = - 1 ) {
newreg = idx0 ;
idx0 = base0 ;
base0 = newreg ;
}
else {
op ( 3 ) ;
op ( 0xC0 + base0 * 8 + idx0 ) ; //add base0,idx0
idx0 = base0 ;
base0 = - 1 ;
}
}
ctok - > rm = CalcRm16 ( base0 , idx0 ) | rm_mod10 ;
}
if ( ctok - > post = = 0 & & ( ctok - > flag & f_reloc ) = = 0 ) compressoffset ( ctok ) ;
}
int CheckMassiv ( char * & buf , int sizeel , int treg , int * idx , int * base , long * num )
{
ITOK oitok ;
SINFO ostr ;
unsigned char * oldinput ;
unsigned int oldinptr , oldendinptr ;
unsigned char bcha ;
int otok ;
char * ostring ;
char * ofsst ;
int retcode = - 1 ;
//07.09.04 22:45
COM_MOD * ocurmod = cur_mod ;
cur_mod = NULL ;
/////////////////
ostring = BackString ( ( char * ) string ) ;
ofsst = BackString ( buf ) ;
free ( buf ) ;
buf = NULL ;
oldinput = input ; //<2F> <> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> ६<EFBFBD> <E0A5AC> <EFBFBD> <EFBFBD>
oldinptr = inptr2 ;
bcha = cha2 ;
oldendinptr = endinptr ;
otok = tok ;
oitok = itok ;
ostr = strinf ;
strinf . bufstr = NULL ;
if ( idx & & * idx = = - 1 & & * base = = - 1 ) {
char * tbuf ;
int i ;
int idx0 , base0 ;
long numr ;
int operand ;
int startptr , skipvar ;
int firsttok ;
i = 0 ;
idx0 = base0 = - 1 ;
numr = 0 ;
if ( * ofsst = = ' & ' ) i + + ;
tbuf = BackString ( ofsst + i ) ;
// puts(tbuf);
input = ( unsigned char * ) tbuf ;
inptr2 = 1 ;
cha2 = input [ 0 ] ;
endinptr = strlen ( ( char * ) input ) ;
operand = tk_plus ;
startptr = 0 ;
firsttok = tk_eof ;
do {
skipvar = FALSE ;
getoperand ( ) ;
if ( operand = = tk_plus ) {
if ( tok = = tk_reg32 ) {
if ( itok . number ! = treg ) {
skipvar = TRUE ;
if ( idx0 = = - 1 ) idx0 = itok . number ;
else if ( base0 = = - 1 ) base0 = itok . number ;
else skipvar = FALSE ;
}
else if ( firsttok = = tk_eof ) firsttok = tk_reg32 ;
}
else if ( tok = = tk_number ) {
numr + = itok . number ;
skipvar = TRUE ;
}
else if ( firsttok = = tk_eof ) firsttok = tok ;
}
if ( operand = = tk_minus & & tok = = tk_number ) {
numr - = itok . number ;
skipvar = TRUE ;
}
if ( skipvar ) {
for ( ; startptr < inptr2 - 1 ; startptr + + ) input [ startptr ] = ' ' ;
}
startptr = inptr2 - 1 ;
nexttok ( ) ;
if ( tok = = tk_plus | | tok = = tk_minus ) {
if ( firsttok = = tk_eof ) {
if ( tok = = tk_minus ) break ;
for ( ; startptr < inptr2 - 1 ; startptr + + ) input [ startptr ] = ' ' ;
startptr = inptr2 - 1 ;
firsttok = tok ;
}
operand = tok ;
}
else break ;
} while ( 1 ) ;
// printf("%s (%u) >%s\n",(startfileinfo+currentfileinfo)->filename,linenumber,tbuf);
if ( tok = = tk_semicolon /*&&(idx0!=-1||base0!=-1)*/ ) {
* idx = idx0 ;
* base = base0 ;
* num + = numr ;
free ( ofsst ) ;
ofsst = tbuf ;
// printf("idx0=%d base0=%d num=%d\n",idx0,base0,numr);
}
else free ( tbuf ) ;
}
input = ( unsigned char * ) ofsst ;
inptr2 = 1 ;
cha2 = input [ 0 ] ;
if ( cha2 = = ' & ' ) {
inptr2 = 2 ;
cha2 = input [ 1 ] ;
}
endinptr = strlen ( ( char * ) input ) ;
getoperand ( ) ;
if ( am32 & & sizeel = = 1 & & tok = = tk_reg32 & & itok2 . type = = tp_stopper ) retcode = itok . number ;
else {
warningreg ( regs [ am32 ] [ treg ] ) ;
if ( ( chip = = 7 | | chip = = 8 ) & & am32 = = FALSE & & ( ( sizeel > 1 & & sizeel < 6 ) | | sizeel = = 8 | | sizeel = = 9 ) ) {
//<2F> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> 饭<EFBFBD> <E9A5AD> <20> <20> <> <EFBFBD> ⭮<EFBFBD> <E2ADAE> ॣ<> <E0A5A3> <EFBFBD> <EFBFBD> <EFBFBD>
op ( 0x31 ) ;
op ( 0xC0 + treg * 9 ) ;
}
ofsst = NULL ;
if ( treg = = AX ) do_e_axmath ( 0 , ( am32 + 1 ) * 2 , & ofsst ) ;
else getintoreg ( treg , ( am32 + 1 ) * 2 , 0 , & ofsst ) ;
IDXToReg ( ( char * ) input , sizeel , treg ) ;
}
strinf = ostr ;
tok = otok ;
itok = oitok ;
endoffile = 0 ;
free ( input ) ;
input = oldinput ;
inptr2 = oldinptr ;
cur_mod = ocurmod ; //07.09.04 22:45
cha2 = bcha ;
endinptr = oldendinptr ;
otok = 0 ;
strcpy ( ( char * ) string , ostring ) ;
free ( ostring ) ;
if ( sizeel > 1 ) RegMulNum ( treg , sizeel , ( am32 + 1 ) * 2 , 0 , & otok , 0 ) ;
return retcode ;
}
void nextchar ( )
{
if ( inptr < endinptr ) {
cha = input [ inptr ] ;
endoffile = 0 ;
if ( savestring3 ) string3 [ posstr3 + + ] = cha ;
inptr + + ;
precha = 0 ;
if ( inptr = = endinptr & & cur_mod & & displaytokerrors ) {
precha = cur_mod - > input [ cur_mod - > inptr ] ;
// printf("cha=%02X\n",cha);
}
}
else {
if ( cur_mod ) {
if ( displaytokerrors ) {
inptr = cur_mod - > inptr ;
input = cur_mod - > input ;
// printf("last cha=%02X\n",input[inptr]);
if ( cur_mod - > numparamdef ) clearregstat ( ) ;
endinptr = cur_mod - > endinptr ;
linenumber = cur_mod - > linenumber ;
currentfileinfo = cur_mod - > currentfileinfo ;
COM_MOD * temp = cur_mod ;
cur_mod = cur_mod - > next ;
if ( temp - > freze = = FALSE ) {
if ( temp - > paramdef ) free ( temp - > paramdef ) ;
// if(debug)printf("Free curmod %08X new cur_mod %08X\n",temp,cur_mod);
free ( temp ) ;
}
// else if(debug)printf("Freze curmod %08X\n",temp);
nextchar ( ) ;
// printf("%c\n",cha);
if ( ! cur_mod ) notdef = TRUE ;
}
else {
cha = cur_mod - > input [ cur_mod - > inptr2 ] ;
cur_mod - > inptr2 + + ;
}
}
else {
cha = 26 ;
endoffile + + ;
if ( endoffile > 2 ) unexpectedeof ( ) ;
}
}
}
void ScanTok2 ( )
{
inptr2 = inptr ;
linenum2 = linenumber ;
cha2 = cha ;
displaytokerrors = 0 ;
tokscan ( & tok2 , & itok2 , string2 ) ;
}
unsigned int ScanTok3 ( )
{
unsigned int oinptr , oline , otok , rtok ;
unsigned char ocha ;
ITOK oitok ;
ocha = cha ;
oinptr = inptr ;
oline = linenumber ;
otok = tok ;
oitok = itok ;
do {
FastTok ( 1 ) ;
if ( tok = = tk_id | | tok = = tk_ID ) {
char disp = displaytokerrors ;
displaytokerrors = 0 ;
strcpy ( ( char * ) string3 , itok . name ) ;
searchtree ( & itok , & tok , string3 ) ; //NEW 09.06.06 20:29
// searchtree2(definestart,&itok,&tok,string3);
displaytokerrors = disp ;
}
} while ( tok = = tk_endline ) ;
rtok = tok ;
tok = otok ;
cha = ocha ;
itok = oitok ;
inptr = oinptr ;
linenumber = oline ;
return rtok ;
}
//extern idrec *crec;
void nexttok ( )
{
# ifdef DEBUGMODE
if ( debug ) puts ( " start nexttok " ) ;
# endif
inptr = inptr2 ;
linenumber = linenum2 ;
cha = cha2 ;
displaytokerrors = 1 ;
tokscan ( & tok , & itok , string ) ; //ࠧ<> <E0A0A7> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD>
// printf("input=%08X inptr=%08X tok=%d %s\n",input,inptr,tok,itok.name);
if ( tok = = tk_dblcolon & & numblocks ) {
skiplocals = TRUE ;
tokscan ( & tok , & itok , string ) ; //ࠧ<> <E0A0A7> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD>
}
ScanTok2 ( ) ;
if ( tok2 = = tk_dblcolon & & numblocks ) {
skiplocals = TRUE ;
tokscan ( & tok2 , & itok2 , string2 ) ;
}
if ( tok2 = = tk_tilda ) {
if ( ScanTok3 ( ) = = tk_number ) {
tok2 = tk_number ;
// puts("tok2=tk_tilda tok3=tk_number");
}
}
linenumber = linenum2 ;
// new !!! 02.04.02 20:22
if ( tok = = tk_int & & idasm = = TRUE & & tok2 = = tk_number ) {
tok = tk_idasm ;
itok . rm = a_int ;
}
// new !!! 02.04.02 20:22
# ifdef DEBUGMODE
if ( debug ) printdebuginfo ( ) ;
# endif
if ( tok2 = = tk_number ) {
if ( tok = = tk_not ) {
nexttok ( ) ;
if ( itok . rm ! = tk_float & & itok . rm ! = tk_double ) {
if ( scanlexmode = = RESLEX ) {
if ( itok . number ) itok . number = 0 ;
else itok . number = 1 ;
}
else itok . lnumber ^ = - 1 ;
}
else illegalfloat ( ) ;
return ;
}
if ( tok = = tk_tilda ) {
// puts("tok=tk_tilda tok2=tk_number");
nexttok ( ) ;
if ( itok . rm ! = tk_float & & itok . rm ! = tk_double ) itok . lnumber = ~ itok . lnumber ;
else illegalfloat ( ) ;
return ;
}
}
if ( idasm = = TRUE & & tok = = tk_loop & & tok2 ! = tk_openbracket ) {
tok = tk_idasm ;
itok . rm = a_loop ;
return ;
}
if ( tok = = tk_dollar ) {
if ( itok2 . type = = tp_opperand | | itok2 . type = = tp_stopper | | tok2 = = tk_dollar ) {
tok = tk_number ;
itok . number = outptr ;
if ( FixUp ) itok . flag | = f_reloc ; //new!!!
return ;
}
int qq ; //09.07.08 13:27 new
if ( ( qq = CheckAsmName ( itok2 . name ) ) ! = - 1 ) {
tok = tk_idasm ;
itok . rm = qq ;
strcpy ( itok . name , itok2 . name ) ;
ScanTok2 ( ) ;
}
}
if ( tok > = tk_charvar & & tok < = tk_doublevar ) {
localrec * ptr ;
ptr = itok . locrec ;
switch ( itok . type ) {
case tp_paramvar :
// case tp_ppointer:
// case tp_pfpointer:
if ( ptr - > fuse = = NOTINITVAR & & tok2 = = tk_assign & & ( ! asmparam ) ) warningnotused ( itok . name , 4 ) ;
goto llq ;
case tp_localvar :
// case tp_lpointer:
// case tp_lfpointer:
if ( ptr - > fuse = = NOTINITVAR & & tok2 ! = tk_assign ) {
if ( asmparam ) ptr - > fuse | = INITVAR ;
else warningusenotintvar ( itok . name ) ;
}
llq :
ptr - > fuse | = ( unsigned char ) ( tok2 = = tk_assign ? INITVAR : USEDVAR ) ;
break ;
}
# ifdef OPTVARCONST
if ( calcnumber & & CheckConstVar ( & itok ) ) tok = tk_number ;
# endif
}
# ifdef OPTVARCONST
if ( tok2 > = tk_charvar & & tok2 < = tk_doublevar ) {
if ( calcnumber & & CheckConstVar ( & itok2 ) ) tok2 = tk_number ;
}
# endif
if ( usedirectiv = = FALSE & & calcnumber = = FALSE ) while ( tok = = tk_question ) directive ( ) ;
//16.08.04 00:23
if ( tok = = tk_at & & tok2 = = tk_macro ) {
nexttok ( ) ;
}
# ifdef OPTVARCONST
displaytokerrors = 1 ;
# endif
// if(crec)printf("num=%08X\n",crec->recnumber);
}
void whitespace ( ) //<2F> ய<EFBFBD> <E0AEAF> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> ᨬ<> <E1A8AC> <EFBFBD> <EFBFBD> <EFBFBD>
{
while ( isspace ( cha ) | | cha = = 255 | | cha = = 0 ) {
if ( cha = = 13 ) {
linenumber + + ;
if ( ( dbg & 2 ) & & displaytokerrors & & notdef ) startline = ( char * ) ( input + inptr + 1 ) ;
if ( scanlexmode = = RESLEX | | scanlexmode = = DEFLEX | | scanlexmode = = ASMLEX ) break ;
}
nextchar ( ) ;
}
}
unsigned char convert_char ( )
//Returns the value of the current character. Parses \n and \x00 etc.
//cha equals the last character used.
{
int hold = 0 ;
int i ;
unsigned char c ;
if ( cha ! = ' \\ ' ) {
if ( cha = = 13 ) {
linenumber + + ;
if ( ( dbg & 2 ) & & displaytokerrors & & notdef ) startline = ( char * ) ( input + inptr + 1 ) ;
}
return ( cha ) ;
}
nextchar ( ) ; // move past '\\'
switch ( cha ) {
case ' a ' : return ( ' \a ' ) ; // what is \a anyway?
case ' b ' : return ( ' \b ' ) ;
case ' f ' : return ( ' \f ' ) ;
case ' l ' : return ( 10 ) ;
case ' n ' : return ( 13 ) ;
// case 'p': return('<27> ');
case ' r ' : return ( 13 ) ;
case ' t ' : return ( ' \t ' ) ;
case ' v ' : return ( ' \v ' ) ;
case ' x ' :
for ( i = 0 ; i < 2 ; i + + ) {
c = cha ;
nextchar ( ) ;
hold * = 16 ;
if ( isdigit ( cha ) ) hold + = cha - ' 0 ' ;
else if ( isxdigit ( cha ) ) hold + = ( cha & 0x5f ) - ' 7 ' ;
else {
// expectederror("hexadecimal digit");
if ( savestring3 ) posstr3 - - ;
inptr - - ;
cha = c ;
break ;
}
}
return ( unsigned char ) hold ;
default :
if ( isdigit ( cha ) ) {
hold = cha - ' 0 ' ;
for ( i = 0 ; i < 2 ; i + + ) {
c = cha ;
nextchar ( ) ;
if ( isdigit ( cha ) ) hold = hold * 10 + ( cha - ' 0 ' ) ;
else {
// expectederror("decimal digit");
if ( savestring3 ) posstr3 - - ;
inptr - - ;
cha = c ;
break ;
}
}
return ( unsigned char ) hold ;
}
return cha ;
}
}
void convert_string ( unsigned char * str )
{
int k , j , i ;
unsigned char c ;
unsigned char hold ;
for ( k = 0 , j = 0 ; ; k + + , j + + ) {
c = str [ k ] ;
if ( c = = ' \\ ' ) {
c = str [ + + k ] ;
switch ( c ) {
case ' a ' : hold = ' \a ' ; break ; // what is \a anyway?
case ' b ' : hold = ' \b ' ; break ;
case ' f ' : hold = ' \f ' ; break ;
case ' l ' : hold = 10 ; break ;
case ' n ' : str [ j + + ] = 13 ; hold = 10 ; break ;
case ' r ' : hold = 13 ; break ;
case ' t ' : hold = ' \t ' ; break ;
case ' v ' : hold = ' \v ' ; break ;
case ' x ' :
hold = 0 ;
for ( i = 0 ; i < 2 ; i + + ) {
c = str [ + + k ] ;
hold * = ( unsigned char ) 16 ;
if ( isdigit ( c ) ) hold + = ( unsigned char ) ( c - ' 0 ' ) ;
else if ( isxdigit ( c ) ) hold + = ( unsigned char ) ( ( c & 0x5f ) - ' 7 ' ) ;
else {
k - - ;
break ;
}
}
break ;
default :
hold = c ;
if ( isdigit ( c ) ) {
hold - = ' 0 ' ;
for ( i = 0 ; i < 2 ; i + + ) {
c = str [ + + k ] ;
if ( isdigit ( c ) ) hold = ( unsigned char ) ( hold * 10 + ( c - ' 0 ' ) ) ;
else {
k - - ;
break ;
}
}
}
}
str [ j ] = hold ;
}
else str [ j ] = c ;
if ( c = = 0 ) break ;
}
}
int CheckChar2 ( )
{
if ( isalnum ( cha ) | | cha = = ' _ ' | | cha > = 0x80 ) return TRUE ;
return FALSE ;
}
void GetTokString ( int * tok4 , ITOK * itok4 , unsigned char * string4 , int useunicode )
{
int strptr = 0 ;
if ( displaytokerrors ) {
savestring3 = TRUE ;
posstr3 = 0 ;
}
nextstr :
nextchar ( ) ; //<2F> <> ப<EFBFBD> <E0AEAA> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> ⠭<EFBFBD> <E2A0AD>
while ( cha ! = ' \" ' & & ! endoffile & & strptr < STRLEN - 1 ) {
string4 [ strptr + + ] = convert_char ( ) ;
if ( ( char ) cha = = ' n ' & & string4 [ strptr - 1 ] = = 13 ) { //have to add char 10 for \n value
string4 [ strptr + + ] = 10 ;
}
nextchar ( ) ;
}
if ( displaytokerrors ) {
savestring3 = FALSE ;
string3 [ posstr3 - 1 ] = 0 ;
}
if ( strptr > = ( STRLEN - 1 ) & & displaytokerrors ) preerror ( " Maximum String Length Exceeded " ) ;
string4 [ strptr ] = 0 ;
* tok4 = tk_string ;
// itok4->number=strptr;
itok4 - > rm = 1 ; //<2F> <> <EFBFBD> <EFBFBD> <20> ਣ<EFBFBD> <E0A8A3> <EFBFBD> <EFBFBD> <20> <> ப<EFBFBD>
if ( cha ! = ' \" ' ) expected ( ' \" ' ) ;
while ( cha ! = ' \" ' & & ! endoffile ) nextchar ( ) ; //scan until closing '\"'
nextchar ( ) ;
if ( dosstring ) itok4 - > flag = dos_term ;
CheckConvertString ( ( char * ) string4 ) ;
switch ( cha ) {
case ' z ' :
itok4 - > flag = zero_term ;
nextchar ( ) ;
break ;
case ' n ' :
itok4 - > flag = no_term ;
nextchar ( ) ;
break ;
case ' $ ' :
itok4 - > flag = dos_term ;
nextchar ( ) ;
break ;
}
CheckConvertString ( ( char * ) string4 ) ;
// 10.08.04 22:20
whitespace ( ) ; //<2F> ய<EFBFBD> <E0AEAF> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> ᨬ<> <E1A8AC> <EFBFBD> <EFBFBD> <EFBFBD>
if ( cha = = ' \" ' ) {
if ( displaytokerrors ) savestring3 = TRUE ;
goto nextstr ;
}
if ( useunicode & & displaytokerrors ) {
char * bak ;
bak = BackString ( ( char * ) string4 ) ;
strptr = MultiByteToWideChar ( CP_ACP , MB_PRECOMPOSED , bak , - 1 , ( wchar_t * ) string4 , STRLEN ) - 1 ;
// printf("size string=%d\n",strptr);
// if(itok4->flag==no_term)strptr--;
strptr * = 2 ;
// string4[strptr-2]=string4[strptr-1]=0;
itok4 - > flag | = s_unicod ;
free ( bak ) ;
}
itok4 - > number = strptr ;
}
void tokscan ( int * tok4 , ITOK * itok4 , unsigned char * string4 )
// <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> 䨪<EFBFBD> <E4A8AA> <EFBFBD> , <20> <> ४⨢ ...
{
int useme ;
unsigned int strptr = 0 ;
char uppercase = 1 , next = 1 ;
//<2F> <> ⠭<EFBFBD> <E2A0AD> <EFBFBD> <EFBFBD> <20> <> 㬮<> 砭<EFBFBD> <E7A0AD>
# ifdef DEBUGMODE
if ( debug ) printf ( " start tokscan input=%08X inptr=%08X %c%s \n " , input , inptr , cha , input + inptr ) ;
# endif
if ( am32 = = FALSE ) {
itok4 - > rm = rm_d16 ;
itok4 - > sib = CODE16 ;
}
else {
itok4 - > rm = rm_d32 ;
itok4 - > sib = CODE32 ;
}
itok4 - > segm = DS ;
itok4 - > lnumber = 0 ;
itok4 - > post = 0 ;
itok4 - > flag = 0 ;
itok4 - > size = 0 ;
itok4 - > rec = NULL ;
itok4 - > type = tp_ucnovn ;
itok4 - > npointr = 0 ;
itok4 - > name [ 0 ] = 0 ;
whitespace ( ) ; //<2F> ய<EFBFBD> <E0AEAF> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> ᨬ<> <E1A8AC> <EFBFBD> <EFBFBD> <EFBFBD>
// if(displaytokerrors)printf("%c ",cha);
if ( isalpha ( cha ) | | ( cha = = ' _ ' ) | | ( cha > = 0x80 ) ) { //<2F> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> 䨪<EFBFBD> <E4A8AA> <EFBFBD> <EFBFBD>
do {
string4 [ strptr + + ] = cha ;
if ( islower ( cha ) ) uppercase = 0 ;
nextchar ( ) ;
} while ( ( strptr < IDLENGTH ) & & ( CheckChar2 ( ) = = TRUE ) ) ;
if ( strptr > = IDLENGTH ) { //<2F> <> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> 32
if ( displaytokerrors ) preerror ( " Maximum length for an identifier exceeded " ) ;
while ( CheckChar2 ( ) = = TRUE ) nextchar ( ) ; //<2F> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <> <E1ABAE>
strptr = IDLENGTH - 1 ; //<2F> <> १<EFBFBD> <E0A5A7> <EFBFBD> <20> <> 32
}
if ( cha = = ' ~ ' & & strptr < IDLENGTH - 1 ) {
string4 [ strptr + + ] = cha ;
nextchar ( ) ;
if ( cha ! = ' ( ' ) {
inptr - - ;
strptr - - ;
cha = ' ~ ' ;
}
}
string4 [ strptr ] = 0 ;
strcpy ( itok4 - > name , ( char * ) string4 ) ;
// if(displaytokerrors)printf("%s (%u) >%s\n",(startfileinfo+currentfileinfo)->filename,linenumber,itok4->name);
# ifdef DEBUGMODE
if ( debug ) printf ( " ID: '%s' cur_mod=%08X prev cur_mod=%08X \n " , itok4 - > name , cur_mod , cur_mod = = NULL ? 0 : cur_mod - > next ) ;
# endif
if ( scanlexmode = = RESLEX ) {
if ( stricmp ( ( char * ) string4 , " not " ) = = 0 ) * tok4 = tk_not ;
else if ( stricmp ( ( char * ) string4 , " or " ) = = 0 ) * tok4 = tk_or ;
else if ( stricmp ( ( char * ) string4 , " xor " ) = = 0 ) * tok4 = tk_xor ;
else if ( stricmp ( ( char * ) string4 , " and " ) = = 0 ) * tok4 = tk_and ;
else {
if ( uppercase ) * tok4 = tk_ID ;
else * tok4 = tk_id ;
searchtree ( itok4 , tok4 , string4 ) ;
if ( * tok4 = = tk_id | | * tok4 = = tk_ID ) {
if ( ( useme = CheckResName ( itok4 - > name ) ) ! = - 1 ) {
* tok4 = tk_rescommand ;
itok4 - > number = useme ;
}
}
}
return ;
}
if ( uppercase ) { //<2F> <> <EFBFBD> 孨<EFBFBD> ॣ<> <E0A5A3> <EFBFBD> <EFBFBD>
if ( strptr = = 1 & & string4 [ 0 ] = = ' L ' & & cha = = ' " ' ) {
itok4 - > name [ 0 ] = 0 ;
GetTokString ( tok4 , itok4 , string4 , TRUE ) ;
return ;
}
* tok4 = tk_ID ;
if ( string4 [ 1 ] = = ' S ' & & strptr > = 5 & & strptr < = 8 ) {
for ( useme = 0 ; useme < ID2S ; useme + + ) { //<2F> <EFBFBD> ઠ <20> <> ESBYTE ...
if ( strcmp ( ( char * ) string4 , id2 [ useme ] ) = = 0 ) {
* tok4 = tk_charvar + useme % DATATYPES ;
itok4 - > segm = useme / DATATYPES ;
itok4 - > number = 0 ;
itok4 - > post = POINTER ;
goto yesid ;
}
}
}
}
else * tok4 = tk_id ;
if ( strptr = = 2 ) { //<2F> <> <EFBFBD> <EFBFBD> <EFBFBD> 2 ᨬ<> <E1A8AC> <EFBFBD> <EFBFBD> check for AX, CX, DX, ...
if ( ( string4 [ 0 ] & 0x5f ) = = ' S ' & & ( string4 [ 1 ] & 0x5f ) = = ' T ' ) {
if ( cha = = ' ( ' ) {
nextchar ( ) ;
if ( cha > = ' 0 ' & & cha < = ' 7 ' ) {
itok4 - > number = cha - ' 0 ' ;
nextchar ( ) ;
if ( cha ! = ' ) ' ) expected ( ' ) ' ) ;
nextchar ( ) ;
* tok4 = tk_fpust ;
}
}
else {
itok4 - > number = 0 ;
* tok4 = tk_fpust ;
}
return ;
}
if ( asmparam | | * tok4 = = tk_ID ) {
for ( useme = 0 ; useme < 8 ; useme + + ) {
int i ;
if ( asmparam ) i = stricmp ( ( char * ) string4 , regs [ 0 ] [ useme ] ) ;
else i = strcmp ( ( char * ) string4 , regs [ 0 ] [ useme ] ) ;
if ( i = = 0 ) {
* tok4 = tk_reg ;
itok4 - > number = useme ;
extreg :
if ( cha = = ' . ' ) {
tag_massiv ( tok4 , itok4 , string4 ) ;
goto yesid ;
}
return ;
}
if ( asmparam ) i = stricmp ( ( char * ) string4 , begs [ useme ] ) ;
else i = strcmp ( ( char * ) string4 , begs [ useme ] ) ;
if ( i = = 0 ) {
* tok4 = tk_beg ;
itok4 - > number = useme ;
return ;
}
}
if ( string4 [ 1 ] = = ' S ' | | ( asmparam & & string4 [ 1 ] = = ' s ' ) ) {
for ( useme = 0 ; useme < 6 ; useme + + ) { // check for CS, SS, ...
if ( string4 [ 0 ] = = segs [ useme ] [ 0 ] | | ( asmparam & & ( string4 [ 0 ] & 0x5F ) = = segs [ useme ] [ 0 ] ) ) {
if ( cha = = ' : ' ) {
int oinptr = inptr ;
unsigned char ocha = cha ;
int oline = linenumber ;
nextchar ( ) ;
/* switch(cha&(asmparam==FALSE?0xFF:0x5F)){
case ' E ' :
case ' B ' :
case ' S ' :
case ' D ' : */
tokscan ( tok4 , itok4 , string4 ) ;
if ( * tok4 > = tk_bits & & * tok4 < = tk_doublevar ) {
itok4 - > segm = useme ;
goto yesid ;
}
// }
inptr = oinptr ;
cha = ocha ;
linenumber = oline ;
}
* tok4 = tk_seg ;
itok4 - > number = useme ;
return ;
}
}
}
}
}
if ( strptr = = 3 & & ( string4 [ 0 ] = = ' E ' | | ( asmparam & & string4 [ 0 ] = = ' e ' ) ) ) { // check for EAX, ECX, EDX, ...
for ( useme = 0 ; useme < 8 ; useme + + ) {
int i ;
if ( asmparam ) i = stricmp ( ( char * ) & string4 [ 1 ] , regs [ 0 ] [ useme ] ) ;
else i = strcmp ( ( char * ) & string4 [ 1 ] , regs [ 0 ] [ useme ] ) ;
if ( i = = 0 ) {
* tok4 = tk_reg32 ;
itok4 - > number = useme ;
extreg32 :
if ( cha = = ' . ' ) {
tag_massiv ( tok4 , itok4 , string4 ) ;
goto yesid ;
}
if ( cha = = ' : ' ) {
int oinptr = inptr ;
unsigned char ocha = cha ;
int oline = linenumber ;
nextchar ( ) ;
tokscan ( tok4 , itok4 , string4 ) ;
if ( * tok4 = = tk_reg32 | | * tok4 = = tk_reg ) {
itok4 - > number | = useme * 256 ;
* tok4 = tk_reg64 ;
goto yesid ;
}
inptr = oinptr ;
cha = ocha ;
linenumber = oline ;
}
return ;
}
}
}
if ( asmparam ) {
if ( ( string4 [ 1 ] & 0x5f ) = = ' R ' ) {
if ( string4 [ 2 ] > = ' 0 ' & & string4 [ 2 ] < = ' 7 ' ) {
itok4 - > number = string4 [ 2 ] - ' 0 ' ;
switch ( ( string4 [ 0 ] & 0x5f ) ) {
case ' C ' : * tok4 = tk_controlreg ; return ; // check for CR0, CR1, ...
case ' D ' : * tok4 = tk_debugreg ; return ; //check for DR0, DR1, ...
case ' T ' : * tok4 = tk_testreg ; return ; //check for TR0, TR1, ...
default : itok4 - > number = 0 ; break ;
}
}
}
else if ( ( * ( short * ) & string [ 0 ] & 0x5f5f ) = = 0x4d4d ) {
if ( string4 [ 2 ] > = ' 0 ' & & string4 [ 2 ] < = ' 7 ' ) {
itok4 - > number = string4 [ 2 ] - ' 0 ' ;
* tok4 = tk_mmxreg ;
return ;
}
}
else if ( ( * ( short * ) & string [ 1 ] & 0x5f5f ) = = 0x4d4d & & ( string4 [ 0 ] & 0x5f ) = = ' X ' ) {
if ( string4 [ 3 ] > = ' 0 ' & & string4 [ 3 ] < = ' 7 ' ) {
itok4 - > number = string4 [ 3 ] - ' 0 ' ;
* tok4 = tk_xmmreg ;
return ;
}
}
}
if ( useasm = = FALSE ) {
if ( ( useme = FastSearch ( id , idofs , 2 , ( char * ) string4 ) ) ! = - 1 ) * tok4 = useme ;
else if ( idasm = = TRUE & & ( useme = CheckAsmName ( ( char * ) string4 ) ) ! = - 1 ) {
* tok4 = tk_idasm ;
itok4 - > rm = useme ;
return ;
}
}
if ( * tok4 = = tk_id | | * tok4 = = tk_ID ) {
if ( cur_mod & & cur_mod - > numparamdef & & ( displaytokerrors | | scanalltoks ) ) { //18.03.05 15:12
/* if(debug&&cur_mod){
printf ( " Find %s in %d entries curmod=%08X \n " , itok4 - > name , cur_mod - > numparamdef , cur_mod ) ;
COM_MOD * nmod ;
nmod = cur_mod ;
while ( nmod ) {
printf ( " \t input=%08X inptr=%08X \n " , nmod - > input , nmod - > inptr ) ;
nmod = nmod - > next ;
}
} */
if ( CheckDefPar ( itok4 - > name ) ) {
tokscan ( tok4 , itok4 , string4 ) ;
if ( displaytokerrors = = 0 ) {
inptr = cur_mod - > inptr ;
input = cur_mod - > input ;
endinptr = cur_mod - > endinptr ;
linenumber = cur_mod - > linenumber ;
currentfileinfo = cur_mod - > currentfileinfo ;
COM_MOD * temp = cur_mod ;
cur_mod = cur_mod - > next ;
free ( temp ) ;
nextchar ( ) ;
}
# ifdef DEBUGMODE
if ( debug ) printf ( " 1601 tok=%d input=%08X inptr=%08X disp=%d %s %c%40s \n \t %s \n " , * tok4 , input , inptr , displaytokerrors , itok4 - > name , cha , input + inptr , " " /*input*/ ) ;
# endif
return ;
}
}
if ( searchlocals ( itok4 , tok4 , string4 ) = = FALSE ) { //<2F> <> <EFBFBD> <EFBFBD> <EFBFBD> <20> ।<EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> ⮪
//<2F> <20> <> 祣<EFBFBD> <20> <> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <20> <20> <> ॢ<EFBFBD> <20> <> ६<EFBFBD> <E0A5AC> <EFBFBD> <EFBFBD>
searchtree ( itok4 , tok4 , string4 ) ;
if ( * tok4 = = tk_endline ) {
if ( scanlexmode ! = DEFLEX ) {
tokscan ( tok4 , itok4 , string4 ) ;
# ifdef DEBUGMODE
if ( debug ) printf ( " 1610 tok=%d input=%08X inptr=%08X disp=%d %s %c%40s \n \t %s \n " , * tok4 , input , inptr , displaytokerrors , itok4 - > name , cha , input + inptr , " " /*input*/ ) ;
# endif
return ;
}
* tok4 = tk_macro ;
}
if ( * tok4 = = tk_number | | * tok4 = = tk_idasm ) return ;
if ( ( * tok4 > = tk_bits & & * tok4 < = tk_doublevar ) | | * tok4 = = tk_pointer ) {
if ( itok4 - > rm = = rm_d16 | | itok4 - > rm = = rm_d32 ) {
if ( am32 = = FALSE ) {
itok4 - > rm = rm_d16 ;
itok4 - > sib = CODE16 ;
}
else {
itok4 - > rm = rm_d32 ;
itok4 - > sib = CODE32 ;
}
}
if ( itok4 - > post = = DYNAMIC_POST ) { //<2F> ८<EFBFBD> ࠧ<EFBFBD> <E0A0A7> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <20> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD>
if ( alignword & & * tok4 ! = tk_charvar & & * tok4 ! = tk_bytevar ) { //<2F> <> <EFBFBD> <E0AEA2> <EFBFBD> <EFBFBD> <20> <> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD>
switch ( * tok4 ) {
case tk_intvar :
case tk_wordvar :
if ( postsize % 2 = = 1 ) postsize + + ;
break ;
default :
if ( postsize % 4 ! = 0 ) postsize + = 4 - ( postsize % 4 ) ;
break ;
}
}
idrec * ptr = itok4 - > rec ;
itok4 - > post = ptr - > recpost = 1 ;
itok4 - > number = ptr - > recnumber = postsize ;
if ( am32 = = FALSE & & ( postsize + itok4 - > size ) > 0xFFFFL ) tobigpost ( ) ;
postsize + = itok4 - > size ;
}
else if ( itok4 - > post = = DYNAMIC_VAR ) {
idrec * ptr = itok4 - > rec ;
itok4 - > post = ptr - > recpost = USED_DIN_VAR ;
}
}
}
if ( tok = = tk_reg ) goto extreg ;
if ( tok = = tk_reg32 ) goto extreg32 ;
}
switch ( * tok4 ) {
int len ;
case tk_dataptr : * tok4 = tk_number ; itok4 - > number = outptrdata ;
if ( FixUp ) itok . flag | = f_reloc ; //new!!!
break ;
case tk_codeptr : * tok4 = tk_number ; itok4 - > number = outptr ;
if ( FixUp ) itok . flag | = f_reloc ; //new!!!
break ;
case tk_postptr : * tok4 = tk_number ; itok4 - > number = postsize ; break ;
case tk_line : * tok4 = tk_number ; itok4 - > number = linenumber ; break ;
case tk_file :
* tok4 = tk_string ;
strcpy ( ( char * ) string4 , ( startfileinfo + currentfileinfo ) - > filename ) ;
itok4 - > number = strlen ( ( char * ) string4 ) ;
break ;
case tk_structvar :
struct idrec * ptrs ;
ptrs = itok4 - > rec ;
// puts(itok4->name);
dostructvar2 ( tok4 , itok4 , ( structteg * ) ptrs - > newid , string4 ) ;
break ;
case tk_sizeof :
dosizeof ( itok4 ) ;
if ( itok4 - > post ) * tok4 = tk_postnumber ;
else * tok4 = tk_number ;
break ;
case tk_signed :
case tk_unsigned :
case tk_int :
case tk_long :
case tk_short :
if ( itok4 - > type ! = tp_modif ) {
GetTypeVar ( tok4 ) ;
itok4 - > type = tp_modif ;
}
break ;
case tk_ID :
// printf("%s %s %d %c\n",itok.name,string4,strptr,cha);
if ( strlen ( itok4 - > name ) = = 1 & & itok4 - > name [ 0 ] = = ' L ' & & cha = = ' " ' ) {
itok4 - > name [ 0 ] = 0 ;
GetTokString ( tok4 , itok4 , string4 , TRUE ) ;
return ;
}
case tk_id :
if ( findofset = = FALSE ) {
struct structteg * tteg ;
// if(displaytokerrors)printf("find teg %s cha=%02X\n",itok4->name,cha);
if ( ( ( tteg = FindTeg ( FALSE , itok4 - > name ) ) ! = NULL | |
( tteg = FindTeg ( TRUE , itok4 - > name ) ) ! = NULL ) & & ( cha = = ' . ' | | precha = = ' . ' ) ) {
// if(displaytokerrors)puts("finding");
dostructvar2 ( tok4 , itok4 , tteg , string4 ) ;
// printf("tok=%d\n",*tok4);
if ( displaytokerrors & & ( * tok4 = = tk_proc | | * tok4 = = tk_declare | |
* tok4 = = tk_undefproc ) & & ( itok4 - > flag & f_static ) = = 0 ) unknownobj ( itok4 - > name ) ;
}
}
break ;
}
if ( * tok4 = = tk_string & & displaytokerrors ) {
strcpy ( ( char * ) string3 , ( char * ) string4 ) ;
if ( itok4 - > rm = = 2 ) {
convert_string ( string4 ) ;
itok4 - > rm - - ;
}
if ( dosstring ) itok . flag = dos_term ;
}
yesid :
if ( ( * tok4 > = tk_bits & & * tok4 < = tk_doublevar ) | | * tok4 = = tk_pointer ) {
whitespace ( ) ; //<2F> ய<EFBFBD> <E0AEAF> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> ᨬ<> <E1A8AC> <EFBFBD> <EFBFBD> <EFBFBD>
if ( cha = = ' [ ' ) calcrm ( itok4 , * tok4 ) ; //<2F> <> ࠡ<EFBFBD> ⪠ <20> <> ࠦ<EFBFBD> <E0A0A6> <EFBFBD> <EFBFBD> <20> []
}
if ( itok4 - > rm ! = rm_d16 & & * tok4 ! = tk_proc & & * tok4 ! = tk_undefproc & &
* tok4 ! = tk_apiproc & & * tok4 ! = tk_declare & & ( ! ( * tok4 = = tk_pointer & & itok4 - > type = = tk_proc ) ) )
if ( itok4 - > post = = 0 & & ( itok4 - > flag & f_reloc ) = = 0 ) { // cannot compress if POST var
compressoffset ( itok4 ) ;
}
next = 0 ;
}
else if ( isdigit ( cha ) ) { //<2F> <>
inptr - - ;
itok4 - > lnumber = scannumber ( & itok4 - > rm ) ;
* tok4 = tk_number ;
next = 0 ;
}
else switch ( cha ) {
case ' \" ' :
GetTokString ( tok4 , itok4 , string4 , FALSE ) ;
next = 0 ;
break ;
case ' \' ' : //ᨬ<> <E1A8AC> <EFBFBD> 쭠<EFBFBD> <20> <> <EFBFBD> <EFBFBD> ⠭<EFBFBD> <E2A0AD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> 1 ᨬ<> <E1A8AC> <EFBFBD> <EFBFBD>
nextchar ( ) ;
next = 0 ;
if ( scanlexmode = = RESLEX ) {
* tok4 = tk_singlquote ;
break ;
}
* tok4 = tk_number ;
itok4 - > number = 0 ;
while ( cha ! = ' \' ' & & ! endoffile ) { // special character
itok4 - > lnumber = itok4 - > lnumber * 256 + convert_char ( ) ;
nextchar ( ) ;
}
if ( cha ! = ' \' ' ) {
if ( displaytokerrors ) expected ( ' \' ' ) ;
}
else nextchar ( ) ;
next = 0 ;
break ;
case ' - ' :
nextchar ( ) ;
switch ( cha ) {
case ' = ' : * tok4 = tk_minusequals ; break ; //<2F> <> <EFBFBD> <EFBFBD> <EFBFBD> ࠢ<> <E0A0A2>
case ' - ' : * tok4 = tk_minusminus ; break ; //<2F> <> <EFBFBD> <EFBFBD> <EFBFBD> -<2D> <> <EFBFBD> <EFBFBD> <EFBFBD>
default : * tok4 = tk_minus ; next = 0 ; itok4 - > type = tp_opperand ; break ; //<2F> <> <EFBFBD> <EFBFBD> <EFBFBD>
}
break ;
case ' + ' :
nextchar ( ) ;
switch ( cha ) {
case ' = ' : * tok4 = tk_plusequals ; break ; //<2F> <> <EFBFBD> <EFBFBD> ࠢ<> <E0A0A2>
case ' + ' : * tok4 = tk_plusplus ; break ; //<2F> <> <EFBFBD> <EFBFBD> -<2D> <> <EFBFBD> <EFBFBD>
default : whitespace ( ) ; // spaces allowed between
if ( cha = = ' - ' ) * tok4 = tk_minus ; // optimization of + -
else {
* tok4 = tk_plus ; //<2F> <> <EFBFBD> <EFBFBD>
next = 0 ;
}
itok4 - > type = tp_opperand ;
break ;
}
break ;
case ' * ' :
nextchar ( ) ;
switch ( cha ) {
case ' = ' : * tok4 = tk_multequals ; break ;
case ' - ' : * tok4 = tk_multminus ; break ; //㬭<> <E3ACAD> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD>
default :
* tok4 = tk_mult ; //㬭<> <E3ACAD> <EFBFBD> <EFBFBD> <EFBFBD>
next = 0 ;
}
itok4 - > type = tp_opperand ;
break ;
case ' / ' : nextchar ( ) ;
switch ( cha ) {
case ' * ' : nextchar ( ) ; //ᮬ<> <E1AEAC> <EFBFBD> <EFBFBD>
useme = 1 ;
while ( ! endoffile & & useme > 0 ) {
whitespace ( ) ;
if ( cha = = ' * ' ) {
nextchar ( ) ;
if ( cha = = ' / ' ) {
nextchar ( ) ;
if ( cha = = ' / ' ) nextchar ( ) ;
else useme - - ;
}
continue ;
}
else if ( cha = = ' / ' ) {
nextchar ( ) ;
if ( cha = = ' * ' ) useme + + ;
else if ( cha = = ' / ' ) {
nextchar ( ) ;
continue ;
}
else continue ;
}
nextchar ( ) ;
}
if ( endoffile ) {
* tok4 = tk_eof ;
if ( useme > 0 & & displaytokerrors ) unexpectedeof ( ) ;
}
else tokscan ( tok4 , itok4 , string4 ) ;
break ;
case ' / ' :
do {
nextchar ( ) ;
} while ( ! endoffile & & cha ! = 13 ) ; //<2F> <> ப<EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD>
if ( endoffile ) * tok4 = tk_eof ;
else {
if ( scanlexmode = = DEFLEX ) * tok4 = tk_endline ;
else {
whitespace ( ) ;
if ( cha = = 13 ) nextchar ( ) ;
tokscan ( tok4 , itok4 , string4 ) ;
}
}
break ;
case ' = ' : * tok4 = tk_divequals ; nextchar ( ) ; return ;
default :
whitespace ( ) ;
if ( cha = = ' - ' ) {
* tok4 = tk_divminus ; //<2F> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD>
nextchar ( ) ;
}
else * tok4 = tk_div ;
itok4 - > type = tp_opperand ;
break ;
}
next = 0 ;
break ;
case ' % ' :
nextchar ( ) ;
whitespace ( ) ;
if ( cha = = ' - ' ) * tok4 = tk_modminus ; //<2F> <> <EFBFBD> <EFBFBD> ⮪ <20> <> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD>
else {
* tok4 = tk_mod ;
next = 0 ;
}
itok4 - > type = tp_opperand ;
break ;
case ' | ' :
nextchar ( ) ;
switch ( cha ) {
case ' = ' : * tok4 = tk_orequals ; break ; //OR=
case ' | ' : * tok4 = tk_oror ; break ; //OR-OR
default :
whitespace ( ) ;
if ( cha = = ' - ' ) * tok4 = tk_orminus ; //OR-
else {
* tok4 = tk_or ;
if ( cha = = 13 ) nextchar ( ) ; //OR
next = 0 ;
}
itok4 - > type = tp_opperand ;
break ;
}
break ;
case ' & ' :
nextchar ( ) ;
switch ( cha ) {
case ' = ' : * tok4 = tk_andequals ; break ; //AND=
case ' & ' : * tok4 = tk_andand ; break ;
default :
whitespace ( ) ;
if ( cha = = ' - ' ) * tok4 = tk_andminus ;
else {
* tok4 = tk_and ;
next = 0 ;
}
itok4 - > type = tp_opperand ;
break ;
}
break ;
case ' ! ' :
nextchar ( ) ;
if ( cha = = ' = ' ) {
* tok4 = tk_notequal ; //!=
itok4 - > type = tp_compare ;
}
else {
* tok4 = tk_not ;
next = 0 ;
}
break ;
case ' ^ ' :
nextchar ( ) ;
if ( cha = = ' = ' ) * tok4 = tk_xorequals ; //XOR=
else {
whitespace ( ) ;
if ( cha = = ' - ' ) * tok4 = tk_xorminus ;
else {
* tok4 = tk_xor ;
next = 0 ;
}
itok4 - > type = tp_opperand ;
}
break ;
case ' = ' :
nextchar ( ) ;
if ( cha = = ' = ' ) {
* tok4 = tk_equalto ; //==
itok4 - > type = tp_compare ;
}
else {
* tok4 = tk_assign ; //<2F> <> <EFBFBD> <EFBFBD> <E1A2AE> <EFBFBD>
next = 0 ;
}
break ;
case ' > ' :
nextchar ( ) ;
switch ( cha ) {
case ' > ' :
nextchar ( ) ;
if ( cha = = ' = ' ) * tok4 = tk_rrequals ; //ᤢ<> <E1A4A2> <20> <> ࠢ<EFBFBD> <20> <20> <> <EFBFBD> <EFBFBD> <E1A2AE> <EFBFBD> <EFBFBD> <EFBFBD>
else {
whitespace ( ) ;
if ( cha = = ' - ' ) * tok4 = tk_rrminus ;
else {
* tok4 = tk_rr ; //ᤢ<> <E1A4A2> <20> <> ࠢ<EFBFBD>
next = 0 ;
}
itok4 - > type = tp_opperand ;
}
break ;
case ' < ' : * tok4 = tk_swap ; break ; //<2F> <> <EFBFBD> <EFBFBD> <EFBFBD>
case ' = ' : * tok4 = tk_greaterequal ; itok4 - > type = tp_compare ; break ; //<2F> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> ࠢ<> <E0A0A2>
default : * tok4 = tk_greater ; next = 0 ; itok4 - > type = tp_compare ; break ; //<2F> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD>
}
break ;
case ' < ' :
nextchar ( ) ;
switch ( cha ) {
case ' < ' :
nextchar ( ) ;
if ( cha = = ' = ' ) * tok4 = tk_llequals ; //ᤢ<> <E1A4A2> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <20> <20> <> <EFBFBD> <EFBFBD> <E1A2AE> <EFBFBD> <EFBFBD> <EFBFBD>
else {
whitespace ( ) ;
if ( cha = = ' - ' ) * tok4 = tk_llminus ;
else {
* tok4 = tk_ll ; //ᤢ<> <E1A4A2> <20> <> <EFBFBD> <EFBFBD> <EFBFBD>
next = 0 ;
}
itok4 - > type = tp_opperand ;
}
break ;
case ' > ' : * tok4 = tk_notequal ; itok4 - > type = tp_compare ; break ; //!=
case ' = ' : * tok4 = tk_lessequal ; itok4 - > type = tp_compare ; break ; //<2F> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> ࠢ<> <E0A0A2>
default : * tok4 = tk_less ; next = 0 ; itok4 - > type = tp_compare ; break ; //<2F> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD>
}
break ;
case ' # ' :
next = 0 ;
nextchar ( ) ;
findofset = TRUE ;
tokscan ( tok4 , itok4 , string4 ) ;
findofset = FALSE ;
if ( ( useme = GetDirective ( ( char * ) string4 ) ) ! = - 1 ) {
itok4 - > number = useme ;
* tok4 = tk_question ;
break ;
}
if ( * tok4 = = tk_dblcolon ) {
skiplocals = TRUE ;
tokscan ( tok4 , itok4 , string4 ) ;
}
/* char buf[16];
strncpy ( buf , ( char * ) ( input + inptr ) , 15 ) ;
buf [ 15 ] = 0 ; */
// printf("sib=%08X tok=%d rm=%d post=%d number=%d size=%d segm=%d flag=%08X %s\n",itok4->sib,*tok4,itok4->rm,itok4->post,itok4->number,itok4->size,itok4->segm,itok4->flag,itok4->name/*,buf*/);
// printf("skiplocals=%d skipfind=%d searchteg=%08X\n",skiplocals,skipfind,searchteg);
switch ( * tok4 ) {
case tk_structvar :
// printf("%08X %s\n",itok4->sib,itok4->name);
if ( ( itok4 - > sib & 1 ) = = 0 ) {
ofsstr ( tok4 , itok4 ) ;
// if(displaytokerrors)printf("sib=%08X tok=%d rm=%d post=%d number=%d size=%d segm=%d flag=%08X %s\n",itok4->sib,*tok4,itok4->rm,itok4->post,itok4->number,itok4->size,itok4->segm,itok4->flag,itok4->name/*,buf*/);
break ;
}
itok4 - > rm = ( am32 = = 0 ? rm_d16 : rm_d32 ) ;
case tk_struct :
* tok4 = tk_number ;
if ( bufrm ) {
* tok4 = tk_rmnumber ;
if ( itok4 - > type = = tp_classvar ) itok4 - > flag | = f_useidx ;
}
break ;
case tk_apiproc : //!!!16.12.06 23:06
itok4 - > rm = tk_undefofs ;
* tok4 = tk_apioffset ;
if ( FixUp ) itok4 - > flag | = f_reloc ; //new!!! 27.06.05 22:25
strcpy ( ( char * ) string4 , itok4 - > name ) ;
// printf("sib=%08X tok=%d rm=%d post=%d number=%d size=%d segm=%d %s\n",itok4->sib,*tok4,itok4->rm,itok4->post,itok4->number,itok4->size,itok4->segm,itok4->name/*,buf*/);
break ;
case tk_proc :
case tk_interruptproc :
if ( cha = = ' . ' ) goto structofs ;
procofs :
if ( itok4 - > segm ! = NOT_DYNAMIC ) {
if ( displaytokerrors ) {
idrec * ptr = itok4 - > rec ;
itok4 - > segm = ptr - > recsegm = DYNAMIC_USED ;
}
itok4 - > rm = * tok4 = tk_undefofs ; //ᬥ饭<E1ACA5> <E9A5AD> <20> <> <EFBFBD> <20> <> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> ⭮<EFBFBD> <20> <> ⪨
itok4 - > number = 0 ;
// if(FixUp)itok4->flag|=f_reloc; //new!!! 27.06.05 22:25
}
else {
* tok4 = tk_number ;
itok4 - > segm = CS ; //(splitdata==FALSE)?DS:CS;
// if(FixUp)itok4->flag|=f_reloc;
}
if ( FixUp ) itok4 - > flag | = f_reloc ; //new!!! 27.06.05 22:25
strcpy ( ( char * ) string4 , itok4 - > name ) ;
// printf("sib=%08X tok=%d rm=%d post=%d number=%d size=%d segm=%d %s\n",itok4->sib,*tok4,itok4->rm,itok4->post,itok4->number,itok4->size,itok4->segm,itok4->name/*,buf*/);
break ;
case tk_id :
case tk_ID :
structofs :
struct structteg * tteg ;
if ( ( ( tteg = FindTeg ( FALSE , itok4 - > name ) ) ! = NULL | |
( tteg = FindTeg ( TRUE , itok4 - > name ) ) ! = NULL ) /*&&cha=='.'*/ ) {
dostructvar2 ( tok4 , itok4 , tteg , string4 ) ;
// printf("sib=%08X tok=%d rm=%d post=%d number=%d size=%d %s\n",itok4->sib,*tok4,itok4->rm,itok4->post,itok4->number,itok4->size,itok4->name/*,buf*/);
if ( * tok4 = = tk_proc ) goto procofs ; //04.10.04 14:25
if ( * tok4 = = tk_declare ) goto undefofs ; //24.09.04 00:33
// printf("tok=%d segm=%d %s\n",*tok4,itok4->segm,itok4->name);
if ( strinf . bufstr ) {
* tok4 = tk_rmnumber ;
if ( itok4 - > type = = tp_classvar ) itok4 - > flag | = f_useidx ;
}
else {
if ( FixUp & & * tok4 = = tk_proc ) itok4 - > flag | = f_reloc ; //new!!!
else itok4 - > flag & = ~ f_reloc ;
// else itok4->flag&=!f_reloc; 16.08.04 18:51
//30.09.04 20:22
if ( itok4 - > post ) {
* tok4 = tk_postnumber ;
itok4 - > rm = tk_undefofs ;
}
else
/////
* tok4 = tk_number ;
}
}
else {
undefofs :
itok4 - > rm = * tok4 = tk_undefofs ; //ᬥ饭<E1ACA5> <E9A5AD> <20> <> <EFBFBD> <20> <> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> ⭮<EFBFBD> <20> <> ⪨
itok4 - > number = 0 ;
if ( FixUp ) itok4 - > flag | = f_reloc ; //new!!!
}
case tk_number :
case tk_rmnumber :
break ;
case tk_reg :
case tk_reg32 :
itok4 - > rm = RegToRM ( itok4 - > number , * tok4 ) /*|rm_mod10*/ ;
* tok4 = ( am32 = = 0 ? tk_wordvar : tk_dwordvar ) ; //tk_rmnumber;
itok4 - > number = 0 ;
break ;
default :
if ( cha = = ' . ' ) goto structofs ;
if ( ( * tok4 > = tk_bits & & * tok4 < = tk_doublevar ) | | tok = = tk_pointer ) {
# ifdef OPTVARCONST
if ( displaytokerrors ) ClearVarByNum ( itok4 ) ;
# endif
switch ( itok4 - > type ) {
case tp_localvar :
case tp_paramvar :
localrec * ptr ;
ptr = itok4 - > locrec ;
ptr - > fuse | = ( unsigned char ) ( INITVAR | USEDVAR ) ;
break ;
case tk_proc :
itok4 - > rm = itok4 - > sib ;
itok4 - > sib = am32 = = 0 ? CODE16 : CODE32 ;
break ;
}
itok4 - > size = GetVarSize ( * tok4 ) ;
if ( ( itok4 - > sib = = CODE16 & & itok4 - > rm = = rm_d16 ) | |
( itok4 - > sib = = CODE32 & & itok4 - > rm = = rm_d32 ) ) {
if ( itok4 - > post = = 0 ) {
* tok4 = tk_number ;
itok4 - > segm = DS ;
if ( FixUp ) itok4 - > flag | = f_reloc ;
itok4 - > rm = am32 = = FALSE ? tk_word : tk_dword ;
}
else {
* tok4 = tk_postnumber ;
itok4 - > rm = tk_undefofs ;
}
}
else {
* tok4 = tk_rmnumber ;
if ( itok4 - > type = = tp_classvar ) itok4 - > flag | = f_useidx ;
}
}
else {
itok4 - > rm = * tok4 = tk_undefofs ; //ᬥ饭<E1ACA5> <E9A5AD> <20> <> <EFBFBD> <20> <> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> ⭮<EFBFBD> <20> <> ⪨
itok4 - > number = 0 ;
strcpy ( ( char * ) string4 , itok4 - > name ) ;
}
break ;
}
itok4 - > type = tp_ofs ;
// if(displaytokerrors)printf("name=%s tok=%d post=%d flag=%08X rm=%d\n",itok4->name,*tok4,itok4->post,itok4->flag,itok4->rm);
break ;
case ' ( ' :
if ( * ( unsigned short * ) & ( input [ inptr ] ) = =
# ifdef _WC_
' ) E '
# else
' E ) '
# endif
| |
( * ( unsigned short * ) & ( input [ inptr ] ) = =
# ifdef _WC_
' ) e '
# else
' e ) '
# endif
) ) {
for ( useme = 0 ; useme < 8 ; useme + + ) {
int i ;
if ( asmparam ) i = strnicmp ( ( char * ) input + inptr + 2 , regs [ 0 ] [ useme ] , 2 ) ;
else i = strncmp ( ( char * ) input + inptr + 2 , regs [ 0 ] [ useme ] , 2 ) ;
if ( i = = 0 ) {
inptr + = 4 ;
nextchar ( ) ;
itok4 - > number = useme ;
if ( am32 ) {
* tok4 = tk_reg32 ;
goto extreg32 ;
}
* tok4 = tk_reg ;
goto extreg ;
}
}
}
* tok4 = tk_openbracket ;
break ;
case ' : ' :
nextchar ( ) ;
if ( cha ! = ' : ' ) {
next = 0 ;
* tok4 = tk_colon ;
}
else * tok4 = tk_dblcolon ;
break ;
case ' ; ' : itok4 - > type = tp_stopper ; * tok4 = tk_semicolon ; break ;
case ' ) ' : itok4 - > type = tp_stopper ; * tok4 = tk_closebracket ; break ;
case ' { ' : * tok4 = tk_openbrace ; break ;
case ' } ' : itok4 - > type = tp_stopper ; * tok4 = tk_closebrace ; break ;
case ' [ ' : * tok4 = tk_openblock ; break ;
case ' ] ' : itok4 - > type = tp_stopper ; * tok4 = tk_closeblock ; break ;
case ' , ' : itok4 - > type = tp_stopper ; * tok4 = tk_camma ; break ;
case ' . ' :
next = 0 ;
nextchar ( ) ;
if ( cha ! = ' . ' ) {
* tok4 = tk_period ;
break ;
}
nextchar ( ) ;
if ( cha ! = ' . ' ) {
badtoken ( ) ;
nextchar ( ) ;
tokscan ( tok4 , itok4 , string4 ) ;
break ;
}
nextchar ( ) ;
* tok4 = tk_multipoint ;
break ;
case ' @ ' : * tok4 = tk_at ; break ;
case ' $ ' : * tok4 = tk_dollar ; break ;
case ' ? ' :
nextchar ( ) ;
tokscan ( tok4 , itok4 , string4 ) ;
* tok4 = tk_question ;
itok4 - > number = GetDirective ( ( char * ) string4 ) ;
return ;
case ' ~ ' : * tok4 = tk_tilda ; break ;
case 26 : * tok4 = tk_eof ; return ;
case 13 : * tok4 = tk_endline ; break ;
case ' \\ ' :
nextchar ( ) ;
if ( cha = = 13 ) {
tokscan ( tok4 , itok4 , string4 ) ;
if ( * tok4 = = tk_endline ) tokscan ( tok4 , itok4 , string4 ) ;
return ;
}
default :
badtoken ( ) ;
nextchar ( ) ;
tokscan ( tok4 , itok4 , string4 ) ;
return ;
}
if ( next ) nextchar ( ) ;
# ifdef DEBUGMODE
if ( debug ) printf ( " 2172 tok=%d input=%08X inptr=%08X disp=%d %s %X %s \n " , * tok4 , input , inptr , displaytokerrors , itok4 - > name , cha , input + inptr ) ;
# endif
}
void NewMod ( int numipar )
{
COM_MOD * newm ;
int oline ;
int numpar = 0 , ns , i , size , nsize ;
char * buf = NULL ;
newm = ( COM_MOD * ) MALLOC ( sizeof ( COM_MOD ) ) ;
newm - > numparamdef = numipar ;
newm - > freze = FALSE ;
size = 0 ;
whitespace ( ) ;
if ( cha = = ' ( ' ) {
nextchar ( ) ;
whitespace ( ) ;
if ( cha ! = ' ) ' ) {
inptr - - ;
oline = linenumber ;
for ( i = inptr , ns = 1 ; ns > 0 ; i + + ) { //<2F> <> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> ࠬ<EFBFBD> <E0A0AC>
switch ( input [ i ] ) {
case ' ( ' : ns + + ; break ;
case ' ) ' : ns - - ; break ;
case ' , ' :
if ( ns = = 1 ) {
numpar + + ;
nsize = i - inptr ;
if ( ! buf ) buf = ( char * ) MALLOC ( nsize + 1 ) ;
else buf = ( char * ) REALLOC ( buf , size + nsize + 1 ) ;
strncpy ( buf + size , ( char * ) ( input + inptr ) , nsize ) ;
buf [ size + nsize ] = 0 ;
strbtrim ( buf + size ) ;
// puts(buf+size);
size + = strlen ( buf + size ) + 1 ;
inptr + = nsize + 1 ;
}
break ;
case ' / ' :
i = skipcomment ( i ) ;
break ;
case ' " ' :
case 0x27 :
i = skipstring ( i , input [ i ] ) ;
break ;
}
if ( ( unsigned int ) i > = endinptr ) {
unexpectedeof ( ) ;
break ;
}
}
linenumber = oline ;
numpar + + ;
nsize = i - inptr ;
if ( ! buf ) buf = ( char * ) MALLOC ( nsize ) ;
else buf = ( char * ) REALLOC ( buf , size + nsize ) ;
strncpy ( buf + size , ( char * ) ( input + inptr ) , nsize - 1 ) ;
buf [ size + nsize - 1 ] = 0 ;
strbtrim ( buf + size ) ;
// puts(buf+size);
inptr = i ;
}
if ( numipar > numpar ) missingpar ( itok . name ) ;
else if ( numipar < numpar ) extraparam ( itok . name ) ;
newm - > numparamdef = numpar ;
}
else inptr - - ;
newm - > input = input ;
newm - > inptr2 = newm - > inptr = inptr ;
newm - > endinptr = endinptr ;
newm - > linenumber = linenumber ;
newm - > currentfileinfo = currentfileinfo ;
newm - > paramdef = buf ;
newm - > next = cur_mod ;
cur_mod = newm ;
// if(debug)printf("New curmod %08X numpar=%d input=%08X prev curmod=%08X\n",cur_mod,numipar,input,cur_mod->next);
nextchar ( ) ;
/* char *temp=buf;
for ( i = 0 ; i < numpar ; i + + ) {
nsize = strlen ( temp ) + 1 ;
puts ( temp ) ;
temp + = nsize ;
} */
}
void BackMod ( )
{
if ( cur_mod ) {
inptr = cur_mod - > inptr ;
inptr2 = cur_mod - > inptr2 ;
input = cur_mod - > input ;
endinptr = cur_mod - > endinptr ;
linenumber = cur_mod - > linenumber ;
currentfileinfo = cur_mod - > currentfileinfo ;
cur_mod = cur_mod - > next ;
cha2 = input [ inptr2 ] ;
}
}
char * FindDefPar ( char * name , COM_MOD * cmod )
{
char * temp ;
int i , numpar , nsize = 0 ;
numpar = cmod - > numparamdef ;
temp = cmod - > declareparamdef ;
// if(debug)printf("check for %s\n",name);
for ( i = 0 ; i < numpar ; i + + ) {
nsize = strlen ( temp ) + 1 ;
// if(debug)printf("\t%s\n",temp);
if ( strcmp ( name , temp ) = = 0 ) {
temp = cmod - > paramdef ;
for ( ; i > 0 ; i - - ) {
temp + = strlen ( temp ) + 1 ;
}
return temp ;
}
temp + = nsize ;
}
return NULL ;
}
int CheckDefPar ( char * name )
{
char * temp , * nname ;
COM_MOD * fmod ;
fmod = cur_mod ;
nname = name ;
while ( ( temp = FindDefPar ( nname , fmod ) ) ! = NULL ) {
nname = temp ;
if ( fmod - > next = = NULL ) break ;
fmod = fmod - > next ;
}
if ( fmod = = cur_mod & & temp = = NULL ) return FALSE ;
SetNewStr ( nname ) ;
return TRUE ;
}
void SetNewStr ( char * name )
{
COM_MOD * fmod ;
fmod = ( COM_MOD * ) MALLOC ( sizeof ( COM_MOD ) ) ;
fmod - > next = cur_mod ;
fmod - > numparamdef = 0 ;
fmod - > paramdef = NULL ;
fmod - > freze = FALSE ;
fmod - > input = input ;
fmod - > inptr2 = fmod - > inptr = inptr - 1 ;
fmod - > endinptr = endinptr ;
fmod - > linenumber = linenumber ;
fmod - > currentfileinfo = currentfileinfo ;
cur_mod = fmod ;
// if(debug)printf("new curmod %08X prev cur_mod=%08X old input %08X %s\n",cur_mod,cur_mod->next,input,name);
input = ( unsigned char * ) ( name ) ;
inptr = 1 ;
cha = input [ 0 ] ;
endinptr = strlen ( name ) + 1 ;
}
int searchtree2 ( idrec * fptr , ITOK * itok4 , int * tok4 , unsigned char * string4 )
//<2F> <> <EFBFBD> <EFBFBD> <EFBFBD> <20> <20> <> ॢ<EFBFBD> <20> <> ६<EFBFBD> <E0A5AC> <EFBFBD> <EFBFBD>
{
struct idrec * ptr ;
int cmpresult ;
for ( ptr = fptr ; ptr ! = NULL ; ) {
if ( ( cmpresult = strcmp ( ptr - > recid , ( char * ) string4 ) ) = = 0 ) {
if ( scanlexmode = = RESLEX & & ptr - > rectok ! = tk_number & & ptr - > rectok ! = tk_string ) break ;
itok4 - > lnumber = ptr - > reclnumber ;
itok4 - > rm = ptr - > recrm ;
* tok4 = ptr - > rectok ;
itok4 - > post = ptr - > recpost ;
itok4 - > segm = ptr - > recsegm ;
itok4 - > flag | = ptr - > flag ;
itok4 - > size = ptr - > recsize ;
itok4 - > sib = ptr - > recsib ;
itok4 - > rec = ptr ;
itok4 - > type = ptr - > type ;
itok4 - > npointr = ptr - > npointr ;
// if(debug)printf("Find: tok=%d\n",*tok4);
if ( displaytokerrors ) {
ptr - > count + + ;
// printf("%s notdoneprestuff=%d tok=%d segm=%d\n",itok4->name,notdoneprestuff,*tok4,itok4->segm);
if ( notdoneprestuff = = 2 & & * tok4 = = tk_proc & & itok4 - > segm = = DYNAMIC ) AddDynamicList ( ptr ) ;
}
if ( * tok4 = = tk_macro ) {
// printf("tok=%d %s %s\n",*tok4,itok4->name,input);
if ( dirmode = = dm_if ) return TRUE ;
if ( scanlexmode = = DEFLEX | | scanlexmode = = DEFLEX2 ) * tok4 = tk_id ;
else if ( displaytokerrors ) {
NewMod ( itok4 - > size ) ;
notdef = FALSE ;
cur_mod - > declareparamdef = ptr - > newid ;
input = ( unsigned char * ) ( ptr - > sbuf ) ;
inptr = 1 ;
cha = input [ 0 ] ;
endinptr = strlen ( ( char * ) input ) ;
// if(debug)printf("New cur_mod tok=%d numpar=%d %s %s\n",*tok4,cur_mod->numparamdef,itok4->name,input);
// debug=TRUE;
clearregstat ( ) ;
* tok4 = tk_endline ;
return TRUE ;
}
}
else if ( ptr - > newid ) {
switch ( * tok4 ) {
case tk_string :
memcpy ( ( char * ) string4 , ptr - > newid , itok4 - > number ) ;
if ( displaytokerrors & & itok4 - > rm = = 1 & & ptr - > sbuf ) strcpy ( ( char * ) string3 , ptr - > sbuf ) ;
break ;
case tk_structvar :
itok4 - > segm = 0 ;
if ( ptr - > recpost = = DYNAMIC_POST ) {
ptr - > recpost = itok4 - > post = 1 ;
if ( alignword ) { //<2F> <> <EFBFBD> <E0AEA2> <EFBFBD> <EFBFBD> <20> <> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD>
if ( postsize % 2 = = 1 ) postsize + + ;
}
itok4 - > number = ptr - > recnumber = postsize ;
if ( am32 = = FALSE & & ( ptr - > recsize + postsize ) > 0xFFFFL ) tobigpost ( ) ;
postsize + = ptr - > recsize ;
}
else if ( ptr - > recpost = = DYNAMIC_VAR ) itok4 - > post = ptr - > recpost = USED_DIN_VAR ;
return TRUE ;
case tk_proc :
case tk_apiproc :
case tk_declare :
case tk_undefproc :
strcpy ( ( char * ) string4 , ptr - > newid ) ;
break ;
default :
if ( scanlexmode = = DEFLEX2 ) {
* tok4 = tk_id ;
return TRUE ;
}
strcpy ( ( char * ) string4 , ptr - > newid ) ;
if ( strcmp ( ( char * ) string4 , ptr - > recid ) ! = 0 ) { // see if ID has changed
// searchtree2(fptr,itok4,tok4,string4); // search again
searchtree ( itok4 , tok4 , string4 ) ; // search again
switch ( * tok4 ) {
case tk_proc :
case tk_apiproc :
case tk_declare :
case tk_undefproc :
strcpy ( itok4 - > name , ptr - > recid ) ; //<2F> <> <EFBFBD> <20> 㦭<EFBFBD> <20> <> <EFBFBD> undefine
break ;
default :
strncpy ( itok4 - > name , ( char * ) string4 , IDLENGTH - 1 ) ; //<2F> <> <EFBFBD> <20> 㦭<EFBFBD> <20> <> <EFBFBD> undefine
break ;
}
return TRUE ;
}
break ;
}
}
else string4 [ 0 ] = 0 ;
strcpy ( itok4 - > name , ptr - > recid ) ; //<2F> <> <EFBFBD> <20> 㦭<EFBFBD> <20> <> <EFBFBD> undefine
if ( displaytokerrors ) ptr - > count + + ;
break ;
}
else if ( cmpresult < 0 ) ptr = ptr - > left ;
else ptr = ptr - > right ;
}
if ( ptr = = NULL ) return FALSE ;
else return TRUE ;
}
int searchtree ( ITOK * itok4 , int * tok4 , unsigned char * string4 )
{
int retval = FALSE ;
if ( skipfind = = FALSE ) {
if ( staticlist ) retval = searchtree2 ( staticlist , itok4 , tok4 , string4 ) ;
if ( ! retval ) retval = searchtree2 ( treestart , itok4 , tok4 , string4 ) ;
if ( ! retval ) {
if ( ( retval = searchtree2 ( definestart , itok4 , tok4 , string4 ) ) = = TRUE ) {
if ( scanlexmode = = DEFLEX2 ) * tok4 = tk_id ;
}
}
}
return retval ;
}
void AddDynamicList ( idrec * ptr )
{
// printf("Add dinamic list %s %08X seg=%d tok=%d\n",ptr->recid,ptr,ptr->recsegm,ptr->rectok);
if ( DynamicList = = NULL ) {
sizeDL = STEPDL ;
DynamicList = ( volatile idrec * * ) MALLOC ( sizeof ( idrec * * ) * sizeDL ) ;
countDP = 0 ;
}
else if ( sizeDL = = ( countDP + 1 ) ) {
sizeDL + = STEPDL ;
DynamicList = ( volatile idrec * * ) REALLOC ( DynamicList , sizeof ( idrec * * ) * sizeDL ) ;
}
for ( int i = 0 ; i < countDP ; i + + ) if ( ptr = = DynamicList [ i ] ) return ;
DynamicList [ countDP ] = ptr ;
countDP + + ;
}
void docals ( struct idrec * ptr )
/* extract any procedures required from interal library and insert any
dynamic procedures that have been called . */
{
if ( ptr ! = NULL ) {
// printf("%s\n",ptr->recid);
tok = ptr - > rectok ;
if ( sdp_mode = = FALSE & & ( ptr - > flag & f_export ) ! = 0 & & tok = = tk_proc ) {
if ( lexport = = NULL ) {
lexport = ( struct listexport * ) MALLOC ( sizeof ( struct listexport ) ) ;
lexport - > address = ptr - > recnumber ;
strcpy ( lexport - > name , ptr - > recid ) ;
numexport = 1 ;
}
else {
int cmpname , i ;
for ( i = 0 ; i < numexport ; i + + ) {
if ( ( cmpname = strcmp ( ptr - > recid , ( lexport + i ) - > name ) ) < = 0 ) break ;
}
if ( cmpname ! = 0 ) {
lexport = ( struct listexport * ) REALLOC ( lexport , sizeof ( struct listexport ) * ( numexport + 1 ) ) ;
if ( cmpname < 0 ) {
for ( int j = numexport ; j > i ; j - - ) {
memcpy ( & ( lexport + j ) - > address , & ( lexport + j - 1 ) - > address , sizeof ( struct listexport ) ) ;
}
}
numexport + + ;
( lexport + i ) - > address = ptr - > recnumber ;
strcpy ( ( lexport + i ) - > name , ptr - > recid ) ;
}
}
}
if ( ! ( ptr - > flag & f_extern ) ) {
if ( tok = = tk_undefproc ) {
strcpy ( itok . name , ptr - > recid ) ;
if ( sdp_mode ) {
int boutptr = outptr ;
int i ;
if ( ( ptr - > flag & f_typeproc ) = = tp_fastcall ) {
if ( ( i = includeit ( 1 ) ) ! = - 1 ) {
if ( updatecall ( ( unsigned int ) ptr - > recnumber , boutptr , 0 ) > 0 ) {
ptr - > rectok = tk_proc ;
ptr - > recnumber = boutptr ; // record location placed
ptr - > recrm = i ;
ptr - > count + + ;
}
}
}
else {
if ( ( i = includeproc ( ) ) ! = - 1 ) {
if ( updatecall ( ( unsigned int ) ptr - > recnumber , boutptr , 0 ) > 0 ) {
ptr - > rectok = tk_proc ;
ptr - > recnumber = boutptr ; // record location placed
ptr - > recrm = i ;
ptr - > count + + ;
}
}
}
}
else {
if ( updatecall ( ( unsigned int ) ptr - > recnumber , outptr , 0 ) > 0 ) {
ptr - > recnumber = outptr ; // record location placed
linenumber = ptr - > line ;
currentfileinfo = ptr - > file ;
if ( ( ptr - > flag & f_typeproc ) = = tp_fastcall ) {
if ( includeit ( 1 ) = = - 1 ) thisundefined ( itok . name ) ;
}
else {
if ( includeproc ( ) = = - 1 ) thisundefined ( itok . name ) ;
}
ptr - > rectok = tk_proc ;
ptr - > count + + ;
}
}
}
else if ( tok = = tk_proc ) {
// printf("%08X %s\n",ptr->recpost,ptr->recid);
itok . segm = ptr - > recsegm ;
if ( itok . segm = = DYNAMIC_USED ) {
// printf("%08X %s\n",ptr->recpost,ptr->recid);
// if(updatecall((unsigned int)ptr->recnumber,outptr,0)>0){
itok . number = ptr - > recnumber ;
itok . flag = ptr - > flag ;
itok . post = ptr - > recpost ;
strcpy ( itok . name , ptr - > recid ) ;
if ( ptr - > newid = = NULL ) string [ 0 ] = 0 ;
else strcpy ( ( char * ) string , ( char * ) ptr - > newid ) ;
itok . rm = ptr - > recrm ;
itok . size = ptr - > recsize ;
itok . rec = ptr ;
insert_dynamic ( ) ;
// }
}
}
// else printf("tok=%d %s\n",tok,ptr->recid);
}
docals ( ptr - > left ) ;
docals ( ptr - > right ) ;
}
}
void docalls2 ( )
{
// puts("start docalls2");
docals ( treestart ) ;
for ( unsigned int i = 0 ; i < totalmodule ; i + + ) docals ( ( startfileinfo + i ) - > stlist ) ;
// puts("end docalls2");
}
void docalls ( ) /* attempt to declare undefs from library and dynamic proc's */
{
int numdinproc ;
// puts("start docalls");
notdoneprestuff = 2 ;
docalls2 ( ) ;
while ( DynamicList ! = NULL ) {
idrec * ptr ;
numdinproc = 0 ;
// printf("%d dinamic proc\n",countDP);
for ( int i = 0 ; i < countDP ; i + + ) {
ptr = ( idrec * ) DynamicList [ i ] ;
tok = ptr - > rectok ;
itok . segm = ptr - > recsegm ;
// printf("%d %08X seg=%d tok=%d %s\n",i+1,ptr,itok.segm,ptr->rectok,ptr->recid);
if ( itok . segm = = DYNAMIC_USED ) {
itok . number = ptr - > recnumber ;
itok . flag = ptr - > flag ;
strcpy ( itok . name , ptr - > recid ) ;
if ( ptr - > newid = = NULL ) string [ 0 ] = 0 ;
else strcpy ( ( char * ) string , ( char * ) ptr - > newid ) ;
itok . rm = ptr - > recrm ;
itok . size = ptr - > recsize ;
itok . rec = ptr ;
insert_dynamic ( ) ;
numdinproc + + ;
}
}
docalls2 ( ) ;
if ( numdinproc = = 0 ) break ;
}
free ( DynamicList ) ;
DynamicList = NULL ;
countDP = 0 ;
// puts("end docalls");
}
void CreatParamDestr ( idrec * ptrs )
{
if ( am32 = = FALSE ) {
structadr . rm = rm_d16 ;
structadr . sib = CODE16 ;
}
else {
structadr . rm = rm_d32 ;
structadr . sib = CODE32 ;
}
structadr . segm = DS ;
structadr . number = ptrs - > recnumber ;
structadr . flag = 0 ;
structadr . size = 0 ; //addofs
structadr . rec = NULL ;
structadr . type = tp_ucnovn ;
structadr . npointr = 0 ;
structadr . post = ptrs - > recpost ;
if ( ptrs - > recsegm = = USEDSTR ) structadr . sib + + ;
if ( structadr . post = = LOCAL ) {
if ( ESPloc & & am32 ) {
structadr . rm = rm_mod10 | rm_sib ;
structadr . sib = 0x24 ;
structadr . number + = addESP ;
}
else {
structadr . rm = rm_mod10 | ( am32 = = FALSE ? rm_BP : rm_EBP ) ;
}
structadr . segm = SS ;
compressoffset ( & structadr ) ;
}
}
void CallDestr ( idrec * ptr )
{
int oinptr2 ;
char ocha2 ;
int oldendinptr = endinptr ;
unsigned char odbg ;
int otok , otok2 ;
unsigned char * oinput ;
ITOK oitok ; //18.08.04 19:07
oinptr2 = inptr2 ;
ocha2 = cha2 ;
odbg = dbg ;
dbg = 0 ;
otok = tok ;
otok2 = tok2 ;
oitok = itok ; //18.08.04 19:07
oinput = input ;
string [ 0 ] = 0 ;
if ( ptr - > newid ) strcpy ( ( char * ) string , ptr - > newid ) ;
itok . type = ptr - > type ;
itok . npointr = ptr - > npointr ;
itok . rm = ptr - > recrm ;
itok . flag = ptr - > flag ;
itok . rec = ptr ;
strcpy ( itok . name , ptr - > recid ) ;
itok . number = ptr - > recnumber ;
tok = ptr - > rectok ;
itok . post = ptr - > recpost ;
itok . segm = ptr - > recsegm ;
itok . sib = ptr - > recsib ;
ptr - > count + + ;
if ( itok . segm = = DYNAMIC ) AddDynamicList ( ptr ) ;
tok2 = tk_openbracket ;
input = ( unsigned char * ) " (); " ;
inptr2 = 1 ;
cha2 = ' ( ' ;
endinptr = 3 ;
docommand ( ) ;
tok = otok ;
input = oinput ;
inptr2 = oinptr2 ;
cha2 = ocha2 ;
tok2 = otok2 ;
endinptr = oldendinptr ;
dbg = odbg ;
itok = oitok ; //18.08.04 19:07
}
elementteg * FindOneDestr ( structteg * searcht )
{
elementteg * bazael = searcht - > baza , * retrez = NULL ;
idrec * ptrs ;
int i ;
/// new!
for ( i = 0 ; i < searcht - > numoper ; i + + ) {
ptrs = ( bazael + i ) - > rec ;
if ( ( bazael + i ) - > tok = = tk_proc & & ( ptrs - > flag & fs_destructor ) ! = 0 ) return ( bazael + i ) ;
}
for ( i = 0 ; i < searcht - > numoper ; i + + ) {
ptrs = ( bazael + i ) - > rec ;
if ( ( bazael + i ) - > tok = = tk_baseclass
| | ( bazael + i ) - > tok = = tk_struct //new 20.06.05 21:32
) {
if ( ( retrez = FindOneDestr ( ( structteg * ) ptrs ) ) ! = NULL ) break ;
}
}
return retrez ;
}
void Destructor ( idrec * ptrs )
{
char name [ IDLENGTH ] ;
struct elementteg * bazael ;
int addofs ;
structteg * tteg ;
tteg = ( structteg * ) ptrs - > newid ;
sprintf ( name , " %s~ " , tteg - > name ) ;
if ( ( bazael = FindClassEl ( tteg , ( unsigned char * ) name , & addofs , NULL ) ) = = NULL ) {
if ( ( bazael = FindOneDestr ( tteg ) ) = = NULL ) preerror ( " destructor not defined " ) ;
}
if ( ptrs - > recsize ) CreatParamDestr ( ptrs ) ;
else structadr . sib = THIS_ZEROSIZE ;
CallDestr ( bazael - > rec ) ;
}
void RunNew ( int size )
{
char buf [ 128 ] ;
int oinptr2 ;
char ocha2 ;
int oldendinptr = endinptr ;
unsigned char odbg ;
int otok , otok2 ;
unsigned char * oinput ;
oinptr2 = inptr2 ;
ocha2 = cha2 ;
odbg = dbg ;
sprintf ( buf , " __new(%u);} " , size ) ;
dbg = 0 ;
otok = tok ;
otok2 = tok2 ;
oinput = input ;
input = ( unsigned char * ) buf ;
inptr2 = 1 ;
cha2 = ' _ ' ;
tok = tk_openbrace ;
endinptr = strlen ( buf ) ;
doblock ( ) ;
tok = otok ;
tok2 = otok2 ;
input = oinput ;
inptr2 = oinptr2 ;
cha2 = ocha2 ;
endinptr = oldendinptr ;
dbg = odbg ;
}
void donew ( )
{
structteg * tteg ;
elementteg * bazael ;
int addofs = 0 ;
struct idrec * ptr ;
nexttok ( ) ;
if ( ( tteg = FindTeg ( FALSE ) ) = = NULL & & ( tteg = FindTeg ( TRUE ) ) = = NULL ) {
tegnotfound ( ) ;
er :
while ( tok2 ! = tk_semicolon & & tok ! = tk_eof ) nexttok ( ) ;
return ;
}
// printf("flag=%08X\n",tteg->flag);
if ( ( tteg - > flag & fs_constructor ) = = 0 ) {
RunNew ( tteg - > size ) ;
goto er ;
}
bazael = FindClassEl ( tteg , ( unsigned char * ) tteg - > name , & addofs , NULL ) ;
structadr . sib = THIS_NEW ;
structadr . number = tteg - > size ;
ptr = bazael - > rec ;
string [ 0 ] = 0 ;
if ( ptr - > newid ! = NULL ) strcpy ( ( char * ) string , ptr - > newid ) ;
itok . type = ptr - > type ;
itok . npointr = ptr - > npointr ;
itok . rm = ptr - > recrm ;
itok . flag = ptr - > flag ;
itok . rec = ptr ;
strcpy ( itok . name , ptr - > recid ) ;
itok . number = ptr - > recnumber ;
tok = ptr - > rectok ;
itok . post = ptr - > recpost ;
itok . segm = ptr - > recsegm ;
itok . sib = ptr - > recsib ;
ptr - > count + + ;
if ( itok . segm = = DYNAMIC ) AddDynamicList ( ptr ) ;
// docommand();
if ( dbg ) AddLine ( ) ;
int oflag = current_proc_type ;
current_proc_type & = ~ f_static ;
if ( tok = = tk_proc ) doanyproc ( ) ;
else doanyundefproc ( ) ;
current_proc_type = oflag ;
}
void dodelete ( )
{
int addofs = 0 ;
int oinptr , oinptr2 ;
char ocha2 ;
int oldendinptr = endinptr ;
unsigned char odbg ;
unsigned char * oinput ;
structteg * tteg = NULL ;
elementteg * bazael ;
char buf [ 128 ] ;
getoperand ( ) ;
if ( tok = = tk_structvar ) {
oinptr = tok2 ;
// if((itok.flag&fs_useconstr)!=0){
if ( ( itok . flag & fs_destructor ) ! = 0 ) {
Destructor ( itok . rec ) ;
}
else if ( itok . rec - > newid & & AskUseDestr ( ( structteg * ) itok . rec - > newid ) ) Destructor ( itok . rec ) ;
// }
if ( oinptr ! = tk_semicolon ) nexttok ( ) ;
}
else {
ITOK wtok ;
char * wbuf ;
wbuf = bufrm ;
bufrm = NULL ;
wtok = itok ;
SINFO wstr ;
wstr = strinf ;
strinf . bufstr = NULL ;
getinto_e_ax ( 0 , tok , & wtok , wbuf , & wstr , ( am32 + 1 ) * 2 ) ;
bufrm = NULL ;
strinf . bufstr = NULL ;
if ( tok2 ! = tk_semicolon ) {
nexttok ( ) ;
if ( ( tteg = FindTeg ( FALSE ) ) = = NULL & & ( tteg = FindTeg ( TRUE ) ) = = NULL ) {
tegnotfound ( ) ;
while ( tok ! = tk_semicolon & & tok ! = tk_eof ) nexttok ( ) ;
return ;
}
}
oinptr2 = inptr2 ;
ocha2 = cha2 ;
odbg = dbg ;
dbg = 0 ;
oinput = input ;
int oflag = current_proc_type ;
current_proc_type & = ~ f_static ;
if ( tteg ) {
structadr . number = 0 ;
if ( ( tteg - > flag & fs_destructor ) ! = 0 ) {
op ( 0x50 ) ;
addESP + = am32 = = FALSE ? 2 : 4 ;
sprintf ( buf , " %s~ " , tteg - > name ) ;
bazael = FindClassEl ( tteg , ( unsigned char * ) buf , & addofs , NULL ) ;
structadr . sib = THIS_REG ;
structadr . rm = AX ;
structadr . size = addofs ; // ???? 19.08.04 12:54 <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <20> ᯮ<EFBFBD> <E1AFAE> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD>
CallDestr ( bazael - > rec ) ;
addESP - = am32 = = FALSE ? 2 : 4 ;
op ( 0x58 ) ;
}
else if ( AskUseDestr ( tteg ) ) {
bazael = FindOneDestr ( tteg ) ;
op ( 0x50 ) ;
addESP + = am32 = = FALSE ? 2 : 4 ;
structadr . sib = THIS_REG ;
structadr . rm = AX ;
structadr . size = 0 ; //addofs;
CallDestr ( bazael - > rec ) ;
addESP - = am32 = = FALSE ? 2 : 4 ;
op ( 0x58 ) ;
}
}
input = ( unsigned char * ) " __delete((E)AX);} " ;
inptr2 = 1 ;
cha2 = ' _ ' ;
endinptr = strlen ( ( char * ) input ) ;
tok = tk_openbrace ;
doblock ( ) ;
input = oinput ;
inptr2 = oinptr2 ;
cha2 = ocha2 ;
endinptr = oldendinptr ;
dbg = odbg ;
current_proc_type = oflag ;
}
nextseminext ( ) ;
}
int AskUseDestr ( structteg * searcht )
{
elementteg * bazael = searcht - > baza ;
if ( ( searcht - > flag & fs_destructor ) ! = 0 ) return TRUE ;
for ( int i = 0 ; i < searcht - > numoper ; i + + ) {
// printf("tok=%d\n",(bazael+i)->tok);
if ( ( bazael + i ) - > tok = = tk_baseclass
| | ( bazael + i ) - > tok = = tk_struct //new 20.06.05 21:33
) {
if ( AskUseDestr ( ( structteg * ) ( bazael + i ) - > rec ) ) return TRUE ;
}
}
return FALSE ;
}
void AutoDestructor ( )
{
struct localrec * ptrs ;
int calldestruct = FALSE ;
int zerosize = FALSE ;
treelocalrec * ftlr ;
for ( ftlr = tlr ; ftlr ! = NULL ; ftlr = ftlr - > next ) {
for ( ptrs = ftlr - > lrec ; ptrs ! = NULL ; ptrs = ptrs - > rec . next ) {
if ( ptrs - > rec . rectok = = tk_structvar ) {
if ( ( ptrs - > rec . flag & fs_destructor ) ! = 0 | | AskUseDestr ( ( structteg * ) ptrs - > rec . newid ) ) {
if ( ! calldestruct ) {
calldestruct = TRUE ;
if ( ptrs - > rec . recsize = = 0 | | returntype = = tk_void ) zerosize = TRUE ;
else {
op66 ( r32 ) ;
op ( 0x50 ) ;
addESP + = 4 ;
}
}
Destructor ( & ptrs - > rec ) ;
}
}
}
}
if ( calldestruct & & zerosize = = FALSE ) {
op66 ( r32 ) ;
op ( 0x58 ) ;
addESP - = 4 ;
}
}
elementteg * FindClassEl ( structteg * searcht , unsigned char * string4 , int * addofs ,
structteg * subteg )
{
struct elementteg * bazael = searcht - > baza ;
int numclass = 0 ;
void * * listclass ;
//11.08.04 22:54
char name [ IDLENGTH ] ;
strcpy ( name , searcht - > name ) ;
for ( unsigned int i = 0 ; i < searcht - > numoper ; i + + ) {
if ( ( bazael + i ) - > tok = = tk_baseclass ) {
if ( ! numclass ) listclass = ( void * * ) MALLOC ( sizeof ( void * * ) ) ;
else listclass = ( void * * ) REALLOC ( listclass , sizeof ( void * * ) * ( numclass + 1 ) ) ;
listclass [ numclass ] = ( void * ) ( bazael + i ) - > nteg ;
numclass + + ;
continue ;
}
if ( strcmp ( ( bazael + i ) - > name , ( char * ) string4 ) = = 0 ) {
if ( subteg & & subteg ! = searcht ) continue ;
if ( numclass ) free ( listclass ) ;
//11.08.04 22:54
strcpy ( ( char * ) string4 , name ) ;
return ( bazael + i ) ;
}
}
if ( numclass ) {
structteg * ssubteg = subteg ;
for ( int i = numclass - 1 ; i > = 0 ; i - - ) {
structteg * s = ( structteg * ) listclass [ i ] ;
if ( subteg = = searcht ) ssubteg = s ;
if ( ( bazael = FindClassEl ( s , string4 , addofs , ssubteg ) ) ! = NULL ) {
i - - ;
while ( i > = 0 ) {
s = ( structteg * ) listclass [ i ] ;
* addofs + = s - > size ;
i - - ;
}
free ( listclass ) ;
return bazael ;
}
}
free ( listclass ) ;
}
return NULL ;
}
int CallDestructor ( structteg * searcht )
{
elementteg * bazael = searcht - > baza ;
idrec * ptrs ;
for ( int i = 0 ; i < searcht - > numoper ; i + + ) {
ptrs = ( bazael + i ) - > rec ;
if ( ( searcht - > flag & fs_destructor ) = = 0 ) {
if ( ( bazael + i ) - > tok = = tk_baseclass ) {
if ( CallDestructor ( ( structteg * ) ptrs ) ) return TRUE ;
}
}
else if ( ( bazael + i ) - > tok = = tk_proc & & ( ptrs - > flag & fs_destructor ) ! = 0 ) {
structadr . sib = THIS_PARAM ;
structadr . number = 0 ; //addofs;
CallDestr ( ptrs ) ;
return TRUE ;
}
}
return FALSE ;
}
void CopyTok ( int * tok4 , ITOK * itok4 , idrec * ptr )
{
itok4 - > number = ptr - > recnumber ;
itok4 - > rm = ptr - > recrm ;
* tok4 = ptr - > rectok ;
itok4 - > post = ptr - > recpost ;
itok4 - > segm = ptr - > recsegm ;
itok4 - > flag = ptr - > flag ;
itok4 - > size = ptr - > recsize ;
itok4 - > sib = ptr - > recsib ;
itok4 - > rec = ptr ;
itok4 - > type = ptr - > type ;
itok4 - > npointr = ptr - > npointr ;
}
int searchlocals ( ITOK * itok4 , int * tok4 , unsigned char * string4 )
//<2F> <> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> ६<EFBFBD> <E0A5AC> <EFBFBD> <EFBFBD> <20> <> 易<EFBFBD> <EFA7A0> <EFBFBD> <EFBFBD> ᯨ᪠
{
if ( skiplocals ) {
skiplocals = FALSE ;
return FALSE ;
}
if ( skipfind = = LOCAL ) return FALSE ;
treelocalrec * ftlr ;
struct localrec * ptr ;
for ( ftlr = tlr ; ftlr ! = NULL ; ftlr = ftlr - > next ) {
for ( ptr = ftlr - > lrec ; ptr ! = NULL ; ptr = ptr - > rec . next ) {
// puts(ptr->rec.recid);
if ( strcmp ( ptr - > rec . recid , ( char * ) string4 ) = = 0 ) {
itok4 - > number = ptr - > rec . recnumber ;
* tok4 = ptr - > rec . rectok ;
itok4 - > locrec = ptr ;
if ( displaytokerrors ) {
if ( mapfile ) {
if ( ptr - > li . count = = 0 ) ptr - > li . usedfirst = linenumber ;
else ptr - > li . usedlast = linenumber ;
ptr - > li . count + + ;
}
if ( * tok4 = = tk_structvar ) ptr - > rec . count + + ;
}
// printf("type=%d num=%08X %s\n",ptr->rec.type,ptr->rec.recnumber,ptr->rec.recid);
if ( ptr - > rec . type = = tp_postvar ) {
itok4 - > segm = DS ;
itok4 - > flag = ptr - > rec . flag ;
itok4 - > size = ptr - > rec . recsize ;
itok4 - > rm = ( am32 = = FALSE ? rm_d16 : rm_d32 ) ;
itok4 - > npointr = ptr - > rec . npointr ;
itok4 - > type = tp_localvar ;
itok4 - > post = 1 ;
if ( * tok4 = = tk_structvar ) {
itok4 - > rec = & ptr - > rec ;
itok4 - > post = ptr - > rec . recpost ;
// itok4->segm=0;
}
return TRUE ;
}
if ( ptr - > rec . type = = tp_gvar ) {
itok4 - > number = 0 ;
itok4 - > rm = ( am32 = = FALSE ? rm_d16 : rm_d32 ) ;
itok4 - > segm = DS ;
itok4 - > size = ptr - > rec . recsize ;
itok4 - > npointr = ptr - > rec . npointr ;
itok4 - > type = ptr - > rec . recsib ; //????01.09.05 15:58
itok4 - > post = USED_DIN_VAR ;
if ( ptr - > rec . recpost = = DYNAMIC_VAR ) ptr - > rec . recpost = USED_DIN_VAR ;
itok4 - > rec = & ptr - > rec ;
ptr - > fuse = USEDVAR ;
if ( * tok4 = = tk_structvar ) {
itok4 - > number = ptr - > rec . recnumber ;
itok4 - > flag | = ptr - > rec . flag ;
}
return TRUE ;
}
itok4 - > type = ptr - > rec . type ;
if ( ptr - > rec . type = = tp_paramvar | | ptr - > rec . type = = tp_localvar ) {
if ( ESPloc & & am32 ) {
itok4 - > rm = rm_mod10 | rm_sib ;
itok4 - > sib = 0x24 ;
if ( ptr - > rec . type = = tp_paramvar ) itok4 - > number + = localsize + addESP ;
else itok4 - > number + = - 4 + addESP ;
}
else itok4 - > rm = rm_mod10 | ( am32 = = FALSE ? rm_BP : rm_EBP ) ;
itok4 - > segm = SS ;
itok4 - > npointr = ptr - > rec . npointr ;
if ( ptr - > rec . npointr ) {
itok4 - > type = ( unsigned short ) * tok4 - tk_charvar + tk_char ;
* tok4 = tk_pointer ;
}
if ( * tok4 = = tk_structvar ) {
itok4 - > rec = & ptr - > rec ;
itok4 - > post = ptr - > rec . recpost ;
itok4 - > segm = 0 ;
}
}
else if ( ! ( ptr - > rec . rectok = = tk_locallabel | | ptr - > rec . rectok = = tk_number ) ) {
internalerror ( " Bad *tok4 value in searchlocals " ) ;
}
itok4 - > size = ptr - > rec . recsize ;
itok4 - > flag = ptr - > rec . flag ;
return TRUE ;
}
}
}
if ( searchteg ) {
struct elementteg * bazael ;
int addofs = 0 ;
structteg * subteg = NULL ;
if ( cha = = ' : ' & & cha2 = = ' : ' ) {
nextchar ( ) ;
nextchar ( ) ;
if ( ( subteg = FindTeg ( TRUE , itok4 - > name ) ) = = NULL & & displaytokerrors ) undefclass ( itok4 - > name ) ;
tokscan ( tok4 , itok4 , string4 ) ;
whitespace ( ) ;
}
if ( destructor ) {
destructor = FALSE ;
strcat ( ( char * ) string4 , " ~ " ) ;
}
if ( ( bazael = FindClassEl ( searchteg , string4 , & addofs , subteg ) ) ! = NULL ) {
* tok4 = bazael - > tok ;
itok4 - > type = tp_classvar ;
// printf("tok=%d bazael->rec=%08X %s\n",*tok4,bazael->rec,itok4->name);
if ( * tok4 = = tk_proc | | * tok4 = = tk_pointer ) {
idrec * ptr = bazael - > rec ;
if ( strchr ( itok4 - > name , ' @ ' ) = = NULL ) {
strcat ( itok4 - > name , " @ " ) ;
strcat ( itok4 - > name , ( char * ) string4 ) ;
}
// }
// printf("tok=%d %s %s\n",*tok4,ptr->recid,ptr->newid);
if ( * tok4 = = tk_proc & & ptr - > newid ! = NULL ) strcpy ( ( char * ) string4 , ptr - > newid ) ;
CopyTok ( tok4 , itok4 , bazael - > rec ) ;
structadr . sib = THIS_PARAM ;
structadr . number = 0 ; //addofs;
if ( displaytokerrors ) {
ptr - > count + + ;
if ( * tok4 = = tk_proc ) {
if ( itok4 - > segm = = DYNAMIC ) AddDynamicList ( ptr ) ;
}
}
if ( * tok4 = = tk_pointer ) goto locvar ;
}
else if ( * tok4 = = tk_struct ) {
* tok4 = tk_structvar ;
// printf("teg=%08X\n",bazael->nteg);
dostructvar2 ( tok4 , itok4 , ( structteg * ) bazael - > nteg , string4 ) ;
if ( * tok4 = = tk_structvar ) {
itok4 - > rec = ( idrec * ) bazael - > nteg ;
itok4 - > number + = ( itok4 - > post = = 0 ? 0 : itok4 - > rm * ( ( structteg * ) bazael - > nteg ) - > size ) ;
itok4 - > size = ( itok4 - > post = = 0 ? bazael - > numel : 1 ) * ( ( structteg * ) bazael - > nteg ) - > size ;
itok4 - > number + = bazael - > ofs + addofs ;
if ( displaytokerrors ) {
if ( strinf . bufstr ! = NULL ) free ( strinf . bufstr ) ;
strinf . bufstr = ( char * ) MALLOC ( 7 ) ;
strcpy ( strinf . bufstr , " &this; " ) ;
strinf . size = 1 ;
}
// itok4->flag|=f_useidx;
// if(itok4->sib>=CODE16)itok4->sib++;
return TRUE ;
}
else if ( * tok4 = = tk_proc ) {
structadr . sib = THIS_PARAM ;
structadr . number + = bazael - > ofs + addofs ;
if ( itok4 - > sib > = CODE16 ) itok4 - > sib + + ;
return TRUE ;
}
goto locvar ; ;
}
else {
if ( bazael - > rec ) { //static var
CopyTok ( tok4 , itok4 , bazael - > rec ) ;
return TRUE ;
}
locvar :
itok4 - > number + = bazael - > ofs + addofs ;
if ( displaytokerrors ) {
if ( bufrm ! = NULL ) free ( bufrm ) ;
bufrm = ( char * ) MALLOC ( 7 ) ;
strcpy ( bufrm , " &this; " ) ;
}
// itok4->flag|=f_useidx;
if ( itok4 - > sib > = CODE16 ) itok4 - > sib + + ;
// printf("sib=%08X tok=%d rm=%d post=%d number=%d size=%d %s\n",itok4->sib,*tok4,itok4->rm,itok4->post,itok4->number,itok4->size,string4);
}
return TRUE ;
}
}
return FALSE ;
}
void dostructvar2 ( int * tok4 , ITOK * itok4 , struct structteg * tteg , unsigned char * string4 ) //ࠧ<> <E0A0A7> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <20> <> ६<EFBFBD> <E0A5AC> <EFBFBD> <EFBFBD> <EFBFBD> <20> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD>
{
struct elementteg * bazael ;
int numel = 0 ;
int usenumstruct = FALSE ;
int sopenb ;
long cnum ;
ITOK cstok ;
char * cstring ;
char c = 0 ;
int i ;
structteg * subteg = NULL ;
structadr = * itok4 ;
// bazael=tteg->baza;
whitespace ( ) ; //<2F> ய<EFBFBD> <E0AEAF> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> ᨬ<> <E1A8AC> <EFBFBD> <EFBFBD> <EFBFBD>
cstring = ( char * ) MALLOC ( STRLEN ) ;
if ( cha = = ' [ ' ) { //[ <09> <> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD>
usenumstruct = TRUE ;
nextchar ( ) ;
sopenb = inptr ;
unsigned char bcha = cha ;
tokscan ( & i , & cstok , ( unsigned char * ) cstring ) ;
if ( bufrm ) {
free ( bufrm ) ;
bufrm = NULL ;
}
if ( i = = tk_number ) { //<2F> <> <EFBFBD> <E1ABAE> <EFBFBD>
ITOK dstok ;
memcpy ( & dstok , itok4 , sizeof ( ITOK ) ) ;
calcnum ( & i , & cstok , cstring , & cnum ) ;
memcpy ( itok4 , & dstok , sizeof ( ITOK ) ) ;
if ( i ! = tk_closeblock ) goto notnum ;
numel = cnum ;
}
else {
notnum :
//new!!!
if ( displaytokerrors ) {
if ( itok4 - > segm = = USEDSTR ) preerror ( " only once possible use variable an index structure " ) ;
// if(itok4->segm==USEDSTR&&displaytokerrors)preerror("only once possible use variable an index structure");
itok4 - > segm = USEDSTR ;
SRBackBuf ( 0 ) ;
AddBackBuf ( sopenb , bcha ) ;
CharToBackBuf ( ' ; ' ) ;
CharToBackBuf ( 0 ) ;
if ( cha ! = ' ] ' ) blockerror ( ) ;
if ( strinf . bufstr ! = NULL ) free ( strinf . bufstr ) ; //internalerror("Previous block was not used");
strinf . bufstr = ( char * ) REALLOC ( BackTextBlock , SizeBackBuf + 1 ) ;
SRBackBuf ( 1 ) ;
nextchar ( ) ;
//new!!!
}
else {
do {
tokscan ( & i , & cstok , ( unsigned char * ) cstring ) ;
if ( i = = tk_eof ) break ;
} while ( i ! = tk_closeblock ) ;
}
c = 1 ;
strinf . size = tteg - > size ;
}
itok4 - > flag | = f_useidx ;
whitespace ( ) ; //<2F> ய<EFBFBD> <E0AEAF> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> ᨬ<> <E1A8AC> <EFBFBD> <EFBFBD> <EFBFBD>
}
if ( cha = = ' . ' ) {
int fdestr = FALSE ;
nextchar ( ) ;
if ( cha = = ' ~ ' ) {
nextchar ( ) ;
fdestr = TRUE ;
}
skipfind = LOCAL ;
do {
tokscan ( & i , & cstok , ( unsigned char * ) cstring ) ;
// puts(cstok.name);
if ( cha = = ' . ' ) searchtree2 ( definestart , & cstok , & i , ( unsigned char * ) cstring ) ;
} while ( i = = tk_endline ) ;
whitespace ( ) ;
if ( cha = = ' : ' ) {
nextchar ( ) ;
if ( cha ! = ' : ' ) expectederror ( " :: " ) ;
nextchar ( ) ;
if ( ( subteg = FindTeg ( TRUE , cstok . name ) ) = = NULL & & displaytokerrors ) undefclass ( cstok . name ) ;
tokscan ( & i , & cstok , ( unsigned char * ) cstring ) ;
whitespace ( ) ;
}
skipfind = FALSE ;
int addofs = 0 ;
if ( fdestr ) strcat ( cstok . name , " ~ " ) ;
if ( ( bazael = FindClassEl ( tteg , ( unsigned char * ) cstok . name , & addofs , subteg ) ) = = NULL ) {
if ( displaytokerrors ) unknownstruct ( cstok . name , tteg - > name ) ;
* tok4 = tk_number ;
free ( cstring ) ;
return ;
}
free ( cstring ) ;
* tok4 = bazael - > tok ;
itok4 - > size = bazael - > numel * GetVarSize ( * tok4 ) ;
cnum = ( c = = 0 ? tteg - > size * numel : 0 ) ;
if ( ( itok4 - > flag & f_extern ) ! = 0 ) itok4 - > number + = ( ( bazael - > ofs + cnum ) < < 16 ) ;
else itok4 - > number + = bazael - > ofs + cnum ;
if ( * tok4 = = tk_struct ) {
* tok4 = tk_structvar ;
itok4 - > size = bazael - > numel * ( ( structteg * ) bazael - > nteg ) - > size ;
dostructvar2 ( tok4 , itok4 , ( structteg * ) bazael - > nteg , string4 ) ;
return ;
}
if ( ( itok4 - > flag & f_extern ) ! = 0 ) itok4 - > number + = addofs < < 16 ;
else itok4 - > number + = addofs ;
// printf("tok=%d %s\n",*tok4,bufrm);
if ( * tok4 = = tk_proc | | * tok4 = = tk_pointer ) {
idrec * ptr ; //=NULL;
if ( * tok4 = = tk_proc ) {
if ( am32 = = FALSE ) {
structadr . rm = rm_d16 ;
structadr . sib = CODE16 ;
}
else {
structadr . rm = rm_d32 ;
structadr . sib = CODE32 ;
}
structadr . segm = DS ;
structadr . number = itok4 - > number ;
// structadr.number=0;
structadr . flag = 0 ;
structadr . size = addofs ;
structadr . type = tp_ucnovn ;
structadr . npointr = 0 ;
structadr . post = itok4 - > post ;
structadr . rec = ( structadr . post = = USED_DIN_VAR ? itok4 - > rec : NULL ) ;
if ( itok4 - > segm = = USEDSTR ) structadr . sib + + ;
if ( structadr . post = = LOCAL ) {
if ( ESPloc & & am32 ) {
structadr . rm = rm_mod10 | rm_sib ;
structadr . sib = 0x24 ; //???
structadr . number + = addESP ;
}
else {
structadr . rm = rm_mod10 | ( am32 = = FALSE ? rm_BP : rm_EBP ) ;
}
structadr . segm = SS ;
compressoffset ( & structadr ) ;
if ( tteg - > size = = 0 ) structadr . sib = THIS_ZEROSIZE ; //14.11.05 13:51
}
/* if(strcmp(bazael->name,tteg->name)==0&&itok4->rec){ //<2F> 맮<EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD>
ptr = itok4 - > rec ;
// printf("constructor %08X\n",ptr);
} */
}
// if(ptr)printf("new address constructor %08X\n",bazael->rec);
ptr = bazael - > rec ;
itok4 - > type = ptr - > type ;
itok4 - > npointr = ptr - > npointr ;
itok4 - > rm = ptr - > recrm ;
itok4 - > flag = ptr - > flag ;
itok4 - > rec = ptr ;
strcpy ( itok4 - > name , ptr - > recid ) ;
if ( * tok4 = = tk_pointer ) {
// puts("Check this code");
string4 [ 0 ] = 0 ;
if ( ptr - > newid ! = NULL ) strcpy ( ( char * ) string4 , ptr - > newid ) ;
* tok4 = ptr - > rectok ;
//!!!
if ( itok4 - > type = = tk_proc & & cha ! = ' ( ' ) {
itok4 - > type = ( am32 = = FALSE ? tk_wordvar : tk_dwordvar ) ;
goto notbit ;
}
if ( itok4 - > type ! = tk_proc ) goto notbit ;
// printf("post=%08X %s\n",itok4->post,itok4->name);
if ( itok4 - > post = = LOCAL ) {
if ( ESPloc & & am32 ) {
itok4 - > rm = rm_mod10 | rm_sib ;
itok4 - > sib = 0x24 ;
itok4 - > number + = addESP ;
}
else {
itok4 - > sib = rm_mod10 | ( am32 = = FALSE ? rm_BP : rm_EBP ) ; //???rm
}
itok4 - > segm = SS ;
itok4 - > post = FALSE ;
}
else {
itok4 - > sib = ( am32 = = FALSE ? rm_d16 : rm_d32 ) ; //<2F> <> ⠭<EFBFBD> <E2A0AD> <EFBFBD> <EFBFBD> <20> <> 㬮<> 砭<EFBFBD> <E7A0AD>
itok4 - > segm = DS ;
}
// itok4->post=0;
itok4 - > flag | = f_useidx ;
return ;
}
itok4 - > number = ptr - > recnumber ;
* tok4 = ptr - > rectok ;
itok4 - > post = ptr - > recpost ;
itok4 - > segm = ptr - > recsegm ;
itok4 - > sib = ptr - > recsib ;
itok4 - > size = ptr - > recsize ; //11.08.04 00:24
//11.09.04 00:28
if ( strchr ( itok4 - > name , ' @ ' ) = = NULL ) {
strcat ( itok4 - > name , " @ " ) ;
strcat ( itok4 - > name , ( char * ) string4 ) ;
}
string4 [ 0 ] = 0 ;
if ( ptr - > newid ! = NULL ) strcpy ( ( char * ) string4 , ptr - > newid ) ;
////////////////////
// printf("tok=%d num=%d %s\n",*tok4,itok4->number,itok4->name);
if ( displaytokerrors ) {
ptr - > count + + ;
if ( * tok4 = = tk_proc & & itok4 - > segm = = DYNAMIC ) AddDynamicList ( ptr ) ;
if ( * tok4 ! = tk_proc & & * tok4 ! = tk_undefproc & & * tok4 ! = tk_declare ) thisundefined ( ptr - > recid , FALSE ) ;
}
return ;
}
// if((itok4->flag&f_extern)!=0)itok4->number+=addofs;
// else itok4->number+=addofs;
if ( * tok4 = = tk_bits ) {
itok4 - > flag | = f_useidx ;
itok4 - > number + = bazael - > bit . ofs / 8 ;
if ( ( bazael - > bit . ofs % 8 ) = = 0 ) {
switch ( bazael - > bit . siz ) {
case 8 :
* tok4 = tk_bytevar ;
goto notbit ;
case 16 :
* tok4 = tk_wordvar ;
goto notbit ;
case 32 :
* tok4 = tk_dwordvar ;
goto notbit ;
}
}
itok4 - > bit . siz = bazael - > bit . siz ;
itok4 - > bit . ofs = bazael - > bit . ofs % 8 ;
}
else if ( bazael - > rec ) { //static var
CopyTok ( tok4 , itok4 , bazael - > rec ) ;
return ;
}
notbit :
itok4 - > sib = cstok . sib ;
if ( itok4 - > post = = LOCAL ) {
if ( ESPloc & & am32 ) {
itok4 - > rm = rm_mod10 | rm_sib ;
// printf("sib=%x tok=%d name=%s\n",itok4->sib,*tok4,itok4->name);
itok4 - > sib = 0x24 ;
itok4 - > number + = addESP ;
}
else {
itok4 - > rm = rm_mod10 | ( am32 = = FALSE ? rm_BP : rm_EBP ) ;
if ( itok4 - > segm = = USEDSTR & & itok4 - > sib > = CODE16 ) itok4 - > sib + + ;
}
itok4 - > segm = SS ;
itok4 - > post = FALSE ;
itok4 - > flag = f_useidx ;
}
else {
itok4 - > rm = ( am32 = = FALSE ? rm_d16 : rm_d32 ) ; //<2F> <> ⠭<EFBFBD> <E2A0AD> <EFBFBD> <EFBFBD> <20> <> 㬮<> 砭<EFBFBD> <E7A0AD>
if ( itok4 - > segm = = USEDSTR & & itok4 - > sib > = CODE16 ) itok4 - > sib + + ;
itok4 - > segm = DS ;
itok4 - > flag = FixUp | f_useidx ;
}
return ;
}
// itok4->size=(numel==0?bazael->numel:1)*((structteg *)bazael->nteg)->size;
// itok4->rec=(idrec *)tteg;
itok4 - > rm = numel ;
itok4 - > post = usenumstruct ;
free ( cstring ) ;
}
void dosizeof ( ITOK * itok4 ) //<2F> <> <EFBFBD> <20> <> <EFBFBD> 祭<EFBFBD> <E7A5AD> sizeof
{
struct structteg * tteg ;
int i , brase = FALSE ;
ITOK cstok ;
whitespace ( ) ; //<2F> ய<EFBFBD> <E0AEAF> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> ᨬ<> <E1A8AC> <EFBFBD> <EFBFBD> <EFBFBD>
itok4 - > number = 0 ;
if ( cha = = ' ( ' ) {
nextchar ( ) ;
brase = TRUE ;
}
// if((cha!='(')&&(displaytokerrors))expected('(');
// nextchar();
cstok . name [ 0 ] = 0 ;
// if(displaytokerrors)puts("start sizeof");
tokscan ( & i , & cstok , string2 ) ;
// if(displaytokerrors)printf("tok=%d findoffset=%d %s\n",i,findofset,cstok.name);
if ( i = = tk_dblcolon & & numblocks ) {
skiplocals = TRUE ;
tokscan ( & i , & cstok , string2 ) ;
}
if ( strcmp ( cstok . name , " __CODESIZE " ) = = 0 ) {
itok4 - > post = CODE_SIZE + am32 ;
}
else if ( strcmp ( cstok . name , " __DATASIZE " ) = = 0 ) {
itok4 - > post = DATA_SIZE + am32 ;
}
else if ( strcmp ( cstok . name , " __POSTSIZE " ) = = 0 ) {
itok4 - > post = POST_SIZE + am32 ;
}
else if ( strcmp ( cstok . name , " __STACKSIZE " ) = = 0 ) {
itok4 - > post = STACK_SIZE + am32 ;
}
else {
switch ( i ) {
case tk_char :
case tk_byte :
case tk_beg :
itok4 - > number = 1 ;
break ;
case tk_int :
case tk_word :
case tk_reg :
case tk_seg :
itok4 - > number = 2 ;
break ;
case tk_float :
case tk_reg32 :
case tk_long :
case tk_dword :
itok4 - > number = 4 ;
break ;
case tk_double :
case tk_qword :
itok4 - > number = 8 ;
break ;
case tk_string :
itok4 - > number = cstok . number ;
if ( /*itok4->*/ cstok . flag ! = no_term ) itok4 - > number + + ;
break ;
case tk_bits :
itok4 - > number = cstok . bit . siz ;
break ;
case tk_proc :
case tk_charvar :
case tk_bytevar :
case tk_intvar :
case tk_wordvar :
case tk_longvar :
case tk_dwordvar :
case tk_floatvar :
case tk_structvar :
case tk_qwordvar :
case tk_doublevar :
case tk_interruptproc :
if ( cstok . size = = 0 ) if ( displaytokerrors ) preerror ( " unknown size " ) ;
itok4 - > number = cstok . size ;
break ;
default :
if ( ( tteg = FindTeg ( FALSE , cstok . name ) ) ! = NULL | | ( tteg = FindTeg ( TRUE , cstok . name ) ) ! = NULL ) {
if ( cha = = ' . ' ) {
dostructvar2 ( & i , itok4 , tteg , string2 ) ;
itok4 - > number = itok4 - > size ;
if ( bufrm ) {
free ( bufrm ) ;
bufrm = NULL ;
}
}
else itok4 - > number = tteg - > size ;
itok4 - > flag = 0 ;
break ;
}
if ( strcmp ( " file " , ( char * ) string2 ) = = 0 ) {
displaytokerrors = 1 ;
tokscan ( & i , & cstok , string2 ) ;
if ( i = = tk_string ) {
struct stat statbuf ;
if ( stat ( ( char * ) string3 , & statbuf ) ! = 0 ) unableopenfile ( ( char * ) string3 ) ;
else itok4 - > number = statbuf . st_size ;
}
else stringexpected ( ) ;
}
else if ( displaytokerrors ) preerror ( " illegal use of sizeof " ) ;
break ;
}
}
whitespace ( ) ; //<2F> ய<EFBFBD> <E0AEAF> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> ᨬ<> <E1A8AC> <EFBFBD> <EFBFBD> <EFBFBD>
if ( brase ) {
if ( cha ! = ' ) ' & & displaytokerrors ) expected ( ' ) ' ) ;
nextchar ( ) ;
}
}
void ofsstr ( int * tok4 , ITOK * itok4 )
{
struct structteg * tteg ;
int newreg = ( idxregs [ 4 ] = = 255 ? idxregs [ 0 ] : idxregs [ 4 ] ) ; //14.06.06 20:06
int poststr ;
int flagstr ;
if ( itok4 - > type = = tp_classvar ) {
tteg = ( structteg * ) itok4 - > rec ;
poststr = 0 ;
flagstr = f_useidx ;
}
else {
struct idrec * ptrs ;
ptrs = itok4 - > rec ;
tteg = ( structteg * ) ptrs - > newid ;
poststr = ptrs - > recpost ;
flagstr = ptrs - > flag ;
}
if ( tteg = = NULL ) {
if ( displaytokerrors ) {
unknowntagstruct ( itok4 - > name ) ;
}
return ;
}
if ( strinf . bufstr = = NULL & & itok4 - > post = = TRUE ) itok4 - > number + = ( tteg - > size * ( itok4 - > rm ) ) ;
itok4 - > size = tteg - > size ;
itok4 - > sib = ( am32 = = FALSE ? CODE16 : CODE32 ) ;
char ocha = cha ;
int binptr = inptr ;
if ( poststr = = LOCAL ) {
itok4 - > rm = rm_mod10 ;
if ( strinf . bufstr = = NULL ) {
if ( ESPloc & & am32 ) {
itok4 - > rm | = rm_sib ;
itok4 - > sib = 0x24 ;
}
else {
itok4 - > rm | = ( am32 = = FALSE ? rm_BP : rm_EBP ) ;
}
}
else {
if ( displaytokerrors ) {
if ( ( newreg = CheckIDXReg ( strinf . bufstr , strinf . size , idxregs [ 0 ] ) ) ! = NOINREG ) {
if ( newreg = = SKIPREG ) {
newreg = idxregs [ 0 ] ;
}
else {
if ( am32 = = FALSE & & newreg ! = DI ) goto noopt1 ;
waralreadinitreg ( regs [ am32 ] [ idxregs [ 0 ] ] , regs [ am32 ] [ newreg ] ) ;
}
free ( strinf . bufstr ) ;
strinf . bufstr = NULL ;
goto cont1 ;
}
newreg = idxregs [ 0 ] ;
noopt1 :
CheckMassiv ( strinf . bufstr , strinf . size , idxregs [ 0 ] ) ;
cont1 : ;
}
if ( am32 = = FALSE ) itok4 - > rm | = CalcRm16 ( BP , newreg ) ;
else {
itok4 - > sib = ( newreg < < 3 ) + ( ESPloc ? ESP : EBP ) ;
itok4 - > rm = 4 | rm_mod10 ;
}
}
itok4 - > segm = SS ;
if ( ESPloc & & am32 ) itok4 - > number + = addESP ;
// else itok4->number-=localsize;
* tok4 = tk_rmnumber ;
if ( itok4 - > type = = tp_classvar ) itok4 - > flag | = f_useidx ;
itok4 - > post = FALSE ;
compressoffset ( itok4 ) ;
}
else {
itok4 - > post = poststr ;
if ( strinf . bufstr = = NULL ) {
itok4 - > rm = ( am32 = = FALSE ? rm_d16 : rm_d32 ) ; //<2F> <> ⠭<EFBFBD> <E2A0AD> <EFBFBD> <EFBFBD> <20> <> 㬮<> 砭<EFBFBD> <E7A0AD>
if ( itok4 - > post ! = 0 ) * tok4 = tk_postnumber ;
else * tok4 = tk_number ;
}
else {
if ( displaytokerrors ) {
if ( ( newreg = CheckIDXReg ( strinf . bufstr , strinf . size , idxregs [ 0 ] ) ) ! = NOINREG ) {
if ( newreg = = SKIPREG ) {
newreg = idxregs [ 0 ] ;
}
else {
if ( am32 = = FALSE & & newreg ! = DI & & newreg ! = BX ) goto noopt2 ;
waralreadinitreg ( regs [ am32 ] [ idxregs [ 0 ] ] , regs [ am32 ] [ newreg ] ) ;
}
free ( strinf . bufstr ) ;
strinf . bufstr = NULL ;
goto cont2 ;
}
newreg = ( idxregs [ 4 ] = = 255 ? idxregs [ 0 ] : idxregs [ 4 ] ) ; //14.06.06 20:06
noopt2 :
CheckMassiv ( strinf . bufstr , strinf . size , ( idxregs [ 4 ] = = 255 ? idxregs [ 0 ] : idxregs [ 4 ] ) ) ;
cont2 : ;
}
itok4 - > rm = RegToRM ( newreg , ( am32 = = FALSE ? tk_reg : tk_reg32 ) ) | rm_mod10 ;
* tok4 = tk_rmnumber ;
}
itok4 - > segm = DS ;
}
if ( itok4 - > post = = 0 & & ( itok4 - > flag & f_reloc ) = = 0 ) { // cannot compress if POST var
compressoffset ( itok4 ) ;
}
// compressoffset(itok4);
itok4 - > flag | = flagstr ;
inptr = binptr ;
cha = ocha ;
}
void AddUndefOff ( int segm , char * ostring ) //<2F> <> 䨪<EFBFBD> <E4A8AA> <EFBFBD> <E0AEA2> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> 饭<EFBFBD> <E9A5AD> <20> <20> <> <EFBFBD> <20> <> <20> <> <EFBFBD> <EFBFBD> <EFA2AB> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD>
/*segm - ᥣ<> <E1A5A3> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> 㤠 <20> <> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> 饭<EFBFBD> <E9A5AD>
0 - ᥣ <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD>
1 - ᥣ <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD>
2 - ᥣ <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> , <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> ᥭ <EFBFBD> <EFBFBD> <EFBFBD> ⠡ <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> ६ <EFBFBD> 饭 <EFBFBD> <EFBFBD>
3 - ᥣ <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> , <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> ᥭ <EFBFBD> <EFBFBD> <EFBFBD> ⠡ <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> ६ <EFBFBD> 饭 <EFBFBD> <EFBFBD>
*/
{
UNDEFOFF * curptr ;
if ( undefoffstart = = NULL ) { //<2F> <20> <> <EFBFBD> <20> <> <20> 뫮 <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> ⮪
undefoffstart = ( UNDEFOFF * ) MALLOC ( sizeof ( UNDEFOFF ) ) ;
memset ( undefoffstart , 0 , sizeof ( UNDEFOFF ) ) ;
strcpy ( undefoffstart - > name , ostring ) ;
}
for ( curptr = undefoffstart ; ; curptr = curptr - > next ) {
if ( strcmp ( curptr - > name , ostring ) = = 0 ) { //࠭<> <E0A0AD> 㦥 <20> <> <EFBFBD> <EFBFBD> 頫<EFBFBD> <E9A0AB> <EFBFBD> <20> <20> <> <EFBFBD>
//⠡<> <E2A0A1> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> 饭<EFBFBD> <E9A5AD> <20> undef
if ( curptr - > pos = = NULL ) curptr - > pos = ( IOFS * ) MALLOC ( sizeof ( IOFS ) * ( curptr - > num + 1 ) ) ;
else curptr - > pos = ( IOFS * ) REALLOC ( curptr - > pos , sizeof ( IOFS ) * ( curptr - > num + 1 ) ) ;
( curptr - > pos + curptr - > num ) - > ofs = segm = = 0 ? outptr : outptrdata ;
( curptr - > pos + curptr - > num ) - > dataseg = ( unsigned char ) segm ;
( curptr - > pos + curptr - > num ) - > line = linenumber ;
( curptr - > pos + curptr - > num ) - > file = currentfileinfo ;
curptr - > num + + ;
return ;
}
if ( curptr - > next = = NULL ) break ; //<2F> <> <EFBFBD> <EFBFBD> <EFBFBD> ᯨ᪠
}
curptr = curptr - > next = ( UNDEFOFF * ) MALLOC ( sizeof ( UNDEFOFF ) ) ; //<2F> <> <EFBFBD> <EFBFBD> <EFBFBD> undef
memset ( curptr , 0 , sizeof ( UNDEFOFF ) ) ;
strcpy ( curptr - > name , ostring ) ;
curptr - > num = 1 ;
curptr - > pos = ( IOFS * ) MALLOC ( sizeof ( IOFS ) ) ;
curptr - > pos - > ofs = segm = = 0 ? outptr : outptrdata ;
curptr - > pos - > dataseg = ( unsigned char ) segm ;
curptr - > pos - > line = linenumber ;
curptr - > pos - > file = currentfileinfo ;
}
int CheckUseAsUndef ( unsigned char * name )
{
UNDEFOFF * curptr ;
int count = 0 ;
if ( undefoffstart = = NULL ) return 0 ; //<2F> <> <20> 뫮 <20> <> <EFBFBD> <EFBFBD> 饭<EFBFBD> <E9A5AD> <20> undef
for ( curptr = undefoffstart ; ; curptr = curptr - > next ) {
if ( strcmp ( curptr - > name , ( char * ) name ) = = 0 ) { //<2F> <> 諨
count = curptr - > num ;
break ;
}
if ( curptr - > next = = NULL ) break ;
}
return count ;
}
int FindOff ( unsigned char * name , int base ) //<2F> <> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> 뫮<EFBFBD> <20> <> ⥪<> 饥 <20> <> <EFBFBD>
{
/*-----------------13.08.00 23:48-------------------
<EFBFBD> <EFBFBD> <EFBFBD> ᬮ <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> 楤 <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> ࠧ <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD>
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */
UNDEFOFF * curptr , * prev ;
unsigned char segm ;
unsigned int ofs , valofs ;
int count = 0 ;
if ( undefoffstart = = NULL ) return 0 ; //<2F> <> <20> 뫮 <20> <> <EFBFBD> <EFBFBD> 饭<EFBFBD> <E9A5AD> <20> undef
for ( curptr = undefoffstart ; ; curptr = curptr - > next ) {
if ( strcmp ( curptr - > name , ( char * ) name ) = = 0 ) { //<2F> <> 諨
for ( int i = 0 ; i < curptr - > num ; i + + ) {
ofs = ( curptr - > pos + i ) - > ofs ;
segm = ( curptr - > pos + i ) - > dataseg ;
if ( base = = DS & & dynamic_flag ) { //<2F> 뫮 <20> <> <EFBFBD> <EFBFBD> 饭<EFBFBD> <E9A5AD> <20> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> ᪨<EFBFBD> <20> <> <EFBFBD> <EFBFBD> . <20> <> ६<EFBFBD> <E0A5AC> <EFBFBD> <EFBFBD> <EFBFBD>
CheckPosts ( ) ;
( postbuf + posts ) - > type = ( unsigned short ) ( am32 = = 0 ? DIN_VAR : DIN_VAR32 ) ;
( postbuf + posts ) - > num = ( int ) itok . rec ;
( postbuf + posts ) - > loc = ofs ;
}
else {
if ( ( segm & 1 ) = = 0 | | modelmem = = TINY ) { //<2F> ᥣ<> <E1A5A3> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD>
if ( base ! = VARPOST ) {
// if(am32==FALSE)valofs=*(unsigned short *)&output[ofs];
// else valofs=*(unsigned long *)&output[ofs];
// valofs+=(base==CS?outptr:outptrdata);
valofs = ( base = = CS ? outptr : outptrdata ) ;
}
else valofs = postsize ;
if ( am32 = = FALSE ) * ( unsigned short * ) & output [ ofs ] + = ( unsigned short ) valofs ;
else * ( unsigned long * ) & output [ ofs ] + = valofs ;
}
else {
if ( am32 = = FALSE ) * ( unsigned short * ) & outputdata [ ofs ] + = ( unsigned short ) ( base = = CS ? outptr : outptrdata ) ;
else * ( unsigned long * ) & outputdata [ ofs ] + = ( unsigned long ) ( base = = CS ? outptr : outptrdata ) ;
}
if ( ( FixUp ! = FALSE & & ( segm & 2 ) = = 0 ) /*||base==VARPOST*/ ) {
CheckPosts ( ) ;
( postbuf + posts ) - > type = ( unsigned char )
// (base==VARPOST?(am32==FALSE?POST_VAR:POST_VAR32):
( ( segm & 1 ) = = 0 ? ( am32 = = FALSE ? FIX_VAR : FIX_VAR32 ) :
( am32 = = FALSE ? FIX_CODE : FIX_CODE32 )
// )
) ;
( postbuf + posts ) - > loc = ofs ;
posts + + ;
}
if ( base = = VARPOST ) {
unsigned int i ;
for ( i = 0 ; i < posts ; i + + ) {
if ( ofs = = ( postbuf + i ) - > loc ) break ;
}
if ( i = = posts ) {
CheckPosts ( ) ;
posts + + ;
( postbuf + i ) - > loc = ofs ;
}
( postbuf + i ) - > type = ( unsigned char ) ( am32 = = FALSE ? POST_VAR : POST_VAR32 ) ;
}
}
}
free ( curptr - > pos ) ;
if ( undefoffstart - > next = = NULL ) undefoffstart = NULL ;
else if ( undefoffstart = = curptr ) undefoffstart = curptr - > next ;
else {
for ( prev = undefoffstart ; prev - > next ! = curptr ; prev = prev - > next ) ;
prev - > next = curptr - > next ;
}
count = curptr - > num ;
free ( curptr ) ;
break ;
}
if ( curptr - > next = = NULL ) break ;
}
return count ;
}
int FindUseName ( char * name ) //<2F> <> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> 뫮<EFBFBD> <20> <> ⥪<> 饥 <20> <> <EFBFBD>
{
UNDEFOFF * curptr ;
if ( undefoffstart ) {
for ( curptr = undefoffstart ; ; curptr = curptr - > next ) {
if ( strcmp ( curptr - > name , ( char * ) name ) = = 0 ) { //<2F> <> 諨
return curptr - > num ;
}
if ( curptr - > next = = NULL ) break ;
}
}
return 0 ;
}
int GetDirective ( char * str )
{
int i ;
i = FastSearch ( dirlist , ofsdir , 1 , str ) ;
// printf("i=%d %s\n",i,str);
if ( i ! = - 1 & & i < d_end1 & & notdoneprestuff ! = TRUE & & displaytokerrors ! = 0 ) {
char buf [ 80 ] ;
sprintf ( buf , " Too late to change %s " , str ) ;
preerror ( buf ) ;
}
return i ;
}
int FastSearch ( unsigned char * list , short * ofs , int type , char * str )
{
if ( ( strlen ( str ) - 1 ) > 0 ) {
short offs = - 1 ;
unsigned char c ;
c = str [ 0 ] ;
switch ( type ) {
case 0 :
if ( c > = ' A ' & & c < = ' Z ' ) offs = ofs [ c - ' A ' ] ;
break ;
case 1 :
if ( c = = ' D ' ) offs = ofs [ 0 ] ;
else if ( c > = ' a ' & & c < = ' z ' ) offs = ofs [ c - 0x60 ] ;
break ;
case 2 :
if ( c = = ' _ ' ) offs = ofs [ 26 ] ;
else if ( c > = ' a ' & & c < = ' z ' ) offs = ofs [ c - ' a ' + 27 ] ;
else offs = ofs [ c - ' A ' ] ;
break ;
case 3 :
if ( c > = ' a ' & & c < = ' z ' ) offs = ofs [ c - 0x61 ] ;
break ;
}
// if(type==0)printf("%s\n",str);
if ( offs ! = - 1 ) {
for ( unsigned char * ii = ( unsigned char * ) ( list + offs ) ; ; ii + + ) {
short types ;
if ( ( types = * ( short * ) & * ii ) = = - 1 ) break ;
ii + = 2 ;
unsigned char c = * ii ;
int i ;
i = 1 ;
while ( c = = str [ i ] ) {
if ( c = = 0 ) return types ;
ii + + ;
i + + ;
c = * ii ;
}
if ( c > str [ i ] ) break ;
while ( * ii ! = 0 ) ii + + ;
}
}
}
return - 1 ;
}
/*-----------------05.01.00 22:56-------------------
<EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> ࠬ <EFBFBD>
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */
int GetVarSize ( int var )
{
switch ( var ) {
case tk_reg :
case tk_intvar :
case tk_seg :
case tk_wordvar : return 2 ;
case tk_bits :
case tk_charvar :
case tk_beg :
case tk_bytevar : return 1 ;
case tk_pointer :
if ( am32 = = 0 ) return 2 ;
case tk_longvar :
case tk_dwordvar :
case tk_reg32 :
case tk_floatvar : return 4 ;
case tk_doublevar :
case tk_qwordvar : return 8 ;
default :
if ( am32 ) return 4 ;
}
return 2 ;
}
unsigned long getsizebit ( int size )
{
unsigned long num ;
nexttok ( ) ;
if ( tok ! = tk_number ) numexpected ( ) ;
num = doconstdwordmath ( ) ;
if ( num > ( unsigned int ) ( size * 8 ) ) preerror ( " Bit field to large " ) ;
return num ;
}
int GetFirstDestr ( structteg * searcht )
{
elementteg * bazael = searcht - > baza ;
idrec * ptrs ;
if ( ( searcht - > flag & fs_destructor ) ! = 0 ) return TRUE ;
for ( int i = 0 ; i < searcht - > numoper ; i + + ) {
ptrs = ( bazael + i ) - > rec ;
if ( ( bazael + i ) - > tok = = tk_baseclass ) {
if ( GetFirstDestr ( ( structteg * ) ptrs ) ) return TRUE ;
}
}
return FALSE ;
}
void AddTegToTree ( structteg * newteg , int Global )
{
struct structteg * tteg ;
int i ;
tteg = ( Global = = TRUE ? tegtree : ltegtree ) ;
if ( tteg = = NULL ) ( Global = = TRUE ? tegtree : ltegtree ) = newteg ;
else {
while ( ( ( i = strcmp ( tteg - > name , newteg - > name ) ) < 0 & & tteg - > left ! = NULL ) | | ( i > 0 & & tteg - > right ! = NULL ) )
tteg = ( i < 0 ? tteg - > left : tteg - > right ) ;
( i < 0 ? tteg - > left : tteg - > right ) = newteg ;
}
}
int IsClass ( structteg * searcht )
{
elementteg * bazael = searcht - > baza ;
if ( ( searcht - > flag & fs_destructor ) ! = 0 ) return TRUE ;
for ( int i = 0 ; i < searcht - > numoper ; i + + ) {
if ( ( bazael + i ) - > tok = = tk_baseclass ) return TRUE ;
// if(IsClass((structteg *)(bazael+i)->rec))return TRUE;
else if ( ( bazael + i ) - > tok = = tk_proc ) {
if ( ( bazael + i ) - > rec & & ( ( bazael + i ) - > rec - > flag & f_classproc ) ) return TRUE ;
}
}
return FALSE ;
}
struct structteg * CreatTeg ( int Global , int useunion , int noname ) //ᮧ<> <E1AEA7> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> ⥣
{
struct structteg * newteg , * tteg ;
struct elementteg * bazael ;
int ssize = 0 , numel = 0 , localtok , size , numt , nameid = FALSE , tsize ;
int bitofs = 0 , bitsize = 0 , i , type ;
int isdestr = FALSE , isbase = 0 ;
int unionsize = 0 ;
newteg = ( struct structteg * ) MALLOC ( sizeof ( struct structteg ) ) ;
newteg - > left = newteg - > right = NULL ;
newteg - > baza = NULL ;
newteg - > flag = useunion ;
newteg - > name [ 0 ] = 0 ;
if ( tok = = tk_ID | | tok = = tk_id ) {
strcpy ( newteg - > name , itok . name ) ;
AddTegToTree ( newteg , Global ) ;
nexttok ( ) ;
nameid = TRUE ;
}
if ( tok = = tk_colon ) {
nexttok ( ) ;
do {
if ( ( tteg = FindTeg ( TRUE ) ) = = NULL ) undefclass ( itok . name ) ;
else {
size = tteg - > size ;
if ( numel = = 0 ) bazael = ( struct elementteg * ) MALLOC ( sizeof ( struct elementteg ) ) ;
else bazael = ( struct elementteg * ) REALLOC ( bazael , sizeof ( struct elementteg ) * ( numel + 1 ) ) ;
for ( i = 0 ; i < numel ; i + + ) {
if ( strcmp ( ( bazael + i ) - > name , itok . name ) = = 0 ) {
sprintf ( ( char * ) string , " Dublicate base class '%s' " , itok . name ) ;
preerror ( ( char * ) string ) ;
}
}
strcpy ( ( bazael + numel ) - > name , itok . name ) ;
( bazael + numel ) - > tok = tk_baseclass ;
( bazael + numel ) - > ofs = ssize ;
( bazael + numel ) - > numel = 1 ;
ssize + = size ;
( bazael + numel ) - > nteg = tteg ;
numel + + ;
isbase + + ;
}
nexttok ( ) ;
if ( tok = = tk_openbrace ) break ;
expecting ( tk_camma ) ;
} while ( tok ! = tk_eof ) ;
if ( useunion ) preerror ( " union cannot have a base type " ) ;
}
expecting ( tk_openbrace ) ;
while ( tok ! = tk_closebrace & & tok ! = tk_eof ) {
int oflag , orm , npointr ;
int utestInitVar = FALSE ;
orm = tokens ;
npointr = oflag = 0 ;
type = variable ;
if ( tok = = tk_tilda ) {
newteg - > flag | = fs_destructor ;
oflag | = fs_destructor ;
// oflag=newteg->flag;
nexttok ( ) ;
isdestr = TRUE ;
}
//13.09.04 00:08
if ( tok = = tk_static ) {
oflag | = f_static ;
nexttok ( ) ;
}
/////////////
switch ( tok ) {
case tk_int : orm = tok ; localtok = tk_intvar ; size = 2 ; break ;
case tk_word : orm = tok ; localtok = tk_wordvar ; size = 2 ; break ;
case tk_char : orm = tok ; localtok = tk_charvar ; size = 1 ; break ;
case tk_byte : orm = tok ; localtok = tk_bytevar ; size = 1 ; break ;
case tk_long : orm = tok ; localtok = tk_longvar ; size = 4 ; break ;
case tk_dword : orm = tok ; localtok = tk_dwordvar ; size = 4 ; break ;
case tk_float : orm = tok ; localtok = tk_floatvar ; size = 4 ; break ;
case tk_qword : orm = tok ; localtok = tk_qwordvar ; size = 8 ; break ;
case tk_double : orm = tok ; localtok = tk_doublevar ; size = 8 ; break ;
case tk_union :
nexttok ( ) ;
i = FALSE ;
if ( bitofs & & ( ! useunion ) ) {
ssize + = ( bitofs + 7 ) / 8 ;
bitofs = 0 ;
}
if ( tok = = tk_openbrace ) i = TRUE ;
if ( ( tteg = CreatTeg ( Global , TRUE , i ) ) ! = NULL ) {
if ( tok = = tk_semicolon ) {
if ( numel = = 0 ) bazael = ( struct elementteg * ) MALLOC ( sizeof ( struct elementteg ) * tteg - > numoper ) ;
else bazael = ( struct elementteg * ) REALLOC ( bazael , sizeof ( struct elementteg ) * ( numel + tteg - > numoper ) ) ;
for ( i = 0 ; i < tteg - > numoper ; i + + ) ( tteg - > baza + i ) - > ofs + = ssize ;
memcpy ( ( elementteg * ) ( bazael + numel ) , tteg - > baza , sizeof ( struct elementteg ) * tteg - > numoper ) ;
tsize = tteg - > size ;
if ( useunion = = FALSE ) ssize + = tsize ;
else if ( unionsize < ( unsigned int ) ( tsize ) ) unionsize = tsize ;
numel + = tteg - > numoper ;
free ( tteg - > baza ) ;
free ( tteg ) ;
size = 0 ;
nexttok ( ) ;
break ;
}
else {
tsize = size = tteg - > size ;
localtok = tk_struct ;
goto dproc2 ;
}
}
else declareunion ( ) ;
break ;
case tk_struct :
nexttok ( ) ;
case tk_id :
case tk_ID :
if ( bitofs & & ( ! useunion ) ) {
ssize + = ( bitofs + 7 ) / 8 ;
bitofs = 0 ;
}
i = 0 ;
if ( tok = = tk_openbrace | | tok2 = = tk_openbrace ) {
if ( tok = = tk_openbrace ) i = TRUE ;
if ( ( tteg = CreatTeg ( Global , FALSE , i ) ) ! = NULL ) {
if ( tok ! = tk_semicolon ) {
tsize = size = tteg - > size ;
localtok = tk_struct ;
// printf("tok=%d %s\n",tok,itok.name);
goto dproc2 ;
}
else {
if ( numel = = 0 ) bazael = ( struct elementteg * ) MALLOC ( sizeof ( struct elementteg ) * tteg - > numoper ) ;
else bazael = ( struct elementteg * ) REALLOC ( bazael , sizeof ( struct elementteg ) * ( numel + tteg - > numoper ) ) ;
for ( i = 0 ; i < tteg - > numoper ; i + + ) ( tteg - > baza + i ) - > ofs + = ssize ;
memcpy ( ( elementteg * ) ( bazael + numel ) , tteg - > baza , sizeof ( struct elementteg ) * tteg - > numoper ) ;
tsize = tteg - > size ;
if ( useunion = = FALSE ) ssize + = tsize ;
else if ( unionsize < ( unsigned int ) ( tsize ) ) unionsize = tsize ;
numel + = tteg - > numoper ;
free ( tteg - > baza ) ;
free ( tteg ) ;
size = 0 ;
nexttok ( ) ;
break ;
}
}
datatype_expected ( ) ;
}
if ( strcmp ( itok . name , newteg - > name ) = = 0 & & tok2 = = tk_openbracket ) {
if ( oflag = = 0 ) {
newteg - > flag | = fs_constructor ;
oflag | = fs_constructor ;
orm = am32 = = FALSE ? tk_word : tk_dword ;
}
else if ( oflag = = fs_destructor ) {
strcat ( itok . name , " ~ " ) ;
orm = tk_void ;
}
goto dproc2 ;
}
if ( ( tteg = FindTeg ( FALSE ) ) ! = NULL | | ( tteg = FindTeg ( TRUE ) ) ! = NULL ) {
if ( tok2 = = tk_mult ) {
while ( tok2 = = tk_mult ) nexttok ( ) ;
if ( am32 ) {
localtok = tk_dwordvar ;
size = 4 ;
orm = tk_dword ;
}
else {
localtok = tk_wordvar ;
size = 2 ;
orm = tk_word ;
}
warpointerstruct ( ) ;
}
else {
size = tteg - > size ;
localtok = tk_struct ;
}
goto locvar ;
// break;
}
default :
skipfind = LOCAL ; //<2F> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <20> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> 쭮<EFBFBD> <20> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> 쭮<EFBFBD> ᯨ᪥
utestInitVar = TRUE ;
if ( ( i = testInitVar ( ) ) = = FALSE | | i = = 2 ) { //<2F> <> ।<EFBFBD> <E0A5A4> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> 楤<EFBFBD> <E6A5A4> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <20> <> <20> <> ࠡ<EFBFBD> <E0A0A1> 뢠<EFBFBD> <EBA2A0>
skipfind = FALSE ; //ࠧ<> <E0A0A7> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD>
FindEndLex ( ) ;
datatype_expected ( ) ;
nexttok ( ) ;
size = 0 ;
break ;
}
oflag | = itok . flag ;
npointr = itok . npointr ;
if ( itok . npointr ) itok . rm = ( am32 = = TRUE ? tk_dword : tk_word ) ;
orm = itok . rm ;
if ( tok2 = = tk_openbracket & & strcmp ( itok . name , newteg - > name ) = = 0 ) {
newteg - > flag | = fs_constructor ;
oflag | = fs_constructor ;
if ( orm = = tokens ) orm = am32 = = FALSE ? tk_word : tk_dword ;
}
/* if(tok==tk_openbracket){
if ( itok . npointr ) orm = am32 = = FALSE ? tk_word : tk_dword ;
npointr = 0 ;
nexttok ( ) ;
while ( tok = = tk_mult ) { //㪠<> <E3AAA0> ⥫<EFBFBD> <20> <> <20> <> <EFBFBD> 楤<EFBFBD> <E6A5A4> <EFBFBD>
npointr + + ;
nexttok ( ) ;
}
type = pointer ;
} */
goto dproc2 ;
}
if ( size ! = 0 ) {
locvar :
do {
tsize = size ;
skipfind = LOCAL ; //<2F> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <20> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> 쭮<EFBFBD> <20> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> 쭮<EFBFBD> ᯨ᪥
nexttok ( ) ;
if ( tok = = tk_colon ) {
numt = getsizebit ( size ) ;
if ( numt = = 0 ) numt = size * 8 - bitofs % ( size * 8 ) ; //(am32==0?16:32)-bitofs%(am32==0?16:32);
bitofs + = numt ;
continue ;
}
dproc2 :
if ( numel = = 0 ) bazael = ( struct elementteg * ) MALLOC ( sizeof ( struct elementteg ) ) ;
else bazael = ( struct elementteg * ) REALLOC ( bazael , sizeof ( struct elementteg ) * ( numel + 1 ) ) ;
if ( tok ! = tk_ID & & tok ! = tk_id ) {
utestInitVar = TRUE ;
if ( testInitVar ( ) = = FALSE ) { //<2F> <> ।<EFBFBD> <E0A5A4> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> 楤<EFBFBD> <E6A5A4> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <20> <> <20> <> ࠡ<EFBFBD> <E0A0A1> 뢠<EFBFBD> <EBA2A0>
idalreadydefined ( ) ;
}
else {
oflag | = itok . flag ;
npointr = itok . npointr ;
if ( itok . npointr ) itok . rm = ( am32 = = TRUE ? tk_dword : tk_word ) ;
if ( itok . rm ! = tokens ) orm = itok . rm ;
if ( tok = = tk_openbracket ) {
if ( itok . npointr ) orm = am32 = = FALSE ? tk_word : tk_dword ;
npointr = 0 ;
nexttok ( ) ;
while ( tok = = tk_mult ) { //㪠<> <E3AAA0> ⥫<EFBFBD> <20> <> <20> <> <EFBFBD> 楤<EFBFBD> <E6A5A4> <EFBFBD>
npointr + + ;
nexttok ( ) ;
}
type = pointer ;
}
for ( i = 0 ; i < numel ; i + + ) {
if ( strcmp ( ( bazael + i ) - > name , itok . name ) = = 0 ) idalreadydefined ( ) ;
}
strcpy ( ( bazael + numel ) - > name , itok . name ) ;
if ( tok2 = = tk_openbracket & & strcmp ( itok . name , newteg - > name ) = = 0 ) {
newteg - > flag | = fs_constructor ;
oflag | = fs_constructor ;
if ( orm = = tokens ) orm = am32 = = FALSE ? tk_word : tk_dword ;
}
nexttok ( ) ;
if ( tok = = tk_openbracket | | type = = pointer ) goto dproc ;
if ( npointr ) {
idrec * nrec ;
nrec = ( bazael + numel ) - > rec = ( idrec * ) MALLOC ( sizeof ( idrec ) ) ;
strcpy ( nrec - > recid , ( bazael + numel ) - > name ) ; //<> <E1AAAE> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD>
nrec - > newid = NULL ;
nrec - > npointr = ( unsigned short ) npointr ;
nrec - > flag = oflag ;
nrec - > line = linenumber ;
nrec - > file = currentfileinfo ;
nrec - > rectok = ( bazael + numel ) - > tok = tk_pointer ;
nrec - > type = ( unsigned short ) orm ;
tsize = 2 ;
if ( am32 | | ( oflag & f_far ) ) tsize = 4 ;
goto endelteg ;
}
else unuseableinput ( ) ;
}
}
else {
for ( i = 0 ; i < numel ; i + + ) {
if ( strcmp ( ( bazael + i ) - > name , itok . name ) = = 0 ) {
idalreadydefined ( ) ;
FindEndLex ( ) ;
break ;
}
}
strcpy ( ( bazael + numel ) - > name , itok . name /*(char *)string*/ ) ;
if ( tok2 = = tk_openbracket & & utestInitVar = = FALSE ) {
if ( tok = = tk_id ) oflag | = ( comfile = = file_w32 ? tp_stdcall : tp_pascal ) ; //⨯ <20> <> <EFBFBD> <EFBFBD> <20> <> 㬮<> 砭<EFBFBD> <E7A0AD>
else oflag = tp_fastcall ;
}
// printf("tok=%d %s\n",tok,itok.name);
nexttok ( ) ;
if ( tok = = tk_colon ) {
numt = getsizebit ( size ) ;
if ( numt = = 0 ) preerror ( " Bit fields must contain at least one bit " ) ;
( bazael + numel ) - > ofs = ssize ;
( bazael + numel ) - > tok = tk_bits ;
( bazael + numel ) - > bit . siz = numt ;
( bazael + numel ) - > bit . ofs = bitofs ;
if ( useunion = = FALSE ) bitofs + = numt ;
else if ( numt > bitsize ) bitsize = numt ;
// printf("n=%d size=%d %s\n",numel,numt,(bazael+numel)->name);
}
else if ( tok = = tk_openbracket ) {
dproc :
idrec * nrec ;
param [ 0 ] = 0 ;
if ( type = = pointer ) expecting ( tk_closebracket ) ;
else {
if ( npointr ) {
orm = am32 = = FALSE ? tk_word : tk_dword ;
npointr = 0 ;
}
}
skipfind = FALSE ; //ࠧ<> <E0A0A7> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD>
expecting ( tk_openbracket ) ;
if ( ( oflag & f_typeproc ) = = tp_fastcall ) declareparamreg ( ) ;
else declareparamstack ( ) ;
skipfind = LOCAL ;
nrec = ( bazael + numel ) - > rec = ( idrec * ) MALLOC ( sizeof ( idrec ) ) ;
strcpy ( nrec - > recid , ( bazael + numel ) - > name ) ; //<> <E1AAAE> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD>
nrec - > newid = NULL ;
// printf("name=%s param=%s\n",nrec->recid,param);
if ( param [ 0 ] ! = 0 ) nrec - > newid = BackString ( ( char * ) param ) ;
if ( orm = = tokens ) orm = am32 = = FALSE ? tk_word : tk_dword ; //tk_void;
nrec - > npointr = ( unsigned short ) npointr ;
nrec - > recrm = orm ;
nrec - > flag = oflag ;
nrec - > line = linenumber ;
nrec - > file = currentfileinfo ;
nrec - > count = 0 ;
nrec - > recpost = 0 ; //itok.post;
nrec - > recsize = 0 ; //itok.size;
nrec - > recsib = ( am32 = = TRUE ? CODE32 : CODE16 ) ; //itok.sib;
nrec - > sbuf = NULL ;
if ( npointr ) {
nrec - > rectok = ( bazael + numel ) - > tok = tk_pointer ;
nrec - > type = tk_proc ;
nrec - > recsib = am32 = = FALSE ? rm_d16 : rm_d32 ;
tsize = 2 ;
if ( am32 | | ( oflag & f_far ) ) tsize = 4 ;
if ( bitofs & & ( ! useunion ) ) {
ssize + = ( bitofs + 7 ) / 8 ;
bitofs = 0 ;
}
tsize = Align ( tsize , strpackcur ) ; //new 16.03.05 14:21
nrec - > recnumber = ( bazael + numel ) - > ofs = ssize ;
if ( useunion = = FALSE ) ssize + = tsize ;
else if ( unionsize < ( unsigned int ) ( tsize ) ) unionsize = tsize ;
}
else {
( bazael + numel ) - > tok = tk_proc ;
nrec - > rectok = tk_declare ;
nrec - > type = tp_ucnovn ;
nrec - > recsegm = NOT_DYNAMIC ;
( bazael + numel ) - > ofs = 0 ;
nrec - > recnumber = secondcallnum + + ;
nrec - > flag | = f_classproc ;
}
( bazael + numel ) - > numel = 1 ;
nexttok ( ) ;
if ( tok = = tk_openbracket ) IsUses ( nrec ) ;
// printf("name=%s post=%08X\n",nrec->recid,nrec->recpost);
}
else {
( bazael + numel ) - > rec = NULL ;
( bazael + numel ) - > tok = localtok ;
endelteg :
if ( bitofs & & ( ! useunion ) ) {
ssize + = ( bitofs + 7 ) / 8 ;
bitofs = 0 ;
}
( bazael + numel ) - > ofs = ssize ;
numt = 1 ;
if ( tok = = tk_openblock ) { //[
skipfind = FALSE ;
nexttok ( ) ;
numt = doconstlongmath ( ) ;
expecting ( tk_closeblock ) ;
skipfind = LOCAL ;
}
( bazael + numel ) - > numel = numt ;
// printf("%d: unionsize=%d elemsize=%d\n",numel,unionsize,tsize*numt);
if ( ( oflag & f_static ) ) {
idrec * nrec ;
nrec = ( bazael + numel ) - > rec = ( idrec * ) MALLOC ( sizeof ( idrec ) ) ;
strcpy ( nrec - > recid , ( bazael + numel ) - > name ) ; //<> <E1AAAE> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD>
nrec - > line = linenumber ;
nrec - > file = currentfileinfo ;
nrec - > count = 0 ;
nrec - > sbuf = NULL ;
nrec - > recsize = tsize * numt ;
nrec - > recsegm = DS ;
if ( localtok = = tk_struct ) {
nrec - > recsib = 0 ;
nrec - > newid = ( char * ) tteg ;
( bazael + numel ) - > tok = nrec - > rectok = tk_structvar ;
nrec - > flag = /*flag|*/ tteg - > flag ;
if ( FixUp ) nrec - > flag | = f_reloc ;
nrec - > recrm = numt ;
}
else {
nrec - > newid = NULL ;
nrec - > npointr = ( unsigned short ) npointr ;
nrec - > recrm = ( am32 = = FALSE ? rm_d16 : rm_d32 ) ;
if ( FixUp ) oflag | = f_reloc ;
nrec - > flag = oflag ;
nrec - > recsib = ( am32 = = TRUE ? CODE32 : CODE16 ) ; //itok.sib;
nrec - > rectok = localtok ;
nrec - > type = tp_ucnovn ;
}
if ( tok = = tk_assign ) {
skipfind = FALSE ; //ࠧ<> <E0A0A7> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD>
nrec - > recpost = 0 ;
if ( localtok = = tk_struct ) {
if ( alignword ) alignersize + = AlignCD ( DS , 2 ) ; //<2F> <> <EFBFBD> <E0AEA2> <EFBFBD> <EFBFBD>
nrec - > recnumber = outptrdata ; //<2F> <> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> 砫<EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD>
i = initstructvar ( tteg , numt ) ;
if ( numt = = 0 ) {
numt = i / tteg - > size ;
if ( ( i % tteg - > size ) ! = 0 ) {
numt + + ;
i = tteg - > size - ( i % tteg - > size ) ;
for ( ; i ! = 0 ; i - - ) opd ( 0 ) ;
i = numt * tteg - > size ;
}
nrec - > recrm = numel ;
nrec - > recsize = i ;
}
datasize + = i ;
}
else {
if ( alignword ) alignersize + = AlignCD ( DS , tsize ) ;
nrec - > recnumber = outptrdata ;
initglobalvar ( orm , numt , tsize , variable ) ;
datasize + = tsize * numt ;
}
}
else {
nrec - > recpost = 1 ;
if ( localtok = = tk_struct ) {
if ( numt = = 0 ) {
ZeroMassiv ( ) ;
break ;
}
}
if ( alignword ) { //<2F> <> <EFBFBD> <E0AEA2> <EFBFBD> <EFBFBD> <20> <> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD>
if ( postsize % 2 = = 1 ) postsize + + ;
if ( tsize = = 4 & & postsize % 4 ! = 0 ) postsize + = 2 ;
}
nrec - > recnumber = postsize ;
AddPostData ( numt * tteg - > size ) ;
}
}
else {
tsize = Align ( tsize * numt , strpackcur ) ; //new 16.03.05 14:21
if ( useunion = = FALSE ) ssize + = tsize ;
else if ( unionsize < ( unsigned int ) tsize ) unionsize = tsize ;
if ( localtok = = tk_struct ) ( bazael + numel ) - > nteg = tteg ;
}
}
if ( useunion ) bitofs = 0 ;
numel + + ;
}
newteg - > size = ssize + unionsize ;
} while ( tok = = tk_camma ) ;
skipfind = FALSE ; //ࠧ<> <E0A0A7> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD>
seminext ( ) ;
}
} ; //while(tok!=tk_closebrace&&tok!=tk_eof);
if ( bitofs & & useunion = = FALSE ) ssize + = ( bitofs + 7 ) / 8 ;
else if ( bitsize & & ( ( unsigned int ) ( ( bitsize + 7 ) / 8 ) > unionsize ) ) unionsize = ( bitsize + 7 ) / 8 ;
// printf("bitofs=%d size=%d\n",bitofs,ssize);
if ( isdestr = = FALSE & & isbase > 1 ) {
char * buf = ( char * ) MALLOC ( 16 ) ;
strcpy ( buf , " (){ " ) ;
int j ;
for ( i = 0 , j = 0 ; i < isbase ; i + + ) {
if ( GetFirstDestr ( ( structteg * ) ( bazael + i ) - > nteg ) ) j + + ;
}
if ( j > 1 ) {
strcat ( buf , " }; " ) ;
int oflag , oinptr2 ;
char ocha2 ;
int oldendinptr = endinptr ;
char * oinput ;
idrec * nrec ;
oinptr2 = inptr2 ;
ocha2 = cha2 ;
oinput = ( char * ) input ;
string [ 0 ] = 0 ;
newteg - > flag | = fs_destructor ;
strcpy ( itok . name , newteg - > name ) ;
if ( CidOrID ( ) = = tk_ID ) oflag = tp_fastcall ;
else oflag = ( comfile = = file_w32 ? tp_stdcall : tp_pascal ) ;
bazael = ( struct elementteg * ) REALLOC ( bazael , sizeof ( struct elementteg ) * ( numel + 1 ) ) ;
strcpy ( ( bazael + numel ) - > name , itok . name ) ;
strcat ( ( bazael + numel ) - > name , " ~ " ) ;
itok . rec = nrec = ( bazael + numel ) - > rec = ( idrec * ) MALLOC ( sizeof ( idrec ) ) ;
strcpy ( nrec - > recid , itok . name ) ; //<> <E1AAAE> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD>
nrec - > newid = NULL ;
itok . npointr = nrec - > npointr = 0 ;
itok . rm = nrec - > recrm = tk_void ;
itok . flag = nrec - > flag = fs_destructor | oflag | f_classproc ;
nrec - > line = linenumber ;
nrec - > file = currentfileinfo ;
nrec - > count = 0 ;
itok . post = nrec - > recpost = 0 ;
itok . size = nrec - > recsize = 0 ;
itok . sib = nrec - > recsib = ( am32 = = TRUE ? CODE32 : CODE16 ) ;
nrec - > sbuf = NULL ;
( bazael + numel ) - > tok = tk_proc ;
tok = nrec - > rectok = tk_declare ;
itok . type = nrec - > type = tp_ucnovn ;
itok . segm = nrec - > recsegm = NOT_DYNAMIC ;
( bazael + numel ) - > ofs = 0 ;
itok . number = nrec - > recnumber = secondcallnum + + ;
( bazael + numel ) - > numel = 1 ;
numel + + ;
input = ( unsigned char * ) buf ;
inptr2 = 1 ;
cha2 = ' ( ' ;
endinptr = strlen ( buf ) ;
searchteg = newteg ;
dynamic_proc ( ) ;
searchteg = NULL ;
input = ( unsigned char * ) oinput ;
inptr2 = oinptr2 ;
cha2 = ocha2 ;
endinptr = oldendinptr ;
}
free ( buf ) ;
}
newteg - > size = ssize + unionsize ;
newteg - > numoper = numel ;
newteg - > baza = bazael ;
nexttok ( ) ;
if ( noname = = FALSE & & nameid = = FALSE ) {
if ( tok = = tk_ID | | tok = = tk_id ) {
strcpy ( newteg - > name , itok . name ) ;
AddTegToTree ( newteg , Global ) ;
}
else {
notstructname ( ) ;
if ( newteg - > baza ) free ( newteg - > baza ) ;
free ( newteg ) ;
newteg = NULL ;
}
}
return newteg ;
}
struct structteg * FindTeg ( int Global , char * name ) //<2F> <> <EFBFBD> <EFBFBD> <EFBFBD> ⥣
{
struct structteg * tteg ;
int i ;
char * tn ;
if ( ( tn = strchr ( name , ' @ ' ) ) ! = NULL ) * tn = 0 ;
tteg = ( Global = = TRUE ? tegtree : ltegtree ) ;
while ( tteg & & ( i = strcmp ( tteg - > name , name ) ) ! = 0 ) tteg = ( i < 0 ? tteg - > left : tteg - > right ) ;
return tteg ;
}
unsigned int SaveVal ( unsigned long long val , int type )
{
unsigned int loop = 0 ;
switch ( type ) {
case tk_bytevar :
case tk_charvar :
opd ( val ) ;
break ;
case tk_wordvar :
case tk_intvar :
outwordd ( val ) ;
loop + + ;
break ;
case tk_dwordvar :
case tk_longvar :
case tk_floatvar :
outdwordd ( val ) ;
loop + = 3 ;
break ;
case tk_qwordvar :
case tk_doublevar :
outqwordd ( val ) ;
loop + = 7 ;
break ;
case tk_pointer :
if ( am32 ) {
outdwordd ( val ) ;
loop + = 3 ;
}
else {
outwordd ( val ) ;
loop + + ;
}
break ;
case tk_proc :
loop - - ;
break ;
default : internalerror ( " Bad type variable " ) ;
}
return loop ;
}
void FillTeg ( unsigned long long val , unsigned int numel , struct structteg * tteg )
/*-----------------03.10.99 00:20-------------------
<EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> 묨 <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> 稭 <EFBFBD> <EFBFBD> <EFBFBD>
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */
{
struct elementteg * elem = tteg - > baza ;
int bitofs = 0 ;
unsigned int startstruct ;
if ( dbg & 2 ) AddDataLine ( 1 /*,variable*/ ) ;
for ( unsigned int j = 0 ; j < numel ; j + + ) {
startstruct = outptrdata ;
for ( unsigned int c = 0 ; c < tteg - > numoper ; c + + ) {
if ( ( elem + c ) - > ofs ) outptrdata = startstruct + ( elem + c ) - > ofs ;
if ( splitdata = = FALSE ) outptr = outptrdata ;
int type = ( elem + c ) - > tok ;
if ( type = = tk_bits ) {
opb ( val , ( elem + c ) - > bit . ofs , ( elem + c ) - > bit . siz ) ;
bitofs = ( elem + c ) - > bit . ofs + ( elem + c ) - > bit . siz ;
}
else {
if ( bitofs ) {
CorrectOfsBit ( bitofs ) ;
bitofs = 0 ;
}
for ( unsigned int i = 0 ; i < ( elem + c ) - > numel ; i + + ) {
if ( type = = tk_struct | | type = = tk_baseclass ) {
FillTeg ( val , ( elem + c ) - > numel , ( struct structteg * ) ( elem + c ) - > nteg ) ;
break ;
}
SaveVal ( val , type ) ;
}
}
}
}
if ( bitofs ) CorrectOfsBit ( bitofs ) ;
}
unsigned int Fill2Teg ( unsigned int numel , struct structteg * tteg )
/*-----------------03.10.99 00:20-------------------
<EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> 稭 <EFBFBD> <EFBFBD> <EFBFBD>
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */
{
unsigned long long hold ;
struct elementteg * elem = tteg - > baza ;
unsigned int tnumel = 0 ; //<2F> <> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> ⨯ <>
unsigned int ttype = 0 ; //<2F> <> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD>
unsigned int nums = 0 ; //<2F> <> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD>
unsigned int loop = 0 ; //<2F> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> ࠧ<> <E0A0A7> <EFBFBD>
int type = tokens ;
int bitofs = 0 ;
unsigned int startstruct = outptrdata ;
scanalltoks = FALSE ;
for ( ; ; ) {
hold = 0 ;
if ( tnumel = = ( elem + ttype ) - > numel | | type = = tk_bits ) {
tnumel = 0 ;
ttype + + ;
if ( ttype = = tteg - > numoper ) {
ttype = 0 ;
nums + + ;
startstruct = outptrdata ;
if ( nums = = numel ) {
scanalltoks = TRUE ;
return loop ;
}
}
loop = ( elem + ttype ) - > ofs ;
outptrdata = startstruct + loop ;
if ( splitdata = = FALSE ) outptr = outptrdata ;
loop + = tteg - > size * nums ;
}
tnumel + + ;
type = ( elem + ttype ) - > tok ;
// puts((elem+ttype)->name);
if ( type = = tk_struct | | type = = tk_baseclass ) {
tnumel = ( elem + ttype ) - > numel ;
loop + = Fill2Teg ( ( elem + ttype ) - > numel , ( struct structteg * ) ( elem + ttype ) - > nteg ) ;
if ( tok = = tk_closebrace ) break ;
continue ;
}
if ( type = = tk_proc ) continue ;
if ( ( elem + ttype ) - > rec & & ( ( elem + ttype ) - > rec - > flag & f_static ) ) continue ;
if ( dbg & 2 ) AddDataLine ( ( char ) GetVarSize ( type ) /*,variable*/ ) ;
loopsw :
int htok = tok ;
// printf("tok=%d\n",tok);
switch ( tok ) {
case tk_camma :
hold = 0 ;
goto strl3 ;
case tk_postnumber :
( itok . flag & f_extern ) = = 0 ? setwordpost ( & itok ) : setwordext ( & itok . number ) ;
itok . flag = 0 ;
// goto strl1;
case tk_undefofs :
// AddUndefOff(1,itok.name);
//strl1:
tok = tk_number ;
if ( htok = = tk_undefofs ) AddUndefOff ( 3 , itok . name ) ;
hold + = doconstdwordmath ( ) ;
if ( tok = = tk_plus & & tok2 = = tk_postnumber & & htok ! = tk_undefofs ) {
nexttok ( ) ;
goto loopsw ;
}
goto strl2 ;
case tk_minus :
case tk_number :
if ( type = = tk_bytevar | | type = = tk_wordvar | | type = = tk_dwordvar | | type = = tk_bits | | type = = tk_pointer ) {
hold = doconstdwordmath ( ) ;
}
else if ( type = = tk_charvar | | type = = tk_intvar | | type = = tk_longvar ) {
hold = doconstlongmath ( ) ;
}
else if ( type = = tk_floatvar ) hold = doconstfloatmath ( ) ;
else if ( type = = tk_doublevar ) hold = doconstdoublemath ( ) ;
else if ( type = = tk_qwordvar ) hold = doconstqwordmath ( ) ;
// printf("tok=%d num=%08X\n",tok,hold);
strl2 :
if ( ( postnumflag & f_reloc ) ! = 0 ) AddReloc ( ) ;
strl3 :
if ( type = = tk_bits ) {
opb ( hold , ( elem + ttype ) - > bit . ofs , ( elem + ttype ) - > bit . siz ) ;
bitofs = ( elem + ttype ) - > bit . ofs + ( elem + ttype ) - > bit . siz ;
}
else {
if ( bitofs ) {
CorrectOfsBit ( bitofs ) ;
loop + = ( bitofs + 7 ) / 8 ;
bitofs = 0 ;
}
loop + = SaveVal ( hold , type ) ;
}
break ;
case tk_string :
if ( type = = tk_bytevar | | type = = tk_charvar ) {
unsigned int i ;
if ( ( unsigned int ) itok . number < ( elem + ttype ) - > numel ) i = itok . number ;
else i = ( elem + ttype ) - > numel ;
tnumel = 0 ;
for ( ; tnumel < i ; tnumel + + ) {
opd ( string [ tnumel ] ) ;
}
if ( tnumel < ( elem + ttype ) - > numel ) {
switch ( itok . flag & 3 ) {
case zero_term :
if ( itok . flag & s_unicod ) opd ( 0 ) ;
opd ( 0 ) ;
tnumel + + ;
break ;
case dos_term :
if ( itok . flag & s_unicod ) opd ( 0 ) ;
opd ( ' $ ' ) ;
tnumel + + ;
break ;
}
while ( tnumel < ( elem + ttype ) - > numel ) {
opd ( aligner ) ;
tnumel + + ;
}
}
loop + = tnumel - 1 ;
nexttok ( ) ;
break ;
}
if ( am32 = = FALSE ) {
outwordd ( addpoststring ( ) ) ;
if ( type = = tk_longvar | | type = = tk_dwordvar ) {
loop + = 2 ;
outword ( 0 ) ;
}
loop + + ;
}
else {
if ( type = = tk_intvar | | type = = tk_wordvar ) dwordvalexpected ( ) ;
outdwordd ( addpoststring ( ) ) ;
loop + = 3 ;
}
nexttok ( ) ;
break ;
default :
numexpected ( ) ;
nexttok ( ) ;
break ;
}
loop + + ;
if ( tok = = tk_closebrace ) break ;
// printf("tok=%d\n",tok);
expecting ( tk_camma ) ;
}
scanalltoks = TRUE ;
if ( bitofs ) {
CorrectOfsBit ( bitofs ) ;
loop + = ( bitofs + 7 ) / 8 ;
}
return loop ;
}
unsigned int initstructvar ( structteg * tteg , int numel )
{
unsigned int loop = 0 ;
nexttok ( ) ;
switch ( tok ) { //<2F> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> 稭<EFBFBD> <E7A8AD> <EFBFBD>
case tk_minus :
case tk_number :
if ( numel = = 0 ) ZeroMassiv ( ) ;
FillTeg ( doconstqwordmath ( ) , numel , tteg ) ;
loop = numel * tteg - > size ;
break ;
case tk_from : //<2F> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> 䠩<> <20> <20> <> <EFBFBD> <EFBFBD> 묨
nexttok ( ) ;
loop = dofrom ( ) ;
for ( ; loop < tteg - > size * numel ; loop + + ) opd ( aligner ) ;
nexttok ( ) ;
break ;
case tk_extract : //<2F> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <20> ࠣ<EFBFBD> <E0A0A3> <EFBFBD> <EFBFBD> 䠩<> <E4A0A9> <20> <20> <> <EFBFBD> <EFBFBD> 묨
nexttok ( ) ;
loop = doextract ( ) ;
for ( ; loop < tteg - > size * numel ; loop + + ) opd ( aligner ) ;
break ;
case tk_openbrace : //<2F> <> <EFBFBD> ᨢ <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD>
nexttok ( ) ;
loop = Fill2Teg ( numel , tteg ) ;
for ( ; loop < tteg - > size * numel ; loop + + ) opd ( aligner ) ;
if ( tok ! = tk_closebrace ) {
preerror ( " extra parameter at initialization of structure " ) ;
while ( tok ! = tk_closebrace & & tok ! = tk_eof ) nexttok ( ) ;
}
nexttok ( ) ;
break ;
default :
// printf("tok=%d\n",tok);
numexpected ( ) ; nexttok ( ) ; break ;
}
return loop ;
}
void InitStruct2 ( unsigned int flag , structteg * tteg ) //<2F> <> <EFBFBD> 樠<EFBFBD> <E6A8A0> <EFBFBD> <EFBFBD> <EFBFBD> <E0AEA2> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD>
{
struct idrec * newrec = NULL , * ptr ;
int numel , count ;
char done = 0 , dynamic ;
unsigned int loop ;
while ( tok ! = tk_eof & & done = = 0 ) {
loop = 0 ;
// printf("3 tok=%d %s\n",tok,itok.name);
switch ( tok ) {
case tk_id :
case tk_ID : //<2F> <> <EFBFBD> 樠<EFBFBD> <E6A8A0> <EFBFBD> <EFBFBD> <EFBFBD> <E0AEA2> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD>
//<2F> 뤥<EFBFBD> <EBA4A5> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD>
newrec = ( struct idrec * ) MALLOC ( sizeof ( struct idrec ) ) ;
// if(strcmp(itok.name,"ccchrg")==0)printf("rec=%08X teg=%08X size=%X %s\n",newrec,tteg,sizeof(idrec),itok.name);
ptr = ( ( flag & f_static ) = = 0 ? treestart : staticlist ) ; //<2F> <> 砫<EFBFBD> <20> <> ॢ<EFBFBD>
if ( ptr = = NULL ) ( ( flag & f_static ) = = 0 ? treestart : staticlist ) = newrec ; //<2F> <> 砫<EFBFBD> <20> <> ॢ<EFBFBD>
else { //<2F> <> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> ப<EFBFBD> <20> <20> <> ॢ<EFBFBD>
while ( ( ( numel = strcmp ( ptr - > recid , itok . name ) ) < 0 & & ptr - > left ! = NULL ) | | ( numel > 0 & & ptr - > right ! = NULL ) ) {
ptr = ( numel < 0 ? ptr - > left : ptr - > right ) ;
}
( numel < 0 ? ptr - > left : ptr - > right ) = newrec ; //<2F> <> ப<EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD>
}
newrec - > recsib = 0 ;
strcpy ( newrec - > recid , itok . name ) ; //<> <E1AAAE> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD>
newrec - > newid = ( char * ) tteg ;
newrec - > left = NULL ;
newrec - > right = NULL ;
newrec - > rectok = tk_structvar ;
newrec - > flag = flag | tteg - > flag ;
newrec - > line = linenumber ;
newrec - > file = currentfileinfo ;
newrec - > type = tp_gvar ;
if ( FixUp ) newrec - > flag | = f_reloc ;
numel = 1 ;
nexttok ( ) ;
if ( tok = = tk_openblock ) { //[
nexttok ( ) ;
if ( tok ! = tk_closeblock ) numel = doconstlongmath ( ) ; //<2F> <> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> ⮢
else numel = 0 ;
expecting ( tk_closeblock ) ; //]
}
newrec - > recrm = numel ;
newrec - > recsize = numel * tteg - > size ;
dynamic = FALSE ;
if ( tok = = tk_assign | | notpost = = TRUE ) { //=
if ( useStartup = = TRUE & & tok ! = tk_assign & & numel ! = 0 ) {
if ( SaveStruct ( numel * tteg - > size , newrec ) = = TRUE ) break ;
}
if ( alignword & & ( ! dynamic_flag ) ) alignersize + = AlignCD ( DS , 2 ) ; //<2F> <> <EFBFBD> <E0AEA2> <EFBFBD> <EFBFBD>
// NotPostUnion();
itok . rec = newrec ;
if ( ( count = FindOff ( ( unsigned char * ) newrec - > recid , DS ) ) = = 0 ) {
if ( dynamic_flag ) dynamic = DYNAMIC_VAR ;
}
else if ( dynamic_flag ) dynamic = USED_DIN_VAR ;
newrec - > recnumber = ( dynamic = = 0 ? outptrdata : 0 ) ; //<2F> <> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> 砫<EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD>
newrec - > recpost = dynamic ;
if ( notpost = = TRUE & & tok ! = tk_assign ) {
if ( numel = = 0 ) ZeroMassiv ( ) ;
for ( ; loop < tteg - > size * numel ; loop + + ) opd ( aligner ) ;
datasize + = loop ;
break ;
}
if ( dynamic ) newrec - > sbuf = dynamic_var ( ) ;
else {
loop = initstructvar ( tteg , numel ) ;
if ( numel = = 0 ) {
numel = loop / tteg - > size ;
if ( ( loop % tteg - > size ) ! = 0 ) {
numel + + ;
int i = tteg - > size - ( loop % tteg - > size ) ;
for ( ; i ! = 0 ; i - - ) opd ( 0 ) ;
loop = numel * tteg - > size ;
}
newrec - > recrm = numel ;
newrec - > recsize = loop ;
}
datasize + = loop ;
}
}
else {
if ( numel = = 0 ) {
ZeroMassiv ( ) ;
break ;
}
if ( CheckUseAsUndef ( ( unsigned char * ) newrec - > recid ) = = 0 & & dynamic_flag ) dynamic = TRUE ;
switch ( tok ) { //<2F> <> <EFBFBD> <EFBFBD> <EFBFBD> 樠<EFBFBD> <E6A8A0> <EFBFBD> <EFBFBD> <EFBFBD> <E0AEA2> <EFBFBD> <EFBFBD> <EFBFBD>
default : expected ( ' ; ' ) ;
case tk_semicolon : done = 1 ; // ;
case tk_camma : //, post global type
// long longpostsize;
if ( useStartup = = TRUE ) {
if ( SaveStruct ( numel * tteg - > size , newrec ) = = TRUE ) {
nexttok ( ) ;
break ;
}
}
newrec - > recpost = dynamic + 1 ;
loop = numel * tteg - > size ;
if ( ( flag & f_extern ) = = 0 & & dynamic = = 0 ) {
if ( alignword ) { //<2F> <> <EFBFBD> <E0AEA2> <EFBFBD> <EFBFBD> <20> <> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD>
if ( postsize % 2 = = 1 ) postsize + + ;
}
newrec - > recnumber = postsize ;
}
else newrec - > recnumber = externnum + + ;
count = FindOff ( ( unsigned char * ) newrec - > recid , VARPOST ) ;
if ( ( flag & f_extern ) = = 0 & & dynamic = = 0 )
/*-----------------10.09.02 23:21-------------------
<EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> 맮 <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> FindOff
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */
AddPostData ( loop ) ;
nexttok ( ) ;
break ;
}
}
newrec - > count = count ;
break ;
case tk_proc :
case tk_qwordvar :
case tk_doublevar :
case tk_floatvar :
case tk_dwordvar :
case tk_longvar :
case tk_charvar :
case tk_intvar :
case tk_bytevar :
case tk_wordvar : idalreadydefined ( ) ; nexttok ( ) ; break ;
default :
if ( newrec ) expected ( ' ; ' ) ;
else errstruct ( ) ;
FindStopTok ( ) ;
case tk_semicolon : done = 1 ;
case tk_camma : nexttok ( ) ; break ;
}
}
dopoststrings ( ) ;
}
void InitStruct ( ) //<2F> <> <EFBFBD> 樠<EFBFBD> <E6A8A0> <EFBFBD> <EFBFBD> <EFBFBD> <E0AEA2> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD>
{
struct structteg * tteg ;
unsigned int flag ;
//if(debug)puts("start init struct");
flag = itok . flag ;
if ( fstatic ) {
flag | = f_static ;
fstatic = FALSE ;
}
if ( tok = = tk_struct ) nexttok ( ) ;
else if ( tok2 ! = tk_id & & tok2 ! = tk_ID ) {
if ( tok2 = = tk_dblcolon ) {
itok . flag = f_classproc ;
itok . rm = am32 = = FALSE ? tk_word : tk_dword ; //tk_void;
itok . npointr = 0 ;
doclassproc ( 0 /*comfile==file_w32?tk_stdcall:tk_pascal 18.10.05 10:52*/ ) ;
return ;
}
notstructname ( ) ;
}
tteg = FindTeg ( TRUE ) ;
if ( tteg = = NULL ) {
if ( tok = = tk_openbrace | | tok2 = = tk_openbrace | | tok = = tk_colon | | tok2 = = tk_colon )
tteg = CreatTeg ( TRUE ) ; //<2F> <> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> ᮧ<> <E1AEA7> <EFBFBD> <EFBFBD> ⥣
else {
while ( tok ! = tk_semicolon & & tok ! = tk_eof ) nexttok ( ) ;
tegnotfound ( ) ;
return ;
}
}
else {
if ( tok2 = = tk_openbrace ) idalreadydefined ( ) ;
nexttok ( ) ;
}
InitStruct2 ( flag , tteg ) ;
}
unsigned long LocalStruct2 ( int flag , int * localline , int binptr , char bcha , structteg * tteg ) //<2F> <> <EFBFBD> 樠<EFBFBD> <E6A8A0> <EFBFBD> <EFBFBD> <EFBFBD> <E0AEA2> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD>
{
int numel , first = FALSE ;
struct localrec * newrec ;
unsigned long size = 0 ;
skipfind = TRUE ; //<2F> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <20> ᪠<EFBFBD> <E1AAA0> <20> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> 쭮<EFBFBD> <20> <> ॢ<EFBFBD>
do {
if ( first ! = FALSE ) {
binptr = inptr2 ;
bcha = cha2 ;
nexttok ( ) ;
}
first = TRUE ;
if ( tok ! = tk_ID & & tok ! = tk_id ) idalreadydefined ( ) ;
else { //<2F> <> <EFBFBD> 樠<EFBFBD> <E6A8A0> <EFBFBD> <EFBFBD> <EFBFBD> <E0AEA2> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD>
numel = 1 ;
newrec = addlocalvar ( ( char * ) string , tk_structvar , localsize ) ;
newrec - > rec . newid = ( char * ) tteg ;
newrec - > rec . flag = tteg - > flag ;
newrec - > rec . type = tp_localvar ;
nexttok ( ) ;
if ( tok = = tk_openblock ) { //[
skipfind = FALSE ;
nexttok ( ) ;
numel = doconstlongmath ( ) ; //<2F> <> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> ⮢
skipfind = TRUE ;
expecting ( tk_closeblock ) ; //]
}
newrec - > rec . recrm = numel ;
size = numel * tteg - > size ;
newrec - > rec . recsize = size ;
if ( flag & f_static ) {
// if(bcha==0)not_union_static();
if ( tok = = tk_assign ) {
// newrec->rec.rectok=tk_structvar;
newrec - > rec . recnumber = 0 ;
newrec - > rec . recpost = DYNAMIC_VAR ;
// newrec->rec.recsize=tteg->size;
// newrec->rec.recrm=numel;
newrec - > rec . line = linenumber ;
newrec - > rec . file = currentfileinfo ;
newrec - > rec . npointr = 0 ;
newrec - > rec . sbuf = dynamic_var ( ) ;
newrec - > rec . recsib = newrec - > rec . type = tp_gvar ;
}
else {
newrec - > rec . recpost = TRUE ;
if ( alignword ) { //<2F> <> <EFBFBD> <E0AEA2> <EFBFBD> <EFBFBD> <20> <> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD>
if ( postsize % 2 = = 1 ) postsize + + ;
}
newrec - > rec . recnumber = postsize ;
AddPostData ( size ) ;
}
size = 0 ;
}
else {
size = Align ( size , ( am32 = = FALSE ? 2 : 4 ) ) ;
newrec - > rec . recpost = LOCAL ;
newrec - > rec . recnumber = - localsize - size ;
// localsize+=size;
if ( tok = = tk_assign ) {
if ( * localline = = 0 ) * localline = linenumber ;
AddBackBuf ( binptr , bcha ) ;
}
}
}
localsize + = size ;
} while ( tok = = tk_camma ) ;
skipfind = FALSE ; //<2F> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <20> ᪠<EFBFBD> <E1AAA0> <20> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> 쭮<EFBFBD> <20> <> ॢ<EFBFBD>
// localsize+=size;
itok . name [ 0 ] = 0 ;
seminext ( ) ;
return size ;
}
unsigned long LocalStruct ( int flag , int * localline ) //<2F> <> <EFBFBD> 樠<EFBFBD> <E6A8A0> <EFBFBD> <EFBFBD> <EFBFBD> <E0AEA2> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD>
{
struct structteg * tteg ;
int binptr ;
char bcha ;
structteg * osearchteg ;
osearchteg = searchteg ;
searchteg = NULL ;
skipfind = TRUE ; //<2F> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <20> ᪠<EFBFBD> <E1AAA0> <20> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> 쭮<EFBFBD> <20> <> ॢ<EFBFBD>
if ( tok = = tk_struct ) nexttok ( ) ;
binptr = inptr2 ;
bcha = cha2 ;
if ( ( tteg = FindTeg ( FALSE ) ) = = NULL & & ( tteg = FindTeg ( TRUE ) ) = = NULL ) {
skipfind = FALSE ;
if ( tok = = tk_openbrace | | tok2 = = tk_openbrace ) {
tteg = CreatTeg ( FALSE ) ; //<2F> <> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> ᮧ<> <E1AEA7> <EFBFBD> <EFBFBD> ⥣
}
else {
while ( tok ! = tk_semicolon & & tok ! = tk_eof ) nexttok ( ) ;
tegnotfound ( ) ;
searchteg = osearchteg ;
return 0 ;
}
}
else {
searchteg = osearchteg ;
if ( tok2 = = tk_openbrace ) {
idalreadydefined ( ) ;
SkipBlock2 ( ) ;
return 0 ;
}
nexttok ( ) ;
if ( tok ! = tk_id & & tok ! = tk_ID ) {
notstructname ( ) ;
FindStopTok ( ) ;
return 0 ;
}
}
searchteg = osearchteg ;
return LocalStruct2 ( flag , localline , binptr , bcha , tteg ) ;
}
void dostruct ( )
{
struct structteg * tteg ;
int numel ;
int usenumstr ;
SINFO rstr ;
char * ofsst = NULL ;
int oneloop = FALSE ;
unsigned long hnum ;
unsigned int num , sized = 0 , sign = FALSE ;
unsigned long adr ;
int localstr = FALSE ;
int poststr ;
int flagstr ;
struct idrec * ptrs ;
if ( tok2 = = tk_assign ) {
switch ( ScanTok3 ( ) ) {
case tk_proc :
case tk_apiproc :
case tk_undefproc :
case tk_declare :
ptrs = itok . rec ;
if ( ptrs - > recpost = = LOCAL ) {
if ( ESPloc & & am32 ) {
itok . rm = rm_mod10 | rm_sib ;
itok . sib = 0x24 ;
itok . number + = addESP ;
}
else {
itok . rm = rm_mod10 | ( am32 = = FALSE ? rm_BP : rm_EBP ) ;
}
itok . segm = SS ;
itok . post = 0 ;
compressoffset ( & itok ) ;
}
else {
itok . segm = DS ;
itok . rm = ( am32 = = FALSE ? rm_d16 : rm_d32 ) ; //<2F> <> ⠭<EFBFBD> <E2A0AD> <EFBFBD> <EFBFBD> <20> <> 㬮<> 砭<EFBFBD> <E7A0AD>
itok . post = ptrs - > recpost ;
}
itok . sib = ( am32 = = FALSE ? CODE16 : CODE32 ) ;
itok . flag = ptrs - > flag ;
switch ( itok . size ) {
case 1 :
tok = tk_bytevar ;
dobytevar ( 0 ) ;
break ;
case 2 :
case 3 :
tok = tk_wordvar ;
do_d_wordvar ( 0 , r16 ) ;
break ;
case 4 :
case 5 :
case 6 :
case 7 :
tok = tk_dwordvar ;
do_d_wordvar ( 0 , r32 ) ;
break ;
default :
tok = tk_qwordvar ;
doqwordvar ( ) ;
break ;
}
return ;
}
}
adr = itok . number ;
numel = itok . rm ; //<2F> <> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD>
usenumstr = itok . post ; //<2F> 뫮 㪠<> <E3AAA0> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD>
if ( itok . type = = tp_classvar ) {
tteg = ( structteg * ) itok . rec ;
poststr = 0 ;
flagstr = f_useidx ;
}
else {
ptrs = itok . rec ;
tteg = ( structteg * ) ptrs - > newid ;
if ( ptrs - > recpost = = LOCAL ) localstr = TRUE ;
poststr = ptrs - > recpost ;
flagstr = ptrs - > flag ;
}
rstr = strinf ;
strinf . bufstr = NULL ;
num = itok . size ;
// if(bufrm)printf("num=%d %s\n",adr,bufrm);
nexttok ( ) ;
if ( tok = = tk_assign ) {
getoperand ( ) ;
int starts = 0 ; //ᬥ饭<E1ACA5> <E9A5AD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <20> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD>
if ( tok = = tk_int | | tok = = tk_word ) {
sized = 2 ;
getoperand ( ) ;
}
else if ( tok = = tk_long | | tok = = tk_dword ) {
sized = 4 ;
getoperand ( ) ;
}
else if ( tok = = tk_char | | tok = = tk_byte ) {
sized = 1 ;
getoperand ( ) ;
}
switch ( tok ) {
case tk_charvar :
case tk_bytevar :
case tk_intvar :
case tk_wordvar :
case tk_longvar :
case tk_dwordvar :
int razr , retreg ;
ITOK wtok ;
char * wbuf ;
wbuf = bufrm ;
bufrm = NULL ;
wtok = itok ;
SINFO wstr ;
wstr = strinf ;
strinf . bufstr = NULL ;
if ( ( retreg = CheckIDZReg ( itok . name , AX , razr = GetVarSize ( tok ) ) ) ! = NOINREG ) {
GenRegToReg ( AX , retreg , razr ) ;
IDZToReg ( itok . name , AX , razr ) ;
if ( bufrm ) {
free ( bufrm ) ;
bufrm = NULL ;
}
if ( strinf . bufstr ) {
free ( strinf . bufstr ) ;
strinf . bufstr = NULL ;
}
if ( sized ) {
switch ( razr ) {
case r8 : tok = tk_beg ; break ;
case r16 : tok = tk_reg ; break ;
case r32 : tok = tk_reg32 ; break ;
}
itok . number = 0 ;
goto convr ;
}
break ;
}
IDZToReg ( itok . name , AX , razr ) ;
if ( sized = = 0 ) {
switch ( tok ) {
case tk_charvar :
case tk_bytevar :
getintoal ( tok , & wtok , wbuf , & wstr ) ;
sized = 1 ;
break ;
case tk_intvar :
sign = TRUE ;
case tk_wordvar :
getinto_e_ax ( sign , tok , & wtok , wbuf , & wstr , r16 ) ;
sized = 2 ;
break ;
case tk_longvar :
sign = TRUE ;
case tk_dwordvar :
getinto_e_ax ( sign , tok , & wtok , wbuf , & wstr , r32 ) ;
sized = 4 ;
break ;
}
}
else {
convr :
switch ( sized ) {
case 1 :
getintoal ( tok , & wtok , wbuf , & wstr ) ;
break ;
case 2 :
getinto_e_ax ( 0 , tok , & wtok , wbuf , & wstr , r16 ) ;
break ;
case 4 :
getinto_e_ax ( 0 , tok , & wtok , wbuf , & wstr , r32 ) ;
break ;
}
}
if ( usenumstr ! = FALSE ) {
// num/=ptrs->recrm; //㪠<> <E3AAA0> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> - <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <20> <> <EFBFBD>
num = tteg - > size ;
if ( strinf . bufstr = = NULL ) starts = num * numel ;
}
num / = sized ;
goto fillstr ;
case tk_minus :
nexttok ( ) ;
if ( tok ! = tk_number ) {
errstruct ( ) ;
break ;
}
itok . number = - itok . number ;
case tk_number :
if ( sized = = 0 ) {
sized = 4 ;
if ( itok . number < 65536 ) sized = 2 ;
if ( itok . number < 256 ) sized = 1 ;
}
if ( usenumstr ! = FALSE ) {
// num/=ptrs->recrm; //㪠<> <E3AAA0> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> - <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <20> <> <EFBFBD>
num = tteg - > size ;
if ( strinf . bufstr = = NULL ) starts = num * numel ;
}
if ( strinf . bufstr = = NULL ) {
if ( optimizespeed = = TRUE ) {
if ( sized = = 1 & & ( num % 2 ) = = 0 ) {
sized = 2 ;
itok . number = ( itok . number & 255 ) | ( ( itok . number < < 8 ) & 0xFF00 ) ;
}
if ( chip > 2 & & sized = = 2 & & ( num % 4 ) = = 0 ) {
sized = 4 ;
itok . number = ( itok . number & 0xFFFF ) | ( itok . number < < 16 ) ;
}
}
else {
if ( am32 = = FALSE ) {
if ( sized = = 1 & & ( ( num < 7 & & ( num % 2 ) = = 0 ) | | ( itok . number = = 0 & & num = = 8 ) ) ) {
sized = 2 ;
itok . number = ( itok . number & 255 ) | ( ( itok . number < < 8 ) & 0xFF00 ) ;
}
}
else if ( chip > 2 & & sized ! = 4 & & ( num % 4 ) = = 0 & & itok . number = = 0 ) sized = 4 ;
}
}
num / = sized ;
if ( num = = 1 ) {
oneloop + + ;
hnum = itok . number ;
}
else if ( num = = 2 & & sized = = 2 & & chip > 2 ) {
oneloop + + ;
hnum = ( itok . number & 0xFFFF ) | ( itok . number < < 16 ) ;
sized = 4 ;
num = 1 ;
}
else if ( num = = 4 & & sized = = 1 & & chip > 2 ) {
oneloop + + ;
itok . number & = 255 ;
hnum = itok . number | ( itok . number < < 8 ) | ( itok . number < < 16 ) | ( itok . number < < 24 ) ;
sized = 4 ;
num = 1 ;
}
else {
if ( sized = = 1 ) {
if ( itok . number = = 0 ) outword ( 0x00B0 ) ;
else {
op ( 0xB0 ) ;
op ( itok . number ) ;
}
ConstToReg ( itok . number , AX , r8 ) ;
}
else MovRegNum ( sized , 0 , itok . number , EAX ) ;
}
fillstr :
// itok.number=ptrs->recnumber;
itok . number = adr ;
if ( rstr . bufstr = = NULL ) itok . number + = starts ;
itok . sib = ( am32 = = FALSE ? CODE16 : CODE32 ) ;
if ( localstr ) {
if ( comfile ! = file_w32 & & oneloop = = FALSE ) {
pushss ( ) ;
popes ( ) ;
}
if ( ESPloc & & am32 ) {
itok . rm = rm_mod10 | rm_sib ;
itok . sib = 0x24 ;
itok . number + = addESP ;
}
else {
itok . rm = rm_mod10 | ( am32 = = FALSE ? rm_BP : rm_EBP ) ;
}
itok . segm = SS ;
tok = tk_rmnumber ;
itok . post = 0 ;
itok . size = tteg - > size ;
compressoffset ( & itok ) ;
if ( rstr . bufstr ! = NULL ) CheckAllMassiv ( bufrm , 2 , & rstr , & itok , EDI , EDX ) ;
}
else {
if ( comfile ! = file_w32 & & oneloop = = FALSE ) {
pushds ( ) ;
popes ( ) ;
}
itok . post = poststr ;
itok . segm = DS ;
itok . rm = ( am32 = = FALSE ? rm_d16 : rm_d32 ) ; //<2F> <> ⠭<EFBFBD> <E2A0AD> <EFBFBD> <EFBFBD> <20> <> 㬮<> 砭<EFBFBD> <E7A0AD>
itok . rec = NULL ; //ptrs;
if ( rstr . bufstr = = NULL ) {
if ( itok . post ! = 0 ) tok = tk_postnumber ;
else tok = tk_number ;
}
else {
// printf("bufrm=%s rstr=%s\n",bufrm,rstr.bufstr);
CheckAllMassiv ( bufrm , 2 , & rstr , & itok , EDI , EDX ) ;
// puts("end rm");
tok = tk_rmnumber ;
itok . size = tteg - > size ; // ???? trap
}
}
itok . flag = flagstr ;
if ( oneloop ) {
switch ( sized ) {
case 1 :
outseg ( & itok , 2 ) ;
op ( 0xC6 ) ;
op ( itok . rm ) ;
outaddress ( & itok ) ;
op ( hnum ) ;
break ;
case 2 :
case 4 :
op66 ( sized ) ;
if ( hnum = = 0 ) {
outseg ( & itok , 2 ) ;
op ( 0x83 ) ;
op ( itok . rm + 0x20 ) ;
outaddress ( & itok ) ;
op ( 0 ) ;
break ;
}
if ( ( sized = = 4 & & hnum = = 0xFFFFFFFF ) | | ( sized = = 2 & & hnum = = 0xFFFF ) ) {
outseg ( & itok , 2 ) ;
op ( 0x83 ) ;
op ( itok . rm + 0x8 ) ;
outaddress ( & itok ) ;
op ( 0xFF ) ;
break ;
}
if ( optimizespeed = = 0 & & sized = = 4 & & short_ok ( hnum , TRUE ) ) {
op ( 0x6A ) ;
op ( hnum ) ; //push short number
op66 ( sized ) ;
outseg ( & itok , 2 ) ;
op ( 0x8f ) ;
op ( itok . rm ) ;
outaddress ( & itok ) ;
break ;
}
outseg ( & itok , 2 ) ;
op ( 0xC7 ) ; //mov word[],number
op ( itok . rm ) ;
outaddress ( & itok ) ;
if ( sized = = 2 ) outword ( hnum ) ;
else outdword ( hnum ) ;
break ;
}
}
else {
warningreg ( regs [ am32 ] [ DI ] ) ;
getintoreg_32 ( DI , ( am32 + 1 ) * 2 , 0 , & ofsst ) ;
if ( num < = 2 | | ( num < = 4 & & ( ! optimizespeed ) ) ) {
for ( unsigned int i = 0 ; i < num ; i + + ) {
if ( sized = = 1 ) stosb ( ) ;
else if ( sized = = 2 ) stosw ( ) ;
else stosd ( ) ;
}
}
else {
MovRegNum ( ( am32 + 1 ) * 2 , 0 , num , ECX ) ;
warningreg ( regs [ am32 ] [ CX ] ) ;
ConstToReg ( 0 , ECX , ( am32 + 1 ) * 2 ) ;
op ( 0xF3 ) ; // REPZ
if ( sized = = 1 ) stosb ( ) ;
else if ( sized = = 2 ) stosw ( ) ;
else stosd ( ) ;
}
}
nexttok ( ) ;
break ;
case tk_structvar :
struct structteg * tteg2 ;
int numel2 ;
int usenumstr2 ;
unsigned int num2 ;
int localstr2 ;
int poststr2 ;
int flagstr2 ;
// adr=itok.number;
localstr2 = FALSE ;
numel2 = itok . rm ; //<2F> <> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD>
usenumstr2 = itok . post ; //<2F> 뫮 㪠<> <E3AAA0> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD>
if ( itok . type = = tp_classvar ) {
tteg2 = ( structteg * ) itok . rec ;
poststr2 = 0 ;
flagstr2 = f_useidx ;
}
else {
struct idrec * ptrs ;
ptrs = itok . rec ;
tteg2 = ( structteg * ) ptrs - > newid ;
if ( ptrs - > recpost = = LOCAL ) localstr2 = TRUE ;
poststr2 = ptrs - > recpost ;
flagstr2 = ptrs - > flag ;
}
num2 = itok . size ;
// ptrs2=itok.rec;
// tteg2=(structteg *)ptrs2->newid;
// numel2=itok.rm; //<2F> <> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD>
// num2=tteg2->size;
if ( usenumstr2 ! = FALSE ) {
num2 = tteg - > size ;
if ( strinf . bufstr = = NULL ) starts = num2 * numel2 ;
}
// if(itok.post==FALSE)num2*=ptrs2->recrm; //<2F> <> 㪠<> <E3AAA0> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> - <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD>
// else if(strinf.bufstr==NULL)starts=num2*numel2;
if ( strinf . bufstr = = NULL ) itok . number + = starts ;
itok . sib = ( am32 = = FALSE ? CODE16 : CODE32 ) ;
if ( localstr2 ) {
itok . rm = rm_mod10 ;
if ( strinf . bufstr = = NULL ) {
if ( ESPloc & & am32 ) {
itok . rm | = rm_sib ;
itok . sib = 0x24 ;
}
else {
itok . rm | = ( am32 = = FALSE ? rm_BP : rm_EBP ) ;
}
}
else {
CheckAllMassiv ( bufrm , 2 , & strinf ) ;
if ( am32 = = FALSE ) itok . rm | = rm_BPSI ;
else {
itok . sib = ( ESPloc ? 0x34 : 0x35 ) ;
itok . rm = 4 | rm_mod10 ;
}
}
itok . segm = SS ;
if ( ESPloc & & am32 ) itok . number + = addESP ;
// else itok.number-=localsize;
tok = tk_rmnumber ;
itok . size = tteg2 - > size ;
itok . post = 0 ;
compressoffset ( & itok ) ;
}
else {
itok . post = poststr2 ;
itok . rm = ( am32 = = FALSE ? rm_d16 : rm_d32 ) ; //22.11.04 09:22//<2F> <> ⠭<EFBFBD> <E2A0AD> <EFBFBD> <EFBFBD> <20> <> 㬮<> 砭<EFBFBD> <E7A0AD>
if ( strinf . bufstr = = NULL ) {
if ( itok . post = = TRUE ) tok = tk_postnumber ;
else tok = tk_number ;
}
else {
CheckAllMassiv ( bufrm , 2 , & strinf ) ;
itok . rm = rm_mod10 | ( am32 = = FALSE ? rm_SI : 6 ) ;
tok = tk_rmnumber ;
itok . size = tteg2 - > size ;
}
itok . segm = DS ;
}
///!new
itok . flag = flagstr2 ;
warningreg ( regs [ am32 ] [ SI ] ) ;
///!new
// printf("tok=%d rm=%08X %s",tok,itok.rm,itok.name);
getintoreg_32 ( SI , ( am32 + 1 ) * 2 , 0 , & ofsst ) ;
ClearReg ( SI ) ;
num = tteg - > size ;
starts = 0 ;
if ( usenumstr = = FALSE ) num * = tteg - > size ; //ptrs->recrm; //<2F> <> 㪠<> <E3AAA0> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> - <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD>
else if ( rstr . bufstr = = NULL ) starts = num * numel ;
itok . number = adr ; //ptrs->recnumber;
if ( rstr . bufstr = = NULL ) itok . number + = starts ;
itok . sib = ( am32 = = FALSE ? CODE16 : CODE32 ) ;
if ( localstr ) {
// if(ptrs->recpost==LOCAL){
if ( ESPloc & & am32 ) {
itok . rm = rm_mod10 | rm_sib ;
itok . sib = 0x24 ;
itok . number + = addESP ;
}
else {
itok . rm = rm_mod10 | ( am32 = = FALSE ? rm_BP : rm_EBP ) ;
}
itok . segm = SS ;
tok = tk_rmnumber ;
itok . size = tteg - > size ;
itok . post = 0 ;
compressoffset ( & itok ) ;
if ( rstr . bufstr ! = NULL ) CheckAllMassiv ( bufrm , 2 , & rstr , & itok , EDI , EDX ) ;
}
else {
itok . post = poststr ; //ptrs->recpost;
itok . segm = DS ;
itok . rm = ( am32 = = FALSE ? rm_d16 : rm_d32 ) ; //<2F> <> ⠭<EFBFBD> <E2A0AD> <EFBFBD> <EFBFBD> <20> <> 㬮<> 砭<EFBFBD> <E7A0AD>
if ( rstr . bufstr = = NULL ) {
if ( itok . post = = TRUE ) tok = tk_postnumber ;
else tok = tk_number ;
}
else {
CheckAllMassiv ( bufrm , 2 , & rstr , & itok , EDI , EDX ) ;
tok = tk_rmnumber ;
itok . size = tteg - > size ;
}
}
///!new
itok . flag = flagstr ; //ptrs->flag;
warningreg ( regs [ am32 ] [ DI ] ) ;
if ( num2 > num ) warnsize ( ) ;
ClearReg ( DI ) ;
///!new
usenumstr2 = DS ;
if ( poststr2 = = LOCAL ) usenumstr2 = SS ;
getintoreg_32 ( DI , ( am32 + 1 ) * 2 , 0 , & ofsst ) ;
num = num2 ;
sized = 1 ;
if ( optimizespeed ) {
if ( ( num % 2 ) = = 0 ) sized = 2 ;
if ( chip > 2 & & ( num % 4 ) = = 0 ) sized = 4 ;
}
else {
if ( am32 = = FALSE ) {
if ( ( num % 2 ) = = 0 ) sized = 2 ;
}
else {
if ( chip > 2 & & ( num % 4 ) = = 0 ) sized = 4 ;
}
}
num / = sized ;
///!new
if ( num < = 2 | | ( num < = 4 & & ( ! optimizespeed & & usenumstr2 ! = SS ) ) ) {
for ( unsigned int i = 0 ; i < num ; i + + ) {
if ( usenumstr2 = = SS ) op ( 0x36 ) ;
if ( sized = = 1 ) movsb ( ) ;
else if ( sized = = 2 ) movsw ( ) ;
else movsd ( ) ;
}
}
else {
///!new
MovRegNum ( ( am32 + 1 ) * 2 , 0 , num , ECX ) ;
warningreg ( regs [ am32 ] [ CX ] ) ;
ConstToReg ( 0 , ECX , ( am32 + 1 ) * 2 ) ;
if ( comfile ! = file_w32 ) {
if ( poststr ) pushss ( ) ;
// if(ptrs->recpost==LOCAL)pushss();
else pushds ( ) ;
popes ( ) ;
}
op ( 0xF3 ) ; // REPZ
if ( usenumstr2 = = SS ) op ( 0x36 ) ;
if ( sized = = 1 ) movsb ( ) ;
else if ( sized = = 2 ) movsw ( ) ;
else movsd ( ) ;
}
break ;
default : errstruct ( ) ;
}
}
else {
nexttok ( ) ;
errstruct ( ) ;
}
if ( ofsst ) free ( ofsst ) ;
}
int SaveStruct ( int size , idrec * newrec )
{
int i = 0 ;
if ( ( startStartup + size ) < endStartup ) {
if ( alignword ) { //<2F> <> <EFBFBD> <E0AEA2> <EFBFBD> <EFBFBD> <20> <> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD>
if ( startStartup % 2 = = 1 ) i = 1 ;
}
if ( ( startStartup + size + i ) < = endStartup ) {
startStartup + = i ;
newrec - > recnumber = startStartup ; //<2F> <> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> 砫<EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD>
newrec - > recpost = FALSE ;
startStartup + = size ;
return TRUE ;
}
}
return FALSE ;
}
int CheckAsmName ( char * name )
{
char buf [ IDLENGTH ] ;
strcpy ( buf , name ) ;
strupr ( buf ) ;
return FastSearch ( ( unsigned char * ) asmMnem , ofsmnem , 0 , buf ) ;
}
void FastTok ( int mode , int * tok4 , ITOK * itok4 )
{
int useme ;
int next = 1 ;
* tok4 = tokens ;
itok4 - > type = tp_ucnovn ;
whitespace ( ) ; //<2F> ய<EFBFBD> <E0AEAF> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> ᨬ<> <E1A8AC> <EFBFBD> <EFBFBD> <EFBFBD>
if ( isalpha ( cha ) | | ( cha = = ' _ ' ) | | cha > = 0x80 ) { //<2F> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> 䨪<EFBFBD> <E4A8AA> <EFBFBD> <EFBFBD>
if ( mode = = 1 ) {
int i = 0 ;
do {
itok4 - > name [ i + + ] = cha ;
nextchar ( ) ;
} while ( CheckChar2 ( ) = = TRUE & & i < IDLENGTH ) ;
if ( i = = IDLENGTH ) i - - ;
itok4 - > name [ i ] = 0 ;
}
while ( CheckChar2 ( ) = = TRUE ) nextchar ( ) ; //<2F> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <> <E1ABAE>
* tok4 = tk_id ;
return ;
}
if ( isdigit ( cha ) ) { //<2F> <>
if ( mode = = 1 ) {
inptr - - ;
itok4 - > lnumber = scannumber ( & itok4 - > rm ) ;
}
else {
do {
nextchar ( ) ;
} while ( isdigit ( cha ) ) ;
}
* tok4 = tk_number ;
return ;
}
else switch ( cha ) {
case ' \" ' :
nextchar ( ) ; //<2F> <> ப<EFBFBD> <E0AEAA> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> ⠭<EFBFBD> <E2A0AD>
while ( cha ! = ' \" ' & & ! endoffile ) {
convert_char ( ) ;
nextchar ( ) ;
}
* tok4 = tk_string ;
break ;
case ' \' ' : //ᨬ<> <E1A8AC> <EFBFBD> 쭠<EFBFBD> <20> <> <EFBFBD> <EFBFBD> ⠭<EFBFBD> <E2A0AD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> 1 ᨬ<> <E1A8AC> <EFBFBD> <EFBFBD>
nextchar ( ) ;
while ( cha ! = ' \' ' & & ! endoffile ) { // special character
convert_char ( ) ;
nextchar ( ) ;
}
break ;
case ' / ' : nextchar ( ) ;
switch ( cha ) {
case ' * ' : nextchar ( ) ; //ᮬ<> <E1AEAC> <EFBFBD> <EFBFBD>
useme = 1 ;
if ( mode = = 2 ) itok4 - > number = inptr - 2 ;
while ( ! endoffile & & useme > 0 ) {
whitespace ( ) ;
if ( cha = = ' * ' ) {
nextchar ( ) ;
if ( cha = = ' / ' ) useme - - ;
else continue ;
}
else if ( cha = = ' / ' ) {
nextchar ( ) ;
if ( cha = = ' * ' ) useme + + ;
else continue ;
}
nextchar ( ) ;
}
if ( mode = = 2 ) * tok4 = tk_comment2 ;
else FastTok ( mode , tok4 , itok4 ) ;
if ( endoffile ) * tok4 = tk_eof ;
return ;
case ' / ' :
if ( mode = = 2 ) itok4 - > number = inptr - 2 ;
do {
nextchar ( ) ;
} while ( ! endoffile & & cha ! = 13 ) ; //<2F> <> ப<EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD>
if ( endoffile ) * tok4 = tk_eof ;
if ( mode = = 2 ) * tok4 = tk_comment1 ;
else FastTok ( mode , tok4 , itok4 ) ;
return ;
}
break ;
case ' # ' :
case ' ? ' :
nextchar ( ) ;
// tokscan(&tok,&itok,string);
FastTok ( 1 , tok4 , itok4 ) ;
// if((itok.number=GetDirective((char *)string))!=-1){
if ( * tok4 = = tk_id & & ( itok4 - > number = GetDirective ( itok4 - > name ) ) ! = - 1 ) {
* tok4 = tk_question ;
}
return ;
case ' ; ' : * tok4 = tk_semicolon ; break ;
case ' [ ' : * tok4 = tk_openblock ; break ;
case ' ] ' : * tok4 = tk_closeblock ; break ;
case ' ( ' : * tok4 = tk_openbracket ; break ;
case ' ) ' : * tok4 = tk_closebracket ; break ;
case ' { ' : * tok4 = tk_openbrace ; break ;
case ' } ' : * tok4 = tk_closebrace ; break ;
case ' , ' : * tok4 = tk_camma ; break ;
case ' : ' : * tok4 = tk_colon ; break ;
case 26 : * tok4 = tk_eof ; return ;
case 13 : * tok4 = tk_endline ; break ;
case ' \\ ' :
nextchar ( ) ;
if ( cha = = 13 ) {
FastTok ( mode , tok4 , itok4 ) ;
if ( tok = = tk_endline ) FastTok ( mode , tok4 , itok4 ) ;
return ;
}
break ;
case ' ! ' :
nextchar ( ) ;
if ( cha = = ' = ' ) {
* tok4 = tk_notequal ; //!=
itok4 - > type = tp_compare ;
}
else {
* tok4 = tk_not ;
next = 0 ;
}
break ;
case ' = ' :
nextchar ( ) ;
if ( cha = = ' = ' ) {
* tok4 = tk_equalto ; //==
itok4 - > type = tp_compare ;
}
else {
* tok4 = tk_assign ; //<2F> <> <EFBFBD> <EFBFBD> <E1A2AE> <EFBFBD>
next = 0 ;
}
break ;
case ' > ' :
nextchar ( ) ;
switch ( cha ) {
case ' > ' :
nextchar ( ) ;
if ( cha = = ' = ' ) * tok4 = tk_rrequals ; //ᤢ<> <E1A4A2> <20> <> ࠢ<EFBFBD> <20> <20> <> <EFBFBD> <EFBFBD> <E1A2AE> <EFBFBD> <EFBFBD> <EFBFBD>
else {
* tok4 = tk_rr ; //ᤢ<> <E1A4A2> <20> <> ࠢ<EFBFBD>
next = 0 ;
itok4 - > type = tp_opperand ;
}
break ;
case ' < ' : * tok4 = tk_swap ; break ; //<2F> <> <EFBFBD> <EFBFBD> <EFBFBD>
case ' = ' : * tok4 = tk_greaterequal ; itok4 - > type = tp_compare ; break ; //<2F> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> ࠢ<> <E0A0A2>
default : * tok4 = tk_greater ; next = 0 ; itok4 - > type = tp_compare ; break ; //<2F> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD>
}
break ;
case ' < ' :
nextchar ( ) ;
switch ( cha ) {
case ' < ' :
nextchar ( ) ;
if ( cha = = ' = ' ) * tok4 = tk_llequals ; //ᤢ<> <E1A4A2> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <20> <20> <> <EFBFBD> <EFBFBD> <E1A2AE> <EFBFBD> <EFBFBD> <EFBFBD>
else {
* tok4 = tk_ll ; //ᤢ<> <E1A4A2> <20> <> <EFBFBD> <EFBFBD> <EFBFBD>
next = 0 ;
itok4 - > type = tp_opperand ;
}
break ;
case ' > ' : * tok4 = tk_notequal ; itok4 - > type = tp_compare ; break ; //!=
case ' = ' : * tok4 = tk_lessequal ; itok4 - > type = tp_compare ; break ; //<2F> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> <EFBFBD> ࠢ<> <E0A0A2>
default : * tok4 = tk_less ; next = 0 ; itok4 - > type = tp_compare ; break ; //<2F> <> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD>
}
break ;
}
if ( next ) nextchar ( ) ;
}
void FindDirectiv ( )
//<2F> ७<E1AAAE> <E0A5AD> <EFBFBD> <20> <> <EFBFBD> <EFBFBD> <EFBFBD> <20> <> ४⨢<E0A5AA>
{
inptr = inptr2 ;
cha = cha2 ;
linenumber = linenum2 ;
do {
FastTok ( 0 ) ;
} while ( tok ! = tk_question & & tok ! = tk_eof ) ;
inptr2 = inptr ;
cha2 = cha ;
linenum2 = linenumber ;
}
unsigned long long scannumber ( int * rm )
{
int useme = 0 , binnum = 0 ;
unsigned char c ;
unsigned long long number = 0 ;
* rm = tokens ;
for ( int i = inptr ; ; i + + ) {
c = input [ i ] ;
unsigned char cc = c & ( unsigned char ) 0x5f ;
if ( cc > = ' A ' & & cc < = ' F ' ) {
if ( cc = = ' B ' & & binnum = = 1 ) binnum + + ;
else binnum = 3 ;
useme = 3 ;
}
else if ( c < ' 0 ' | | c > ' 9 ' ) {
if ( useme = = 0 & & c = = ' . ' & & input [ i + 1 ] ! = ' . ' ) { //float
binnum = 3 ;
useme + + ;
* rm = tk_double ;
* ( double * ) & number = atof ( ( char * ) & input [ inptr ] ) ;
// printf("float=%f %08X\n",*(float *)&number,*(long *)&number);
inptr = i + 1 ;
do {
nextchar ( ) ;
} while ( isdigit ( cha ) ) ;
if ( ( cha & 0x5f ) ! = ' E ' ) break ;
nextchar ( ) ;
if ( isdigit ( cha ) | | cha = = ' - ' ) {
do {
nextchar ( ) ;
} while ( isdigit ( cha ) ) ;
}
break ;
}
else if ( cc = = ' H ' ) { //hex
useme = 2 ;
binnum = 3 ;
break ;
}
break ;
}
else if ( c < ' 2 ' & & ( binnum = = 0 | | binnum = = 2 ) ) binnum + + ;
}
if ( binnum = = 2 ) goto cbinnum ;
if ( useme ! = 1 ) {
nextchar ( ) ;
if ( useme = = 2 ) goto hexnum ;
if ( cha = = ' 0 ' ) {
nextchar ( ) ;
switch ( cha & 0x5f ) {
case ' X ' : // hexadecimal number
nextchar ( ) ;
hexnum :
while ( isxdigit ( cha ) ) {
number * = 16 ;
if ( isdigit ( cha ) ) number + = cha - ' 0 ' ;
else number + = ( cha & 0x5f ) - ' 7 ' ;
nextchar ( ) ;
}
if ( useme = = 2 ) nextchar ( ) ;
useme + + ;
break ;
case ' B ' : // binary number
cbinnum :
nextchar ( ) ;
while ( cha = = ' 0 ' | | cha = = ' 1 ' ) {
number = number * 2 + ( cha - ' 0 ' ) ;
nextchar ( ) ;
}
if ( binnum = = 2 ) nextchar ( ) ;
else useme + + ;
break ;
case ' O ' : // octal number
nextchar ( ) ;
while ( cha > = ' 0 ' & & cha < = ' 7 ' ) {
number = number * 8 + ( cha - ' 0 ' ) ;
nextchar ( ) ;
}
useme + + ;
break ;
}
}
if ( useme = = 0 | | useme = = 3 ) { // decimal number
while ( isdigit ( cha ) ) {
number = number * 10 + ( cha - ' 0 ' ) ;
nextchar ( ) ;
}
}
}
c = ( unsigned char ) ( cha & 0x5F ) ;
if ( c = = ' I ' ) {
if ( input [ inptr ] = = ' 6 ' & & input [ inptr + 1 ] = = ' 4 ' ) {
inptr + = 2 ;
nextchar ( ) ;
* rm = tk_qword ;
}
}
else if ( c = = ' L ' | | c = = ' U ' | | c = = ' F ' | | c = = ' Q ' ) {
if ( c = = ' L ' ) * rm = tk_dword ;
if ( c = = ' F ' ) {
* rm = tk_float ;
* ( float * ) & number = * ( double * ) & number ;
}
if ( c = = ' Q ' ) * rm = tk_qword ;
nextchar ( ) ;
c = ( unsigned char ) ( cha & 0x5F ) ;
if ( c = = ' L ' | | c = = ' U ' ) {
if ( c = = ' L ' ) * rm = tk_dword ;
nextchar ( ) ;
}
}
if ( * rm = = tokens ) {
if ( number < 256 ) * rm = tk_byte ;
else if ( number < 65536 ) * rm = tk_word ;
else if ( number < 0x100000000LL ) * rm = tk_dword ;
else * rm = tk_qword ;
}
return number ;
}
void tag_massiv ( int * tok4 , ITOK * itok4 , unsigned char * string4 )
{
struct structteg * tteg ;
int number , tok , rm ;
tok = * tok4 ;
number = itok4 - > number ;
nextchar ( ) ;
//14.09.04 18:52
do {
FastTok ( 1 , tok4 , itok4 ) ;
strcpy ( ( char * ) string4 , itok4 - > name ) ;
searchtree2 ( definestart , itok4 , tok4 , string4 ) ;
} while ( * tok4 = = tk_endline ) ;
///////////////////
// printf("tok=%d %s\n",*tok4,itok4->name);
char * tn ;
if ( ( tn = strchr ( itok4 - > name , ' @ ' ) ) ! = NULL ) * tn = 0 ;
if ( ( tteg = FindTeg ( FALSE , itok4 - > name ) ) ! = NULL | | ( tteg = FindTeg ( TRUE , itok4 - > name ) ) ! = NULL ) {
// printf("tok=%d %s\n",*tok4,itok4->name);
itok4 - > number = 0 ;
dostructvar2 ( tok4 , itok4 , tteg , string4 ) ;
rm = RegToRM ( number , tok ) ;
// printf("tok=%d rm=%d %s\n",*tok4,itok4->rm,itok4->name);
if ( * tok4 = = tk_pointer & & itok4 - > type = = tk_proc ) {
itok4 - > sib = rm | rm_mod10 ;
itok4 - > flag & = ~ f_reloc ;
}
else if ( * tok4 ! = tk_proc & & * tok4 ! = tk_declare /*&&(itok4->flag&f_static) = = 0 <EFBFBD> <EFBFBD> 䥪 <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> ॣ <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> <EFBFBD> */ ) {
itok4 - > rm = rm_mod10 | rm ;
itok4 - > flag & = ~ f_reloc ;
}
if ( * tok4 = = tk_proc | | * tok4 = = tk_declare | | * tok4 = = tk_undefproc ) {
structadr . sib = THIS_REG ;
structadr . rm = number ;
}
else if ( * tok4 = = tk_id | | * tok4 = = tk_ID | | * tok4 = = tk_structvar ) {
* tok4 = tk_rmnumber ;
itok4 - > segm = ( splitdata = = FALSE ) ? DS : CS ;
itok4 - > post = 0 ;
}
if ( bufrm & & strcmp ( bufrm , " &this; " ) = = 0 ) {
free ( bufrm ) ;
bufrm = NULL ;
}
// printf("tok=%d rm=%d post=%d %s\n",*tok4,itok4->rm,itok4->post,itok4->name);
// if(strinf.bufstr)puts(strinf.bufstr);
}
else if ( displaytokerrors ) {
unknowntagstruct ( itok4 - > name ) ;
* tok4 = tk_number ;
}
}
int RegToRM ( int number , int tok4 )
{
int rm ;
if ( displaytokerrors ) {
if ( am32 = = FALSE & & tok4 = = tk_reg32 ) regBXDISIBPexpected ( ) ;
else if ( am32 & & tok4 = = tk_reg ) reg32expected ( ) ;
}
if ( am32 = = FALSE ) {
switch ( number ) {
case BX :
rm = rm_BX ;
break ;
case DI :
rm = rm_DI ;
break ;
case SI :
rm = rm_SI ;
break ;
case BP :
rm = rm_BP ;
break ;
default :
if ( displaytokerrors ) regBXDISIBPexpected ( ) ;
break ;
}
}
else rm = number ;
return rm ;
}
int CheckResName ( char * name )
{
char buf [ IDLENGTH ] ;
strcpy ( buf , name ) ;
strlwr ( buf ) ;
return FastSearch ( ( unsigned char * ) resMnem , ofsres , 3 , buf ) ;
}
int GetTokVar2 ( )
{
ITOK cstok ;
int i ;
unsigned char ocha = cha ;
unsigned int oinptr = inptr ;
int oline = linenumber ;
char odisplay = displaytokerrors ;
displaytokerrors = 0 ;
tokscan ( & i , & cstok , string2 ) ;
displaytokerrors = odisplay ;
switch ( i ) {
case tk_number :
cha = ocha ;
inptr = oinptr ;
linenumber = oline ;
case tk_int :
case tk_char :
case tk_long :
case tk_short :
case tk_byte :
case tk_word :
case tk_dword :
case tk_signed :
case tk_unsigned :
return i ;
}
cha = ocha ;
inptr = oinptr ;
linenumber = oline ;
return 0 ;
}
void GetTypeVar ( int * tok4 )
{
static int use = 0 ;
int i ;
if ( use ) return ;
use = 1 ;
i = GetTokVar2 ( ) ;
if ( * tok4 = = tk_signed ) {
if ( i = = tk_char | | i = = tk_int | | i = = tk_long ) {
* tok4 = i ;
i = GetTokVar2 ( ) ;
if ( * tok4 = = tk_long ) {
if ( i = = tk_long ) * tok4 = tk_qword ;
else if ( i ! = tk_int & & i ! = 0 & & displaytokerrors ) unknowntype ( ) ;
}
if ( * tok4 = = tk_int & & am32 ) * tok4 = tk_long ;
}
else if ( i = = tk_short ) {
i = GetTokVar2 ( ) ;
* tok4 = tk_int ;
if ( i ! = 0 & & i ! = tk_int & & displaytokerrors ) unknowntype ( ) ;
}
else if ( i = = 0 ) * tok4 = ( am32 = = 0 ? tk_int : tk_long ) ;
else if ( displaytokerrors ) unknowntype ( ) ;
}
else if ( * tok4 = = tk_unsigned ) {
switch ( i ) {
case tk_char :
* tok4 = tk_byte ;
break ;
case tk_int :
* tok4 = ( am32 = = 0 ? tk_word : tk_dword ) ;
break ;
case tk_long :
* tok4 = tk_dword ;
i = GetTokVar2 ( ) ;
if ( i = = tk_long ) * tok4 = tk_qword ;
else if ( i ! = tk_int & & i ! = 0 & & displaytokerrors ) unknowntype ( ) ;
break ;
case tk_short :
* tok4 = tk_word ;
i = GetTokVar2 ( ) ;
if ( i ! = 0 & & i ! = tk_int & & displaytokerrors ) unknowntype ( ) ;
break ;
case 0 :
* tok4 = ( am32 = = 0 ? tk_word : tk_dword ) ;
break ;
default :
if ( displaytokerrors ) unknowntype ( ) ;
}
}
else if ( i = = tk_int & & ( * tok4 = = tk_long | | * tok4 = = tk_short ) ) * tok4 = i ;
else if ( * tok4 = = tk_short ) * tok4 = tk_int ;
else if ( * tok4 = = tk_int & & ( ! ( idasm = = TRUE & & i = = tk_number ) ) & & am32 ) * tok4 = tk_long ;
else if ( i = = tk_long & & * tok4 = = tk_long ) * tok4 = tk_qword ;
use = 0 ;
}
int CheckDef ( )
{
int otok ;
if ( skipfind ! = LOCAL ) return FALSE ;
switch ( tok2 ) {
case tk_semicolon :
case tk_assign :
case tk_openblock :
case tk_openbracket :
case tk_camma :
case tk_openbrace :
return FALSE ;
}
otok = tok ;
searchtree2 ( definestart , & itok , & tok , string ) ;
if ( tok = = otok ) return FALSE ;
return TRUE ;
}
/* end of TOKA.C */