* fix list doc
authorcaro <caro>
Tue, 23 Sep 2008 05:17:49 +0000 (05:17 +0000)
committercaro <caro@7cbeb6ba-43b4-40fd-8cce-4c39aea84d33>
Tue, 23 Sep 2008 05:17:49 +0000 (05:17 +0000)
 * minor other doc fixes
 * link the mempool modules statically to libeina when requested
 * don't compile static lib of mempool when they are built as shared lib

git-svn-id: http://svn.enlightenment.org/svn/e/trunk/PROTO/eina@36178 7cbeb6ba-43b4-40fd-8cce-4c39aea84d33

16 files changed:
configure.in
m4/eina_check.m4 [new file with mode: 0644]
src/include/eina_array.h
src/include/eina_inline_list.x
src/include/eina_list.h
src/lib/Makefile.am
src/lib/eina_array.c
src/lib/eina_list.c
src/modules/mp/chained_pool/Makefile.am
src/modules/mp/chained_pool/eina_chained_mempool.c
src/modules/mp/ememoa_fixed/Makefile.am
src/modules/mp/ememoa_fixed/eina_ememoa_fixed.c
src/modules/mp/ememoa_unknown/Makefile.am
src/modules/mp/ememoa_unknown/eina_ememoa_unknown.c
src/modules/mp/pass_through/Makefile.am
src/modules/mp/pass_through/pass_through.c

index 3261477..dfbd1b2 100644 (file)
@@ -101,69 +101,10 @@ AC_MSG_RESULT([$enable_ememoa])
 
 # Static linking
 
-AC_ARG_ENABLE([static-chained-pool],
-   [AC_HELP_STRING([--enable-static-chained-pool], [enable static build of chained pool @<:@default=no@:>@])],
-   [
-    if test "x${enableval}" = "xyes" ; then
-       enable_static_chained_pool="yes"
-    else
-       enable_static_chained_pool="no"
-    fi
-   ],
-   [enable_static_chained_pool="no"]
-)
-AC_MSG_CHECKING([whether chained pool is statically build])
-AC_MSG_RESULT([${enable_static_chained_pool}])
-
-AM_CONDITIONAL(EINA_STATIC_BUILD_CHAINED_POOL, test "x${enable_static_chainedpool}" = "xyes")
-
-AC_ARG_ENABLE([static-ememoa-fixed],
-   [AC_HELP_STRING([--enable-static-ememoa-fixed], [enable static link of ememoa fixed @<:@default=no@:>@])],
-   [
-    if test "x${enableval}" = "xyes" ; then
-       enable_static_ememoa_fixed="yes"
-    else
-       enable_static_ememoa_fixed="no"
-    fi
-   ],
-   [enable_static_ememoa_fixed="no"]
-)
-AC_MSG_CHECKING([whether ememoa fixed is staticlly linked])
-AC_MSG_RESULT([${enable_static_ememoa_fixed}])
-
-AM_CONDITIONAL(EINA_STATIC_BUILD_EMEMOA_FIXED, test "x${enable_static_ememoa_fixed}" = "xyes")
-
-AC_ARG_ENABLE([static-ememoa-unknown],
-   [AC_HELP_STRING([--enable-static-ememoa-unknown], [enable static link of ememoa unknown @<:@default=no@:>@])],
-   [
-    if test "x${enableval}" = "xyes" ; then
-       enable_static_ememoa_unknown="yes"
-    else
-       enable_static_ememoa_unknown="no"
-    fi
-   ],
-   [enable_static_ememoa_unknown="no"]
-)
-AC_MSG_CHECKING([whether ememoa unknown is staticlly linked])
-AC_MSG_RESULT([${enable_static_ememoa_unknown}])
-
-AM_CONDITIONAL(EINA_STATIC_BUILD_EMEMOA_UNKNOWN, test "x${enable_static_ememoa_unknown}" = "xyes")
-
-AC_ARG_ENABLE([static-pass-through],
-   [AC_HELP_STRING([--enable-static-pass-through], [enable static link of pass through @<:@default=no@:>@])],
-   [
-    if test "x${enableval}" = "xyes" ; then
-       enable_static_pass_through="yes"
-    else
-       enable_static_pass_through="no"
-    fi
-   ],
-   [enable_static_pass_through="no"]
-)
-AC_MSG_CHECKING([whether pass through is staticlly linked])
-AC_MSG_RESULT([${enable_static_pass_through}])
-
-AM_CONDITIONAL(EINA_STATIC_BUILD_PASS_THROUGH, test "x${enable_static_pass_through}" = "xyes")
+EINA_CHECK_STATIC([chained-pool], [chained pool])
+EINA_CHECK_STATIC([ememoa-fixed], [ememoa fixed])
+EINA_CHECK_STATIC([ememoa-unknown], [ememoa unknown])
+EINA_CHECK_STATIC([pass-through], [pass through])
 
 
 ### Checks for libraries
