4 * The contents of this file are subject to the terms of the
5 * Common Development and Distribution License, Version 1.0 only
6 * (the "License"). You may not use this file except in compliance
9 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
10 * or http://www.opensolaris.org/os/licensing.
11 * See the License for the specific language governing permissions
12 * and limitations under the License.
14 * When distributing Covered Code, include this CDDL HEADER in each
15 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
16 * If applicable, add the following below this CDDL HEADER, with the
17 * fields enclosed by brackets "[]" replaced with your own identifying
18 * information: Portions Copyright [yyyy] [name of copyright owner]
23 * Copyright 2005 Sun Microsystems, Inc. All rights reserved.
24 * Use is subject to license terms.
27 /* Copyright (c) 1984 AT&T */
28 /* All Rights Reserved */
30 #pragma ident "%Z%%M% %I% %E% SMI"
34 * execlp(name, arg,...,0) (like execl, but does path search)
35 * execvp(name, argv) (like execv, but does path search)
38 #include <sys/param.h>
44 static char *execat(char *, char *, char *);
45 static char *shell
= "/bin/sh";
48 execlp(char *name
, ...)
54 r
= execvp(name
, (char **)args
);
61 execvp(char *name
, char **argv
)
64 char fname
[MAXPATHLEN
];
71 if ((pathstr
= getenv("PATH")) == NULL
)
72 pathstr
= ":/usr/ucb:/bin:/usr/bin";
73 cp
= strchr(name
, '/') ? "": pathstr
;
76 cp
= execat(cp
, name
, fname
);
78 (void) execv(fname
, argv
);
83 for (i
= 1; (newargs
[i
+1] = argv
[i
]) != NULL
; ++i
) {
89 (void) execv(shell
, newargs
);
94 (void) sleep(etxtbsy
);
111 execat(char *s1
, char *s2
, char *si
)
117 end
= s
+ MAXPATHLEN
;
118 while (*s1
&& *s1
!= ':' && s
< end
)
120 if (si
!= s
&& s
< end
)
122 while (*s2
&& s
< end
)
125 return (*s1
? ++s1
: 0);