2008-08-06 11:15:24 -07:00
|
|
|
/* EINA - EFL data type library
|
|
|
|
* Copyright (C) 2008 Cedric Bail
|
|
|
|
*
|
|
|
|
* 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.1 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
|
|
|
|
* 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, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
2008-08-06 08:42:33 -07:00
|
|
|
#ifndef EINA_INLINE_ARRAY_X_
|
|
|
|
#define EINA_INLINE_ARRAY_X_
|
2008-07-30 09:34:54 -07:00
|
|
|
|
|
|
|
|
2008-09-07 12:12:49 -07:00
|
|
|
/**
|
|
|
|
* @cond LOCAL
|
|
|
|
*/
|
|
|
|
|
2008-09-08 05:19:15 -07:00
|
|
|
EAPI Eina_Bool eina_array_grow(Eina_Array *array);
|
2008-07-30 09:34:54 -07:00
|
|
|
|
2008-09-07 12:12:49 -07:00
|
|
|
/**
|
|
|
|
* @endcond
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2008-09-18 22:22:43 -07:00
|
|
|
* @addtogroup Eina_Array_Group Array
|
2008-09-07 12:12:49 -07:00
|
|
|
*
|
|
|
|
* @brief These functions provide array management.
|
|
|
|
*
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Append a data to an array.
|
|
|
|
*
|
|
|
|
* @param array The array.
|
|
|
|
* @param data The data to add.
|
|
|
|
* @return #EINA_TRUE on success, #EINA_FALSE otherwise.
|
|
|
|
*
|
|
|
|
* This function appends @p data to @p array. For performance
|
|
|
|
* reasons, there is no check of @p array. If it is @c NULL or
|
2009-01-29 15:16:23 -08:00
|
|
|
* invalid, the program may crash. If @p data is @c NULL, or if an
|
|
|
|
* allocation is necessary and fails, #EINA_FALSE is returned and
|
|
|
|
* #EINA_ERROR_OUT_OF_MEMORY is set. Otherwise, #EINA_TRUE is
|
|
|
|
* returned.
|
2008-09-07 12:12:49 -07:00
|
|
|
*/
|
|
|
|
static inline Eina_Bool
|
2008-08-26 03:23:45 -07:00
|
|
|
eina_array_push(Eina_Array *array, const void *data)
|
2008-07-30 09:34:54 -07:00
|
|
|
{
|
2008-12-19 09:55:57 -08:00
|
|
|
if (!data) return EINA_FALSE;
|
|
|
|
|
2009-09-08 14:42:17 -07:00
|
|
|
if (EINA_UNLIKELY((array->count + 1) > array->total))
|
2008-09-07 12:12:49 -07:00
|
|
|
if (!eina_array_grow(array)) return EINA_FALSE;
|
2008-08-01 05:26:35 -07:00
|
|
|
|
2008-08-13 02:24:49 -07:00
|
|
|
array->data[array->count++] = (void*) data;
|
2008-09-07 12:12:49 -07:00
|
|
|
return EINA_TRUE;
|
2008-07-30 09:34:54 -07:00
|
|
|
}
|
|
|
|
|
2008-09-07 12:12:49 -07:00
|
|
|
/**
|
|
|
|
* @brief Remove the last data of an array.
|
|
|
|
*
|
|
|
|
* @param array The array.
|
|
|
|
* @return The retrieved data.
|
|
|
|
*
|
2009-01-29 15:16:23 -08:00
|
|
|
* This function removes the last data of @p array, decreases the count
|
|
|
|
* of @p array and returns the data. For performance reasons, there
|
|
|
|
* is no check of @p array. If it is @c NULL or invalid, the program
|
|
|
|
* may crash. If the count member is less or equal than 0, @c NULL is
|
|
|
|
* returned.
|
2008-09-07 12:12:49 -07:00
|
|
|
*/
|
2008-08-26 03:23:45 -07:00
|
|
|
static inline void *
|
|
|
|
eina_array_pop(Eina_Array *array)
|
|
|
|
{
|
|
|
|
if (array->count <= 0) return NULL;
|
|
|
|
return array->data[--array->count];
|
|
|
|
}
|
|
|
|
|
2008-09-07 12:12:49 -07:00
|
|
|
/**
|
|
|
|
* @brief Return the data at a given position in an array.
|
|
|
|
*
|
|
|
|
* @param array The array.
|
|
|
|
* @param index The potition of the data to retrieve.
|
|
|
|
* @return The retrieved data.
|
|
|
|
*
|
|
|
|
* This function returns the data at the position @p index in @p
|
|
|
|
* array. For performance reasons, there is no check of @p array or @p
|
|
|
|
* index. If it is @c NULL or invalid, the program may crash.
|
|
|
|
*/
|
2008-07-30 09:34:54 -07:00
|
|
|
static inline void *
|
2008-09-15 12:17:15 -07:00
|
|
|
eina_array_data_get(const Eina_Array *array, unsigned int index)
|
2008-07-30 09:34:54 -07:00
|
|
|
{
|
|
|
|
return array->data[index];
|
|
|
|
}
|
|
|
|
|
2008-11-05 09:16:07 -08:00
|
|
|
/**
|
|
|
|
* @brief Return the data at a given position in an array.
|
|
|
|
*
|
|
|
|
* @param array The array.
|
2009-06-22 13:03:58 -07:00
|
|
|
* @param index The potition of the data to set.
|
|
|
|
* @param data The data to set.
|
2008-11-05 09:16:07 -08:00
|
|
|
*
|
|
|
|
* This function returns the data at the position @p index in @p
|
|
|
|
* array. For performance reasons, there is no check of @p array or @p
|
|
|
|
* index. If it is @c NULL or invalid, the program may crash.
|
|
|
|
*/
|
|
|
|
static inline void
|
|
|
|
eina_array_data_set(const Eina_Array *array, unsigned int index, const void *data)
|
|
|
|
{
|
|
|
|
array->data[index] = (void*) data;
|
|
|
|
}
|
|
|
|
|
2008-09-07 12:12:49 -07:00
|
|
|
/**
|
2009-06-22 13:03:58 -07:00
|
|
|
* @brief Return the number of elements in an array.
|
2008-09-07 12:12:49 -07:00
|
|
|
*
|
|
|
|
* @param array The array.
|
|
|
|
* @return The number of elements.
|
|
|
|
*
|
|
|
|
* This function returns the number of elements in @p array. For
|
|
|
|
* performance reasons, there is no check of @p array. If it is
|
|
|
|
* @c NULL or invalid, the program may crash.
|
|
|
|
*/
|
2008-08-01 05:26:35 -07:00
|
|
|
static inline unsigned int
|
2008-09-15 12:17:15 -07:00
|
|
|
eina_array_count_get(const Eina_Array *array)
|
2008-08-01 05:26:35 -07:00
|
|
|
{
|
|
|
|
return array->count;
|
|
|
|
}
|
|
|
|
|
2008-09-07 12:12:49 -07:00
|
|
|
/**
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
2008-07-30 09:34:54 -07:00
|
|
|
#endif
|