diff --git a/m4/eina_check.m4 b/m4/eina_check.m4
new file mode 100644 (file)
index 0000000..38eb567
--- /dev/null
@@ -0,0 +1,29 @@
+dnl use: EINA_CHECK_STATIC(foo-bar, description)
+AC_DEFUN([EINA_CHECK_STATIC],
+[
+pushdef([UP], translit([$1], [-a-z], [_A-Z]))dnl
+pushdef([DOWN], translit([$1], [-A-Z], [_a-z]))dnl
+
+AC_ARG_ENABLE([static-$1],
+   [AC_HELP_STRING([--enable-static-$1], [enable static build of $2 @<:@default=no@:>@])],
+   [
+    if test "x${enableval}" = "xyes" ; then
+       enable_static_[]DOWN="yes"
+    else
+       enable_static_[]DOWN="no"
+    fi
+   ],
+   [enable_static_[]DOWN="no"]
+)
+AC_MSG_CHECKING([whether $2 is statically build])
+AC_MSG_RESULT([${enable_static_[]DOWN}])
+
+AM_CONDITIONAL(EINA_STATIC_BUILD_[]UP, test "x${enable_static_[]DOWN}" = "xyes")
+
+if test "x${enable_static_[]DOWN}" = "xyes" ; then
+   AC_DEFINE(EINA_STATIC_BUILD_[]UP, 1, [Set to 1 if $2 is statically built])
+fi
+
+popdef([UP])
+popdef([DOWN])
+])
\ No newline at end of file
index 9a5fd70..9ad1e35 100644 (file)
@@ -88,7 +88,7 @@ EAPI Eina_Accessor *eina_array_accessor_new (const Eina_Array *array);
 
 /**
  * @def EINA_ARRAY_ITER_NEXT
- * @brief Macro to iterate over an array easily
+ * @brief Macro to iterate over an array easily.
  *
  * @param array The array to iterate over.
  * @param index The integer number that is increased while itareting.
index d8e4012..4300a8c 100644 (file)
 #ifndef EINA_LIST_INLINE_H_
 #define EINA_LIST_INLINE_H_
 
+/**
+ * @addtogroup Eina_List_Group List
+ *
+ * @brief These functions provide list management.
+ *
+ * @{
+ */
+
 static inline Eina_List *
 eina_list_last(const Eina_List *list)
 {
@@ -54,4 +62,8 @@ eina_list_count(const Eina_List *list)
    return list->accounting->count;
 }
 
+/**
+ * @}
+ */
+
 #endif /* EINA_LIST_INLINE_H_ */
index 42d3746..9f7f504 100644 (file)
  * @{
  */
 
+/**
+ * @typedef Eina_List
+ * Type for a generic single linked list.
+ */
 typedef struct _Eina_List Eina_List;
+
 typedef struct _Eina_List_Accounting Eina_List_Accounting;
 
+/**
+ * @struct _Eina_List
+ * Type for a generic single linked list.
+ */
 struct _Eina_List /** A linked list node */
 {
    void      *data; /**< Pointer to list element payload */
@@ -53,6 +62,7 @@ struct _Eina_List /** A linked list node */
    Eina_List *prev; /**< Previous member in the list */
    struct _Eina_List_Accounting *accounting; /**< Private list accounting info - don't touch */
 };
+
 struct _Eina_List_Accounting
 {
    Eina_List *last;
@@ -89,6 +99,35 @@ static inline unsigned int eina_list_count(const Eina_List *list);
 EAPI Eina_Iterator *eina_list_iterator_new(const Eina_List *list);
 EAPI Eina_Accessor *eina_list_accessor_new(const Eina_List *list);
 
+/**
+ * @def EINA_LIST_ITER_NEXT
+ * @brief Macro to iterate over a list easily.
+ *
+ * @param list The list to iterate over.
+ * @param l A list that is used as loop index.
+ * @param data The data
+ *
+ * This macro allow the iteration over @p list in an easy way. It
+ * iterates from the first element to the last one. @p data is the
+ * data of each element of the list. @p l is an #Eina_List that is
+ * used as counter.
+ *
+ * This macro can be used for freeing the data of alist, like in
+ * the following example:
+ *
+ * @code
+ * Eina_List *list;
+ * Eina_List *l;
+ * char       *data;
+ *
+ * // list is already filled,
+ * // its elements are just duplicated strings,
+ * // EINA_LIST_ITER_NEXT will be used to free those strings
+ *
+ * EINA_LIST_ITER_NEXT(list, l, data)
+ *   free(data);
+ * @endcode
+ */
 #define EINA_LIST_ITER_NEXT(list, l, data) for (l = list, data = eina_list_data(l); l; l = eina_list_next(l), data = eina_list_data(l))
 
 #include "eina_inline_list.x"
index 2172172..8c3959d 100644 (file)
@@ -31,6 +31,31 @@ eina_benchmark.c \
 eina_stringshare.c
 
 libeina_la_LIBADD = @EINA_LIBS@
+
+if EINA_STATIC_BUILD_CHAINED_POOL
+
+libeina_la_SOURCES += $(top_srcdir)/src/modules/mp/chained_pool/eina_chained_mempool.c
+
+endif
+
+if EINA_STATIC_BUILD_EMEMOA_FIXED
+
+libeina_la_SOURCES += $(top_srcdir)/src/modules/mp/ememoa_fixed/eina_ememoa_fixed.c
+
+endif
+
+if EINA_STATIC_BUILD_EMEMOA_UNKNOWN
+
+libeina_la_SOURCES += $(top_srcdir)/src/modules/mp/ememoa_unknown/eina_ememoa_unknown.c
+
+endif
+
+if EINA_STATIC_BUILD_PASS_THROUGH
+
+libeina_la_SOURCES += $(top_srcdir)/src/modules/mp/pass_through/pass_through.c
+
+endif
+
 libeina_la_LDFLAGS = -no-undefined @lt_enable_auto_import@ -version-info @version_info@
 
 clean-local:
index 3bb7f8c..978b179 100644 (file)
@@ -144,18 +144,6 @@ eina_array_grow(Eina_Array *array)
  *============================================================================*/
 
 /**
- * @addtogroup Eina_Data_Types_Group Data Types
- *
- * @{
- */
-
-/**
- * @addtogroup Eina_Containers_Group Containers
- *
- * @{
- */
-
-/**
  * @addtogroup Eina_Array_Group Array
  *
  * @brief These functions provide array management.
@@ -260,9 +248,10 @@ eina_array_new(unsigned int step)
  * @param array The array to free.
  *
  * This function frees @p array. It calls first eina_array_flush() then
- * free the memory of the pointeur. It's up to the user to free the
- * memory allocated for the elements of @p array. For performance
- * reasons, there is no check of @p array.
+ * free the memory of the pointeur. It does not free the memory
+ * allocated for the elements of @p array. To free them, use
+ * #EINA_ARRAY_ITER_NEXT. For performance reasons, there is no check
+ * of @p array.
  */
 EAPI void
 eina_array_free(Eina_Array *array)
@@ -493,11 +482,3 @@ eina_array_accessor_new(const Eina_Array *array)
  * @}
  */
 
-/**
- * @}
- */
-
-/**
- * @}
- */
-
index cda8699..d1f247f 100644 (file)
  *  CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
  */
 
+
+/**
+ * @page tutorial_list_page List Tutorial
+ *
+ * to be written...
+ *
+ */
+
 #ifdef HAVE_CONFIG_H
 # include "config.h"
 #endif
@@ -280,45 +288,24 @@ eina_list_accessor_free(Eina_Accessor_List *it)
  *============================================================================*/
 
 /**
- * @addtogroup Eina_Data_Types_Group Data Types
- *
- * @{
- */
-
-/**
- * @addtogroup Eina_Containers_Group Containers
- *
- * @{
- */
-
-/**
  * @addtogroup Eina_List_Group List
  *
- * @brief give a small description here : what it is for, what it does
- * , etc...
- *
- * List API. Give some hints about the use (functions that must be
- * used like init / shutdown), general use, etc... Give also a link to
- * tutorial below.
+ * @brief These functions provide single linked list management.
  *
- * @section listtable_algo Algorithm
- *
- * Give here the algorithm used in the implementation
- *
- * @section list_perf Performance
- *
- * Give some hints about performance if it is possible, and an image !
- *
- * @section list_tutorial Tutorial
- *
- * Here is a fantastic tutorial about our list
+ * For more information, you can look at the @ref tutorial_list_page.
  *
  * @{
  */
 
 /**
- * Initialize the eina list internal structure.
- * @return  Zero on failure, non-zero on successful initialization.
+ * @brief Initialize the list module.
+ *
+ * @return 1 or greater on success, 0 on error.
+ *
+ * This function just sets up the error module or Eina. It is also
+ * called by eina_init(). It returns 0 on failure, otherwise it
+ * returns the number of times eina_error_init() has already been
+ * called.
  */
 EAPI int
 eina_list_init(void)
@@ -327,7 +314,15 @@ eina_list_init(void)
 }
 
 /**
- * Shutdown the eina list internal structures
+ * @brief Shut down the list module.
+ *
+ * @return 0 when the error module is completely shut down, 1 or
+ * greater otherwise.
+ *
+ * This function just shut down the error module set up by
+ * eina_list_init(). It is also called by eina_shutdown(). It returns
+ * 0 when it is called the same number of times than
+ * eina_error_init().
  */
 EAPI int
 eina_list_shutdown(void)
