Pridana knihovna getxsock
[mirrors/Programs.git] / c / vizionix / mkxsock.c
index afc9bebe17e519c09fe9cd69d12d2406a401cc26..c3d076bceed54be655439ceebed2373a6e420249 100644 (file)
@@ -3,6 +3,10 @@
 #include <getopt.h>
 #include <gtk/gtk.h>
 
+#define ENV_PREFIX "XSOCK_"
+
+int return_true(void) { return 1; }
+
 void print_help(char ** argv) {
        printf(
                "Usage: %s [args]\n"
@@ -10,6 +14,7 @@ void print_help(char ** argv) {
                "\t -c color\n"
                "\t -w width\n"
                "\t -h height\n"
+               //"\t -r reuse " ENV_PREFIX "* from environment\n"
                "\t -? (display help)"
                "\nExample: %s -c black -w 640 -h 480\n\n",
                argv[0], argv[0]);
@@ -33,6 +38,15 @@ gint main(gint argc, gchar ** argv)
                        case 'h':
                                height = atoi(optarg);
                                break;
+                       case 'r': //Not yet
+                               if(getenv(ENV_PREFIX"PID")
+                                       && getenv(ENV_PREFIX"WID")
+                                       && kill(atoi(getenv(ENV_PREFIX"PID")), 0)
+                               ) {
+                                       puts("REUSABLE");
+                                       return 0;
+                               }
+                               break;
                        case '?':
                                print_help(argv);
                                return 0;
@@ -51,7 +65,7 @@ gint main(gint argc, gchar ** argv)
        //Create window
        GtkWidget *win = gtk_window_new(GTK_WINDOW_TOPLEVEL);
        GtkWidget *sock = gtk_socket_new();
-       g_signal_connect(sock, "plug-removed", gtk_main_quit, NULL);
+       g_signal_connect(sock, "plug-removed", G_CALLBACK(return_true), NULL);
        g_signal_connect(win, "delete-event", gtk_main_quit, NULL);
        gtk_widget_set_size_request(sock, width, height);
        gtk_widget_modify_bg(sock, GTK_STATE_NORMAL, &color);
@@ -62,7 +76,7 @@ gint main(gint argc, gchar ** argv)
        GdkNativeWindow wid = gtk_socket_get_id(GTK_SOCKET(sock));
        int pid;
        if ((pid = fork())) {
-               printf("XSOCK_WID=%d\nXSOCK_PID=%d\n", wid, pid);
+               printf(ENV_PREFIX"WID=%d\n"ENV_PREFIX"PID=%d\n", wid, pid);
                return 0;
        }
        fclose(stdout);
This page took 0.115652 seconds and 4 git commands to generate.