@@ -35,18 +35,6 @@ hashtable_iterator(struct hashtable *h)
}
/*****************************************************************************/
-/* key - return the key of the (key,value) pair at the current position */
-/* value - return the value of the (key,value) pair at the current position */
-
-void *
-hashtable_iterator_key(struct hashtable_itr *i)
-{ return i->e->k; }
-
-void *
-hashtable_iterator_value(struct hashtable_itr *i)
-{ return i->e->v; }
-
-/*****************************************************************************/
/* advance - advance the iterator to the next element
* returns zero if advanced to end of table */
@@ -28,7 +28,7 @@ hashtable_iterator(struct hashtable *h);
/* hashtable_iterator_key
* - return the value of the (key,value) pair at the current position */
-extern inline void *
+static inline void *
hashtable_iterator_key(struct hashtable_itr *i)
{
return i->e->k;
@@ -37,7 +37,7 @@ hashtable_iterator_key(struct hashtable_itr *i)
/*****************************************************************************/
/* value - return the value of the (key,value) pair at the current position */
-extern inline void *
+static inline void *
hashtable_iterator_value(struct hashtable_itr *i)
{
return i->e->v;
GCC 5 changed the default C standard to gnu11 which changed the behavior of the inline keyword. This causes mtd-utils to fail to build with duplicate definition errors involving hashtable_iterator_key and hashtable_iterator_value. This patch fixes the build by making the functions static inline and removing the extra definitions in hashtable_itr.c. Signed-off-by: James Cowgill <james410@cowgill.org.uk> --- mkfs.ubifs/hashtable/hashtable_itr.c | 12 ------------ mkfs.ubifs/hashtable/hashtable_itr.h | 4 ++-- 2 files changed, 2 insertions(+), 14 deletions(-)