diff options
author | Mattias Andrée <maandree@kth.se> | 2018-11-23 20:38:54 +0100 |
---|---|---|
committer | Mattias Andrée <maandree@kth.se> | 2018-11-23 20:38:54 +0100 |
commit | b5ca6729c7b52e8cade6d3808ad8280845ac32ea (patch) | |
tree | 0ddac006e8a6bad962c7c981449ba43fb4bc195f /rawmemrchr_inv.c | |
parent | Add a bunch of function and macros (diff) | |
download | libsimple-b5ca6729c7b52e8cade6d3808ad8280845ac32ea.tar.gz libsimple-b5ca6729c7b52e8cade6d3808ad8280845ac32ea.tar.bz2 libsimple-b5ca6729c7b52e8cade6d3808ad8280845ac32ea.tar.xz |
Some fixes and tests
Signed-off-by: Mattias Andrée <maandree@kth.se>
Diffstat (limited to '')
-rw-r--r-- | rawmemrchr_inv.c | 8 |
1 files changed, 7 insertions, 1 deletions
diff --git a/rawmemrchr_inv.c b/rawmemrchr_inv.c index b60a4fe..6c6b9db 100644 --- a/rawmemrchr_inv.c +++ b/rawmemrchr_inv.c @@ -4,7 +4,7 @@ void * -libsimple_rawmemrchr_inv(const void *s_, int c_, size_t n) /* TODO test, man */ +libsimple_rawmemrchr_inv(const void *s_, int c_, size_t n) /* TODO man */ { char *s = *(char **)(void *)&s_, c = (char)c_; while (s[--n] == c); @@ -18,6 +18,12 @@ libsimple_rawmemrchr_inv(const void *s_, int c_, size_t n) /* TODO test, man */ int main(void) { + assert(!strcmpnul(libsimple_rawmemrchr_inv("aabbaabb", 'b', 8), "abb")); + assert(!strcmpnul(libsimple_rawmemrchr_inv("aabbaabb", 'B', 8), "b")); + assert(!strcmpnul(libsimple_rawmemrchr_inv("AABBAABB", 'b', 8), "B")); + assert(!strcmpnul(libsimple_rawmemrchr_inv("AABBAABB", 'B', 8), "ABB")); + assert(!strcmpnul(libsimple_rawmemrchr_inv("aabbaabb", 'a', 8), "b")); + assert(!strcmpnul(libsimple_rawmemrchr_inv("aabbbb\0", '\0', 8), "b")); return 0; } |