X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=test%2Ftstlog.c;h=96cd95b74fa4953ca2deb0444bba869ae6adf0b6;hb=67471e87c134f2503546cdd250cd169b7d43d566;hp=c41089b64707c772ae65b76a637c6763f635e5a8;hpb=04e7f1b09e302ca5862d752e63e2a6e396c82047;p=yaz-moved-to-github.git diff --git a/test/tstlog.c b/test/tstlog.c index c41089b..96cd95b 100644 --- a/test/tstlog.c +++ b/test/tstlog.c @@ -2,13 +2,22 @@ * Copyright (C) 1995-2005, Index Data ApS * See the file LICENSE for details. * - * $Id: tstlog.c,v 1.7 2005-09-09 10:20:14 adam Exp $ + * $Id: tstlog.c,v 1.11 2006-10-04 07:32:36 adam Exp $ * */ #include +#include #include #include #include +#if HAVE_UNISTD_H +#include +#endif + +void hook_func(int level, const char *msg, void *vp) +{ + fprintf(stderr, "[HOOK level=%d msg=%s]\n", level, msg); +} int main(int argc, char **argv) { @@ -16,12 +25,13 @@ int main(int argc, char **argv) int i, ret; int level = YLOG_LOG; int number = 1; + unsigned int wait_between_log = 0; - while ((ret = options("f:v:l:m:n:s:", argv, argc, &arg)) != -2) + while ((ret = options("f:v:l:m:n:r:w:Hh", argv, argc, &arg)) != -2) { switch (ret) { - case 's': + case 'r': yaz_log_init_max_size(atoi(arg)); break; case 'f': @@ -31,7 +41,10 @@ int main(int argc, char **argv) yaz_log_init_level(yaz_log_mask_str(arg)); break; case 'l': - yaz_log_init_file(arg); + if (!strcmp(arg, "@")) + yaz_log_init_file(0); + else + yaz_log_init_file(arg); break; case 'n': number = atoi(arg); @@ -39,14 +52,27 @@ int main(int argc, char **argv) case 'm': level = yaz_log_module_level(arg); break; + case 'w': + wait_between_log = atoi(arg); + break; + case 'H': + yaz_log_set_handler(hook_func, 0); + break; case 0: for (i = 0; i