bugfixing: always use the right GType when using g_object_get/set; do not free string...
authorBenjamin Otte <otte@gnome.org>
Wed, 6 Feb 2002 08:23:10 +0000 (08:23 +0000)
committerBenjamin Otte <otte@gnome.org>
Wed, 6 Feb 2002 08:23:10 +0000 (08:23 +0000)
Original commit message from CVS:
bugfixing: always use the right GType when using g_object_get/set; do not free strings from g_object_get, they're not yours (see docs/design/part-standards.txt)

tools/gst-launch.c

index 8fd00c3..43f83b6 100644 (file)
@@ -49,19 +49,26 @@ property_change_callback (GObject *object, GstObject *orig, GParamSpec *pspec)
 #ifdef USE_GLIB2
   if (G_IS_PARAM_SPEC_STRING (pspec))
   {
-    gchar *str = NULL;
+    gchar *str;
     g_object_get (orig, pspec->name, &str, NULL);
     g_print ("%s: %s = \"%s\"\n", GST_OBJECT_NAME (orig), pspec->name, str);
-    g_free (str);
   } else if (G_IS_PARAM_SPEC_CHAR (pspec)) {
     gchar str;
     g_object_get (orig, pspec->name, &str, NULL);
     g_print ("%s: %s = \"%c\"\n", GST_OBJECT_NAME (orig), pspec->name, str);
-  } else if (G_IS_PARAM_SPEC_INT (pspec) || G_IS_PARAM_SPEC_INT64 (pspec)) {
+  } else if (G_IS_PARAM_SPEC_INT (pspec)) {
+    gint i;
+    g_object_get (orig, pspec->name, &i, NULL);
+    g_print ("%s: %s = %d\n", GST_OBJECT_NAME (orig), pspec->name, i);
+  } else if (G_IS_PARAM_SPEC_INT64 (pspec)) {
     gint64 i;
     g_object_get (orig, pspec->name, &i, NULL);
     g_print ("%s: %s = %lld\n", GST_OBJECT_NAME (orig), pspec->name, i);
-  } else if (G_IS_PARAM_SPEC_UINT (pspec) || G_IS_PARAM_SPEC_UINT64 (pspec)) {
+  } else if (G_IS_PARAM_SPEC_UINT (pspec)) {
+    guint i;
+    g_object_get (orig, pspec->name, &i, NULL);
+    g_print ("%s: %s = %u\n", GST_OBJECT_NAME (orig), pspec->name, i);
+  } else if (G_IS_PARAM_SPEC_UINT (pspec)) {
     guint64 i;
     g_object_get (orig, pspec->name, &i, NULL);
     g_print ("%s: %s = %llu\n", GST_OBJECT_NAME (orig), pspec->name, i);