Files
Arquivotheca.Solaris-2.5/cmd/csh/sh.misc.c
seta75D 7c4988eac0 Init
2021-10-11 19:38:01 -03:00

505 lines
7.1 KiB
C
Executable File

/* Copyright (c) 1984, 1986, 1987, 1988, 1989 AT&T */
/* All Rights Reserved */
/* THIS IS UNPUBLISHED PROPRIETARY SOURCE CODE OF AT&T */
/* The copyright notice above does not evidence any */
/* actual or intended publication of such source code. */
#ident "@(#)sh.misc.c 1.11 94/08/12 SMI" /* SVr4.0 1.3 */
/*
*******************************************************************
PROPRIETARY NOTICE(Combined)
This source code is unpublished proprietary information
constituting, or derived under license from AT&T's UNIX(r) System V.
In addition, portions of such source code were derived from Berkeley
4.3 BSD under license from the Regents of the University of
California.
Copyright Notice
Notice of copyright on this source code product does not indicate
publication.
(c) 1986, 1987, 1988, 1989 Sun Microsystems, Inc
(c) 1983, 1984, 1985, 1986, 1987, 1988, 1989 AT&T.
All rights reserved.
********************************************************************
*/
/*
* Copyright (c) 1980 Regents of the University of California.
* All rights reserved. The Berkeley Software License Agreement
* specifies the terms and conditions for redistribution.
*/
#include "sh.h"
#include "sh.tconst.h"
/*
* C Shell
*/
any(c, s)
register int c;
register tchar *s;
{
while (s && *s)
if (*s++ == c)
return (1);
return (0);
}
onlyread(cp)
tchar *cp;
{
extern char end[];
return ((char *)cp < end);
}
/*
* WARNING: changes here also need to occur in the XFREE macro in sh.h.
*/
xfree(cp)
char *cp;
{
extern char end[];
#if defined(sparc)
if ((char *)cp >= end && (char *)cp < (char *)&cp)
free(cp);
#elif defined(i386)
if ((char *)cp >= end)
free(cp);
#else
#error xfree function is machine dependant and no machine type is recognized
#endif
}
tchar *
savestr(s)
register tchar *s;
{
tchar *n;
register tchar *p;
if (s == 0)
s = S_ /* "" */;
#ifndef m32
for (p = s; *p++; )
;
n = p = (tchar *)xalloc((unsigned) (p - s)*sizeof (tchar));
while (*p++ = *s++)
;
return (n);
#else
p = (tchar *) xalloc((strlen_(s) + 1)*sizeof (tchar));
strcpy_(p, s);
return (p);
#endif
}
void *
calloc(i, j)
register unsigned i;
unsigned j;
{
register char *cp;
i *= j;
cp = (char *)xalloc(i);
bzero(cp, (int)i);
return (cp);
}
nomem(i)
unsigned i;
{
#ifdef debug
static tchar *av[2] = {0, 0};
#endif
child++;
#ifndef debug
error("Out of memory");
#ifdef lint
i = i;
#endif
#else
showall(av);
printf("i=%d: Out of memory\n", i);
chdir("/usr/bill/cshcore");
abort();
#endif
return (0); /* fool lint */
}
tchar **
blkend(up)
register tchar **up;
{
while (*up)
up++;
return (up);
}
blkpr(av)
register tchar **av;
{
for (; *av; av++) {
printf("%t", *av);
if (av[1])
printf(" ");
}
}
blklen(av)
register tchar **av;
{
register int i = 0;
while (*av++)
i++;
return (i);
}
tchar **
blkcpy(oav, bv)
tchar **oav;
register tchar **bv;
{
register tchar **av = oav;
while (*av++ = *bv++)
continue;
return (oav);
}
tchar **
blkcat(up, vp)
tchar **up, **vp;
{
(void) blkcpy(blkend(up), vp);
return (up);
}
blkfree(av0)
tchar **av0;
{
register tchar **av = av0;
for (; *av; av++)
XFREE(*av)
XFREE((tchar *)av0)
}
tchar **
saveblk(v)
register tchar **v;
{
register tchar **newv =
(tchar **) calloc((unsigned) (blklen(v) + 1),
sizeof (tchar **));
tchar **onewv = newv;
while (*v)
*newv++ = savestr(*v++);
return (onewv);
}
tchar *
strspl(cp, dp)
tchar *cp, *dp;
{
tchar *ep;
register tchar *p, *q;
#ifndef m32
for (p = cp; *p++; )
;
for (q = dp; *q++; )
;
ep = (tchar *) xalloc((unsigned) (((p - cp) +
(q - dp) - 1))*sizeof (tchar));
for (p = ep, q = cp; *p++ = *q++; )
;
for (p--, q = dp; *p++ = *q++; )
;
#else
int len1 = strlen_(cp);
int len2 = strlen_(dp);
ep = (tchar *)xalloc((unsigned) (len1 + len2 + 1)*sizeof (tchar));
strcpy_(ep, cp);
strcat_(ep, dp);
#endif
return (ep);
}
tchar **
blkspl(up, vp)
register tchar **up, **vp;
{
register tchar **wp =
(tchar **) calloc((unsigned) (blklen(up) + blklen(vp) + 1),
sizeof (tchar **));
(void) blkcpy(wp, up);
return (blkcat(wp, vp));
}
lastchr(cp)
register tchar *cp;
{
if (!*cp)
return (0);
while (cp[1])
cp++;
return (*cp);
}
donefds()
{
(void) close(0);
(void) close(1);
(void) close(2);
/*
* To avoid NIS+ functions to get hold of 0/1/2,
* use descriptor 0, and dup it to 1 and 2.
*/
open("/dev/null", 0);
dup(0); dup(0);
didfds = 0;
}
/*
* Move descriptor i to j.
* If j is -1 then we just want to get i to a safe place,
* i.e. to a unit > 2. This also happens in dcopy.
*/
dmove(i, j)
register int i, j;
{
int fd;
if (i == j || i < 0)
return (i);
if (j >= 0) {
fd = dup2(i, j);
if (fd != -1)
setfd(fd);
return (j);
}
j = dcopy(i, j);
if (j != i) {
(void) close(i);
unsetfd(i);
}
return (j);
}
dcopy(i, j)
register int i, j;
{
int fd;
if (i == j || i < 0 || j < 0 && i > 2)
return (i);
if (j >= 0) {
fd = dup2(i, j);
if (fd != -1)
setfd(fd);
return (j);
}
(void) close(j);
unsetfd(j);
return (renum(i, j));
}
renum(i, j)
register int i, j;
{
register int k = dup(i);
if (k < 0)
return (-1);
if (j == -1 && k > 2) {
setfd(k);
return (k);
}
if (k != j) {
j = renum(k, j);
(void) close(k); /* no need ofr unsetfd() */
return (j);
}
return (k);
}
#ifndef copy
copy(to, from, size)
register tchar *to, *from;
register int size;
{
if (size)
do
*to++ = *from++;
while (--size != 0);
}
#endif
/*
* Left shift a command argument list, discarding
* the first c arguments. Used in "shift" commands
* as well as by commands like "repeat".
*/
lshift(v, c)
register tchar **v;
register int c;
{
register tchar **u = v;
while (*u && --c >= 0)
xfree(*u++);
(void) blkcpy(v, u);
}
number(cp)
tchar *cp;
{
if (*cp == '-') {
cp++;
if (!digit(*cp++))
return (0);
}
while (*cp && digit(*cp))
cp++;
return (*cp == 0);
}
tchar **
copyblk(v)
register tchar **v;
{
register tchar **nv =
(tchar **) calloc((unsigned) (blklen(v) + 1),
sizeof (tchar **));
return (blkcpy(nv, v));
}
tchar *
strend(cp)
register tchar *cp;
{
while (*cp)
cp++;
return (cp);
}
tchar *
strip(cp)
tchar *cp;
{
register tchar *dp = cp;
while (*dp++ &= TRIM)
continue;
return (cp);
}
udvar(name)
tchar *name;
{
setname(name);
bferr("Undefined variable");
}
prefix(sub, str)
register tchar *sub, *str;
{
for (;;) {
if (*sub == 0)
return (1);
if (*str == 0)
return (0);
if (*sub++ != *str++)
return (0);
}
}
/*
* blk*_ routines
*/
char **
blkend_(up)
register char **up;
{
while (*up)
up++;
return (up);
}
blklen_(av)
register char **av;
{
register int i = 0;
while (*av++)
i++;
return (i);
}
char **
blkcpy_(oav, bv)
char **oav;
register char **bv;
{
register char **av = oav;
while (*av++ = *bv++)
continue;
return (oav);
}
char **
blkcat_(up, vp)
char **up, **vp;
{
(void) blkcpy_(blkend_(up), vp);
return (up);
}
char **
blkspl_(up, vp)
register char **up, **vp;
{
register char **wp =
(char **) calloc((unsigned) (blklen_(up) + blklen_(vp) + 1),
sizeof (char **));
(void) blkcpy_(wp, up);
return (blkcat_(wp, vp));
}