vppinfra: finish deprecating qsort.c 99/26699/2
authorDave Barach <dave@barachs.net>
Fri, 24 Apr 2020 20:07:37 +0000 (16:07 -0400)
committerDave Barach <dave@barachs.net>
Fri, 24 Apr 2020 20:52:55 +0000 (16:52 -0400)
Minor change to vec_sort_with_function(...): don't depend on the qsort
implementation to deal with null, zero-long, or 1-long vectors

Type: fix

Signed-off-by: Dave Barach <dave@barachs.net>
Change-Id: I7bd7b0421673d2a025363089562aa7c6266fba66

extras/deprecated/vppinfra/qsort.c [moved from src/vppinfra/qsort.c with 100% similarity]
src/vppinfra/vec.h

index 9054eaa..e983610 100644 (file)
@@ -1040,12 +1040,16 @@ do {                                            \
 
 /** \brief Sort a vector using the supplied element comparison function
 
+    Does not depend on the underlying implementation to deal correctly
+    with null, zero-long, or 1-long vectors
+
     @param vec vector to sort
     @param f comparison function
 */
-#define vec_sort_with_function(vec,f)                          \
-do {                                                           \
-  qsort (vec, vec_len (vec), sizeof (vec[0]), (void *) (f));   \
+#define vec_sort_with_function(vec,f)                           \
+do {                                                            \
+  if (vec_len (vec) > 1)                                        \
+    qsort (vec, vec_len (vec), sizeof (vec[0]), (void *) (f));  \
 } while (0)
 
 /** \brief Make a vector containing a NULL terminated c-string.