chiark
/
gitweb
/
~ianmdlvl
/
elogind.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
bus: connect directly via kdbus in sd_bus_open_system_container()
[elogind.git]
/
src
/
shared
/
test-tables.h
diff --git
a/src/shared/test-tables.h
b/src/shared/test-tables.h
index ac7deda39b3810f6f7837d0d8d9b5d6254b4569d..3261302077d4cb1765fa9f477103bd7cd4d80043 100644
(file)
--- a/
src/shared/test-tables.h
+++ b/
src/shared/test-tables.h
@@
-26,21
+26,26
@@
typedef int (*reverse_t)(const char*);
static inline void _test_table(const char *name,
lookup_t lookup,
reverse_t reverse,
static inline void _test_table(const char *name,
lookup_t lookup,
reverse_t reverse,
- int size) {
+ int size,
+ bool sparse) {
int i;
int i;
- for (i =
0; i < size
; i++) {
+ for (i =
-1; i < size + 1
; i++) {
const char* val = lookup(i);
const char* val = lookup(i);
- int rev
= -1
;
+ int rev;
if (val)
rev = reverse(val);
if (val)
rev = reverse(val);
+ else
+ rev = reverse("--no-such--value----");
printf("%s: %d → %s → %d\n", name, i, val, rev);
printf("%s: %d → %s → %d\n", name, i, val, rev);
- if (!val || rev != i)
+ if (i >= 0 && i < size ?
+ sparse ? rev != i && rev != -1 : val == NULL || rev != i :
+ val != NULL || rev != -1)
exit(EXIT_FAILURE);
}
}
#define test_table(lower, upper) \
exit(EXIT_FAILURE);
}
}
#define test_table(lower, upper) \
- _test_table(STRINGIFY(lower), lower##_to_string, lower##_from_string, _##upper##_MAX)
+ _test_table(STRINGIFY(lower), lower##_to_string, lower##_from_string, _##upper##_MAX
, false
)