@@ -336,7 +331,16 @@ eina_list_shutdown(void)
 }
 
 /**
- * Appends the given data to the given linked list.
+ * @brief Append the given data to the given linked list.
+ *
+ * @param list The given list.
+ * @param data The data to append.
+ * @return A list pointer.
+ *
+ * This function appends @p data to @p list. If @p data is @c NULL, a
+ * new list is returned. On success, a new list pointer that should be
+ * used in place of the one given to this function is
+ * returned. Otherwise, the old pointer is returned.
  *
  * The following example code demonstrates how to ensure that the
  * given data has been successfully appended.
@@ -346,19 +350,12 @@ eina_list_shutdown(void)
  * extern void *my_data;
  *
  * list = eina_list_append(list, my_data);
- * if (eina_list_alloc_error())
+ * if (eina_error_get())
  *   {
  *     fprintf(stderr, "ERROR: Memory is low. List allocation failed.\n");
  *     exit(-1);
  *   }
  * @endcode
- *
- * @param   list The given list.  If @c NULL is given, then a new list
- *               is created.
- * @param   data The data to append.
- * @return  A new list pointer that should be used in place of the one
- *          given to this function if successful.  Otherwise, the old
- *          pointer is returned.
  */
 EAPI Eina_List *
 eina_list_append(Eina_List *list, const void *data)
@@ -387,7 +384,16 @@ eina_list_append(Eina_List *list, const void *data)
 }
 
 /**
- * Prepends the given data to the given linked list.
+ * @brief Prepends the given data to the given linked list.
+ *
+ * @param list The given list.
+ * @param data The data to prepend.
+ * @return A list pointer.
+ *
+ * This function prepends @p data to @p list. If @p data is @c NULL, a
+ * new list is returned. On success, a new list pointer that should be
+ * used in place of the one given to this function is
+ * returned. Otherwise, the old pointer is returned.
  *
  * The following example code demonstrates how to ensure that the
  * given data has been successfully prepended.
@@ -398,18 +404,12 @@ eina_list_append(Eina_List *list, const void *data)
  * extern void *my_data;
  *
  * list = eina_list_prepend(list, my_data);
- * if (eina_list_alloc_error())
+ * if (eina_error_get())
  *   {
  *     fprintf(stderr, "ERROR: Memory is low. List allocation failed.\n");
  *     exit(-1);
  *   }
  * @endcode
- *
- * @param   list The given list.
- * @param   data The given data.
- * @return  A new list pointer that should be used in place of the one
- *          given to this function, if successful.  Otherwise, the old
- *          pointer is returned.
  */
 EAPI Eina_List *
 eina_list_prepend(Eina_List *list, const void *data)
