home *** CD-ROM | disk | FTP | other *** search
/ InfoMagic Source Code 1993 July / THE_SOURCE_CODE_CD_ROM.iso / bsd_srcs / usr.bin / window / string.c < prev    next >
Encoding:
C/C++ Source or Header  |  1991-04-18  |  3.6 KB  |  154 lines

  1. /*
  2.  * Copyright (c) 1983 Regents of the University of California.
  3.  * All rights reserved.
  4.  *
  5.  * This code is derived from software contributed to Berkeley by
  6.  * Edward Wang at The University of California, Berkeley.
  7.  *
  8.  * Redistribution and use in source and binary forms, with or without
  9.  * modification, are permitted provided that the following conditions
  10.  * are met:
  11.  * 1. Redistributions of source code must retain the above copyright
  12.  *    notice, this list of conditions and the following disclaimer.
  13.  * 2. Redistributions in binary form must reproduce the above copyright
  14.  *    notice, this list of conditions and the following disclaimer in the
  15.  *    documentation and/or other materials provided with the distribution.
  16.  * 3. All advertising materials mentioning features or use of this software
  17.  *    must display the following acknowledgement:
  18.  *    This product includes software developed by the University of
  19.  *    California, Berkeley and its contributors.
  20.  * 4. Neither the name of the University nor the names of its contributors
  21.  *    may be used to endorse or promote products derived from this software
  22.  *    without specific prior written permission.
  23.  *
  24.  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
  25.  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  26.  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  27.  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
  28.  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  29.  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  30.  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  31.  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  32.  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  33.  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  34.  * SUCH DAMAGE.
  35.  */
  36.  
  37. #ifndef lint
  38. static char sccsid[] = "@(#)string.c    3.13 (Berkeley) 6/6/90";
  39. #endif /* not lint */
  40.  
  41. #include "string.h"
  42.  
  43. char *malloc();
  44.  
  45. char *
  46. str_cpy(s)
  47. register char *s;
  48. {
  49.     char *str;
  50.     register char *p;
  51.  
  52.     str = p = str_alloc(strlen(s) + 1);
  53.     if (p == 0)
  54.         return 0;
  55.     while (*p++ = *s++)
  56.         ;
  57.     return str;
  58. }
  59.  
  60. char *
  61. str_ncpy(s, n)
  62. register char *s;
  63. register n;
  64. {
  65.     int l = strlen(s);
  66.     char *str;
  67.     register char *p;
  68.  
  69.     if (n > l)
  70.         n = l;
  71.     str = p = str_alloc(n + 1);
  72.     if (p == 0)
  73.         return 0;
  74.     while (--n >= 0)
  75.         *p++ = *s++;
  76.     *p = 0;
  77.     return str;
  78. }
  79.  
  80. char *
  81. str_itoa(i)
  82. int i;
  83. {
  84.     char buf[30];
  85.  
  86.     (void) sprintf(buf, "%d", i);
  87.     return str_cpy(buf);
  88. }
  89.  
  90. char *
  91. str_cat(s1, s2)
  92. char *s1, *s2;
  93. {
  94.     char *str;
  95.     register char *p, *q;
  96.  
  97.     str = p = str_alloc(strlen(s1) + strlen(s2) + 1);
  98.     if (p == 0)
  99.         return 0;
  100.     for (q = s1; *p++ = *q++;)
  101.         ;
  102.     for (q = s2, p--; *p++ = *q++;)
  103.         ;
  104.     return str;
  105. }
  106.  
  107. /*
  108.  * match s against p.
  109.  * s can be a prefix of p with at least min characters.
  110.  */
  111. str_match(s, p, min)
  112. register char *s, *p;
  113. register min;
  114. {
  115.     for (; *s && *p && *s == *p; s++, p++, min--)
  116.         ;
  117.     return *s == *p || *s == 0 && min <= 0;
  118. }
  119.  
  120. #ifdef STR_DEBUG
  121. char *
  122. str_alloc(l)
  123. int l;
  124. {
  125.     register struct string *s;
  126.  
  127.     s = (struct string *) malloc((unsigned)l + str_offset);
  128.     if (s == 0)
  129.         return 0;
  130.     if (str_head.s_forw == 0)
  131.         str_head.s_forw = str_head.s_back = &str_head;
  132.     s->s_forw = str_head.s_forw;
  133.     s->s_back = &str_head;
  134.     str_head.s_forw = s;
  135.     s->s_forw->s_back = s;
  136.     return s->s_data;
  137. }
  138.  
  139. str_free(str)
  140. char *str;
  141. {
  142.     register struct string *s;
  143.  
  144.     for (s = str_head.s_forw; s != &str_head && s->s_data != str;
  145.          s = s->s_forw)
  146.         ;
  147.     if (s == &str_head)
  148.         abort();
  149.     s->s_back->s_forw = s->s_forw;
  150.     s->s_forw->s_back = s->s_back;
  151.     free((char *)s);
  152. }
  153. #endif
  154.