X-Git-Url: https://sigrok.org/gitweb/?a=blobdiff_plain;f=src%2Foutput%2Foutput.c;h=0029748bb7398510fc6abdc061ea37732ecf546c;hb=0d14e30ba01fb8258a57cb894feff56990a9cd13;hp=3e432c9f0c7b82458621ef70ab0da8fa16b38364;hpb=63f6df68c67099a207910f38386e0fe77ece127f;p=libsigrok.git diff --git a/src/output/output.c b/src/output/output.c index 3e432c9f..0029748b 100644 --- a/src/output/output.c +++ b/src/output/output.c @@ -1,7 +1,7 @@ /* * This file is part of the libsigrok project. * - * Copyright (C) 2010-2012 Bert Vermeulen + * Copyright (C) 2014 Bert Vermeulen * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by @@ -160,39 +160,52 @@ SR_API const struct sr_output_module *sr_output_find(char *id) * * @since 0.4.0 */ -SR_API const struct sr_option *sr_output_options_get(const struct sr_output_module *o) +SR_API const struct sr_option **sr_output_options_get(const struct sr_output_module *o) { + const struct sr_option *mod_opts, **opts; + int size, i; if (!o || !o->options) return NULL; - return o->options(); + mod_opts = o->options(); + + for (size = 0; mod_opts[size].id; size++) + ; + opts = g_malloc((size + 1) * sizeof(struct sr_option *)); + + for (i = 0; i < size; i++) + opts[i] = &mod_opts[i]; + opts[i] = NULL; + + return opts; } /** * After a call to sr_output_options_get(), this function cleans up all - * resources allocated by that call. + * resources returned by that call. * * @since 0.4.0 */ -SR_API void sr_output_options_free(const struct sr_output_module *o) +SR_API void sr_output_options_free(const struct sr_option **options) { - struct sr_option *opt; + int i; - if (!o || !o->options) + if (!options) return; - for (opt = o->options(); opt->id; opt++) { - if (opt->def) { - g_variant_unref(opt->def); - opt->def = NULL; + for (i = 0; options[i]; i++) { + if (options[i]->def) { + g_variant_unref(options[i]->def); + ((struct sr_option *)options[i])->def = NULL; } - if (opt->values) { - g_slist_free_full(opt->values, (GDestroyNotify)g_variant_unref); - opt->values = NULL; + if (options[i]->values) { + g_slist_free_full(options[i]->values, (GDestroyNotify)g_variant_unref); + ((struct sr_option *)options[i])->values = NULL; } } + g_free(options); } /** @@ -212,7 +225,7 @@ SR_API const struct sr_output *sr_output_new(const struct sr_output_module *o, GHashTable *options, const struct sr_dev_inst *sdi) { struct sr_output *op; - struct sr_option *mod_opts; + const struct sr_option *mod_opts; const GVariantType *gvt; GHashTable *new_opts; GHashTableIter iter; @@ -261,7 +274,6 @@ SR_API const struct sr_output *sr_output_new(const struct sr_output_module *o, } if (op->module->init && op->module->init(op, new_opts) != SR_OK) { - g_hash_table_destroy(new_opts); g_free(op); op = NULL; }