summaryrefslogtreecommitdiff
path: root/launchd/user_startx
diff options
context:
space:
mode:
authorJeremy Huddleston <jeremyhu@apple.com>2011-04-25 23:09:03 -0700
committerJeremy Huddleston <jeremyhu@apple.com>2011-04-26 12:54:46 -0700
commit5f5390886004f785b4338fcff27f287c9aa6cd8c (patch)
tree48147a155ec27823c63027b0a551e7b9304459a9 /launchd/user_startx
parentc6a7f895c8c90b85ed4fd08927c47b0d17ed067a (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/.gitignore1
-rw-r--r--launchd/user_startx/Makefile.am12
-rw-r--r--launchd/user_startx/launchd_startx.c59
-rw-r--r--launchd/user_startx/startx.plist.cpp1
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>