Split our rc commands out into general use vs service commands

This commit is contained in:
Roy Marples 2007-09-24 12:09:43 +00:00
parent 71e0d9e371
commit e95cea3d86
4 changed files with 60 additions and 35 deletions

View File

@ -56,6 +56,8 @@ install::
if test $(LIB) != "lib" ; then \ if test $(LIB) != "lib" ; then \
sed -i'.bak' -e 's,/lib/,/$(LIB)/,g' $(DESTDIR)/$(RC_LIB)/sh/functions.sh || exit $$? ; \ sed -i'.bak' -e 's,/lib/,/$(LIB)/,g' $(DESTDIR)/$(RC_LIB)/sh/functions.sh || exit $$? ; \
rm -f $(DESTDIR)/$(RC_LIB)/sh/functions.sh.bak ; \ rm -f $(DESTDIR)/$(RC_LIB)/sh/functions.sh.bak ; \
sed -i'.bak' -e 's,/lib/,/$(LIB)/,g' $(DESTDIR)/$(RC_LIB)/sh/rc-functions.sh || exit $$? ; \
rm -f $(DESTDIR)/$(RC_LIB)/sh/rc-functions.sh.bak ; \
fi fi
layout: layout:

View File

@ -59,4 +59,10 @@ get_bootparam() {
return 1 return 1
} }
# Add our sbin to $PATH
case "${PATH}" in
/lib/rc/sbin|/lib/rc/sbin:*) ;;
*) export PATH="/lib/rc/sbin:${PATH}" ;;
esac
# vim: set ts=4 : # vim: set ts=4 :

View File

@ -65,22 +65,23 @@ LIB_TARGETS = $(LIBEINFOSO) $(LIBRCSO)
SBIN_TARGETS = rc SBIN_TARGETS = rc
SYS_WHITELIST = env_whitelist SYS_WHITELIST = env_whitelist
TARGET = $(LIB_TARGETS) $(BIN_TARGETS) $(SBIN_TARGETS) $(PRIV_BIN_TARGETS) TARGET = $(LIB_TARGETS) $(BIN_TARGETS) $(SBIN_TARGETS)
RCLINKS = einfon einfo ewarnn ewarn eerrorn eerror ebegin eend ewend \ RC_BINLINKS = einfon einfo ewarnn ewarn eerrorn eerror ebegin eend ewend \
eindent eoutdent esyslog eval_ecolors \ eindent eoutdent esyslog eval_ecolors \
veinfo vewarn vebegin veend vewend veindent veoutdent \ veinfo vewarn vebegin veend vewend veindent veoutdent \
service_starting service_inactive service_started \ service_starting service_inactive service_started \
service_stopping service_stopped \ service_stopping service_stopped \
service_inactive service_wasinactive \ service_inactive service_wasinactive \
service_coldplugged \ service_coldplugged \
mark_service_starting mark_service_inactive mark_service_started \ is_runlevel_start is_runlevel_stop service_started_daemon \
checkown fstabinfo mountinfo rc-depend
RC_SBINLINKS = mark_service_starting mark_service_inactive \
mark_service_started \
mark_service_stopping mark_service_stopped \ mark_service_stopping mark_service_stopped \
mark_service_inactive mark_service_wasinactive \ mark_service_inactive mark_service_wasinactive \
mark_service_coldplugged \ mark_service_coldplugged \
get_options save_options rc-abort rc-depend \ get_options save_options rc-abort
is_runlevel_start is_runlevel_stop service_started_daemon \
checkown fstabinfo mountinfo
BINLINKS = rc-status BINLINKS = rc-status
SBINLINKS = env-update rc-update runscript start-stop-daemon SBINLINKS = env-update rc-update runscript start-stop-daemon
@ -122,7 +123,7 @@ rc: $(LIBEINFOSO) $(LIBRCSO) $(RCOBJS)
$(CC) $(LDFLAGS) -o rc $(RCOBJS) $(LDLIBS) $(LDLIBS_RC) $(CC) $(LDFLAGS) -o rc $(RCOBJS) $(LDLIBS) $(LDLIBS_RC)
links: rc links: rc
for x in $(BINLINKS) $(SBINLINKS) $(RCLINKS) $(RCPRIVLINKS); do ln -sf rc $$x; done for x in $(BINLINKS) $(SBINLINKS) $(RC_BINLINKS) $(RC_SBINLINKS); do ln -sf rc $$x; done
install: $(TARGET) install: $(TARGET)
install -m 0755 -d $(DESTDIR)/$(LIB) install -m 0755 -d $(DESTDIR)/$(LIB)
@ -138,9 +139,11 @@ install: $(TARGET)
install -m 0755 -d $(DESTDIR)/$(RC_LIB)/conf.d install -m 0755 -d $(DESTDIR)/$(RC_LIB)/conf.d
install -m 0644 $(SYS_WHITELIST) $(DESTDIR)/$(RC_LIB)/conf.d install -m 0644 $(SYS_WHITELIST) $(DESTDIR)/$(RC_LIB)/conf.d
install -m 0755 -d $(DESTDIR)/$(RC_LIB)/bin install -m 0755 -d $(DESTDIR)/$(RC_LIB)/bin
install -m 0755 -d $(DESTDIR)/$(RC_LIB)/sbin
for x in $(BINLINKS); do ln -sf ../sbin/rc $(DESTDIR)/bin/$$x; done for x in $(BINLINKS); do ln -sf ../sbin/rc $(DESTDIR)/bin/$$x; done
for x in $(SBINLINKS); do ln -sf rc $(DESTDIR)/sbin/$$x; done for x in $(SBINLINKS); do ln -sf rc $(DESTDIR)/sbin/$$x; done
for x in $(RCLINKS); do ln -sf ../../../sbin/rc $(DESTDIR)/$(RC_LIB)/bin/$$x; done for x in $(RC_BINLINKS); do ln -sf ../../../sbin/rc $(DESTDIR)/$(RC_LIB)/bin/$$x; done
for x in $(RC_SBINLINKS); do ln -sf ../../../sbin/rc $(DESTDIR)/$(RC_LIB)/sbin/$$x; done
if test "$(PAM)" = "pam" ; then \ if test "$(PAM)" = "pam" ; then \
install -m 0755 -d $(DESTDIR)/etc/pam.d ; \ install -m 0755 -d $(DESTDIR)/etc/pam.d ; \
install -m 0644 start-stop-daemon.pam $(DESTDIR)/etc/pam.d/start-stop-daemon ; \ install -m 0644 start-stop-daemon.pam $(DESTDIR)/etc/pam.d/start-stop-daemon ; \

