# HG changeset patch # User Adam Chlipala # Date 1292168104 18000 # Node ID a1aa62b472cf8e22dd412c2c279f6f2f6ce545dd # Parent dab85a49e0abdc7628bcadac53c117fa5fef3d47 Change Basis.debug to use the protocol's debug function diff -r dab85a49e0ab -r a1aa62b472cf include/urweb.h --- a/include/urweb.h Sat Dec 11 19:57:22 2010 -0500 +++ b/include/urweb.h Sun Dec 12 10:35:04 2010 -0500 @@ -20,7 +20,7 @@ void uw_prune_clients(uw_context); failure_kind uw_initialize(uw_context); -uw_context uw_init(void); +uw_context uw_init(void *logger_data, uw_logger log_debug); void uw_close(uw_context); int uw_set_app(uw_context, uw_app*); uw_app *uw_get_app(uw_context); diff -r dab85a49e0ab -r a1aa62b472cf src/c/request.c --- a/src/c/request.c Sat Dec 11 19:57:22 2010 -0500 +++ b/src/c/request.c Sun Dec 12 10:35:04 2010 -0500 @@ -35,7 +35,7 @@ } uw_context uw_request_new_context(uw_app *app, void *logger_data, uw_logger log_error, uw_logger log_debug) { - uw_context ctx = uw_init(); + uw_context ctx = uw_init(logger_data, log_debug); int retries_left = MAX_RETRIES; uw_set_app(ctx, app); diff -r dab85a49e0ab -r a1aa62b472cf src/c/urweb.c --- a/src/c/urweb.c Sat Dec 11 19:57:22 2010 -0500 +++ b/src/c/urweb.c Sun Dec 12 10:35:04 2010 -0500 @@ -442,6 +442,9 @@ void *client_data; + void *logger_data; + uw_logger log_debug; + char error_message[ERROR_BUF_LEN]; }; @@ -450,7 +453,7 @@ size_t uw_heap_max = SIZE_MAX; size_t uw_script_max = SIZE_MAX; -uw_context uw_init() { +uw_context uw_init(void *logger_data, uw_logger log_debug) { uw_context ctx = malloc(sizeof(struct uw_context)); ctx->app = NULL; @@ -501,6 +504,9 @@ ctx->client_data = uw_init_client_data(); + ctx->logger_data = logger_data; + ctx->log_debug = log_debug; + return ctx; } @@ -3441,8 +3447,10 @@ size_t uw_database_max = SIZE_MAX; uw_Basis_unit uw_Basis_debug(uw_context ctx, uw_Basis_string s) { - fprintf(stderr, "%s\n", s); - + if (ctx->log_debug) + ctx->log_debug(ctx->logger_data, "%s\n", s); + else + fprintf(stderr, "%s\n", s); return uw_unit_v; } diff -r dab85a49e0ab -r a1aa62b472cf tests/hog.ur --- a/tests/hog.ur Sat Dec 11 19:57:22 2010 -0500 +++ b/tests/hog.ur Sun Dec 12 10:35:04 2010 -0500 @@ -4,4 +4,6 @@ else more (n-1) ^ more (n-1) -fun main n = return {[more n]} +fun main n = + debug "Let's give this a try...."; + return {[more n]}