[2] | 1 | #define INCL_OS2
|
---|
| 2 | #define INCL_WIN
|
---|
| 3 |
|
---|
| 4 | #include <os2.h>
|
---|
| 5 | #include <ctype.h>
|
---|
| 6 | #include <stdlib.h>
|
---|
| 7 | #include <stdio.h>
|
---|
| 8 | #include <string.h>
|
---|
| 9 | #include "fm3dll.h"
|
---|
| 10 |
|
---|
| 11 | #pragma alloc_text(LITERAL,literal,index,fixup,wildcard)
|
---|
| 12 |
|
---|
| 13 |
|
---|
| 14 | INT index (const CHAR *s,const CHAR c) {
|
---|
| 15 |
|
---|
| 16 | CHAR *p;
|
---|
| 17 |
|
---|
| 18 | p = strchr(s,c);
|
---|
| 19 | if(p == NULL || !*p)
|
---|
| 20 | return -1;
|
---|
| 21 | return (INT)(p - s);
|
---|
| 22 | }
|
---|
| 23 |
|
---|
| 24 |
|
---|
| 25 | /*
|
---|
| 26 | * literal.c
|
---|
| 27 | * Translate a string with tokens in it according to several conventions:
|
---|
| 28 | * 1. \x1b translates to CHAR(0x1b)
|
---|
| 29 | * 2. \27 translates to CHAR(27)
|
---|
| 30 | * 3. \" translates to "
|
---|
| 31 | * 4. \' translates to '
|
---|
| 32 | * 5. \\ translates to \
|
---|
| 33 | * 6. \r translates to carriage return
|
---|
| 34 | * 7. \n translates to linefeed
|
---|
| 35 | * 8. \b translates to backspace
|
---|
| 36 | * 9. \t translates to tab
|
---|
| 37 | * 10. \a translates to bell
|
---|
| 38 | * 11. \f translates to formfeed
|
---|
| 39 | *
|
---|
| 40 | * Synopsis
|
---|
| 41 | * *s = "this\x20is\32a test of \\MSC\\CSM\7"
|
---|
| 42 | * literal(s);
|
---|
| 43 | *
|
---|
| 44 | * ( s now equals "this is a test of \MSC\CSM")
|
---|
| 45 | */
|
---|
| 46 |
|
---|
| 47 | #define HEX "0123456789ABCDEF"
|
---|
| 48 | #define DEC "0123456789"
|
---|
| 49 |
|
---|
| 50 | INT literal (CHAR *fsource) {
|
---|
| 51 |
|
---|
| 52 | register INT wpos,w;
|
---|
| 53 | INT len,oldw;
|
---|
| 54 | CHAR *fdestin,*freeme,wchar;
|
---|
| 55 |
|
---|
| 56 | if(!fsource ||
|
---|
| 57 | !*fsource)
|
---|
| 58 | return 0;
|
---|
| 59 | len = strlen(fsource) + 1;
|
---|
| 60 | freeme = fdestin = malloc(len + 1);
|
---|
| 61 | memset(fdestin,0,len); /* start out with zero'd string */
|
---|
| 62 |
|
---|
| 63 | w = 0; /* set index to first character */
|
---|
| 64 | while(fsource[w]) { /* until end of string */
|
---|
| 65 | switch(fsource[w]) {
|
---|
| 66 | case '\\':
|
---|
| 67 | switch(fsource[w + 1]) {
|
---|
| 68 | case 'x' : /* hexadecimal */
|
---|
| 69 | wchar = 0;
|
---|
| 70 | w += 2; /* get past "\x" */
|
---|
| 71 | if(index(HEX,(CHAR)toupper(fsource[w])) != -1) {
|
---|
| 72 | oldw = w;
|
---|
| 73 | while(((wpos = index(HEX,(CHAR)toupper(fsource[w]))) != -1) &&
|
---|
| 74 | w < oldw + 2) {
|
---|
| 75 | wchar = (CHAR)(wchar << 4) + (CHAR)wpos;
|
---|
| 76 | w++;
|
---|
| 77 | }
|
---|
| 78 | }
|
---|
| 79 | else
|
---|
| 80 | wchar = 'x'; /* just an x */
|
---|
| 81 | w--;
|
---|
| 82 | *fdestin++ = wchar;
|
---|
| 83 | break;
|
---|
| 84 |
|
---|
| 85 | case '\\' : /* we want a "\" */
|
---|
| 86 | w++;
|
---|
| 87 | *fdestin++ = '\\';
|
---|
| 88 | break;
|
---|
| 89 |
|
---|
| 90 | case 't' : /* tab CHAR */
|
---|
| 91 | w++;
|
---|
| 92 | *fdestin++ = '\t';
|
---|
| 93 | break;
|
---|
| 94 |
|
---|
| 95 | case 'n' : /* new line */
|
---|
| 96 | w++;
|
---|
| 97 | *fdestin++ = '\n';
|
---|
| 98 | break;
|
---|
| 99 |
|
---|
| 100 | case 'r' : /* carr return */
|
---|
| 101 | w++;
|
---|
| 102 | *fdestin++ = '\r';
|
---|
| 103 | break;
|
---|
| 104 |
|
---|
| 105 | case 'b' : /* back space */
|
---|
| 106 | w++;
|
---|
| 107 | *fdestin++ = '\b';
|
---|
| 108 | break;
|
---|
| 109 |
|
---|
| 110 | case 'f': /* formfeed */
|
---|
| 111 | w++;
|
---|
| 112 | *fdestin++ = '\x0c';
|
---|
| 113 | break;
|
---|
| 114 |
|
---|
| 115 | case 'a': /* bell */
|
---|
| 116 | w++;
|
---|
| 117 | *fdestin++ = '\07';
|
---|
| 118 | break;
|
---|
| 119 |
|
---|
| 120 | case '\'' : /* single quote */
|
---|
| 121 | w++;
|
---|
| 122 | *fdestin++ = '\'';
|
---|
| 123 | break;
|
---|
| 124 |
|
---|
| 125 | case '\"' : /* double quote */
|
---|
| 126 | w++;
|
---|
| 127 | *fdestin++ = '\"';
|
---|
| 128 | break;
|
---|
| 129 |
|
---|
| 130 | default : /* decimal */
|
---|
| 131 | w++; /* get past "\" */
|
---|
| 132 | wchar = 0;
|
---|
| 133 | if(index(DEC,fsource[w]) != -1) {
|
---|
| 134 | oldw = w;
|
---|
| 135 | do { /* cvt to binary */
|
---|
| 136 | wchar = (CHAR)(wchar * 10 + (fsource[w++] - 48));
|
---|
| 137 | } while (index(DEC,fsource[w]) != -1 && w < oldw + 3);
|
---|
| 138 | w--;
|
---|
| 139 | }
|
---|
| 140 | else
|
---|
| 141 | wchar = fsource[w];
|
---|
| 142 | *fdestin ++ = wchar;
|
---|
| 143 | break;
|
---|
| 144 | }
|
---|
| 145 | break;
|
---|
| 146 |
|
---|
| 147 | default :
|
---|
| 148 | *fdestin++ = fsource[w];
|
---|
| 149 | break;
|
---|
| 150 | }
|
---|
| 151 | w++;
|
---|
| 152 | }
|
---|
| 153 | *fdestin = 0; /* terminate the string */
|
---|
| 154 |
|
---|
| 155 | len = fdestin - freeme;
|
---|
| 156 | memcpy(fsource,freeme,len + 1); /* swap 'em */
|
---|
| 157 | free(freeme);
|
---|
| 158 |
|
---|
| 159 | return len; /* return length of string */
|
---|
| 160 | }
|
---|
| 161 |
|
---|
| 162 |
|
---|
| 163 |
|
---|
| 164 | INT wildcard (const CHAR *fstra,const CHAR *fcarda,const BOOL notfile) {
|
---|
| 165 |
|
---|
| 166 | /* returns TRUE if match */
|
---|
| 167 |
|
---|
| 168 | register const CHAR *fstr = fstra,*fcard = fcarda;
|
---|
| 169 | register INT wmatch = TRUE;
|
---|
| 170 |
|
---|
| 171 | while(wmatch && *fcard && *fstr) {
|
---|
| 172 | switch(*fcard) {
|
---|
| 173 | case '?' : /* character substitution */
|
---|
| 174 | fcard++;
|
---|
| 175 | if(notfile || (*fstr != '.' && *fstr != '/' && *fstr != '\\'))
|
---|
| 176 | fstr++; /* skip (match) next character */
|
---|
| 177 | break;
|
---|
| 178 |
|
---|
| 179 | case '*' :
|
---|
| 180 | /* find next non-wild character in wildcard */
|
---|
| 181 | while(*fcard && (*fcard == '?' || *fcard == '*'))
|
---|
| 182 | fcard++;
|
---|
| 183 | if(!*fcard) /* if last char of wildcard is *, it matches */
|
---|
| 184 | return TRUE;
|
---|
| 185 | /* skip until partition, match, or eos */
|
---|
| 186 | while(*fstr && toupper(*fstr) != toupper(*fcard) &&
|
---|
| 187 | (notfile || (*fstr != '\\' &&
|
---|
| 188 | *fstr != '/' && *fstr != '.')))
|
---|
| 189 | fstr++;
|
---|
| 190 | if(!notfile && !*fstr) /* implicit '.' */
|
---|
| 191 | if(*fcard == '.')
|
---|
| 192 | fcard++;
|
---|
| 193 | break;
|
---|
| 194 |
|
---|
| 195 | default :
|
---|
| 196 | if(!notfile && ((*fstr == '/' || *fstr == '\\') &&
|
---|
| 197 | (*fcard == '/' || *fcard == '\\')))
|
---|
| 198 | wmatch = TRUE;
|
---|
| 199 | else
|
---|
| 200 | wmatch = (toupper(*fstr) == toupper(*fcard));
|
---|
| 201 | fstr++;
|
---|
| 202 | fcard++;
|
---|
| 203 | break;
|
---|
| 204 | }
|
---|
| 205 | }
|
---|
| 206 |
|
---|
| 207 | if ((*fcard && *fcard != '*') || *fstr)
|
---|
| 208 | return 0;
|
---|
| 209 | else
|
---|
| 210 | return wmatch;
|
---|
| 211 | }
|
---|
| 212 |
|
---|
| 213 |
|
---|
| 214 | CHAR * fixup (const CHAR *orig,CHAR *dest,const INT maxlen,const INT datalen) {
|
---|
| 215 |
|
---|
| 216 | register const CHAR *o = orig;
|
---|
| 217 | register CHAR *d = dest,*tp;
|
---|
| 218 | CHAR temp[33] = "\\x";
|
---|
| 219 |
|
---|
| 220 | *d = 0;
|
---|
| 221 | if(orig) {
|
---|
| 222 | while((o - orig) <
|
---|
| 223 | datalen &&
|
---|
| 224 | (d - dest) < maxlen) {
|
---|
| 225 | if(!isprint(*o)) {
|
---|
| 226 | if(*o == '\r') {
|
---|
| 227 | *d = '\\';
|
---|
| 228 | d++;
|
---|
| 229 | *d = 'r';
|
---|
| 230 | d++;
|
---|
| 231 | }
|
---|
| 232 | else if(*o == '\n') {
|
---|
| 233 | *d = '\\';
|
---|
| 234 | d++;
|
---|
| 235 | *d = 'n';
|
---|
| 236 | d++;
|
---|
| 237 | }
|
---|
| 238 | else if(*o == '\b') {
|
---|
| 239 | *d = '\\';
|
---|
| 240 | d++;
|
---|
| 241 | *d = 'b';
|
---|
| 242 | d++;
|
---|
| 243 | }
|
---|
| 244 | else {
|
---|
| 245 | sprintf(&temp[2],"%02hx",*o);
|
---|
| 246 | tp = temp;
|
---|
| 247 | while(*tp)
|
---|
| 248 | *d++ = *tp++;
|
---|
| 249 | }
|
---|
| 250 | o++;
|
---|
| 251 | }
|
---|
| 252 | else {
|
---|
| 253 | if(*o == '\\') {
|
---|
| 254 | *d = '\\';
|
---|
| 255 | d++;
|
---|
| 256 | *d = '\\';
|
---|
| 257 | d++;
|
---|
| 258 | o++;
|
---|
| 259 | }
|
---|
| 260 | else
|
---|
| 261 | *d++ = *o++;
|
---|
| 262 | }
|
---|
| 263 | *d = 0;
|
---|
| 264 | }
|
---|
| 265 | }
|
---|
| 266 | return dest;
|
---|
| 267 | }
|
---|
| 268 |
|
---|