/* * Copyright © 2009, 2010 Codethink Limited * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2 of the licence, 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 * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser 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. * * Author: Ryan Lortie <desrt@desrt.ca> */ #ifndef __G_BUFFER_H__ #define __G_BUFFER_H__ #include <glib/gtypes.h> /* < private > * GBuffer: * @data: a pointer to the data held in the buffer * @size: the size of @data * * A simple refcounted data type representing a byte sequence from an * unspecified origin. * * The purpose of a #GBuffer is to keep the memory region that it holds * alive for as long as anyone holds a reference to the buffer. When * the last reference count is dropped, the memory is released. * * A #GBuffer can come from many different origins that may have * different procedures for freeing the memory region. Examples are * memory from g_malloc(), from memory slices, from a #GMappedFile or * memory from other allocators. */ typedef struct _GBuffer GBuffer; /* < private > * GBufferFreeFunc: * @buffer: the #GBuffer to be freed * * This function is provided by creators of a #GBuffer. It is the * function to be called when the reference count of @buffer drops to * zero. It should free any memory associated with the buffer and free * @buffer itself. */ typedef void (* GBufferFreeFunc) (GBuffer *buffer); struct _GBuffer { gconstpointer data; gsize size; /*< protected >*/ GBufferFreeFunc free_func; /*< private >*/ gint ref_count; }; G_GNUC_INTERNAL GBuffer * g_buffer_new_from_data (gconstpointer data, gsize size); G_GNUC_INTERNAL GBuffer * g_buffer_new_take_data (gpointer data, gsize size); G_GNUC_INTERNAL GBuffer * g_buffer_new_from_static_data (gconstpointer data, gsize size); G_GNUC_INTERNAL GBuffer * g_buffer_new_from_pointer (gconstpointer data, gsize size, GDestroyNotify notify, gpointer user_data); G_GNUC_INTERNAL GBuffer * g_buffer_ref (GBuffer *buffer); G_GNUC_INTERNAL void g_buffer_unref (GBuffer *buffer); #endif /* __G_BUFFER_H__ */