@@ -434,11 +434,20 @@ eina_list_prepend(Eina_List *list, const void *data)
 }
 
 /**
- * Inserts the given data into the given linked list after the specified data.
+ * @brief Insert the given data into the given linked list after the specified data.
  *
- * If @p relative is not in the list, @p data is appended to the end of the
- * list.  If there are multiple instances of @p relative in the list,
- * @p data is inserted after the first instance.
+ * @param list The given linked list.
+ * @param data The data to insert.
+ * @param relative The data to insert after.
+ * @return A list pointer.
+ *
+ * This function inserts @p data to @p list after @p relative. If
+ * @p relative is not in the list, @p data is appended to the end of
+ * the list.  If @p list is @c NULL, a  new list is returned. If there
+ * are multiple instances of @p relative in the list, @p data is
+ * inserted after the first instance.On success, a new list pointer
+ * that should be used in place of the one given to this function is
+ * returned. Otherwise, the old pointer is returned.
  *
  * The following example code demonstrates how to ensure that the
  * given data has been successfully inserted.
@@ -449,25 +458,18 @@ eina_list_prepend(Eina_List *list, const void *data)
  * extern void *relative_member;
  *
  * list = eina_list_append(list, relative_member);
- * if (eina_list_alloc_error())
+ * if (eina_error_get())
  *   {
  *     fprintf(stderr, "ERROR: Memory is low. List allocation failed.\n");
  *     exit(-1);
  *   }
  * list = eina_list_append_relative(list, my_data, relative_member);
- * if (eina_list_alloc_error())
+ * if (eina_error_get())
  *   {
  *     fprintf(stderr, "ERROR: Memory is low. List allocation failed.\n");
  *     exit(-1);
  *   }
  * @endcode
- *
- * @param   list The given linked list.
- * @param   data The given data.
- * @param   relative The data to insert after.
- * @return  A new list pointer that should be used in place of the one
- *          given to this function if successful.  Otherwise, the old pointer
- *          is returned.
  */
 EAPI Eina_List *
 eina_list_append_relative(Eina_List *list, const void *data, const void *relative)
@@ -482,6 +484,23 @@ eina_list_append_relative(Eina_List *list, const void *data, const void *relativ
    return eina_list_append(list, data);
 }
 