View File

@ -860,25 +860,39 @@ int start_stop_daemon (int argc, char **argv)
#endif #endif
/* Clean the environment of any RC_ variables */ /* Clean the environment of any RC_ variables */
STRLIST_FOREACH (environ, env, i) STRLIST_FOREACH (environ, env, i) {
if (env && strncmp (env, "RC_", 3) != 0) { if (strncmp (env, "RC_", 3) == 0 ||
/* For the path r, remove the rcscript bin dir from it */ strncmp (env, "SSD_NICELEVEL=", strlen ("SSD_NICELEVEL=")) == 0)
if (strncmp (env, "PATH=" RC_LIBDIR "/bin:", continue;
strlen ("PATH=" RC_LIBDIR "/bin:")) == 0)
{ /* For the path, remove the rcscript bin dir from it */
char *path = env; if (strncmp (env, "PATH=", 5) == 0) {
char *newpath; char *path = rc_xstrdup (env);
int len; char *newpath = NULL;
path += strlen ("PATH=" RC_LIBDIR "/bin:"); char *p = path;
len = sizeof (char *) * strlen (path) + 6; char *token;
newpath = rc_xmalloc (len);
snprintf (newpath, len, "PATH=%s", path); p += 5;
while ((token = strsep (&p, ":"))) {
if (strcmp (token, RC_LIBDIR "/bin") == 0 ||
strcmp (token, RC_LIBDIR "/sbin") == 0)
continue;
if (newpath)
asprintf (&newpath, "%s:%s", newpath, token);
else
asprintf (&newpath, "PATH=%s", token);
}
rc_strlist_add (&newenv, newpath); rc_strlist_add (&newenv, newpath);
free (path);
free (newpath); free (newpath);
} else } else
rc_strlist_add (&newenv, env); rc_strlist_add (&newenv, env);
} }
STRLIST_FOREACH (newenv, env, i)
einfo ("env %s", env);
umask (022); umask (022);
stdout_fd = devnull_fd; stdout_fd = devnull_fd;