]> git.cworth.org Git - glaze/blobdiff - glaze.c
Add egl definitions and related buildsupport.
[glaze] / glaze.c
diff --git a/glaze.c b/glaze.c
index 72070256fb4365d6874ba58a3d28f94495c5f9e9..02a39275d0b3ba50101988e2386b7e499ecf8c88 100644 (file)
--- a/glaze.c
+++ b/glaze.c
  * THE SOFTWARE.
  */
 
-#define _GNU_SOURCE
-#include <dlfcn.h>
-
-#include "glaze.h"
-
 #include <stdio.h>
 #include <stdlib.h>
+#include <getopt.h>
+#include <limits.h>
+
+#include <glaze.h>
 
-void *
-glaze_lookup (char *function)
+static void
+usage (void)
 {
-       static void *libgl_handle = NULL;
-       void *ret;
+       printf ("Usage: glaze --wrapper=<wrapper> <program> [program args...]\n"
+               "\n"
+               "Execute <program> with <wrapper> providing alternate OpenGL functions.\n");
+}
 
-       if (libgl_handle == NULL) {
-               const char *path;
+enum {
+       WRAPPER_OPT = CHAR_MAX + 1
+};
 
-               path = getenv ("GLAZE_LIBGL");
-               if (path == NULL) {
-                       fprintf (stderr, "GLAZE_LIBGL unset. "
-                                "Please set to path of libGL.so under glaze.\n"
-                               );
-                       exit (1);
-               }
+int
+main (int argc, char *argv[])
+{
+       const char *wrapper = NULL;
+       int opt;
+
+       /* The initial '+' means that getopt will stop looking for
+        * options after the first non-option argument. This means
+        * that a command such as:
+        *
+        *      glaze glenv --renderer=Foo glxgears
+        *
+        * Will do what is intended, (namely, have glaze invoke "glenv
+        * --renderer=Foo glxgears" rather than trying to interpret
+        * --renderer=Foo as an option to glaze itself.
+        */
+       const char *short_options="+h";
+       const struct option long_options[] = {
+               {"help", no_argument, 0, 'h'},
+               {"wrapper", required_argument, 0, WRAPPER_OPT},
+               {0, 0, 0, 0}
+       };
+
+       while (1)
+       {
+               opt = getopt_long (argc, argv, short_options, long_options, NULL);
+               if (opt == -1)
+                       break;
 
-               libgl_handle = dlopen (path, RTLD_LAZY | RTLD_GLOBAL);
-               if (libgl_handle == NULL) {
-                       fprintf (stderr, "Error: Failed to dlopen %s\n", path);
+               switch (opt) {
+               case 'h':
+                       usage ();
+                       return 0;
+               case WRAPPER_OPT:
+                       wrapper = optarg;
+                       break;
+               default:
+                       fprintf (stderr, "Internal error: "
+                                "unexpected getopt value: %d\n", opt);
                        exit (1);
                }
        }
 
-       ret = dlsym (libgl_handle, function);
-
-       if (ret == NULL) {
-               fprintf (stderr, "Error: glaze_lookup failed to dlsym %s\n",
-                        function);
+       if (optind >= argc) {
+               fprintf (stderr, "Error: No program name provided, "
+                        "see (glaze --help)\n");
                exit (1);
        }
 
-       return ret;
+       glaze_execute (argc - optind, &argv[optind], wrapper);
+
+       /* If glaze_execute returns then something went wrong. */
+       return 1;
 }