diff options
author | David Schleef <ds@schleef.org> | 2009-07-13 18:04:14 -0700 |
---|---|---|
committer | David Schleef <ds@schleef.org> | 2009-07-13 18:04:14 -0700 |
commit | 969fbce46ebbe598e63968b58cc675fa4830ec6c (patch) | |
tree | c3a7b18bacdc77ad65b3028790260177f80de3cf /ext | |
parent | 6fd890d65f11fe4da6257944f993a91dd8b6c5f7 (diff) | |
download | gst-plugins-bad-969fbce46ebbe598e63968b58cc675fa4830ec6c.tar.gz gst-plugins-bad-969fbce46ebbe598e63968b58cc675fa4830ec6c.tar.bz2 gst-plugins-bad-969fbce46ebbe598e63968b58cc675fa4830ec6c.zip |
schro: Add enum types for schroedinger settings
Diffstat (limited to 'ext')
-rw-r--r-- | ext/schroedinger/gstschroenc.c | 38 |
1 files changed, 36 insertions, 2 deletions
diff --git a/ext/schroedinger/gstschroenc.c b/ext/schroedinger/gstschroenc.c index 2d0fb39b..24c55e7a 100644 --- a/ext/schroedinger/gstschroenc.c +++ b/ext/schroedinger/gstschroenc.c @@ -149,6 +149,31 @@ gst_schro_enc_base_init (gpointer g_class) gst_element_class_set_details (element_class, &schro_enc_details); } +static GType +register_enum_list (const SchroEncoderSetting * setting) +{ + GType type; + static GEnumValue *enumtypes; + int n; + char *typename; + int i; + + n = setting->max + 1; + + enumtypes = g_malloc0 ((n + 1) * sizeof (GEnumValue)); + for (i = 0; i < n; i++) { + enumtypes[i].value = i; + enumtypes[i].value_name = setting->enum_list[i]; + enumtypes[i].value_nick = setting->enum_list[i]; + } + + typename = g_strdup_printf ("SchroEncoderSettingEnum_%s", setting->name); + type = g_enum_register_static (typename, enumtypes); + g_free (typename); + + return type; +} + static void gst_schro_enc_class_init (GstSchroEncClass * klass) { @@ -183,8 +208,8 @@ gst_schro_enc_class_init (GstSchroEncClass * klass) break; case SCHRO_ENCODER_SETTING_TYPE_ENUM: g_object_class_install_property (gobject_class, i + 1, - g_param_spec_int (setting->name, setting->name, setting->name, - setting->min, setting->max, setting->default_value, + g_param_spec_enum (setting->name, setting->name, setting->name, + register_enum_list (setting), setting->default_value, G_PARAM_READWRITE)); break; case SCHRO_ENCODER_SETTING_TYPE_DOUBLE: @@ -308,6 +333,10 @@ gst_schro_enc_set_property (GObject * object, guint prop_id, schro_encoder_setting_set_double (src->encoder, setting->name, g_value_get_boolean (value)); break; + default: + schro_encoder_setting_set_double (src->encoder, setting->name, + g_value_get_enum (value)); + break; } } } @@ -337,6 +366,11 @@ gst_schro_enc_get_property (GObject * object, guint prop_id, GValue * value, g_value_set_boolean (value, schro_encoder_setting_get_double (src->encoder, setting->name)); break; + default: + /* it's an enum */ + g_value_set_enum (value, + schro_encoder_setting_get_double (src->encoder, setting->name)); + break; } } } |