+/**
+ * @brief Append a list node to a linked list after the specified member
+ *
+ * @param list The given linked list.
+ * @param data The data to insert.
+ * @param relative The list node to insert after.
+ * @return A list pointer.
+ *
+ * This function inserts @p data to @p list after the list node
+ * @p relative. If @p list or @p relative are @c NULL, @p data is just
+ * appended to @p list using eina_list_append(). If @p list is
+ * @c NULL, a  new list is returned. If there are multiple instances
+ * of @p relative in the list, @p data is inserted after the first
+ * instance. On success, a new list pointer that should be used in
+ * place of the one given to this function is returned. Otherwise, the
+ * old pointer is returned.
+ */
 EAPI Eina_List *
 eina_list_append_relative_list(Eina_List *list, const void *data, Eina_List *relative)
 {
@@ -510,18 +529,20 @@ eina_list_append_relative_list(Eina_List *list, const void *data, Eina_List *rel
 }
 
 /**
- * Prepend a data pointer to a linked list before the memeber specified
- * @param list The list handle to prepend @p data too
- * @param data The data pointer to prepend to list @p list before @p relative
- * @param relative The data pointer before which to insert @p data
- * @return A new list handle to replace the old one
-
- * Inserts the given data into the given linked list before the member
- * specified.
+ * @brief Prepend a data pointer to a linked list before the specified member
+ *
+ * @param list The given linked list.
+ * @param data The data to insert.
+ * @param relative The data to insert before.
+ * @return A list pointer.
  *
- * If @p relative is not in the list, @p data is prepended to the
- * start of the list.  If there are multiple instances of @p relative
- * in the list, @p data is inserted before the first instance.
+ * This function inserts @p data to @p list before @p relative. If
+ * @p relative is not in the list, @p data is prepended to the list
+ * with eina_list_prepend(). If @p list is @c NULL, a  new list is
+ * returned. If there are multiple instances of @p relative in the
+ * list, @p data is inserted before the first instance. On success, a
+ * new list pointer that should be used in place of the one given to
+ * this function is returned. Otherwise, the old pointer is returned.
  *
  * The following code example demonstrates how to ensure that the
  * given data has been successfully inserted.
@@ -532,25 +553,18 @@ eina_list_append_relative_list(Eina_List *list, const void *data, Eina_List *rel
  * extern void *relative_member;
  *
  * list = eina_list_append(list, relative_member);
- * if (eina_list_alloc_error())
+ * if (eina_error_get_error())
  *   {
  *     fprintf(stderr, "ERROR: Memory is low. List allocation failed.\n");
  *     exit(-1);
  *   }
  * list = eina_list_prepend_relative(list, my_data, relative_member);
- * if (eina_list_alloc_error())
+ * if (eina_error_get())
  *   {
  *     fprintf(stderr, "ERROR: Memory is low. List allocation failed.\n");
  *     exit(-1);
  *   }
  * @endcode
- *
- * @param   list The given linked list.
- * @param   data The given data.
- * @param   relative The data to insert before.
- * @return  A new list pointer that should be used in place of the one
- *          given to this function if successful.  Otherwise the old pointer
- *          is returned.
  */
 EAPI Eina_List *
 eina_list_prepend_relative(Eina_List *list, const void *data, const void *relative)
@@ -565,6 +579,23 @@ eina_list_prepend_relative(Eina_List *list, const void *data, const void *relati
    return eina_list_prepend(list, data);
 }
 
+/**
+ * @brief Prepend a list node to a linked list before the specified member
+ *
+ * @param list The given linked list.
+ * @param data The data to insert.
+ * @param relative The list node to insert before.
+ * @return A list pointer.
+ *
+ * This function inserts @p data to @p list before the list node
+ * @p relative. If @p list or @p relative are @c NULL, @p data is just
+ * prepended to @p list using eina_list_prepend(). If @p list is
+ * @c NULL, a  new list is returned. If there are multiple instances
+ * of @p relative in the list, @p data is inserted before the first
+ * instance. On success, a new list pointer that should be used in
+ * place of the one given to this function is returned. Otherwise, the
+ * old pointer is returned.
+ */
 EAPI Eina_List *
 eina_list_prepend_relative_list(Eina_List *list, const void *data, Eina_List *relative)
 {
@@ -591,14 +622,18 @@ eina_list_prepend_relative_list(Eina_List *list, const void *data, Eina_List *re
 }
 
 /**
- * Removes the first instance of the specified data from the given list.
- *
- * If the specified data is not in the given list, nothing is done.
- *
- * @param   list The given list.
- * @param   data The specified data.
- * @return  A new list pointer that should be used in place of the one
- *          passed to this functions.
+ * @brief Remove the first instance of the specified data from the given list.
+ *
+ * @param list The given list.
+ * @param data The specified data.
+ * @return A list pointer.
+ *
+ * This function removes the first instance of @p data from
+ * @p list. If the specified data is not in the given list (tihis
+ * include the case where @p data is @c NULL), nothing is done. If
+ * @p list is @c NULL, @c NULL is returned, otherwise a new list
+ * pointer that should be used in place of the one passed to this
+ * function.
  */
 EAPI Eina_List *
 eina_list_remove(Eina_List *list, const void *data)
@@ -614,17 +649,20 @@ eina_list_remove(Eina_List *list, const void *data)
 }
 
 /**
- * Removes the specified data
+ * @brief Remove the specified data.
  *
- * Remove a specified member from a list
- * @param list The list handle to remove @p remove_list from
- * @param remove_list The list node which is to be removed
- * @return A new list handle to replace the old one
+ * @param list The given linked list.
+ * @param remove_list The list node which is to be removed.
+ * @return A list pointer.
  *
- * Calling this function takes the list node @p remove_list and removes it
- * from the list @p list, freeing the list node structure @p remove_list.
+ * This function removes the list node @p remove_list from @p list and
+ * frees the list node structure @p remove_list. If @p list is
+ * @c NULL, this function returns @c NULL. If @p remove_list is
+ * @c NULL, it returns @p list, otherwise, a new list pointer that
+ * should be used in place of the one passed to this function.
+ *
+ * The following code gives an example.
  *
- * Example:
  * @code
  * extern Eina_List *list;
  * Eina_List *l;
@@ -663,18 +701,13 @@ eina_list_remove_list(Eina_List *list, Eina_List *remove_list)
 }
 
 /**
- * Free an entire list and all the nodes, ignoring the data contained
+ * @brief Free an entire list and all the nodes, ignoring the data contained.
+
  * @param list The list to free
  * @return A NULL pointer
  *
- * This function will free all the list nodes in list specified by @p list.
- *
- * Example:
- * @code
- * extern Eina_List *list;
- *
- * list = eina_list_free(list);
- * @endcode
+ * This function frees all the nodes of @p list. It does not free the
+ * data of the nodes. To free them, use #EINA_LIST_ITER_NEXT.
  */
 EAPI Eina_List *
 eina_list_free(Eina_List *list)
@@ -693,15 +726,16 @@ eina_list_free(Eina_List *list)
 }
 
 /**
- * Moves the specified data to the head of the list
+ * @brief Move the specified data to the head of the list.
  *
- * Move a specified member to the head of the list
- * @param list The list handle to move @p inside
- * @param move_list The list node which is to be moved
+ * @param list The list handle to move the data.
+ * @param move_list The list node to move.
  * @return A new list handle to replace the old one
  *
- * Calling this function takes the list node @p move_list and moves it
- * to the front of the @p list.
+ * This function move @p move_list to the front of @p list. If list is
+ * @c NULL, @c NULL is returned. If @p move_list is @c NULL,
+ * @p list is returned. Otherwise, a new list pointer that should be
+ * used in place of the one passed to this function.
  *
  * Example:
  * @code
@@ -747,13 +781,14 @@ eina_list_promote_list(Eina_List *list, Eina_List *move_list)
 }
 
 /**
- * Find a member of a list and return the member
- * @param list The list handle to search for @p data
- * @param data The data pointer to find in the list @p list
- * @return The found member data pointer
+ * @brief Find a member of a list and return the member.
+ *
+ * @param list The list to search for a data.
+ * @param data The data pointer to find in the list.
+ * @return The found member data pointer if foun, @c NULL otherwise.
  *
- * A call to this function will search the list @p list from beginning to end
- * for the first member whose data pointer is @p data. If it is found, @p data
+ * This function searches in @p list from beginning to end for the
+ * first member whose data pointer is @p data. If it is found, @p data
  * will be returned, otherwise NULL will be returned.
  *
  * Example:
@@ -775,28 +810,16 @@ eina_list_find(const Eina_List *list, const void *data)
 }
 
 /**
- * Find a member of a list and return the list node containing that member
- * @param list The list handle to search for @p data
- * @param data The data pointer to find in the list @p list
- * @return The found members list node
+ * @brief Find a member of a list and return the list node containing that member.
  *
- * A call to this function will search the list @p list from beginning to end
- * for the first member whose data pointer is @p data. If it is found, the
- * list node containing the specified member will be returned, otherwise NULL
- * will be returned.
- *
- * Example:
- * @code
- * extern Eina_List *list;
- * extern void *my_data;
- * Eina_List *found_node;
+ * @param list The list to search for data.
+ * @param data The data pointer to find in the list.
+ * @return The found members list node on success, @c NULL otherwise.
  *
- * found_node = eina_list_find_list(list, my_data);
- * if (found_node)
- *   {
- *     printf("Found member %p\n", found_node->data);
- *   }
- * @endcode
+ * This function searches in @p list from beginning to end for the
+ * first member whose data pointer is @p data. If it is found, the
+ * list node containing the specified member is returned, otherwise
+ * @c NULL is returned.
  */
 EAPI Eina_List *
 eina_list_find_list(const Eina_List *list, const void *data)
