Add a generic GstIterator wrapper and use that
authorSebastian Dröge <sebastian.droege@collabora.co.uk>
Sat, 9 May 2009 17:29:40 +0000 (19:29 +0200)
committerSebastian Dröge <sebastian.droege@collabora.co.uk>
Sat, 9 May 2009 17:29:40 +0000 (19:29 +0200)
gstreamer-sharp/Bin.custom
gstreamer-sharp/Element.custom
gstreamer-sharp/Iterator.cs [new file with mode: 0644]
gstreamer-sharp/Makefile.am
gstreamer-sharp/Pad.custom

index 2d1e4b2872ac0837c9883ada983b051c5ee57f77..8b0911bdc34afcfe0314210da65743087ae0c879 100644 (file)
@@ -51,12 +51,6 @@ public Gst.Element GetByInterface (System.Type type) {
   return GetByInterface (t);
 }
 
-[DllImport ("gstreamer-0.10.dll") ]
-static extern int gst_iterator_next (IntPtr iterator, out IntPtr elem);
-[DllImport ("gstreamer-0.10.dll") ]
-static extern void gst_iterator_resync (IntPtr iterator);
-[DllImport ("gstreamer-0.10.dll") ]
-static extern void gst_iterator_free (IntPtr iterator);
 [DllImport ("gstreamer-0.10.dll") ]
 static extern IntPtr gst_bin_iterate_elements (IntPtr bin);
 [DllImport ("gstreamer-0.10.dll") ]
@@ -70,112 +64,38 @@ static extern IntPtr gst_bin_iterate_sources (IntPtr bin);
 [DllImport ("gstreamer-0.10.dll") ]
 static extern IntPtr gst_bin_iterate_all_by_interface (IntPtr bin, IntPtr gtype);
 
-private class ElementEnumerable : IEnumerable {
-  private class ElementEnumerator : IEnumerator {
-    Hashtable seen = new Hashtable ();
-    IntPtr iterator;
-
-    private object current = null;
-    public object Current {
-      get {
-        return current;
-      }
-    }
-
-    public bool MoveNext () {
-      IntPtr raw_ret;
-      bool retry = false;
-
-      if (iterator == IntPtr.Zero)
-        return false;
-
-      do {
-        int ret = gst_iterator_next (iterator, out raw_ret);
-        switch (ret) {
-          case 0:
-            return false;
-          case 1:
-            if (seen.Contains (raw_ret)) {
-              retry = true;
-              break;
-            }
-
-            seen.Add (raw_ret, null);
-            current = GLib.Object.GetObject (raw_ret, true);
-            return true;
-          case 2:
-            gst_iterator_resync (iterator);
-            break;
-          default:
-          case 3:
-            throw new Exception ("Error while iterating bin");
-        }
-      } while (retry);
-
-      return false;
-    }
-
-    public void Reset () {
-      seen.Clear ();
-      if (iterator != IntPtr.Zero)
-        gst_iterator_resync (iterator);
-    }
-
-    public ElementEnumerator (IntPtr iterator) {
-      this.iterator = iterator;
-    }
-  }
-
-  private IntPtr iterator;
-  private ElementEnumerator enumerator;
-
-  public ElementEnumerable (IntPtr iterator) {
-    this.iterator = iterator;
-    this.enumerator = new ElementEnumerator (iterator);
-  }
-
-  public IEnumerator GetEnumerator () {
-    return enumerator;
-  }
-
-  ~ElementEnumerable () {
-    if (iterator != IntPtr.Zero)
-      gst_iterator_free (iterator);
-  }
-}
-
 public IEnumerable Elements {
   get {
-    return new ElementEnumerable (gst_bin_iterate_elements (Handle));
+    return new Enumerable (gst_bin_iterate_elements (Handle));
   }
 }
 
 public IEnumerable ElementsRecurse {
   get {
-    return new ElementEnumerable (gst_bin_iterate_recurse (Handle));
+    return new Enumerable (gst_bin_iterate_recurse (Handle));
   }
 }
 
 public IEnumerable ElementsSorted {
   get {
-    return new ElementEnumerable (gst_bin_iterate_sorted (Handle));
+    return new Enumerable (gst_bin_iterate_sorted (Handle));
   }
 }
 
 public IEnumerable SinkElements {
   get {
-    return new ElementEnumerable (gst_bin_iterate_sinks (Handle));
+    return new Enumerable (gst_bin_iterate_sinks (Handle));
   }
 }
 
 public IEnumerable SourceElements {
   get {
-    return new ElementEnumerable (gst_bin_iterate_sources (Handle));
+    return new Enumerable (gst_bin_iterate_sources (Handle));
   }
 }
 
 public IEnumerable GetAllByInterface (GLib.GType type) {
-  return new ElementEnumerable (gst_bin_iterate_all_by_interface (Handle, type.Val));
+  return new Enumerable (gst_bin_iterate_all_by_interface (Handle, type.Val));
 }
 
 public IEnumerable GetAllByInterface (System.Type type) {
index a7d18c9b3781f5d5c6abb0c89180b84d9e525a0f..1098e425c2f3b2c050001b9d677821ae04b5f163 100644 (file)
@@ -25,12 +25,6 @@ public static void UnlinkMany (params Element [] elements) {
   }
 }
 
