home *** CD-ROM | disk | FTP | other *** search
/ Source Code 1992 March / Source_Code_CD-ROM_Walnut_Creek_March_1992.iso / usenet / altsrcs / 1 / 1709 / regsub.c < prev    next >
C/C++ Source or Header  |  1990-12-28  |  2KB  |  87 lines

  1. /*
  2.  * regsub
  3.  *
  4.  *    Copyright (c) 1986 by University of Toronto.
  5.  *    Written by Henry Spencer.  Not derived from licensed software.
  6.  *
  7.  *    Permission is granted to anyone to use this software for any
  8.  *    purpose on any computer system, and to redistribute it freely,
  9.  *    subject to the following restrictions:
  10.  *
  11.  *    1. The author is not responsible for the consequences of use of
  12.  *        this software, no matter how awful, even if they arise
  13.  *        from defects in it.
  14.  *
  15.  *    2. The origin of this software must not be misrepresented, either
  16.  *        by explicit claim or by omission.
  17.  *
  18.  *    3. Altered versions must be plainly marked as such, and must not
  19.  *        be misrepresented as being the original software.
  20.  */
  21. #include "regexp.h"
  22. #define NULL    (char *)0
  23. /*
  24.  * The first byte of the regexp internal "program" is actually this magic
  25.  * number; the start node begins in the second byte.
  26.  */
  27. #define    MAGIC    0234
  28.  
  29.  
  30. #define CHARBITS 0377
  31. #ifndef CHARBITS
  32. #define    UCHARAT(p)    ((int)*(unsigned char *)(p))
  33. #else
  34. #define    UCHARAT(p)    ((int)*(p)&CHARBITS)
  35. #endif
  36.  
  37. /*
  38.  - regsub - perform substitutions after a regexp match
  39.  */
  40. void regsub(prog, source, dest)
  41. regexp *prog;
  42. char *source;
  43. char *dest;
  44. {
  45.     register char *src;
  46.     register char *dst;
  47.     register char c;
  48.     register int no;
  49.     register int len;
  50.     extern char *strncpy();
  51.  
  52.     if (!prog || !source || !dest) {
  53.         regerror("NULL parm to regsub");
  54.         return;
  55.     }
  56.     if (UCHARAT(prog->program) != MAGIC) {
  57.         regerror("damaged regexp fed to regsub");
  58.         return;
  59.     }
  60.  
  61.     src = source;
  62.     dst = dest;
  63.     while ((c = *src++) != '\0') {
  64.         if (c == '&')
  65.             no = 0;
  66.         else if (c == '\\' && '0' <= *src && *src <= '9')
  67.             no = *src++ - '0';
  68.         else
  69.             no = -1;
  70.  
  71.         if (no < 0) {    /* Ordinary character. */
  72.             if (c == '\\' && *src != '\0')
  73.                 c = *src++;
  74.             *dst++ = c;
  75.         } else if (prog->startp[no] != NULL && prog->endp[no] != NULL) {
  76.             len = (int)(prog->endp[no] - prog->startp[no]);
  77.             strncpy(dst, prog->startp[no], len);
  78.             dst += len;
  79.             if (len !=0 && *(dst-1) == '\0') { /* strncpy hit NUL. */
  80.                 regerror("damaged match string");
  81.                 return;
  82.             }
  83.         }
  84.     }
  85.     *dst++ = '\0';
  86. }
  87.