diff options
author | Jeremy Huddleston <jeremyhu@apple.com> | 2011-04-25 23:09:03 -0700 |
---|---|---|
committer | Jeremy Huddleston <jeremyhu@apple.com> | 2011-04-26 12:54:46 -0700 |
commit | 5f5390886004f785b4338fcff27f287c9aa6cd8c (patch) | |
tree | 48147a155ec27823c63027b0a551e7b9304459a9 /launchd/user_startx | |
parent | c6a7f895c8c90b85ed4fd08927c47b0d17ed067a (diff) |
launchd: Enable stdout/stderr redirection to ASL
Don't rely on launchd to do our logging for us.
Signed-off-by: Jeremy Huddleston <jeremyhu@apple.com>
Reviewed-by: Daniel A. Steffen <dsteffen@apple.com>
Diffstat (limited to 'launchd/user_startx')
-rw-r--r-- | launchd/user_startx/.gitignore | 1 | ||||
-rw-r--r-- | launchd/user_startx/Makefile.am | 12 | ||||
-rw-r--r-- | launchd/user_startx/launchd_startx.c | 59 | ||||
-rw-r--r-- | launchd/user_startx/startx.plist.cpp | 1 |
4 files changed, 70 insertions, 3 deletions
diff --git a/launchd/user_startx/.gitignore b/launchd/user_startx/.gitignore index 60802d7..b87dd68 100644 --- a/launchd/user_startx/.gitignore +++ b/launchd/user_startx/.gitignore @@ -1 +1,2 @@ +launchd_startx *.startx.plist* diff --git a/launchd/user_startx/Makefile.am b/launchd/user_startx/Makefile.am index 600d325..30270dd 100644 --- a/launchd/user_startx/Makefile.am +++ b/launchd/user_startx/Makefile.am @@ -23,10 +23,16 @@ include $(top_srcdir)/cpprules.in xinitrcdir = $(XINITDIR) +xinitrc_PROGRAMS = launchd_startx + +AM_CPPFLAGS = -DXINITDIR=\"$(xinitrcdir)\" -DBINDIR=\"$(bindir)\" -DLAUNCHD_ID_PREFIX=\"$(launchdidprefix)\" + +dist_launchd_startx_SOURCES = \ + ../console_redirect.c \ + launchd_startx.c + CPP_FILES_FLAGS = \ - -DXINITDIR=$(XINITDIR) $(PROGCPPDEFS) -DLIBDIR=$(libdir) \ - -DSHELL_CMD=$(SHELL_CMD) $(STARTX_COOKIE_FLAGS) \ - -D__libexecdir__="$(libexecdir)" \ + -D__xinitrcdir__="$(xinitrcdir)" \ -D__bindir__="$(bindir)" \ -DLAUNCHD_ID_PREFIX="$(launchdidprefix)" diff --git a/launchd/user_startx/launchd_startx.c b/launchd/user_startx/launchd_startx.c new file mode 100644 index 0000000..cf93227 --- /dev/null +++ b/launchd/user_startx/launchd_startx.c @@ -0,0 +1,59 @@ +/* Copyright (c) 2011 Apple Inc. + * + * Permission is hereby granted, free of charge, to any person + * obtaining a copy of this software and associated documentation files + * (the "Software"), to deal in the Software without restriction, + * including without limitation the rights to use, copy, modify, merge, + * publish, distribute, sublicense, and/or sell copies of the Software, + * and to permit persons to whom the Software is furnished to do so, + * subject to the following conditions: + * + * The above copyright notice and this permission notice shall be + * included in all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, + * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF + * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND + * NONINFRINGEMENT. IN NO EVENT SHALL THE ABOVE LISTED COPYRIGHT + * HOLDER(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, + * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER + * DEALINGS IN THE SOFTWARE. + * + * Except as contained in this notice, the name(s) of the above + * copyright holders shall not be used in advertising or otherwise to + * promote the sale, use or other dealings in this Software without + * prior written authorization. + */ + +#include <asl.h> +#include <unistd.h> +#include <stdio.h> +#include <assert.h> +#include <spawn.h> +#include <sys/wait.h> +#include <string.h> +#include <stdlib.h> + +/* console_redirect.c */ +extern int console_redirect(aslclient aslc, aslmsg amsg, int stdout_level, int stderr_level); + +int main(int argc, char **argv, char **envp) { + aslclient aslc; + pid_t child; + int pstat; + + if(argc < 2 || strcmp(argv[1], "--help")) { + fprintf(stderr, "Usage: %s prog [args...]\n", argv[0]); + exit(EXIT_FAILURE); + } + + aslc = asl_open(LAUNCHD_ID_PREFIX".startx", "user", ASL_OPT_NO_DELAY); + (void)console_redirect(aslc, NULL, ASL_LEVEL_INFO, ASL_LEVEL_NOTICE); + + assert(posix_spawnp(&child, argv[1], NULL, NULL, &argv[1], envp) == 0); + + wait4(child, &pstat, 0, (struct rusage *)0); + + return pstat; +} diff --git a/launchd/user_startx/startx.plist.cpp b/launchd/user_startx/startx.plist.cpp index bd4c9e9..1a87527 100644 --- a/launchd/user_startx/startx.plist.cpp +++ b/launchd/user_startx/startx.plist.cpp @@ -6,6 +6,7 @@ <string>LAUNCHD_ID_PREFIX.startx</string> <key>ProgramArguments</key> <array> + <string>__xinitrcdir__/launchd_startx</string> <string>__bindir__/startx</string> </array> <key>Sockets</key> |