-[DllImport ("gstreamer-0.10.dll") ]
-static extern int gst_iterator_next (IntPtr iterator, out IntPtr elem);
-[DllImport ("gstreamer-0.10.dll") ]
-static extern void gst_iterator_resync (IntPtr iterator);
-[DllImport ("gstreamer-0.10.dll") ]
-static extern void gst_iterator_free (IntPtr iterator);
 [DllImport ("gstreamer-0.10.dll") ]
 static extern IntPtr gst_element_iterate_pads (IntPtr element);
 [DllImport ("gstreamer-0.10.dll") ]
@@ -38,95 +32,21 @@ static extern IntPtr gst_element_iterate_src_pads (IntPtr element);
 [DllImport ("gstreamer-0.10.dll") ]
 static extern IntPtr gst_element_iterate_sink_pads (IntPtr element);
 
-private class PadEnumerable : IEnumerable {
-  private class PadEnumerator : IEnumerator {
-    Hashtable seen = new Hashtable ();
-    IntPtr iterator;
-
-    private object current = null;
-    public object Current {
-      get {
-        return current;
-      }
-    }
-
-    public bool MoveNext () {
-      IntPtr raw_ret;
-      bool retry = false;
-
-      if (iterator == IntPtr.Zero)
-        return false;
-
-      do {
-        int ret = gst_iterator_next (iterator, out raw_ret);
-        switch (ret) {
-          case 0:
-            return false;
-          case 1:
-            if (seen.Contains (raw_ret)) {
-              retry = true;
-              break;
-            }
-
-            seen.Add (raw_ret, null);
-            current = GLib.Object.GetObject (raw_ret, true);
-            return true;
-          case 2:
-            gst_iterator_resync (iterator);
-            break;
-          default:
-          case 3:
-            throw new Exception ("Error while iterating pads");
-        }
-      } while (retry);
-
-      return false;
-    }
-
-    public void Reset () {
-      seen.Clear ();
-      if (iterator != IntPtr.Zero)
-        gst_iterator_resync (iterator);
-    }
-
-    public PadEnumerator (IntPtr iterator) {
-      this.iterator = iterator;
-    }
-  }
-
-  private IntPtr iterator;
-  private PadEnumerator enumerator;
-
-  public PadEnumerable (IntPtr iterator) {
-    this.iterator = iterator;
-    this.enumerator = new PadEnumerator (iterator);
-  }
-
-  public IEnumerator GetEnumerator () {
-    return enumerator;
-  }
-
-  ~PadEnumerable () {
-    if (iterator != IntPtr.Zero)
-      gst_iterator_free (iterator);
-  }
-}
-
 public IEnumerable Pads {
   get {
-    return new PadEnumerable (gst_element_iterate_pads (Handle));
+    return new Enumerable (gst_element_iterate_pads (Handle));
   }
 }
 
 public IEnumerable SinkPads {
   get {
-    return new PadEnumerable (gst_element_iterate_sink_pads (Handle));
+    return new Enumerable (gst_element_iterate_sink_pads (Handle));
   }
 }
 
 public IEnumerable SrcPads {
   get {
-    return new PadEnumerable (gst_element_iterate_src_pads (Handle));
+    return new Enumerable (gst_element_iterate_src_pads (Handle));
   }
 }
 
