1: /* $Header: util.c,v 1.0.1.1 88/01/28 11:06:35 root Exp $ 2: * 3: * $Log: util.c,v $ 4: * Revision 1.0.1.1 88/01/28 11:06:35 root 5: * patch8: changed fatal() to support eval operator with exiting. 6: * 7: * Revision 1.0 87/12/18 13:06:30 root 8: * Initial revision 9: * 10: */ 11: 12: #include <stdio.h> 13: 14: #include "handy.h" 15: #include "EXTERN.h" 16: #include "search.h" 17: #include "perl.h" 18: #include "INTERN.h" 19: #include "util.h" 20: 21: #define FLUSH 22: #define MEM_SIZE unsigned int 23: 24: static char nomem[] = "Out of memory!\n"; 25: 26: /* paranoid version of malloc */ 27: 28: static int an = 0; 29: 30: char * 31: safemalloc(size) 32: MEM_SIZE size; 33: { 34: char *ptr; 35: char *malloc(); 36: 37: ptr = malloc(size?size:1); /* malloc(0) is NASTY on our system */ 38: #ifdef DEBUGGING 39: if (debug & 128) 40: fprintf(stderr,"0x%x: (%05d) malloc %d bytes\n",ptr,an++,size); 41: #endif 42: if (ptr != Nullch) 43: return ptr; 44: else { 45: fputs(nomem,stdout) FLUSH; 46: exit(1); 47: } 48: /*NOTREACHED*/ 49: } 50: 51: /* paranoid version of realloc */ 52: 53: char * 54: saferealloc(where,size) 55: char *where; 56: MEM_SIZE size; 57: { 58: char *ptr; 59: char *realloc(); 60: 61: ptr = realloc(where,size?size:1); /* realloc(0) is NASTY on our system */ 62: #ifdef DEBUGGING 63: if (debug & 128) { 64: fprintf(stderr,"0x%x: (%05d) rfree\n",where,an++); 65: fprintf(stderr,"0x%x: (%05d) realloc %d bytes\n",ptr,an++,size); 66: } 67: #endif 68: if (ptr != Nullch) 69: return ptr; 70: else { 71: fputs(nomem,stdout) FLUSH; 72: exit(1); 73: } 74: /*NOTREACHED*/ 75: } 76: 77: /* safe version of free */ 78: 79: safefree(where) 80: char *where; 81: { 82: #ifdef DEBUGGING 83: if (debug & 128) 84: fprintf(stderr,"0x%x: (%05d) free\n",where,an++); 85: #endif 86: free(where); 87: } 88: 89: /* safe version of string copy */ 90: 91: char * 92: safecpy(to,from,len) 93: char *to; 94: register char *from; 95: register int len; 96: { 97: register char *dest = to; 98: 99: if (from != Nullch) 100: for (len--; len && (*dest++ = *from++); len--) ; 101: *dest = '\0'; 102: return to; 103: } 104: 105: #ifdef undef 106: /* safe version of string concatenate, with \n deletion and space padding */ 107: 108: char * 109: safecat(to,from,len) 110: char *to; 111: register char *from; 112: register int len; 113: { 114: register char *dest = to; 115: 116: len--; /* leave room for null */ 117: if (*dest) { 118: while (len && *dest++) len--; 119: if (len) { 120: len--; 121: *(dest-1) = ' '; 122: } 123: } 124: if (from != Nullch) 125: while (len && (*dest++ = *from++)) len--; 126: if (len) 127: dest--; 128: if (*(dest-1) == '\n') 129: dest--; 130: *dest = '\0'; 131: return to; 132: } 133: #endif 134: 135: /* copy a string up to some (non-backslashed) delimiter, if any */ 136: 137: char * 138: cpytill(to,from,delim) 139: register char *to, *from; 140: register int delim; 141: { 142: for (; *from; from++,to++) { 143: if (*from == '\\' && from[1] == delim) 144: from++; 145: else if (*from == delim) 146: break; 147: *to = *from; 148: } 149: *to = '\0'; 150: return from; 151: } 152: 153: /* return ptr to little string in big string, NULL if not found */ 154: 155: char * 156: instr(big, little) 157: char *big, *little; 158: 159: { 160: register char *t, *s, *x; 161: 162: for (t = big; *t; t++) { 163: for (x=t,s=little; *s; x++,s++) { 164: if (!*x) 165: return Nullch; 166: if (*s != *x) 167: break; 168: } 169: if (!*s) 170: return t; 171: } 172: return Nullch; 173: } 174: 175: /* copy a string to a safe spot */ 176: 177: char * 178: savestr(str) 179: char *str; 180: { 181: register char *newaddr = safemalloc((MEM_SIZE)(strlen(str)+1)); 182: 183: (void)strcpy(newaddr,str); 184: return newaddr; 185: } 186: 187: /* grow a static string to at least a certain length */ 188: 189: void 190: growstr(strptr,curlen,newlen) 191: char **strptr; 192: int *curlen; 193: int newlen; 194: { 195: if (newlen > *curlen) { /* need more room? */ 196: if (*curlen) 197: *strptr = saferealloc(*strptr,(MEM_SIZE)newlen); 198: else 199: *strptr = safemalloc((MEM_SIZE)newlen); 200: *curlen = newlen; 201: } 202: } 203: 204: /*VARARGS1*/ 205: fatal(pat,a1,a2,a3,a4) 206: char *pat; 207: { 208: extern FILE *e_fp; 209: extern char *e_tmpname; 210: 211: if (in_eval) { 212: sprintf(tokenbuf,pat,a1,a2,a3,a4); 213: str_set(stabent("@",TRUE)->stab_val,tokenbuf); 214: longjmp(eval_env,1); 215: } 216: fprintf(stderr,pat,a1,a2,a3,a4); 217: if (e_fp) 218: UNLINK(e_tmpname); 219: exit(1); 220: } 221: 222: static bool firstsetenv = TRUE; 223: extern char **environ; 224: 225: void 226: PL_setenv(nam,val) 227: char *nam, *val; 228: { 229: register int i=envix(nam); /* where does it go? */ 230: 231: if (!environ[i]) { /* does not exist yet */ 232: if (firstsetenv) { /* need we copy environment? */ 233: int j; 234: #ifndef lint 235: char **tmpenv = (char**) /* point our wand at memory */ 236: safemalloc((i+2) * sizeof(char*)); 237: #else 238: char **tmpenv = Null(char **); 239: #endif /* lint */ 240: 241: firstsetenv = FALSE; 242: for (j=0; j<i; j++) /* copy environment */ 243: tmpenv[j] = environ[j]; 244: environ = tmpenv; /* tell exec where it is now */ 245: } 246: #ifndef lint 247: else 248: environ = (char**) saferealloc((char*) environ, 249: (i+2) * sizeof(char*)); 250: /* just expand it a bit */ 251: #endif /* lint */ 252: environ[i+1] = Nullch; /* make sure it's null terminated */ 253: } 254: environ[i] = safemalloc(strlen(nam) + strlen(val) + 2); 255: /* this may or may not be in */ 256: /* the old environ structure */ 257: sprintf(environ[i],"%s=%s",nam,val);/* all that work just for this */ 258: } 259: 260: int 261: envix(nam) 262: char *nam; 263: { 264: register int i, len = strlen(nam); 265: 266: for (i = 0; environ[i]; i++) { 267: if (strnEQ(environ[i],nam,len) && environ[i][len] == '=') 268: break; /* strnEQ must come first to avoid */ 269: } /* potential SEGV's */ 270: return i; 271: }