Skip to content

Commit

Permalink
added GNU libunistring benchmark
Browse files Browse the repository at this point in the history
  • Loading branch information
stevengj committed Jul 19, 2014
1 parent 5fbd15b commit a39c1a6
Show file tree
Hide file tree
Showing 3 changed files with 72 additions and 3 deletions.
7 changes: 5 additions & 2 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -10,5 +10,8 @@
*.dSYM
*.txt
*.out
bench
icu
bench/bench
bench/icu
bench/unistring


8 changes: 7 additions & 1 deletion bench/Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -26,8 +26,14 @@ icu: icu.o util.o
icu.out: $(DATAFILES) icu
./icu $(DATAFILES) > $@

unistring: unistring.o util.o
$(CC) $(CFLAGS) $(LDFLAGS) -o $@ unistring.o util.o -lunistring

unistring.out: $(DATAFILES) unistring
./unistring $(DATAFILES) > $@

.c.o:
$(CC) $(CPPFLAGS) -I.. $(CFLAGS) -c -o $@ $<

clean:
rm -rf *.o *.txt bench *.out icu
rm -rf *.o *.txt bench *.out icu unistring
60 changes: 60 additions & 0 deletions bench/unistring.c
Original file line number Diff line number Diff line change
@@ -0,0 +1,60 @@
/* comparitive benchmark of GNU libunistring */

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

/* libunistring */
#include <unistr.h>
#include <uninorm.h>

#include "util.h"

int main(int argc, char **argv)
{
int i;
uninorm_t nf = UNINORM_NFKC;

for (i = 1; i < argc; ++i) {
if (!strcmp(argv[i], "-nfkc")) {
nf = UNINORM_NFKC;
continue;
}
if (!strcmp(argv[i], "-nfkd")) {
nf = UNINORM_NFKD;
continue;
}
if (!strcmp(argv[i], "-nfc")) {
nf = UNINORM_NFC;
continue;
}
if (!strcmp(argv[i], "-nfd")) {
nf = UNINORM_NFD;
continue;
}
if (argv[i][0] == '-') {
fprintf(stderr, "unrecognized option: %s\n", argv[i]);
return EXIT_FAILURE;
}

size_t len;
uint8_t *src = readfile(argv[i], &len);
if (!src) {
fprintf(stderr, "error reading %s\n", argv[i]);
return EXIT_FAILURE;
}

size_t destlen;
uint8_t *dest;
mytime start = gettime();
for (int i = 0; i < 100; ++i) {
dest = u8_normalize(nf, src, len, NULL, &destlen);
if (!dest) return EXIT_FAILURE;
free(dest);
}
printf("%s: %g\n", argv[i], elapsed(gettime(), start) / 100);
free(src);
}

return EXIT_SUCCESS;
}

0 comments on commit a39c1a6

Please sign in to comment.