386BSD 0.1 development
authorWilliam F. Jolitz <wjolitz@soda.berkeley.edu>
Thu, 27 Jun 1991 03:45:44 +0000 (19:45 -0800)
committerWilliam F. Jolitz <wjolitz@soda.berkeley.edu>
Thu, 27 Jun 1991 03:45:44 +0000 (19:45 -0800)
Work on file usr/src/bin/csh/str.c

Co-Authored-By: Lynne Greer Jolitz <ljolitz@cardio.ucsf.edu>
Synthesized-from: 386BSD-0.1

usr/src/bin/csh/str.c [new file with mode: 0644]

diff --git a/usr/src/bin/csh/str.c b/usr/src/bin/csh/str.c
new file mode 100644 (file)
index 0000000..f7ddcec
--- /dev/null
@@ -0,0 +1,416 @@
+/*-
+ * Copyright (c) 1991 The Regents of the University of California.
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ *    notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ *    notice, this list of conditions and the following disclaimer in the
+ *    documentation and/or other materials provided with the distribution.
+ * 3. All advertising materials mentioning features or use of this software
+ *    must display the following acknowledgement:
+ *     This product includes software developed by the University of
+ *     California, Berkeley and its contributors.
+ * 4. Neither the name of the University nor the names of its contributors
+ *    may be used to endorse or promote products derived from this software
+ *    without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
+ * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
+ * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
+ * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
+ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
+ * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
+ */
+
+#ifndef lint
+static char sccsid[] = "@(#)str.c      5.5 (Berkeley) 6/27/91";
+#endif /* not lint */
+
+/*
+ * tc.str.c: Short string package
+ *          This has been a lesson of how to write buggy code!
+ */
+#ifdef SHORT_STRINGS
+
+#if __STDC__
+# include <stdarg.h>
+#else
+# include <varargs.h>
+#endif
+
+#include "csh.h"
+#include "extern.h"
+
+Char  **
+blk2short(src)
+    register char **src;
+{
+    size_t     n;
+    register Char **sdst, **dst;
+
+    /*
+     * Count
+     */
+    for (n = 0; src[n] != NULL; n++);
+    sdst = dst = (Char **) xmalloc((size_t) ((n + 1) * sizeof(Char *)));
+
+    for (; *src != NULL; src++)
+       *dst++ = SAVE(*src);
+    *dst = NULL;
+    return (sdst);
+}
+
+char  **
+short2blk(src)
+    register Char **src;
+{
+    size_t     n;
+    register char **sdst, **dst;
+
+    /*
+     * Count
+     */
+    for (n = 0; src[n] != NULL; n++);
+    sdst = dst = (char **) xmalloc((size_t) ((n + 1) * sizeof(char *)));
+
+    for (; *src != NULL; src++)
+       *dst++ = strsave(short2str(*src));
+    *dst = NULL;
+    return (sdst);
+}
+
+#define MALLOC_INCR    1024
+Char   *
+str2short(src)
+    register char *src;
+{
+    static Char *sdst;
+    static size_t dstsize = 0;
+    register Char *dst, *edst;
+
+    if (src == NULL)
+       return (NULL);
+
+    if (sdst == (NULL)) {
+       dstsize = MALLOC_INCR;
+       sdst = (Char *) xmalloc((size_t) dstsize * sizeof(Char));
+    }
+
+    dst = sdst;
+    edst = &dst[dstsize];
+    while (*src) {
+       *dst++ = (Char) ((unsigned char) *src++);
+       if (dst == edst) {
+           dstsize += MALLOC_INCR;
+           sdst = (Char *) xrealloc((ptr_t) sdst,
+                                    (size_t) dstsize * sizeof(Char));
+           edst = &sdst[dstsize];
+           dst = &edst[-MALLOC_INCR];
+       }
+    }
+    *dst = 0;
+    return (sdst);
+}
+
+char   *
+short2qstr(src)
+    register Char *src;
+{
+    static char *sdst = NULL;
+    static size_t dstsize = 0;
+    register char *dst, *edst;
+
+    if (src == NULL)
+       return (NULL);
+
+    if (sdst == NULL) {
+       dstsize = MALLOC_INCR;
+       sdst = (char *) xmalloc((size_t) dstsize * sizeof(char));
+    }
+    dst = sdst;
+    edst = &dst[dstsize];
+    while (*src) {
+       if (*src & QUOTE) {
+           *dst++ = '\\';
+           if (dst == edst) {
+               dstsize += MALLOC_INCR;
+               sdst = (char *) xrealloc((ptr_t) sdst,
+                                        (size_t) dstsize * sizeof(char));
+               edst = &sdst[dstsize];
+               dst = &edst[-MALLOC_INCR];
+           }
+       }
+       *dst++ = (char) *src++;
+       if (dst == edst) {
+           dstsize += MALLOC_INCR;
+           sdst = (char *) xrealloc((ptr_t) sdst,
+                                    (size_t) dstsize * sizeof(char));
+           edst = &sdst[dstsize];
+           dst = &edst[-MALLOC_INCR];
+       }
+    }
+    *dst = 0;
+    return (sdst);
+}
+char   *
+short2str(src)
+    register Char *src;
+{
+    static char *sdst = NULL;
+    static size_t dstsize = 0;
+    register char *dst, *edst;
+
+    if (src == NULL)
+       return (NULL);
+
+    if (sdst == NULL) {
+       dstsize = MALLOC_INCR;
+       sdst = (char *) xmalloc((size_t) dstsize * sizeof(char));
+    }
+    dst = sdst;
+    edst = &dst[dstsize];
+    while (*src) {
+       *dst++ = (char) *src++;
+       if (dst == edst) {
+           dstsize += MALLOC_INCR;
+           sdst = (char *) xrealloc((ptr_t) sdst,
+                                    (size_t) dstsize * sizeof(char));
+           edst = &sdst[dstsize];
+           dst = &edst[-MALLOC_INCR];
+       }
+    }
+    *dst = 0;
+    return (sdst);
+}
+
+Char   *
+s_strcpy(dst, src)
+    register Char *dst, *src;
+{
+    register Char *sdst;
+
+    sdst = dst;
+    while (*dst++ = *src++);
+    return (sdst);
+}
+
+Char   *
+s_strncpy(dst, src, n)
+    register Char *dst, *src;
+    register size_t n;
+{
+    register Char *sdst;
+
+    if (n == 0)
+       return(dst);
+
+    sdst = dst;
+    do 
+       if ((*dst++ = *src++) == '\0') {
+           while (--n != 0)
+               *dst++ = '\0';
+           return(sdst);
+       }
+    while (--n != 0);
+    return (sdst);
+}
+
+Char   *
+s_strcat(dst, src)
+    register Char *dst, *src;
+{
+    register short *sdst;
+
+    sdst = dst;
+    while (*dst++);
+    --dst;
+    while (*dst++ = *src++);
+    return (sdst);
+}
+
+#ifdef NOTUSED
+Char   *
+s_strncat(dst, src, n)
+    register Char *dst, *src;
+    register size_t n;
+{
+    register Char *sdst;
+
+    if (n == 0) 
+       return (dst);
+
+    sdst = dst;
+
+    while (*dst++);
+    --dst;
+
+    do 
+       if ((*dst++ = *src++) == '\0')
+           return(sdst);
+    while (--n != 0);
+
+    *dst = '\0';
+    return (sdst);
+}
+
+#endif
+
+Char   *
+s_strchr(str, ch)
+    register Char *str;
+    int ch;
+{
+    do
+       if (*str == ch)
+           return (str);
+    while (*str++);
+    return (NULL);
+}
+
+Char   *
+s_strrchr(str, ch)
+    register Char *str;
+    int ch;
+{
+    register Char *rstr;
+
+    rstr = NULL;
+    do
+       if (*str == ch)
+           rstr = str;
+    while (*str++);
+    return (rstr);
+}
+
+size_t
+s_strlen(str)
+    register Char *str;
+{
+    register size_t n;
+
+    for (n = 0; *str++; n++);
+    return (n);
+}
+
+int
+s_strcmp(str1, str2)
+    register Char *str1, *str2;
+{
+    for (; *str1 && *str1 == *str2; str1++, str2++);
+    /*
+     * The following case analysis is necessary so that characters which look
+     * negative collate low against normal characters but high against the
+     * end-of-string NUL.
+     */
+    if (*str1 == '\0' && *str2 == '\0')
+       return (0);
+    else if (*str1 == '\0')
+       return (-1);
+    else if (*str2 == '\0')
+       return (1);
+    else
+       return (*str1 - *str2);
+}
+
+int
+s_strncmp(str1, str2, n)
+    register Char *str1, *str2;
+    register size_t n;
+{
+    if (n == 0)
+       return (0);
+    do {
+        if (*str1 == '\0' || *str1 != *str2)
+           break;
+       str1++, str2++;
+    } while (--n != 0);
+    /*
+     * The following case analysis is necessary so that characters which look
+     * negative collate low against normal characters but high against the
+     * end-of-string NUL.
+     */
+    if (*str1 == '\0' && *str2 == '\0')
+       return (0);
+    else if (*str1 == '\0')
+       return (-1);
+    else if (*str2 == '\0')
+       return (1);
+    else
+       return (*str1 - *str2);
+    return(0);
+}
+
+Char   *
+s_strsave(s)
+    register Char *s;
+{
+    Char   *n;
+    register Char *p;
+
+    if (s == 0)
+       s = STRNULL;
+    for (p = s; *p++;);
+    n = p = (Char *) xmalloc((size_t) ((p - s) * sizeof(Char)));
+    while (*p++ = *s++);
+    return (n);
+}
+
+Char   *
+s_strspl(cp, dp)
+    Char   *cp, *dp;
+{
+    Char   *ep;
+    register Char *p, *q;
+
+    if (!cp)
+       cp = STRNULL;
+    if (!dp)
+       dp = STRNULL;
+    for (p = cp; *p++;);
+    for (q = dp; *q++;);
+    ep = (Char *) xmalloc((size_t)
+                         (((p - cp) + (q - dp) - 1) * sizeof(Char)));
+    for (p = ep, q = cp; *p++ = *q++;);
+    for (p--, q = dp; *p++ = *q++;);
+    return (ep);
+}
+
+Char   *
+s_strend(cp)
+    register Char *cp;
+{
+    if (!cp)
+       return (cp);
+    while (*cp)
+       cp++;
+    return (cp);
+}
+
+#ifdef NOTUSED
+Char   *
+s_strstr(s, t)
+    register Char *s, *t;
+{
+    do {
+       register Char *ss = s;
+       register Char *tt = t;
+
+       do
+           if (*tt == '\0')
+               return (s);
+       while (*ss++ == *tt++);
+    } while (*s++ != '\0');
+    return (NULL);
+}
+#endif
+
+#endif                         /* SHORT_STRINGS */