@@ -811,25 +834,16 @@ eina_list_find_list(const Eina_List *list, const void *data)
 }
 
 /**
- * Get the nth member's data pointer in a list
- * @param list The list to get member number @p n from
- * @param n The number of the element (0 being the first)
- * @return The data pointer stored in the specified element
+ * @brief Get the nth member's data pointer in a list.
  *
- * This function returns the data pointer of element number @p n, in the list
- * @p list. The first element in the array is element number 0. If the element
- * number @p n does not exist, NULL will be returned.
- *
- * Example:
- * @code
- * extern Eina_List *list;
- * extern int number;
- * void *data;
+ * @param list The list to get the specified member number from.
+ * @param n The number of the element (0 being the first).
+ * @return The data pointer stored in the specified element.
  *
- * data = eina_list_nth(list, number);
- * if (data)
- *   printf("Element number %i has data %p\n", number, data);
- * @endcode
+ * This function returns the data pointer of element number @p n, in
+ * the @p list. The first element in the array is element number 0. If
+ * the element number @p n does not exist, @c NULL is
+ * returned. Otherwise, the data of the found element is returned.
  */
 EAPI void *
 eina_list_nth(const Eina_List *list, unsigned int n)
@@ -841,25 +855,18 @@ eina_list_nth(const Eina_List *list, unsigned int n)
 }
 
 /**
- * Get the nth member's list node in a list
- * @param list The list to get member number @p n from
- * @param n The number of the element (0 being the first)
- * @return The list node stored in the numbered element
- *
- * This function returns the list node of element number @p n, in the list
- * @p list. The first element in the array is element number 0. If the element
- * number @p n does not exist, NULL will be returned.
- *
- * Example:
- * @code
- * extern Eina_List *list;
- * extern int number;
- * Eina_List *nth_list;
- *
- * nth_list = eina_list_nth_list(list, number);
- * if (nth_list)
- *   printf("Element number %i has data %p\n", number, nth_list->data);
- * @endcode
+ * @brief Get the nth member's list node in a list.
+ *
+ * @param list The list to get the specfied member number from.
+ * @param n The number of the element (0 being the first).
+ * @return The list node stored in the numbered element.
+ *
+ * This function returns the list node of element number @p n, in
+ * @ list. The first element in the array is element number 0. If the
+ * element number @p n does not exist or @p list is @c NULL or @p n is
+ * greater than the count of elements in @p list minus 1, @c NULL is
+ * returned. Otherwise the list node stored in the numbered element is
+ * returned.
  */
 EAPI Eina_List *
 eina_list_nth_list(const Eina_List *list, unsigned int n)
@@ -895,132 +902,79 @@ eina_list_nth_list(const Eina_List *list, unsigned int n)
 }
 
 /**
- * Get the last list node in the list
- * @param list The list to get the last list node from
- * @return The last list node in the list @p list
+ * @brief Get the last list node in the list.
  *
- * This function will return the last list node in the list (or NULL if the
- * list is empty).
+ * @param list The list to get the last list node from.
+ * @return The last list node in the list.
  *
- * NB: This is a order-1 operation (it takes the same short time regardless of
- * the length of the list).
+ * This function returns the last list node in the list. If @p list is
+ * @c NULL or empty, @c NULL is returned.
  *
- * Example:
- * @code
- * extern Eina_List *list;
- * Eina_List *last, *l;
- *
- * last = eina_list_last(list);
- * printf("The list in reverse:\n");
- * for (l = last; l; l = l->prev)
- *   {
- *     printf("%p\n", l->data);
- *   }
- * @endcode
+ * This is a order-1 operation (it takes the same short time
+ * regardless of the length of the list).
  */
 static inline Eina_List *eina_list_last(const Eina_List *list);
 
 /**
- * Get the next list node after the specified list node
- * @param list The list node to get the next list node from
- * @return The next list node, or NULL if no next list node exists
- *
- * This function returns the next list node after the current one. It is
- * equivalent to list->next.
+ * @brief Get the next list node after the specified list node.
  *
- * Example:
- * @code
- * extern Eina_List *list;
- * Eina_List *l;
+ * @param list The list node to get the next list node from
+ * @return The next list node on success, @c NULL otherwise.
  *
- * printf("The list:\n");
- * for (l = list; l; l = eina_list_next(l))
- *   {
- *     printf("%p\n", l->data);
- *   }
- * @endcode
+ * This function returns the next list node after the current one in
+ * @p list. It is equivalent to list->next. If @p list is @c NULL or
+ * if no next list node exists, it returns @c NULL.
  */
 static inline Eina_List *eina_list_next(const Eina_List *list);
 
 /**
- * Get the previous list node before the specified list node
- * @param list The list node to get the previous list node from
- * @return The previous list node, or NULL if no previous list node exists
+ * @brief Get the previous list node before the specified list node.
  *
- * This function returns the previous list node before the current one. It is
- * equivalent to list->prev.
+ * @param list The list node to get the previous list node from.
+ * @return The previous list node o success, @c NULL otherwise.
+ * if no previous list node exists
  *
- * Example:
- * @code
- * extern Eina_List *list;
- * Eina_List *last, *l;
- *
- * last = eina_list_last(list);
- * printf("The list in reverse:\n");
- * for (l = last; l; l = eina_list_prev(l))
- *   {
- *     printf("%p\n", l->data);
- *   }
- * @endcode
+ * This function returns the previous list node before the current one
+ * in @p list. It is equivalent to list->prev. If @p list is @c NULL or
+ * if no previous list node exists, it returns @c NULL.
  */
 static inline Eina_List *eina_list_prev(const Eina_List *list);
 
 /**
- * Get the list node data member
- * @param list The list node to get the data member of
- * @return The data member from the list node @p list
+ * @brief Get the list node data member.
  *
- * This function returns the data member of the specified list node @p list.
- * It is equivalent to list->data.
+ * @param list The list node to get the data member of.
+ * @return The data member from the list node.
  *
- * Example:
- * @code
- * extern Eina_List *list;
- * Eina_List *l;
- *
- * printf("The list:\n");
- * for (l = list; l; l = eina_list_next(l))
- *   {
- *     printf("%p\n", eina_list_data(l));
- *   }
- * @endcode
+ * This function returns the data member of the specified list node @p
+ * list. It is equivalent to list->data. If @p list is @c NULL, this
+ * function returns @c NULL.
  */
 static inline void *eina_list_data(const Eina_List *list);
 
 /**
- * Get the count of the number of items in a list
- * @param list The list whose count to return
- * @return The number of members in the list @p list
+ * @brief Get the count of the number of items in a list.
  *
- * This function returns how many members in the specified list: @p list. If
- * the list is empty (NULL), 0 is returned.
+ * @param list The list whose count to return.
+ * @return The number of members in the list.
  *
- * NB: This is an order-1 operation and takes the same tiem regardless of the
- * length of the list.
+ * This function returns how many members @p list contains. If the
+ * list is @c NULL, 0 is returned.
  *
- * Example:
- * @code
- * extern Eina_List *list;
- *
- * printf("The list has %i members\n", eina_list_count(list));
- * @endcode
+ * NB: This is an order-1 operation and takes the same tiem regardless
+ * of the length of the list.
  */
 static inline unsigned int eina_list_count(const Eina_List *list);
 
 /**
- * Reverse all the elements in the list
- * @param list The list to reverse
- * @return The list after it has been reversed
+ * @brief Reverse all the elements in the list.
  *
- * This takes a list @p list, and reverses the order of all elements in the
- * list, so the last member is now first, and so on.
- *
- * Example:
- * @code
- * extern Eina_List *list;
+ * @param list The list to reverse.
+ * @return The list after it has been reversed.
  *
- * list = eina_list_reverse(list);
- * @endcode
+ * This function reverses the order of all elements in @p list, so the
+ * last member is now first, and so on. If @p list is @c NULL, this
+ * functon returns @c NULL.
  */
 EAPI Eina_List *
 eina_list_reverse(Eina_List *list)
