diff options
Diffstat (limited to 'gst-libs/gst/netbuffer')
-rw-r--r-- | gst-libs/gst/netbuffer/Makefile.am | 47 | ||||
-rw-r--r-- | gst-libs/gst/netbuffer/README | 9 | ||||
-rw-r--r-- | gst-libs/gst/netbuffer/gstnetbuffer.c | 448 | ||||
-rw-r--r-- | gst-libs/gst/netbuffer/gstnetbuffer.h | 129 |
4 files changed, 0 insertions, 633 deletions
diff --git a/gst-libs/gst/netbuffer/Makefile.am b/gst-libs/gst/netbuffer/Makefile.am deleted file mode 100644 index 7a581098..00000000 --- a/gst-libs/gst/netbuffer/Makefile.am +++ /dev/null @@ -1,47 +0,0 @@ -libgstnetbufferincludedir = $(includedir)/gstreamer-@GST_MAJORMINOR@/gst/netbuffer - -libgstnetbufferinclude_HEADERS = gstnetbuffer.h - -lib_LTLIBRARIES = libgstnetbuffer-@GST_MAJORMINOR@.la - -libgstnetbuffer_@GST_MAJORMINOR@_la_SOURCES = gstnetbuffer.c -libgstnetbuffer_@GST_MAJORMINOR@_la_CFLAGS = $(GST_CFLAGS) -libgstnetbuffer_@GST_MAJORMINOR@_la_LIBADD = $(GST_LIBS) -libgstnetbuffer_@GST_MAJORMINOR@_la_LDFLAGS = $(GST_LIB_LDFLAGS) $(GST_ALL_LDFLAGS) $(GST_LT_LDFLAGS) - -if HAVE_INTROSPECTION -BUILT_GIRSOURCES = GstNetbuffer-@GST_MAJORMINOR@.gir - -gir_headers=$(patsubst %,$(srcdir)/%, $(libgstnetbufferinclude_HEADERS)) -gir_sources=$(patsubst %,$(srcdir)/%, $(libgstnetbuffer_@GST_MAJORMINOR@_la_SOURCES)) -gir_cincludes=$(patsubst %,--c-include='gst/netbuffer/%',$(libgstnetbufferinclude_HEADERS)) - -GstNetbuffer-@GST_MAJORMINOR@.gir: $(INTROSPECTION_SCANNER) libgstnetbuffer-@GST_MAJORMINOR@.la - PKG_CONFIG_PATH="$(PKG_CONFIG_PATH):$(top_builddir)/pkgconfig" \ - $(INTROSPECTION_SCANNER) -v --namespace GstNetbuffer \ - --nsversion=@GST_MAJORMINOR@ \ - --strip-prefix=Gst \ - $(gir_cincludes) \ - --add-include-path=`$(PKG_CONFIG) --variable=libdir gstreamer-0.10`/gst \ - --library=gstnetbuffer-0.10 \ - --include=Gst-0.10 \ - --libtool="$(top_builddir)/libtool" \ - --pkg gstreamer-0.10 \ - --output $@ \ - $(gir_headers) \ - $(gir_sources) - -# INTROSPECTION_GIRDIR/INTROSPECTION_TYPELIBDIR aren't the right place to -# install anything - we need to install inside our prefix. -girdir = $(datadir)/gir-1.0 -gir_DATA = $(BUILT_GIRSOURCES) - -typelibsdir = $(libdir)/girepository-1.0/ - -typelibs_DATA = $(BUILT_GIRSOURCES:.gir=.typelib) - -%.typelib: %.gir $(INTROSPECTION_COMPILER) - $(INTROSPECTION_COMPILER) --includedir=$(srcdir) --includedir=$(builddir) --includedir=`$(PKG_CONFIG) --variable=libdir gstreamer-0.10`/gst $(INTROSPECTION_COMPILER_OPTS) $< -o $(@F) - -CLEANFILES = $(BUILT_GIRSOURCES) $(typelibs_DATA) -endif diff --git a/gst-libs/gst/netbuffer/README b/gst-libs/gst/netbuffer/README deleted file mode 100644 index d55ceb1f..00000000 --- a/gst-libs/gst/netbuffer/README +++ /dev/null @@ -1,9 +0,0 @@ -The network libraries ---------------------- - -GstNetBuffer: - - A GstBuffer subclass that can be used by network sources or sinks to - store additional to and from addresses. This is required for plugins - that operate on this data like RTP. - diff --git a/gst-libs/gst/netbuffer/gstnetbuffer.c b/gst-libs/gst/netbuffer/gstnetbuffer.c deleted file mode 100644 index 3d389f9b..00000000 --- a/gst-libs/gst/netbuffer/gstnetbuffer.c +++ /dev/null @@ -1,448 +0,0 @@ -/* GStreamer - * Copyright (C) <2005> Wim Taymans <wim@fluendo.com> - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Library General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Library General Public License for more details. - * - * You should have received a copy of the GNU Library General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ - -/** - * SECTION:gstnetbuffer - * @short_description: Buffer for use in network sources and sinks - * - * #GstNetBuffer is a subclass of a normal #GstBuffer that contains two - * additional metadata fields of type #GstNetAddress named 'to' and 'from'. The - * buffer can be used to store additional information about the origin of the - * buffer data and is used in various network elements to track the to and from - * addresses. - * - * Last reviewed on 2006-08-21 (0.10.10) - */ - -#include <string.h> - -#include "gstnetbuffer.h" - -static void gst_netbuffer_init (GTypeInstance * instance, gpointer g_class); -static void gst_netbuffer_class_init (gpointer g_class, gpointer class_data); -static void gst_netbuffer_finalize (GstNetBuffer * nbuf); -static GstNetBuffer *gst_netbuffer_copy (GstNetBuffer * nbuf); - -static GstBufferClass *parent_class; - -GType -gst_netbuffer_get_type (void) -{ - static GType _gst_netbuffer_type = 0; - - if (G_UNLIKELY (_gst_netbuffer_type == 0)) { - static const GTypeInfo netbuffer_info = { - sizeof (GstNetBufferClass), - NULL, - NULL, - gst_netbuffer_class_init, - NULL, - NULL, - sizeof (GstNetBuffer), - 0, - gst_netbuffer_init, - NULL - }; - - _gst_netbuffer_type = g_type_register_static (GST_TYPE_BUFFER, - "GstNetBuffer", &netbuffer_info, 0); - } - return _gst_netbuffer_type; -} - -static void -gst_netbuffer_class_init (gpointer g_class, gpointer class_data) -{ - GstMiniObjectClass *mo_class = GST_MINI_OBJECT_CLASS (g_class); - - parent_class = g_type_class_peek_parent (g_class); - - mo_class->copy = (GstMiniObjectCopyFunction) gst_netbuffer_copy; - mo_class->finalize = (GstMiniObjectFinalizeFunction) gst_netbuffer_finalize; -} - -static void -gst_netbuffer_init (GTypeInstance * instance, gpointer g_class) -{ -} - -static void -gst_netbuffer_finalize (GstNetBuffer * nbuf) -{ - GST_MINI_OBJECT_CLASS (parent_class)->finalize (GST_MINI_OBJECT (nbuf)); -} - -static GstNetBuffer * -gst_netbuffer_copy (GstNetBuffer * nbuf) -{ - GstNetBuffer *copy; - - copy = gst_netbuffer_new (); - - /* we simply copy everything from our parent */ - GST_BUFFER_DATA (copy) = - g_memdup (GST_BUFFER_DATA (nbuf), GST_BUFFER_SIZE (nbuf)); - /* make sure it gets freed (even if the parent is subclassed, we return a - normal buffer) */ - GST_BUFFER_MALLOCDATA (copy) = GST_BUFFER_DATA (copy); - GST_BUFFER_SIZE (copy) = GST_BUFFER_SIZE (nbuf); - - memcpy (©->to, &nbuf->to, sizeof (nbuf->to)); - memcpy (©->from, &nbuf->from, sizeof (nbuf->from)); - - /* copy metadata */ - gst_buffer_copy_metadata (GST_BUFFER_CAST (copy), - GST_BUFFER_CAST (nbuf), GST_BUFFER_COPY_ALL); - - return copy; -} - -/** - * gst_netbuffer_new: - * - * Create a new network buffer. - * - * Returns: a new #GstNetBuffer. - */ -GstNetBuffer * -gst_netbuffer_new (void) -{ - GstNetBuffer *buf; - - buf = (GstNetBuffer *) gst_mini_object_new (GST_TYPE_NETBUFFER); - - return buf; -} - -/** - * gst_netaddress_set_ip4_address: - * @naddr: a network address - * @address: an IPv4 network address. - * @port: a port number to set. - * - * Set @naddr with the IPv4 @address and @port pair. - * - * Note that @port and @address must be expressed in network byte order, - * use g_htons() and g_htonl() to convert them to network byte order. - */ -void -gst_netaddress_set_ip4_address (GstNetAddress * naddr, guint32 address, - guint16 port) -{ - g_return_if_fail (naddr != NULL); - - naddr->type = GST_NET_TYPE_IP4; - naddr->address.ip4 = address; - naddr->port = port; -} - -/** - * gst_netaddress_set_ip6_address: - * @naddr: a network address - * @address: an IPv6 network address. - * @port: a port number to set. - * - * Set @naddr with the IPv6 @address and @port pair. - * - * Note that @port must be expressed in network byte order, use g_htons() to convert - * it to network byte order. - */ -void -gst_netaddress_set_ip6_address (GstNetAddress * naddr, guint8 address[16], - guint16 port) -{ - g_return_if_fail (naddr != NULL); - - naddr->type = GST_NET_TYPE_IP6; - memcpy (&naddr->address.ip6, address, 16); - naddr->port = port; -} - -/** - * gst_netaddress_get_net_type: - * @naddr: a network address - * - * Get the type of address stored in @naddr. - * - * Returns: the network type stored in @naddr. - */ -GstNetType -gst_netaddress_get_net_type (const GstNetAddress * naddr) -{ - g_return_val_if_fail (naddr != NULL, GST_NET_TYPE_UNKNOWN); - - return naddr->type; -} - -/** - * gst_netaddress_get_ip4_address: - * @naddr: a network address - * @address: a location to store the address. - * @port: a location to store the port. - * - * Get the IPv4 address stored in @naddr into @address. This function requires - * that the address type of @naddr is of type #GST_NET_TYPE_IP4. - * - * Note that @port and @address are expressed in network byte order, use - * g_ntohs() and g_ntohl() to convert them to host order. - * - * Returns: TRUE if the address could be retrieved. - */ -gboolean -gst_netaddress_get_ip4_address (const GstNetAddress * naddr, guint32 * address, - guint16 * port) -{ - g_return_val_if_fail (naddr != NULL, FALSE); - - if (naddr->type == GST_NET_TYPE_UNKNOWN || naddr->type == GST_NET_TYPE_IP6) - return FALSE; - - if (address) - *address = naddr->address.ip4; - if (port) - *port = naddr->port; - - return TRUE; -} - -/** - * gst_netaddress_get_ip6_address: - * @naddr: a network address - * @address: a location to store the result. - * @port: a location to store the port. - * - * Get the IPv6 address stored in @naddr into @address. - * - * If @naddr is of type GST_NET_TYPE_IP4, the transitional IP6 address is - * returned. - * - * Note that @port is expressed in network byte order, use g_ntohs() to convert - * it to host order. - * - * Returns: TRUE if the address could be retrieved. - */ -gboolean -gst_netaddress_get_ip6_address (const GstNetAddress * naddr, guint8 address[16], - guint16 * port) -{ - static guint8 ip4_transition[16] = - { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0xFF, 0xFF }; - g_return_val_if_fail (naddr != NULL, FALSE); - - if (naddr->type == GST_NET_TYPE_UNKNOWN) - return FALSE; - - if (address) { - if (naddr->type == GST_NET_TYPE_IP6) { - memcpy (address, naddr->address.ip6, 16); - } else { /* naddr->type == GST_NET_TYPE_IP4 */ - memcpy (address, ip4_transition, 12); - memcpy (address + 12, (guint8 *) & (naddr->address.ip4), 4); - } - } - if (port) - *port = naddr->port; - - return TRUE; -} - -/** - * gst_netaddress_get_address_bytes: - * @naddr: a network address - * @address: a location to store the result. - * @port: a location to store the port. - * - * Get just the address bytes stored in @naddr into @address. - * - * Note that @port is expressed in network byte order, use g_ntohs() to convert - * it to host order. IP4 addresses are also stored in network byte order. - * - * Returns: number of bytes actually copied - * - * Since: 0.10.22 - */ -gint -gst_netaddress_get_address_bytes (const GstNetAddress * naddr, - guint8 address[16], guint16 * port) -{ - gint ret = 0; - - g_return_val_if_fail (naddr != NULL, FALSE); - - if (naddr->type == GST_NET_TYPE_UNKNOWN) - return 0; - - if (address) { - if (naddr->type == GST_NET_TYPE_IP6) { - memcpy (address, naddr->address.ip6, 16); - ret = 16; - } else { /* naddr->type == GST_NET_TYPE_IP4 */ - memcpy (address, (guint8 *) & (naddr->address.ip4), 4); - ret = 4; - } - } - if (port) - *port = naddr->port; - - return ret; -} - -/** - * gst_netaddress_set_address_bytes: - * @naddr: a network address - * @type: the address type (IPv4 or IPV6) - * @address: a location to store the result. - * @port: a location to store the port. - * - * Set just the address bytes stored in @naddr into @address. - * - * Note that @port must be expressed in network byte order, use g_htons() to - * convert it to network byte order order. IP4 address bytes must also be - * stored in network byte order. - * - * Returns: number of bytes actually copied - * - * Since: 0.10.22 - */ -gint -gst_netaddress_set_address_bytes (GstNetAddress * naddr, GstNetType type, - guint8 address[16], guint16 port) -{ - gint len = 0; - - g_return_val_if_fail (naddr != NULL, 0); - - naddr->type = type; - switch (naddr->type) { - case GST_NET_TYPE_UNKNOWN: - case GST_NET_TYPE_IP6: - len = 16; - memcpy (naddr->address.ip6, address, 16); - break; - case GST_NET_TYPE_IP4: - len = 4; - memcpy ((guint8 *) & (naddr->address.ip4), address, 4); - break; - } - - if (port) - naddr->port = port; - - return len; -} - -/** - * gst_netaddress_equal: - * @naddr1: The first #GstNetAddress - * @naddr2: The second #GstNetAddress - * - * Compare two #GstNetAddress structures - * - * Returns: TRUE if they are identical, FALSE otherwise - * - * Since: 0.10.18 - */ -gboolean -gst_netaddress_equal (const GstNetAddress * naddr1, - const GstNetAddress * naddr2) -{ - g_return_val_if_fail (naddr1 != NULL, FALSE); - g_return_val_if_fail (naddr2 != NULL, FALSE); - - if (naddr1->type != naddr2->type) - return FALSE; - - if (naddr1->port != naddr2->port) - return FALSE; - - switch (naddr1->type) { - case GST_NET_TYPE_IP4: - if (naddr1->address.ip4 != naddr2->address.ip4) - return FALSE; - break; - case GST_NET_TYPE_IP6: - if (memcmp (naddr1->address.ip6, naddr2->address.ip6, - sizeof (naddr1->address.ip6))) - return FALSE; - break; - default: - break; - } - return TRUE; -} - -/** - * gst_netaddress_to_string: - * @naddr: a #GstNetAddress - * @dest: destination - * @len: len of @dest - * - * Copies a string representation of @naddr into @dest. Up to @len bytes are - * copied. - * - * Returns: the number of bytes which would be produced if the buffer was large - * enough - * - * Since: 0.10.24 - */ -gint -gst_netaddress_to_string (const GstNetAddress * naddr, gchar * dest, gulong len) -{ - gint result; - - g_return_val_if_fail (naddr != NULL, FALSE); - g_return_val_if_fail (dest != NULL, FALSE); - - switch (naddr->type) { - case GST_NET_TYPE_IP4: - { - guint32 address; - guint16 port; - - gst_netaddress_get_ip4_address (naddr, &address, &port); - address = g_ntohl (address); - - result = g_snprintf (dest, len, "%d.%d.%d.%d:%d", (address >> 24) & 0xff, - (address >> 16) & 0xff, (address >> 8) & 0xff, address & 0xff, - g_ntohs (port)); - break; - } - case GST_NET_TYPE_IP6: - { - guint8 address[16]; - guint16 port; - - gst_netaddress_get_ip6_address (naddr, address, &port); - - result = - g_snprintf (dest, len, "[%04x:%04x:%04x:%04x:%04x:%04x:%04x:%04x]:%d", - (address[0] << 8) | address[1], (address[2] << 8) | address[3], - (address[4] << 8) | address[5], (address[6] << 8) | address[7], - (address[8] << 8) | address[9], (address[10] << 8) | address[11], - (address[12] << 8) | address[13], (address[14] << 8) | address[15], - g_ntohs (port)); - break; - } - default: - dest[0] = 0; - result = 0; - break; - } - return result; -} diff --git a/gst-libs/gst/netbuffer/gstnetbuffer.h b/gst-libs/gst/netbuffer/gstnetbuffer.h deleted file mode 100644 index 91770e4d..00000000 --- a/gst-libs/gst/netbuffer/gstnetbuffer.h +++ /dev/null @@ -1,129 +0,0 @@ -/* GStreamer - * Copyright (C) <2005> Wim Taymans <wim@fluendo.com> - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Library General Public - * License as published by the Free Software Foundation; either - * version 2 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Library General Public License for more details. - * - * You should have received a copy of the GNU Library General Public - * License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - */ - -#ifndef __GST_NETBUFFER_H__ -#define __GST_NETBUFFER_H__ - -#include <gst/gst.h> - -G_BEGIN_DECLS - -typedef struct _GstNetBuffer GstNetBuffer; -typedef struct _GstNetBufferClass GstNetBufferClass; -typedef struct _GstNetAddress GstNetAddress; - -#define GST_TYPE_NETBUFFER (gst_netbuffer_get_type()) -#define GST_IS_NETBUFFER(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GST_TYPE_NETBUFFER)) -#define GST_IS_NETBUFFER_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GST_TYPE_NETBUFFER)) -#define GST_NETBUFFER_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GST_TYPE_NETBUFFER, GstNetBufferClass)) -#define GST_NETBUFFER(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), GST_TYPE_NETBUFFER, GstNetBuffer)) -#define GST_NETBUFFER_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GST_TYPE_NETBUFFER, GstNetBufferClass)) - -/** - * GstNetType: - * @GST_NET_TYPE_UNKNOWN: unknown address type - * @GST_NET_TYPE_IP4: an IPv4 address type - * @GST_NET_TYPE_IP6: and IPv6 address type - * - * The Address type used in #GstNetAddress. - */ -typedef enum { - GST_NET_TYPE_UNKNOWN, - GST_NET_TYPE_IP4, - GST_NET_TYPE_IP6, -} GstNetType; - -/** - * GST_NETADDRESS_MAX_LEN: - * - * The maximum length of a string representation of a GstNetAddress as produced - * by gst_netaddress_to_string(). - * - * Since: 0.10.24 - */ -#define GST_NETADDRESS_MAX_LEN 64 - -/** - * GstNetAddress: - * - * An opaque network address as used in #GstNetBuffer. - */ -struct _GstNetAddress { - /*< private >*/ - GstNetType type; - union { - guint8 ip6[16]; - guint32 ip4; - } address; - guint16 port; - /*< private >*/ - gpointer _gst_reserved[GST_PADDING]; -}; - -/** - * GstNetBuffer: - * @buffer: the parent #GstBuffer - * @from: the address where this buffer came from. - * @to: the address where this buffer should go to. - * - * buffer for use in network sources and sinks. - * It contains the source or destination address of the buffer. - */ -struct _GstNetBuffer { - GstBuffer buffer; - - GstNetAddress from; - GstNetAddress to; - - /*< private >*/ - gpointer _gst_reserved[GST_PADDING]; -}; - -struct _GstNetBufferClass { - GstBufferClass buffer_class; - - /*< private >*/ - gpointer _gst_reserved[GST_PADDING]; -}; - -/* creating buffers */ -GType gst_netbuffer_get_type (void); - -GstNetBuffer* gst_netbuffer_new (void); - -/* address operations */ -void gst_netaddress_set_ip4_address (GstNetAddress *naddr, guint32 address, guint16 port); -void gst_netaddress_set_ip6_address (GstNetAddress *naddr, guint8 address[16], guint16 port); -gint gst_netaddress_set_address_bytes (GstNetAddress *naddr, GstNetType type, - guint8 address[16], guint16 port); - -GstNetType gst_netaddress_get_net_type (const GstNetAddress *naddr); -gboolean gst_netaddress_get_ip4_address (const GstNetAddress *naddr, guint32 *address, guint16 *port); -gboolean gst_netaddress_get_ip6_address (const GstNetAddress *naddr, guint8 address[16], guint16 *port); -gint gst_netaddress_get_address_bytes (const GstNetAddress *naddr, guint8 address[16], guint16 *port); - -gboolean gst_netaddress_equal (const GstNetAddress *naddr1, - const GstNetAddress *naddr2); - -gint gst_netaddress_to_string (const GstNetAddress *naddr, gchar *dest, gulong len); - -G_END_DECLS - -#endif /* __GST_NETBUFFER_H__ */ - |