2020-02-15 20:01:48 +00:00
|
|
|
CHashDefineStr *DefineLoad(U8 *dname,U8 *st)
|
|
|
|
{//Create DEFINE hash entry with string.
|
2020-02-20 23:40:10 +00:00
|
|
|
CHashDefineStr *tmph=CAlloc(sizeof(CHashDefineStr));
|
|
|
|
tmph->type=HTT_DEFINE_STR;
|
|
|
|
tmph->str=StrNew(dname);
|
|
|
|
tmph->data=StrNew(st);
|
|
|
|
tmph->count=-1;
|
|
|
|
tmph->src_link=MStrPrint("AD:0x%X",Caller);
|
|
|
|
HashAdd(tmph,Fs->hash_table);
|
|
|
|
return tmph;
|
2020-02-15 20:01:48 +00:00
|
|
|
}
|
|
|
|
|
2020-02-16 00:26:51 +00:00
|
|
|
CHashDefineStr *DefineListLoad(U8 *dname,U8 *list)
|
2020-02-15 20:01:48 +00:00
|
|
|
{//Create DEFINE list. Not efficient, but handy.
|
2020-02-20 23:40:10 +00:00
|
|
|
I64 count=0;
|
|
|
|
U8 *ptr,**idx;
|
|
|
|
CHashDefineStr *tmph=CAlloc(sizeof(CHashDefineStr));
|
|
|
|
tmph->type=HTT_DEFINE_STR;
|
|
|
|
tmph->str=StrNew(dname);
|
|
|
|
tmph->src_link=MStrPrint("AD:0x%X",Caller);
|
|
|
|
ptr=list;
|
|
|
|
while (*ptr) {
|
|
|
|
if (*ptr!='@')
|
|
|
|
count++;
|
|
|
|
while (*ptr++);
|
|
|
|
}
|
|
|
|
tmph->data=MAlloc(ptr+1-list);
|
|
|
|
MemCopy(tmph->data,list,ptr+1-list);
|
|
|
|
tmph->count=count;
|
2020-02-15 20:01:48 +00:00
|
|
|
|
2020-02-20 23:40:10 +00:00
|
|
|
idx=tmph->sub_idx=MAlloc(count*sizeof(U8 *));
|
|
|
|
ptr=list;
|
|
|
|
while (*ptr) {
|
|
|
|
if (*ptr!='@')
|
|
|
|
*idx++=ptr;
|
|
|
|
while (*ptr++);
|
|
|
|
}
|
2020-02-15 20:01:48 +00:00
|
|
|
|
2020-02-20 23:40:10 +00:00
|
|
|
HashAdd(tmph,Fs->hash_table);
|
|
|
|
return tmph;
|
2020-02-15 20:01:48 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
U0 UndefinedDefine(U8 *dname)
|
|
|
|
{
|
2020-02-20 23:40:10 +00:00
|
|
|
ST_ERR_ST "Undefined Define: '%s'.\n",dname;
|
|
|
|
throw('UndefDef');
|
2020-02-15 20:01:48 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
U8 *Define(U8 *dname)
|
|
|
|
{//Look for DEFINE named in hash table, return ptr string.
|
2020-02-20 23:40:10 +00:00
|
|
|
CHashDefineStr *tmph;
|
|
|
|
if (tmph=HashFind(dname,Fs->hash_table,HTT_DEFINE_STR))
|
|
|
|
return tmph->data;
|
|
|
|
else if (dname)
|
|
|
|
UndefinedDefine(dname);
|
|
|
|
else
|
|
|
|
return NULL;
|
2020-02-15 20:01:48 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
U8 *DefineSub(I64 sub,U8 *dname)
|
|
|
|
{//Return DEFINE list entry indexed by number.
|
2020-02-20 23:40:10 +00:00
|
|
|
CHashDefineStr *tmph;
|
|
|
|
if (tmph=HashFind(dname,Fs->hash_table,HTT_DEFINE_STR)) {
|
|
|
|
if (0<=sub<tmph->count)
|
|
|
|
return tmph->sub_idx[sub];
|
|
|
|
else
|
|
|
|
return NULL;
|
|
|
|
} else if (dname)
|
|
|
|
UndefinedDefine(dname);
|
|
|
|
else
|
|
|
|
return NULL;
|
2020-02-15 20:01:48 +00:00
|
|
|
}
|
|
|
|
|
2020-02-16 00:20:04 +00:00
|
|
|
I64 DefineCount(U8 *dname)
|
|
|
|
{//Return count of entries in define list.
|
2020-02-20 23:40:10 +00:00
|
|
|
CHashDefineStr *tmph;
|
|
|
|
if (tmph=HashFind(dname,Fs->hash_table,HTT_DEFINE_STR))
|
|
|
|
return tmph->count;
|
|
|
|
else if (dname)
|
|
|
|
UndefinedDefine(dname);
|
|
|
|
else
|
|
|
|
return -1;
|
2020-02-15 20:01:48 +00:00
|
|
|
}
|
|
|
|
|
2020-02-16 00:26:51 +00:00
|
|
|
I64 DefineMatch(U8 *needle,U8 *haystack_list_dname,I64 flags=0)
|
2020-02-15 20:01:48 +00:00
|
|
|
{//Find match for string in define list.
|
2020-02-20 23:40:10 +00:00
|
|
|
return ListMatch(needle,Define(haystack_list_dname),flags);
|
2020-02-15 20:01:48 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
U0 DefinePrint(U8 *dname,U8 *src,...)
|
|
|
|
{//Create DEFINE entry with $LK,"Print",A="FI:::/Doc/Print.DD"$()ed string.
|
2020-02-20 23:40:10 +00:00
|
|
|
U8 *buf=StrPrintJoin(NULL,src,argc,argv);
|
|
|
|
DefineLoad(dname,buf);
|
|
|
|
Free(buf);
|
2020-02-15 20:01:48 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
U0 SysDefinesLoad()
|
|
|
|
{
|
2020-02-23 08:36:07 +00:00
|
|
|
DefineListLoad("ST_OFF_ON",
|
|
|
|
"Off\0"
|
|
|
|
"On\0");
|
|
|
|
|
|
|
|
DefineListLoad("ST_HTT_TYPES",
|
|
|
|
"ExportSysSym\0"
|
|
|
|
"ImportSysSym\0"
|
|
|
|
"DefineStr\0"
|
|
|
|
"GlbVar\0"
|
|
|
|
"Class\0"
|
|
|
|
"IntType\0"
|
|
|
|
"Funct\0"
|
|
|
|
"Word\0"
|
|
|
|
"DictWord\0"
|
|
|
|
"KeyWord\0"
|
|
|
|
"AsmKeyWord\0"
|
|
|
|
"OpCode\0"
|
|
|
|
"Reg\0"
|
|
|
|
"File\0"
|
|
|
|
"Module\0"
|
|
|
|
"HelpFile\0"
|
2020-03-01 01:59:50 +00:00
|
|
|
"Frame Ptr\0"
|
|
|
|
" \0 \0 \0 \0 \0 \0"
|
2020-02-23 08:36:07 +00:00
|
|
|
"Private\0"
|
|
|
|
"Public\0"
|
|
|
|
"Export\0"
|
|
|
|
"Import\0"
|
|
|
|
"Imm\0"
|
|
|
|
"Goto\0"
|
|
|
|
"Res\0"
|
|
|
|
"Unres\0"
|
|
|
|
"Local\0");
|
|
|
|
|
|
|
|
DefineListLoad("ST_DAYS_OF_WEEK",
|
|
|
|
"Sunday\0"
|
|
|
|
"Monday\0"
|
|
|
|
"Tuesday\0"
|
|
|
|
"Wednesday\0"
|
|
|
|
"Thursday\0"
|
|
|
|
"Friday\0"
|
|
|
|
"Saturday\0");
|
|
|
|
|
|
|
|
DefineListLoad("ST_MONTHS",
|
|
|
|
"January\0"
|
|
|
|
"February\0"
|
|
|
|
"March\0"
|
|
|
|
"April\0"
|
|
|
|
"May\0"
|
|
|
|
"June\0"
|
|
|
|
"July\0"
|
|
|
|
"August\0"
|
|
|
|
"September\0"
|
|
|
|
"October\0"
|
|
|
|
"November\0"
|
|
|
|
"December\0");
|
|
|
|
|
|
|
|
DefineListLoad("ST_FILE_ATTRS",
|
|
|
|
"R\0"
|
|
|
|
"H\0"
|
|
|
|
"S\0"
|
|
|
|
"V\0"
|
|
|
|
"D\0"
|
|
|
|
"A\0"
|
2020-03-01 01:59:50 +00:00
|
|
|
" \0"
|
|
|
|
" \0"
|
2020-02-23 08:36:07 +00:00
|
|
|
"X\0"
|
|
|
|
"T\0"
|
|
|
|
"C\0"
|
|
|
|
"F\0");
|
|
|
|
|
|
|
|
DefineListLoad("ST_FILE_UTIL_FLAGS",
|
|
|
|
"r\0"
|
|
|
|
"d\0"
|
|
|
|
"i\0"
|
|
|
|
"a\0"
|
|
|
|
"c\0"
|
|
|
|
"R\0"
|
|
|
|
"p\0"
|
|
|
|
"m\0"
|
|
|
|
"s\0"
|
|
|
|
"D\0"
|
|
|
|
"F\0"
|
|
|
|
"T\0"
|
|
|
|
"$$\0"
|
|
|
|
"S\0"
|
|
|
|
"A\0"
|
|
|
|
"J\0"
|
|
|
|
"G\0"
|
|
|
|
"O\0"
|
|
|
|
"P\0"
|
|
|
|
"f\0"
|
|
|
|
"l\0"
|
|
|
|
"lb\0"
|
|
|
|
"la\0");
|
|
|
|
|
2020-02-20 23:40:10 +00:00
|
|
|
DefineListLoad("ST_BLKDEV_TYPES",
|
|
|
|
"NULL\0RAM\0ATA\0FILE_READ\0FILE_WRITE\0ATAPI\0");
|
|
|
|
DefineListLoad("ST_DRIVE_TYPES",
|
|
|
|
"NULL\0REDSEA\0FAT32\0ISO9660\0NTFS\0UNKNOWN\0");
|
|
|
|
DefineListLoad("ST_COLORS","BLACK\0BLUE\0GREEN\0CYAN\0"
|
|
|
|
"RED\0PURPLE\0BROWN\0LTGRAY\0DKGRAY\0LTBLUE\0LTGREEN\0"
|
|
|
|
"LTCYAN\0LTRED\0LTPURPLE\0YELLOW\0WHITE\0");
|
2020-02-28 05:58:31 +00:00
|
|
|
DefineListLoad("ST_INT_NAMES",
|
|
|
|
"Divide Error\0"
|
|
|
|
"SingleStep\0"
|
|
|
|
"NMI\0"
|
|
|
|
"Breakpoint\0"
|
|
|
|
"Overflow\0"
|
|
|
|
"BOUND Range Exceeded\0"
|
|
|
|
"Invalid Opcode\0"
|
|
|
|
"No Math Coprocessor\0"
|
|
|
|
"Double Fault\0"
|
|
|
|
"Coprocessor Segment Fault\0"
|
|
|
|
"Invalid TASK\0"
|
|
|
|
"Segment Not Present\0"
|
|
|
|
"Stack Segment Fault\0"
|
|
|
|
"General Protection\0"
|
|
|
|
"Page Fault\0"
|
2020-03-01 01:59:50 +00:00
|
|
|
" \0"
|
2020-02-28 05:58:31 +00:00
|
|
|
"Math Fault\0"
|
|
|
|
"Alignment Check\0"
|
|
|
|
"Machine Check\0"
|
|
|
|
"SIMD Exception\0"
|
2020-03-01 01:59:50 +00:00
|
|
|
" \0 \0 \0 \0 \0 \0 \0 \0 \0 \0 \0 \0 \0 \0 \0 \0 \0 \0 \0 \0 \0 \0 \0 \0 \0 \0 \0 \0"
|
2020-02-28 05:58:31 +00:00
|
|
|
"MP Crash\0"
|
|
|
|
"Wake\0"
|
|
|
|
"Debug\0");
|
2020-02-15 20:01:48 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
U8 *Color2Str(U8 *buf,CColorROPU32 c)
|
|
|
|
{//$LK,"CColorROPU32",A="MN:CColorROPU32"$ with flags to $LK,"DCLighting",A="MN:DCLighting"$ str.
|
2020-02-20 23:40:10 +00:00
|
|
|
*buf=0;
|
|
|
|
if (c.c0.rop&ROPBF_TWO_SIDED)
|
|
|
|
CatPrint(buf,"TWO|");
|
|
|
|
if (c.c0.rop&ROPBF_HALF_RANGE_COLOR)
|
|
|
|
CatPrint(buf,"HALF|");
|
|
|
|
if (0<=c.c0.color<16)
|
|
|
|
CatPrint(buf,DefineSub(c.c0.color,"ST_COLORS"));
|
|
|
|
else if (c.c0.color==TRANSPARENT)
|
|
|
|
CatPrint(buf,"TRANSPARENT");
|
|
|
|
else
|
|
|
|
CatPrint(buf,"INVALID");
|
|
|
|
if (c&ROPF_DITHER) {
|
|
|
|
CatPrint(buf,"/");
|
|
|
|
if (c.c1.rop&ROPBF_TWO_SIDED)
|
|
|
|
CatPrint(buf,"TWO|");
|
|
|
|
if (c.c1.rop&ROPBF_HALF_RANGE_COLOR)
|
|
|
|
CatPrint(buf,"HALF|");
|
|
|
|
if (0<=c.c1.color<16)
|
|
|
|
CatPrint(buf,DefineSub(c.c1.color,"ST_COLORS"));
|
|
|
|
else if (c.c1.color==TRANSPARENT)
|
|
|
|
CatPrint(buf,"TRANSPARENT");
|
|
|
|
else
|
|
|
|
CatPrint(buf,"INVALID");
|
|
|
|
}
|
|
|
|
return buf;
|
2020-02-15 20:01:48 +00:00
|
|
|
}
|
|
|
|
|
2020-02-16 00:26:51 +00:00
|
|
|
U8 *str2color_list="/,)}>";
|
2020-02-15 20:01:48 +00:00
|
|
|
|
|
|
|
CColorROPU16 Str2ColorU16(U8 *st)
|
|
|
|
{//$LK,"DCLighting",A="MN:DCLighting"$ color str with flags to $LK,"CColorROPU16",A="MN:CColorROPU16"$.
|
2020-02-20 23:40:10 +00:00
|
|
|
CColorROPU16 res=COLOR_INVALID;
|
|
|
|
I64 i;
|
|
|
|
U8 *ptr,*ptr2,*st2;
|
|
|
|
if (!st) return COLOR_INVALID;
|
|
|
|
while (TRUE) {
|
|
|
|
if (!*st||StrOcc(str2color_list,*st))
|
|
|
|
return res;
|
|
|
|
if (Bt(char_bmp_alpha,*st)) {
|
|
|
|
ptr=st;
|
|
|
|
while (Bt(char_bmp_alpha_numeric,*ptr))
|
|
|
|
ptr++;
|
|
|
|
st2=ptr2=MAlloc(ptr-st+1);
|
|
|
|
while (st<ptr)
|
|
|
|
*ptr2++=*st++;
|
|
|
|
*ptr2++=0;
|
|
|
|
if (!StrICompare(st2,"TWO"))
|
|
|
|
res.rop|=ROPBF_TWO_SIDED;
|
|
|
|
else if (!StrICompare(st2,"HALF"))
|
|
|
|
res.rop|=ROPBF_HALF_RANGE_COLOR;
|
|
|
|
else if ((i=DefineMatch(st2,"ST_COLORS",LMF_IGNORE_CASE))>=0)
|
|
|
|
res.color=i;
|
|
|
|
else if (!StrICompare(st2,"TRANSPARENT"))
|
|
|
|
res.color=TRANSPARENT;
|
|
|
|
else {
|
|
|
|
Free(st2);
|
|
|
|
return COLOR_INVALID;
|
|
|
|
}
|
|
|
|
Free(st2);
|
|
|
|
} else if (*st=='+'||*st=='|'||Bt(char_bmp_white_space,*st))
|
|
|
|
st++;
|
|
|
|
else if ('0'<=*st<='9') {
|
|
|
|
i=Str2I64(st,10,&ptr);
|
|
|
|
if (0<=i<=0xFF) {
|
|
|
|
res.color=i;
|
|
|
|
st=ptr;
|
|
|
|
} else
|
|
|
|
return COLOR_INVALID;
|
|
|
|
} else
|
|
|
|
return COLOR_INVALID;
|
|
|
|
}
|
2020-02-15 20:01:48 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
CColorROPU32 Str2ColorU32(U8 *st)
|
|
|
|
{//$LK,"DCLighting",A="MN:DCLighting"$ color str with flags to $LK,"CColorROPU32",A="MN:CColorROPU32"$.
|
2020-02-20 23:40:10 +00:00
|
|
|
U8 *st2;
|
|
|
|
CColorROPU32 res=0;
|
|
|
|
if (!st) return COLOR_INVALID;
|
|
|
|
st2=MAlloc(StrLen(st)+1);
|
|
|
|
StrFirstRemove(st,str2color_list,st2);
|
|
|
|
res.c0=Str2ColorU16(st2);
|
|
|
|
if (*st) {
|
|
|
|
res.c1=Str2ColorU16(st);
|
|
|
|
res|=ROPF_DITHER;
|
|
|
|
}
|
|
|
|
if (res.c0.color==COLOR_INVALID||res.c1.color==COLOR_INVALID)
|
|
|
|
return COLOR_INVALID;
|
|
|
|
else
|
|
|
|
return res;
|
2020-02-15 20:01:48 +00:00
|
|
|
}
|