@@ -1046,16 +1000,19 @@ eina_list_reverse(Eina_List *list)
 }
 
 /**
- * Sort a list according to the ordering func will return
- * @param list The list handle to sort
- * @param size The length of the list to sort
+ * @brief Sort a list according to the ordering func will return.
+ *
+ * @param list The list handle to sort.
+ * @param size The length of the list to sort.
  * @param func A function pointer that can handle comparing the list data
- * nodes
- * @return A new sorted list
+ * nodes.
+ * @return A new sorted list.
  *
- * This function sorts your list.  The data in your nodes can be arbitrary,
- * you just have to be smart enough to know what kind of data is in your
- * lists
+ * This function sorts @p list. @p size if the number of the first
+ * element to sort. If @p size is 0 or greater than the number of
+ * elements in @p list, all the elemnts are sorted. @p func is used to
+ * compare two elements of @p list. If @p list or @p func are @c NULL,
+ * this function returns @c NULL.
  *
  * Example:
  * @code
@@ -1073,7 +1030,7 @@ eina_list_reverse(Eina_List *list)
  * extern Eina_List *list;
  *
  * list = eina_list_sort(list, eina_list_count(list), sort_cb);
- * if (eina_list_alloc_error())
+ * if (eina_error_get())
  *   {
  *     fprintf(stderr, "ERROR: Memory is low. List Sorting failed.\n");
  *     exit(-1);
@@ -1182,6 +1139,18 @@ eina_list_sort(Eina_List *list, unsigned int size, int (*func)(void *, void *))
    return list;
 }
 
+/**
+ * @brief Returned a new iterator asociated to a list.
+ *
+ * @param list The list.
+ * @return A new iterator.
+ *
+ * This function returns a newly allocated iterator associated to
+ * @p list. If @p list is @c NULL or the count member of @p list is
+ * less or equal than 0, this function returns NULL. If the memory can
+ * not be allocated, NULL is returned and #EINA_ERROR_OUT_OF_MEMORY is
+ * set. Otherwise, a valid iterator is returned.
+ */
 EAPI Eina_Iterator *
 eina_list_iterator_new(const Eina_List *list)
 {
@@ -1206,6 +1175,18 @@ eina_list_iterator_new(const Eina_List *list)
    return &it->iterator;
 }
 
+/**
+ * @brief Returned a new accessor asociated to a list.
+ *
+ * @param list The list.
+ * @return A new accessor.
+ *
+ * This function returns a newly allocated accessor associated to
+ * @p list. If @p list is @c NULL or the count member of @p list is
+ * less or equal than 0, this function returns NULL. If the memory can
+ * not be allocated, NULL is returned and #EINA_ERROR_OUT_OF_MEMORY is
+ * set. Otherwise, a valid accessor is returned.
+ */
 EAPI Eina_Accessor *
 eina_list_accessor_new(const Eina_List *list)
 {
@@ -1234,11 +1215,3 @@ eina_list_accessor_new(const Eina_List *list)
 /**
  * @}
  */
-
-/**
- * @}
- */
-
-/**
- * @}
- */
index 06a897e..0d5612c 100644 (file)
@@ -5,6 +5,8 @@ AM_CPPFLAGS = \
 -I$(top_srcdir)/src/include \
 @COVERAGE_CFLAGS@
 
+if !EINA_STATIC_BUILD_CHAINED_POOL
+
 controllerdir = $(libdir)/eina/chained_pool/
 controller_LTLIBRARIES = eina_chained_mempool.la
 
@@ -13,7 +15,10 @@ eina_chained_mempool.c
 
 eina_chained_mempool_la_LIBADD = $(top_builddir)/src/lib/libeina.la @COVERAGE_LIBS@
 eina_chained_mempool_la_LDFLAGS = -no-undefined @lt_enable_auto_import@ -module -avoid-version
+eina_chained_mempool_la_LIBTOOLFLAGS = --tag=disable-static
 eina_chained_mempool_la_DEPENDENCIES = $(top_builddir)/src/lib/libeina.la
 
+endif
+
 clean-local:
        rm -rf *.gcno
index b610509..4e761c3 100644 (file)
@@ -205,6 +205,8 @@ eina_chained_mempool_shutdown(void *data)
    free(mp);
 }
 