diff --git a/gstreamer-sharp/Iterator.cs b/gstreamer-sharp/Iterator.cs
new file mode 100644 (file)
index 0000000..1e33131
--- /dev/null
@@ -0,0 +1,90 @@
+using System;
+using System.Collections;
+using System.Runtime.InteropServices;
+using GLib;
+
+namespace Gst {
+
+  internal class Enumerable : IEnumerable {
+    private class Enumerator : IEnumerator {
+      Hashtable seen = new Hashtable ();
+      IntPtr iterator;
+
+      private object current = null;
+      public object Current {
+        get {
+          return current;
+        }
+      }
+
+      public bool MoveNext () {
+        IntPtr raw_ret;
+        bool retry = false;
+
+        if (iterator == IntPtr.Zero)
+          return false;
+
+        do {
+          int ret = gst_iterator_next (iterator, out raw_ret);
+          switch (ret) {
+            case 0:
+              return false;
+            case 1:
+              if (seen.Contains (raw_ret)) {
+                retry = true;
+                break;
+              }
+
+              seen.Add (raw_ret, null);
+              current = GLib.Object.GetObject (raw_ret, true);
+              return true;
+            case 2:
+              gst_iterator_resync (iterator);
+             retry = true;
+              break;
+            default:
+            case 3:
+              throw new Exception ("Error while iterating pads");
+          }
+        } while (retry);
+
+        return false;
+      }
+
+      public void Reset () {
+        seen.Clear ();
+        if (iterator != IntPtr.Zero)
+          gst_iterator_resync (iterator);
+      }
+
+      public Enumerator (IntPtr iterator) {
+        this.iterator = iterator;
+      }
+    }
+
+    private IntPtr iterator;
+    private Enumerator enumerator;
+
+    public Enumerable (IntPtr iterator) {
+      this.iterator = iterator;
+      this.enumerator = new Enumerator (iterator);
+    }
+
+    public IEnumerator GetEnumerator () {
+      return enumerator;
+    }
+
+    ~Enumerable () {
+      if (iterator != IntPtr.Zero)
+        gst_iterator_free (iterator);
+    }
+
+    [DllImport ("gstreamer-0.10.dll") ]
+    static extern int gst_iterator_next (IntPtr iterator, out IntPtr elem);
+    [DllImport ("gstreamer-0.10.dll") ]
+    static extern void gst_iterator_resync (IntPtr iterator);
+    [DllImport ("gstreamer-0.10.dll") ]
+    static extern void gst_iterator_free (IntPtr iterator);
+
+  }
+}
index 5b61419df63059305c5808508945c0a17845d865..4c4174f73b96e99eacf51590bb3a5011aba07164 100644 (file)
@@ -44,6 +44,7 @@ sources = \
        AssemblyInfo.cs \
        GError.cs \
        Value.cs \
+       Iterator.cs \
        GstSharp.PadQueryTypeFunctionNative.cs \
        PadQueryTypeFunction.cs \
        TypeFindDelegates.cs \
index 1a4cc0af5ca9954761696bba8a2d50fbfa036880..b0e36a4cc6a061ea35eaa600a4c9f8b52b249caf 100644 (file)
@@ -431,94 +431,15 @@ public bool StreamTryLock () {
   return g_static_rec_mutex_trylock (StreamLockPtr);
 }
 
-[DllImport ("gstreamer-0.10.dll") ]
-static extern int gst_iterator_next (IntPtr iterator, out IntPtr elem);
-[DllImport ("gstreamer-0.10.dll") ]
-static extern void gst_iterator_resync (IntPtr iterator);
-[DllImport ("gstreamer-0.10.dll") ]
-static extern void gst_iterator_free (IntPtr iterator);
 [DllImport ("gstreamer-0.10.dll") ]
 static extern IntPtr gst_pad_iterate_internal_links (IntPtr pad);
 [DllImport ("gstreamer-0.10.dll") ]
 static extern IntPtr gst_pad_iterate_internal_links_default (IntPtr pad);
 
-private class PadEnumerable : IEnumerable {
-  private class PadEnumerator : IEnumerator {
-    Hashtable seen = new Hashtable ();
-    IntPtr iterator;
-
-    private object current = null;
-    public object Current {
-      get {
-        return current;
-      }
-    }
-
-    public bool MoveNext () {
-      IntPtr raw_ret;
-      bool retry = false;
-
-      if (iterator == IntPtr.Zero)
-        return false;
-
-      do {
-        int ret = gst_iterator_next (iterator, out raw_ret);
-        switch (ret) {
-          case 0:
-            return false;
-          case 1:
-            if (seen.Contains (raw_ret)) {
-              retry = true;
-              break;
-            }
-
-            seen.Add (raw_ret, null);
-            current = GLib.Object.GetObject (raw_ret, true);
-            return true;
-          case 2:
-            gst_iterator_resync (iterator);
-            break;
-          default:
-          case 3:
-            throw new Exception ("Error while iterating pads");
-        }
-      } while (retry);
-
-      return false;
-    }
-
-    public void Reset () {
-      seen.Clear ();
-      if (iterator != IntPtr.Zero)
-        gst_iterator_resync (iterator);
-    }
-
-    public PadEnumerator (IntPtr iterator) {
-      this.iterator = iterator;
-    }
-  }
-
-  private IntPtr iterator;
-  private PadEnumerator enumerator;
-
-  public PadEnumerable (IntPtr iterator) {
-    this.iterator = iterator;
-    this.enumerator = new PadEnumerator (iterator);
-  }
-
-  public IEnumerator GetEnumerator () {
-    return enumerator;
-  }
-
-  ~PadEnumerable () {
-    if (iterator != IntPtr.Zero)
-      gst_iterator_free (iterator);
-  }
-}
 
 public IEnumerable InternalLinks {
   get {
-    return new PadEnumerable (gst_pad_iterate_internal_links (Handle));
+    return new Enumerable (gst_pad_iterate_internal_links (Handle));
   }
 }