]> sigrok.org Git - libsigrok.git/blobdiff - src/output/srzip.c
Build: Set local include directories in Makefile.am
[libsigrok.git] / src / output / srzip.c
index 18a79d5b50b15403319af4c916340c819113ee84..ae066cde228b4f66a240458cf0f803281b0e6db4 100644 (file)
@@ -24,7 +24,7 @@
 #include <glib.h>
 #include <glib/gstdio.h>
 #include <zip.h>
-#include "libsigrok.h"
+#include <libsigrok/libsigrok.h>
 #include "libsigrok-internal.h"
 
 #define LOG_PREFIX "output/srzip"
@@ -39,11 +39,16 @@ static int init(struct sr_output *o, GHashTable *options)
 {
        struct out_context *outc;
 
+       (void)options;
+
+       if (strlen(o->filename) == 0) {
+               sr_info("srzip output module requires a file name, cannot save.");
+               return SR_ERR_ARG;
+       }
+
        outc = g_malloc0(sizeof(struct out_context));
+       outc->filename = g_strdup(o->filename);
        o->priv = outc;
-       outc->filename = g_strdup(g_variant_get_string(g_hash_table_lookup(options, "filename"), NULL));
-       if (strlen(outc->filename) == 0)
-               return SR_ERR_ARG;
 
        return SR_OK;
 }
@@ -296,7 +301,6 @@ static int cleanup(struct sr_output *o)
 }
 
 static struct sr_option options[] = {
-       { "filename", "Filename", "File to write", NULL, NULL },
        ALL_ZERO
 };
 
@@ -312,9 +316,10 @@ SR_PRIV struct sr_output_module output_srzip = {
        .id = "srzip",
        .name = "srzip",
        .desc = "srzip session file",
+       .exts = (const char*[]){"sr", NULL},
+       .flags = SR_OUTPUT_INTERNAL_IO_HANDLING,
        .options = get_options,
        .init = init,
        .receive = receive,
        .cleanup = cleanup,
 };
-