]> sigrok.org Git - sigrok-cli.git/blobdiff - session.c
options: Type of G_OPTION_ARG_NONE is gboolean
[sigrok-cli.git] / session.c
index 6e101784606dc4d168a824be891f48413ceffb33..6f402056c0eadfdac17b4ad829bf191aa2bdbf5e 100644 (file)
--- a/session.c
+++ b/session.c
@@ -17,6 +17,7 @@
  * along with this program.  If not, see <http://www.gnu.org/licenses/>.
  */
 
+#include <config.h>
 #include <glib.h>
 #include <glib/gstdio.h>
 #include <string.h>
@@ -358,7 +359,7 @@ int opt_to_gvar(char *key, char *value, struct sr_config *src)
        double tmp_double, dlow, dhigh;
        uint64_t tmp_u64, p, q, low, high, mqflags;
        uint32_t mq;
-       GVariant *rational[2], *range[2], *gvar, *gtup[2];
+       GVariant *rational[2], *range[2], *gtup[2];
        GVariantBuilder *vbl;
        gboolean tmp_bool;
        gchar **keyval;
@@ -453,7 +454,7 @@ int opt_to_gvar(char *key, char *value, struct sr_config *src)
                        g_strfreev(keyval);
                }
                break;
-       case SR_T_MQLIST:
+       case SR_T_MQ:
                /*
                  Argument is MQ id e.g. ("voltage") optionally followed by one
                  or more /<mqflag> e.g. "/ac".
@@ -475,12 +476,9 @@ int opt_to_gvar(char *key, char *value, struct sr_config *src)
                }
                g_strfreev(keyval);
                if (ret != -1) {
-                       vbl = g_variant_builder_new(G_VARIANT_TYPE_ARRAY);
                        gtup[0] = g_variant_new_uint32(mq);
                        gtup[1] = g_variant_new_uint64(mqflags);
-                       gvar = g_variant_new_tuple(gtup, 2);
-                       g_variant_builder_add_value(vbl, gvar);
-                       src->data = g_variant_builder_end(vbl);
+                       src->data = g_variant_new_tuple(gtup, 2);
                }
                break;
        default:
@@ -609,6 +607,7 @@ void run_session(void)
                return;
        }
 
+       trigger = NULL;
        if (opt_triggers) {
                if (!parse_triggerstring(sdi, opt_triggers, &trigger)) {
                        sr_session_destroy(session);
@@ -697,6 +696,9 @@ void run_session(void)
        if (opt_continuous)
                clear_anykey();
 
+       if (trigger)
+               sr_trigger_free(trigger);
+
        sr_session_datafeed_callback_remove_all(session);
        sr_session_destroy(session);