summaryrefslogtreecommitdiff
path: root/src/main.cc
diff options
context:
space:
mode:
authorDana Jansens <danakj@orodu.net>2002-04-11 03:20:38 +0000
committerDana Jansens <danakj@orodu.net>2002-04-11 03:20:38 +0000
commitdfc5f034581f5a26cba5c4811500438f89f0634a (patch)
treeefb1e3af799383aa5835a736cabf658d18db4be5 /src/main.cc
parent17532e906b1dd6340bb1eccd2d9724643637958b (diff)
Initial revision
Diffstat (limited to 'src/main.cc')
-rw-r--r--src/main.cc186
1 files changed, 186 insertions, 0 deletions
diff --git a/src/main.cc b/src/main.cc
new file mode 100644
index 00000000..0a0ad5ba
--- /dev/null
+++ b/src/main.cc
@@ -0,0 +1,186 @@
+// main.cc for Openbox
+// Copyright (c) 2001 Sean 'Shaleh' Perry <shaleh@debian.org>
+// Copyright (c) 1997 - 2000 Brad Hughes (bhughes@tcac.net)
+//
+// 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 AUTHORS OR COPYRIGHT HOLDERS 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.
+
+// stupid macros needed to access some functions in version 2 of the GNU C
+// library
+#ifndef _GNU_SOURCE
+#define _GNU_SOURCE
+#endif // _GNU_SOURCE
+
+#include "../version.h"
+
+#ifdef HAVE_CONFIG_H
+# include "../config.h"
+#endif // HAVE_CONFIG_H
+
+#include "i18n.h"
+#include "openbox.h"
+
+#ifdef HAVE_STDIO_H
+# include <stdio.h>
+#endif // HAVE_STDIO_H
+
+#ifdef STDC_HEADERS
+# include <stdlib.h>
+# include <string.h>
+#endif // STDC_HEADERS
+
+#ifdef HAVE_UNISTD_H
+#include <sys/types.h>
+#endif // HAVE_UNISTD_H
+
+#ifdef HAVE_SYS_PARAM_H
+# include <sys/param.h>
+#endif // HAVE_SYS_PARAM_H
+
+#ifndef MAXPATHLEN
+#define MAXPATHLEN 255
+#endif // MAXPATHLEN
+
+
+static void showHelp(int exitval) {
+ // print program usage and command line options
+ printf(i18n->getMessage(mainSet, mainUsage,
+ "Openbox %s : (c) 2002 - 2002 Ben Jansens\n"
+ "\t\t\t 2001 - 2002 Sean 'Shaleh' Perry\n\n"
+ "\t\t\t 1997 - 2000 Brad Hughes\n\n"
+ " -display <string>\t\tuse display connection.\n"
+ " -rc <string>\t\t\tuse alternate resource file.\n"
+ " -version\t\t\tdisplay version and exit.\n"
+ " -help\t\t\t\tdisplay this help text and exit.\n\n"),
+ __openbox_version);
+
+ // some people have requested that we print out compile options
+ // as well
+ fprintf(stdout,i18n->getMessage(mainSet, mainCompileOptions,
+ "Compile time options:\n"
+ " Debugging:\t\t\t%s\n"
+ " Interlacing:\t\t\t%s\n"
+ " Shape:\t\t\t%s\n"
+ " Slit:\t\t\t\t%s\n"
+ " 8bpp Ordered Dithering:\t%s\n"
+ " Event Clobbering:\t\t%s\n\n"),
+#ifdef DEBUG
+ i18n->getMessage(CommonSet, CommonYes, "yes"),
+#else // !DEBUG
+ i18n->getMessage(CommonSet, CommonNo, "no"),
+#endif // DEBUG
+
+#ifdef INTERLACE
+ i18n->getMessage(CommonSet, CommonYes, "yes"),
+#else // !INTERLACE
+ i18n->getMessage(CommonSet, CommonNo, "no"),
+#endif // INTERLACE
+
+#ifdef SHAPE
+ i18n->getMessage(CommonSet, CommonYes, "yes"),
+#else // !SHAPE
+ i18n->getMessage(CommonSet, CommonNo, "no"),
+#endif // SHAPE
+
+#ifdef SLIT
+ i18n->getMessage(CommonSet, CommonYes, "yes"),
+#else // !SLIT
+ i18n->getMessage(CommonSet, CommonNo, "no"),
+#endif // SLIT
+
+#ifdef ORDEREDPSEUDO
+ i18n->getMessage(CommonSet, CommonYes, "yes"),
+#else // !ORDEREDPSEUDO
+ i18n->getMessage(CommonSet, CommonNo, "no"),
+#endif // ORDEREDPSEUDO
+
+#ifndef NOCLOBBER
+ i18n->getMessage(CommonSet, CommonYes, "yes")
+#else // !NOCLOBBER
+ i18n->getMessage(CommonSet, CommonNo, "no")
+#endif // NOCLOBBER
+ );
+
+ ::exit(exitval);
+}
+
+int main(int argc, char **argv) {
+ char *session_display = (char *) 0;
+ char *rc_file = (char *) 0;
+
+ NLSInit("openbox.cat");
+
+ for (int i = 1; i < argc; ++i) {
+ if (! strcmp(argv[i], "-rc")) {
+ // look for alternative rc file to use
+
+ if ((++i) >= argc) {
+ fprintf(stderr,
+ i18n->getMessage(mainSet, mainRCRequiresArg,
+ "error: '-rc' requires and argument\n"));
+
+ ::exit(1);
+ }
+
+ rc_file = argv[i];
+ } else if (! strcmp(argv[i], "-display")) {
+ // check for -display option... to run on a display other than the one
+ // set by the environment variable DISPLAY
+
+ if ((++i) >= argc) {
+ fprintf(stderr,
+ i18n->getMessage(mainSet, mainDISPLAYRequiresArg,
+ "error: '-display' requires an argument\n"));
+
+ ::exit(1);
+ }
+
+ session_display = argv[i];
+ char dtmp[MAXPATHLEN];
+ sprintf(dtmp, "DISPLAY=%s", session_display);
+
+ if (putenv(dtmp)) {
+ fprintf(stderr,
+ i18n->
+ getMessage(mainSet, mainWarnDisplaySet,
+ "warning: couldn't set environment variable 'DISPLAY'\n"));
+ perror("putenv()");
+ }
+ } else if (! strcmp(argv[i], "-version")) {
+ // print current version string
+ printf("Openbox %s : (c) 1997 - 2000 Brad Hughes\n"
+ "\t\t\t 2001 - 2002 Sean 'Shaleh' Perry\n",
+ __openbox_version);
+
+ ::exit(0);
+ } else if (! strcmp(argv[i], "-help")) {
+ showHelp(0);
+ } else { // invalid command line option
+ showHelp(-1);
+ }
+ }
+
+#ifdef __EMX__
+ _chdir2(getenv("X11ROOT"));
+#endif // __EMX__
+
+ Openbox openbox(argc, argv, session_display, rc_file);
+ openbox.eventLoop();
+
+ return(0);
+}