+#ifndef EINA_STATIC_BUILD_CHAINED_POOL
+
 static Eina_Mempool_Backend mp_backend = {
   .init = &eina_chained_mempool_init,
   .shutdown = &eina_chained_mempool_shutdown,
@@ -214,3 +216,5 @@ static Eina_Mempool_Backend mp_backend = {
 };
 
 EINA_MODULE("chained_mempool", "mp", NULL, &mp_backend);
+
+#endif /* ! EINA_STATIC_BUILD_CHAINED_POOL */
index 3d23b6e..41033db 100644 (file)
@@ -9,6 +9,8 @@ AM_CPPFLAGS = \
 
 if EINA_ENABLE_EMEMOA
 
+if !EINA_STATIC_BUILD_EMEMOA_FIXED
+
 controllerdir = $(libdir)/eina/chained_pool/
 controller_LTLIBRARIES = eina_ememoa_fixed.la
 
@@ -17,9 +19,12 @@ eina_ememoa_fixed.c
 
 eina_ememoa_fixed_la_LIBADD       = $(top_builddir)/src/lib/libeina.la @EMEMOA_LIBS@ @COVERAGE_LIBS@
 eina_ememoa_fixed_la_LDFLAGS      = -no-undefined @lt_enable_auto_import@ -module -avoid-version
+eina_ememoa_fixed_la_LIBTOOLFLAGS = --tag=disable-static
 eina_ememoa_fixed_la_DEPENDENCIES = $(top_builddir)/src/lib/libeina.la
 
 endif
 
+endif
+
 clean-local:
        rm -rf *.gcno
index ba6fa94..77d2578 100644 (file)
@@ -132,6 +132,8 @@ eina_ememoa_fixed_shutdown(void *data)
    free(efm);
 }
 
+#ifndef EINA_STATIC_BUILD_EMEMOA_FIXED
+
 static Eina_Mempool_Backend mp_backend = {
   .init = &eina_ememoa_fixed_init,
   .shutdown = &eina_ememoa_fixed_shutdown,
@@ -143,3 +145,5 @@ static Eina_Mempool_Backend mp_backend = {
 };
 
 EINA_MODULE("ememoa_fixed", "mp", NULL, &mp_backend);
+
+#endif /* ! EINA_STATIC_BUILD_EMEMOA_FIXED */
index 5c7dcd0..5939b9b 100644 (file)
@@ -9,6 +9,8 @@ AM_CPPFLAGS = \
 
 if EINA_ENABLE_EMEMOA
 
+if !EINA_STATIC_BUILD_EMEMOA_UNKNOWN
+
 controllerdir = $(libdir)/eina/chained_pool/
 controller_LTLIBRARIES = eina_ememoa_unknown.la
 
@@ -17,9 +19,12 @@ eina_ememoa_unknown.c
 
 eina_ememoa_unknown_la_LIBADD       = $(top_builddir)/src/lib/libeina.la @EMEMOA_LIBS@ @COVERAGE_LIBS@
 eina_ememoa_unknown_la_LDFLAGS      = -no-undefined @lt_enable_auto_import@ -module -avoid-version
+eina_ememoa_unknown_la_LIBTOOLFLAGS = --tag=disable-static
 eina_ememoa_unknown_la_DEPENDENCIES = $(top_builddir)/src/lib/libeina.la
 
 endif
 
+endif
+
 clean-local:
        rm -rf *.gcno
index 1c3dfec..4d49db3 100644 (file)
@@ -138,6 +138,8 @@ eina_ememoa_unknown_size_shutdown(void *data)
    free(efm);
 }
 
+#ifndef EINA_STATIC_BUILD_EMEMOA_UNKNOWN
+
 static Eina_Mempool_Backend mp_backend = {
   .init = &eina_ememoa_unknown_size_init,
   .shutdown = &eina_ememoa_unknown_size_shutdown,
@@ -149,3 +151,5 @@ static Eina_Mempool_Backend mp_backend = {
 };
 
 EINA_MODULE("ememoa_unknown", "mp", NULL, &mp_backend);
+
+#endif /* ! EINA_STATIC_BUILD_EMEMOA_UNKNOWN */
index d2f6522..9314aa5 100644 (file)
@@ -7,6 +7,8 @@ AM_CPPFLAGS = \
 @COVERAGE_CFLAGS@ \
 @EMEMOA_CFLAGS@
 
+if !EINA_STATIC_BUILD_PASS_THROUGH
+
 controllerdir = $(libdir)/eina/pass_through/
 controller_LTLIBRARIES = pass_through.la
 
@@ -15,8 +17,11 @@ pass_through.c
 
 pass_through_la_LIBADD       = $(top_builddir)/src/lib/libeina.la @COVERAGE_LIBS@
 pass_through_la_LDFLAGS      = -no-undefined @lt_enable_auto_import@ -module -avoid-version
+pass_through_la_LIBTOOLFLAGS = --tag=disable-static
 pass_through_la_DEPENDENCIES = $(top_builddir)/src/lib/libeina.la
 
+endif
+
 clean-local:
        rm -rf *.gcno
 
index 312ac70..9144736 100644 (file)
@@ -59,6 +59,8 @@ eina_pass_through_shutdown(__UNUSED__ void *data)
 {
 }
 
+#ifndef EINA_STATIC_BUILD_PASS_THROUGH
+
 static Eina_Mempool_Backend mp_backend = {
   .init = &eina_pass_through_init,
   .shutdown = &eina_pass_through_shutdown,
@@ -71,3 +73,5 @@ static Eina_Mempool_Backend mp_backend = {
 
 EINA_MODULE("pass_through", "mp", NULL, &mp_backend);
 
+#endif /* ! EINA_STATIC_BUILD_PASS_THROUGH */
+