GArray: Documentation cleanups

This commit is contained in:
Matthias Clasen 2014-02-01 20:45:25 -05:00
parent 8f57d6dd1d
commit cbd585495c
2 changed files with 145 additions and 141 deletions

View File

@ -96,7 +96,7 @@ typedef struct _GRealArray GRealArray;
* @len: the number of elements in the #GArray not including the
* possible terminating zero element.
*
* Contains the public fields of a #GArray.
* Contains the public fields of a GArray.
*/
struct _GRealArray
{
@ -817,19 +817,19 @@ g_array_maybe_expand (GRealArray *array,
*
* An example using a #GPtrArray:
* |[<!-- language="C" -->
* GPtrArray *gparray;
* GPtrArray *array;
* gchar *string1 = "one", *string2 = "two", *string3 = "three";
*
* gparray = g_ptr_array_new ();
* g_ptr_array_add (gparray, (gpointer) string1);
* g_ptr_array_add (gparray, (gpointer) string2);
* g_ptr_array_add (gparray, (gpointer) string3);
* g_ptr_array_add (array, (gpointer) string1);
* g_ptr_array_add (array, (gpointer) string2);
* g_ptr_array_add (array, (gpointer) string3);
*
* if (g_ptr_array_index (gparray, 0) != (gpointer) string1)
* if (g_ptr_array_index (array, 0) != (gpointer) string1)
* g_print ("ERROR: got %p instead of %p\n",
* g_ptr_array_index (gparray, 0), string1);
* g_ptr_array_index (array, 0), string1);
*
* g_ptr_array_free (gparray, TRUE);
* g_ptr_array_free (array, TRUE);
* ]|
*/
@ -895,7 +895,9 @@ g_ptr_array_new (void)
GPtrArray*
g_ptr_array_sized_new (guint reserved_size)
{
GRealPtrArray *array = g_slice_new (GRealPtrArray);
GRealPtrArray *array;
array = g_slice_new (GRealPtrArray);
array->pdata = NULL;
array->len = 0;
@ -930,6 +932,7 @@ g_ptr_array_new_with_free_func (GDestroyNotify element_free_func)
array = g_ptr_array_new ();
g_ptr_array_set_free_func (array, element_free_func);
return array;
}
@ -959,6 +962,7 @@ g_ptr_array_new_full (guint reserved_size,
array = g_ptr_array_sized_new (reserved_size);
g_ptr_array_set_free_func (array, element_free_func);
return array;
}
@ -1025,6 +1029,7 @@ void
g_ptr_array_unref (GPtrArray *array)
{
GRealPtrArray *rarray = (GRealPtrArray *)array;
g_return_if_fail (array);
if (g_atomic_int_dec_and_test (&rarray->ref_count))
@ -1051,51 +1056,51 @@ g_ptr_array_unref (GPtrArray *array)
* The pointer array should be freed using g_free().
*/
gpointer*
g_ptr_array_free (GPtrArray *farray,
g_ptr_array_free (GPtrArray *array,
gboolean free_segment)
{
GRealPtrArray *array = (GRealPtrArray*) farray;
GRealPtrArray *rarray = (GRealPtrArray *)array;
ArrayFreeFlags flags;
g_return_val_if_fail (array, NULL);
g_return_val_if_fail (rarray, NULL);
flags = (free_segment ? FREE_SEGMENT : 0);
/* if others are holding a reference, preserve the wrapper but
* do free/return the data
*/
if (!g_atomic_int_dec_and_test (&array->ref_count))
if (!g_atomic_int_dec_and_test (&rarray->ref_count))
flags |= PRESERVE_WRAPPER;
return ptr_array_free (farray, flags);
return ptr_array_free (array, flags);
}
static gpointer *
ptr_array_free (GPtrArray *farray,
ptr_array_free (GPtrArray *array,
ArrayFreeFlags flags)
{
GRealPtrArray *array = (GRealPtrArray*) farray;
GRealPtrArray *rarray = (GRealPtrArray *)array;
gpointer *segment;
if (flags & FREE_SEGMENT)
{
if (array->element_free_func != NULL)
g_ptr_array_foreach (farray, (GFunc) array->element_free_func, NULL);
g_free (array->pdata);
if (rarray->element_free_func != NULL)
g_ptr_array_foreach (array, (GFunc) rarray->element_free_func, NULL);
g_free (rarray->pdata);
segment = NULL;
}
else
segment = array->pdata;
segment = rarray->pdata;
if (flags & PRESERVE_WRAPPER)
{
array->pdata = NULL;
array->len = 0;
array->alloc = 0;
rarray->pdata = NULL;
rarray->len = 0;
rarray->alloc = 0;
}
else
{
g_slice_free1 (sizeof (GRealPtrArray), array);
g_slice_free1 (sizeof (GRealPtrArray), rarray);
}
return segment;
@ -1128,30 +1133,30 @@ g_ptr_array_maybe_expand (GRealPtrArray *array,
* called for the removed elements.
*/
void
g_ptr_array_set_size (GPtrArray *farray,
g_ptr_array_set_size (GPtrArray *array,
gint length)
{
GRealPtrArray* array = (GRealPtrArray*) farray;
GRealPtrArray *rarray = (GRealPtrArray *)array;
g_return_if_fail (array);
g_return_if_fail (rarray);
if (length > array->len)
if (length > rarray->len)
{
int i;
g_ptr_array_maybe_expand (array, (length - array->len));
g_ptr_array_maybe_expand (rarray, (length - rarray->len));
/* This is not
* memset (array->pdata + array->len, 0,
* sizeof (gpointer) * (length - array->len));
* to make it really portable. Remember (void*)NULL needn't be
* bitwise zero. It of course is silly not to use memset (..,0,..).
*/
for (i = array->len; i < length; i++)
array->pdata[i] = NULL;
for (i = rarray->len; i < length; i++)
rarray->pdata[i] = NULL;
}
else if (length < array->len)
g_ptr_array_remove_range (farray, length, array->len - length);
else if (length < rarray->len)
g_ptr_array_remove_range (array, length, rarray->len - length);
array->len = length;
rarray->len = length;
}
/**
@ -1167,29 +1172,29 @@ g_ptr_array_set_size (GPtrArray *farray,
* Returns: the pointer which was removed
*/
gpointer
g_ptr_array_remove_index (GPtrArray *farray,
g_ptr_array_remove_index (GPtrArray *array,
guint index_)
{
GRealPtrArray* array = (GRealPtrArray*) farray;
GRealPtrArray *rarray = (GRealPtrArray *)array;
gpointer result;
g_return_val_if_fail (array, NULL);
g_return_val_if_fail (rarray, NULL);
g_return_val_if_fail (index_ < array->len, NULL);
g_return_val_if_fail (index_ < rarray->len, NULL);
result = array->pdata[index_];
result = rarray->pdata[index_];
if (array->element_free_func != NULL)
array->element_free_func (array->pdata[index_]);
if (rarray->element_free_func != NULL)
rarray->element_free_func (rarray->pdata[index_]);
if (index_ != array->len - 1)
memmove (array->pdata + index_, array->pdata + index_ + 1,
sizeof (gpointer) * (array->len - index_ - 1));
if (index_ != rarray->len - 1)
memmove (rarray->pdata + index_, rarray->pdata + index_ + 1,
sizeof (gpointer) * (rarray->len - index_ - 1));
array->len -= 1;
rarray->len -= 1;
if (G_UNLIKELY (g_mem_gc_friendly))
array->pdata[array->len] = NULL;
rarray->pdata[rarray->len] = NULL;
return result;
}
@ -1208,28 +1213,28 @@ g_ptr_array_remove_index (GPtrArray *farray,
* Returns: the pointer which was removed
*/
gpointer
g_ptr_array_remove_index_fast (GPtrArray *farray,
g_ptr_array_remove_index_fast (GPtrArray *array,
guint index_)
{
GRealPtrArray* array = (GRealPtrArray*) farray;
GRealPtrArray *rarray = (GRealPtrArray *)array;
gpointer result;
g_return_val_if_fail (array, NULL);
g_return_val_if_fail (rarray, NULL);
g_return_val_if_fail (index_ < array->len, NULL);
g_return_val_if_fail (index_ < rarray->len, NULL);
result = array->pdata[index_];
result = rarray->pdata[index_];
if (array->element_free_func != NULL)
array->element_free_func (array->pdata[index_]);
if (rarray->element_free_func != NULL)
rarray->element_free_func (rarray->pdata[index_]);
if (index_ != array->len - 1)
array->pdata[index_] = array->pdata[array->len - 1];
if (index_ != rarray->len - 1)
rarray->pdata[index_] = rarray->pdata[rarray->len - 1];
array->len -= 1;
rarray->len -= 1;
if (G_UNLIKELY (g_mem_gc_friendly))
array->pdata[array->len] = NULL;
rarray->pdata[rarray->len] = NULL;
return result;
}
@ -1242,47 +1247,47 @@ g_ptr_array_remove_index_fast (GPtrArray *farray,
*
* Removes the given number of pointers starting at the given index
* from a #GPtrArray. The following elements are moved to close the
* gap. If @array has a non-%NULL #GDestroyNotify function it is called
* for the removed elements.
* gap. If @array has a non-%NULL #GDestroyNotify function it is
* called for the removed elements.
*
* Returns: the @array
*
* Since: 2.4
*/
GPtrArray*
g_ptr_array_remove_range (GPtrArray *farray,
g_ptr_array_remove_range (GPtrArray *array,
guint index_,
guint length)
{
GRealPtrArray* array = (GRealPtrArray*) farray;
GRealPtrArray *rarray = (GRealPtrArray *)array;
guint n;
g_return_val_if_fail (array != NULL, NULL);
g_return_val_if_fail (index_ < array->len, NULL);
g_return_val_if_fail (index_ + length <= array->len, NULL);
g_return_val_if_fail (rarray != NULL, NULL);
g_return_val_if_fail (index_ < rarray->len, NULL);
g_return_val_if_fail (index_ + length <= rarray->len, NULL);
if (array->element_free_func != NULL)
if (rarray->element_free_func != NULL)
{
for (n = index_; n < index_ + length; n++)
array->element_free_func (array->pdata[n]);
rarray->element_free_func (rarray->pdata[n]);
}
if (index_ + length != array->len)
if (index_ + length != rarray->len)
{
memmove (&array->pdata[index_],
&array->pdata[index_ + length],
(array->len - (index_ + length)) * sizeof (gpointer));
memmove (&rarray->pdata[index_],
&rarray->pdata[index_ + length],
(rarray->len - (index_ + length)) * sizeof (gpointer));
}
array->len -= length;
rarray->len -= length;
if (G_UNLIKELY (g_mem_gc_friendly))
{
guint i;
for (i = 0; i < length; i++)
array->pdata[array->len + i] = NULL;
rarray->pdata[rarray->len + i] = NULL;
}
return farray;
return array;
}
/**
@ -1302,10 +1307,10 @@ g_ptr_array_remove_range (GPtrArray *farray,
* is not found in the array
*/
gboolean
g_ptr_array_remove (GPtrArray *farray,
g_ptr_array_remove (GPtrArray *array,
gpointer data)
{
GRealPtrArray* array = (GRealPtrArray*) farray;
GRealPtrArray *rarray = (GRealPtrArray *)array;
guint i;
g_return_val_if_fail (array, FALSE);
@ -1339,19 +1344,19 @@ g_ptr_array_remove (GPtrArray *farray,
* Returns: %TRUE if the pointer was found in the array
*/
gboolean
g_ptr_array_remove_fast (GPtrArray *farray,
g_ptr_array_remove_fast (GPtrArray *array,
gpointer data)
{
GRealPtrArray* array = (GRealPtrArray*) farray;
GRealPtrArray *rarray = (GRealPtrArray *)array;
guint i;
g_return_val_if_fail (array, FALSE);
g_return_val_if_fail (rarray, FALSE);
for (i = 0; i < array->len; i += 1)
for (i = 0; i < rarray->len; i += 1)
{
if (array->pdata[i] == data)
if (rarray->pdata[i] == data)
{
g_ptr_array_remove_index_fast (farray, i);
g_ptr_array_remove_index_fast (array, i);
return TRUE;
}
}
@ -1368,16 +1373,16 @@ g_ptr_array_remove_fast (GPtrArray *farray,
* in size automatically if necessary.
*/
void
g_ptr_array_add (GPtrArray *farray,
g_ptr_array_add (GPtrArray *array,
gpointer data)
{
GRealPtrArray* array = (GRealPtrArray*) farray;
GRealPtrArray *rarray = (GRealPtrArray *)array;
g_return_if_fail (array);
g_return_if_fail (rarray);
g_ptr_array_maybe_expand (array, 1);
g_ptr_array_maybe_expand (rarray, 1);
array->pdata[array->len++] = data;
rarray->pdata[rarray->len++] = data;
}
/**
@ -1392,28 +1397,28 @@ g_ptr_array_add (GPtrArray *farray,
* Since: 2.40
*/
void
g_ptr_array_insert (GPtrArray *farray,
g_ptr_array_insert (GPtrArray *array,
gint index_,
gpointer data)
{
GRealPtrArray* array = (GRealPtrArray*) farray;
GRealPtrArray *rarray = (GRealPtrArray *)array;
g_return_if_fail (array);
g_return_if_fail (rarray);
g_return_if_fail (index_ >= -1);
g_return_if_fail (index_ <= (gint)array->len);
g_return_if_fail (index_ <= (gint)rarray->len);
g_ptr_array_maybe_expand (array, 1);
g_ptr_array_maybe_expand (rarray, 1);
if (index_ < 0)
index_ = array->len;
index_ = rarray->len;
if (index_ < array->len)
memmove (&(array->pdata[index_ + 1]),
&(array->pdata[index_]),
(array->len - index_) * sizeof (gpointer));
if (index_ < rarray->len)
memmove (&(rarray->pdata[index_ + 1]),
&(rarray->pdata[index_]),
(rarray->len - index_) * sizeof (gpointer));
array->len++;
array->pdata[index_] = data;
rarray->len++;
rarray->pdata[index_] = data;
}
/**
@ -1543,8 +1548,7 @@ g_ptr_array_foreach (GPtrArray *array,
* elements are added to the #GByteArray
* @len: the number of elements in the #GByteArray
*
* The #GByteArray-struct allows access to the public fields of
* a #GByteArray.
* Contains the public fields of a GByteArray.
*/
/**
@ -1660,8 +1664,8 @@ g_byte_array_free_to_bytes (GByteArray *array)
* g_byte_array_ref:
* @array: A #GByteArray
*
* Atomically increments the reference count of @array by one. This
* function is MT-safe and may be called from any thread.
* Atomically increments the reference count of @array by one.
* This function is thread-safe and may be called from any thread.
*
* Returns: The passed in #GByteArray
*
@ -1679,7 +1683,7 @@ g_byte_array_ref (GByteArray *array)
*
* Atomically decrements the reference count of @array by one. If the
* reference count drops to 0, all memory allocated by the array is
* released. This function is MT-safe and may be called from any
* released. This function is thread-safe and may be called from any
* thread.
*
* Since: 2.22
@ -1696,8 +1700,8 @@ g_byte_array_unref (GByteArray *array)
* @data: the byte data to be added
* @len: the number of bytes to add
*
* Adds the given bytes to the end of the #GByteArray. The array will
* grow in size automatically if necessary.
* Adds the given bytes to the end of the #GByteArray.
* The array will grow in size automatically if necessary.
*
* Returns: the #GByteArray
*/
@ -1717,8 +1721,8 @@ g_byte_array_append (GByteArray *array,
* @data: the byte data to be added
* @len: the number of bytes to add
*
* Adds the given data to the start of the #GByteArray. The array will
* grow in size automatically if necessary.
* Adds the given data to the start of the #GByteArray.
* The array will grow in size automatically if necessary.
*
* Returns: the #GByteArray
*/
@ -1755,8 +1759,8 @@ g_byte_array_set_size (GByteArray *array,
* @array: a #GByteArray
* @index_: the index of the byte to remove
*
* Removes the byte at the given index from a #GByteArray. The
* following bytes are moved down one place.
* Removes the byte at the given index from a #GByteArray.
* The following bytes are moved down one place.
*
* Returns: the #GByteArray
**/

View File

@ -168,7 +168,7 @@ GLIB_AVAILABLE_IN_ALL
void g_ptr_array_add (GPtrArray *array,
gpointer data);
GLIB_AVAILABLE_IN_2_40
void g_ptr_array_insert (GPtrArray *farray,
void g_ptr_array_insert (GPtrArray *array,
gint index_,
gpointer data);
GLIB_AVAILABLE_IN_ALL