s/cookie_file/cookie_dir/g
[uzbl-mobile] / uzblctrl.c
index 6379606..f0fe732 100644 (file)
@@ -1,3 +1,4 @@
+/* -*- c-basic-offset: 4; -*- */
 /* Socket code more or less completely copied from here: http://www.ecst.csuchico.edu/~beej/guide/ipc/usock.html */
 
 #include <gtk/gtk.h>
@@ -22,7 +23,7 @@ static gchar* command;
 
 static GOptionEntry entries[] =
 {
-    { "socket",  's', 0, G_OPTION_ARG_STRING, &sockpath, "Socket path of the client uzbl", NULL },
+    { "socket",  's', 0, G_OPTION_ARG_STRING, &sockpath, "Path to the uzbl socket",        NULL },
     { "command", 'c', 0, G_OPTION_ARG_STRING, &command,  "The uzbl command to execute",    NULL },
     { NULL,       0,  0, 0,                    NULL,      NULL,                            NULL }
 };
@@ -30,35 +31,41 @@ static GOptionEntry entries[] =
 int
 main(int argc, char* argv[]) {
     GError *error = NULL;
-    GOptionContext* context = g_option_context_new ("- some stuff here maybe someday");
+    GOptionContext* context = g_option_context_new ("- utility for controlling and interacting with uzbl through its socket file"); //TODO: get stuff back from uzbl
     g_option_context_add_main_entries (context, entries, NULL);
     g_option_context_add_group        (context, gtk_get_option_group (TRUE));
     g_option_context_parse            (context, &argc, &argv, &error);
-    
-    int s, len;
-    struct sockaddr_un remote;
-    
-    if ((s = socket (AF_UNIX, SOCK_STREAM, 0)) == -1) {
-        perror ("socket");
-        exit (1);
-    }
-    
-    remote.sun_family = AF_UNIX;
-    strcpy (remote.sun_path, (char *) sockpath);
-    len = strlen (remote.sun_path) + sizeof (remote.sun_family);
 
-    if (connect (s, (struct sockaddr *) &remote, len) == -1) {
-        perror ("connect");
-        exit (1);
-    }
-    
-    if (send (s, command, strlen (command), 0) == -1) {
-        perror ("send");
-        exit (1);
+
+    if (sockpath && command) {
+        int s, len;
+        struct sockaddr_un remote;
+        
+        if ((s = socket (AF_UNIX, SOCK_STREAM, 0)) == -1) {
+            perror ("socket");
+            exit (1);
+        }
+        
+        remote.sun_family = AF_UNIX;
+        strcpy (remote.sun_path, (char *) sockpath);
+        len = strlen (remote.sun_path) + sizeof (remote.sun_family);
+        
+        if (connect (s, (struct sockaddr *) &remote, len) == -1) {
+            perror ("connect");
+            exit (1);
+        }
+        
+        if (send (s, command, strlen (command), 0) == -1) {
+            perror ("send");
+            exit (1);
+        }
+        
+        close(s);
+        
+        return 0;
+    } else {
+        puts ("Usage: uzblctrl -s /path/to/socket -c \"command\"");
+        return 1;
     }
-    
-    close(s);
-    
-    return 0;
 }
 /* vi: set et ts=4: */