Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 1 | /* |
Namhyung Kim | 5f9273d | 2011-12-13 22:52:03 +0900 | [diff] [blame] | 2 | * usage.c |
| 3 | * |
| 4 | * Various reporting routines. |
| 5 | * Originally copied from GIT source. |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 6 | * |
| 7 | * Copyright (C) Linus Torvalds, 2005 |
| 8 | */ |
| 9 | #include "util.h" |
Arnaldo Carvalho de Melo | 0d37aa3 | 2012-01-19 14:08:15 -0200 | [diff] [blame] | 10 | #include "debug.h" |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 11 | |
| 12 | static void report(const char *prefix, const char *err, va_list params) |
| 13 | { |
| 14 | char msg[1024]; |
| 15 | vsnprintf(msg, sizeof(msg), err, params); |
Ingo Molnar | 716c69f | 2009-06-07 17:31:52 +0200 | [diff] [blame] | 16 | fprintf(stderr, " %s%s\n", prefix, msg); |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 17 | } |
| 18 | |
| 19 | static NORETURN void usage_builtin(const char *err) |
| 20 | { |
Ingo Molnar | 716c69f | 2009-06-07 17:31:52 +0200 | [diff] [blame] | 21 | fprintf(stderr, "\n Usage: %s\n", err); |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 22 | exit(129); |
| 23 | } |
| 24 | |
| 25 | static NORETURN void die_builtin(const char *err, va_list params) |
| 26 | { |
Ingo Molnar | 716c69f | 2009-06-07 17:31:52 +0200 | [diff] [blame] | 27 | report(" Fatal: ", err, params); |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 28 | exit(128); |
| 29 | } |
| 30 | |
| 31 | static void error_builtin(const char *err, va_list params) |
| 32 | { |
Ingo Molnar | 716c69f | 2009-06-07 17:31:52 +0200 | [diff] [blame] | 33 | report(" Error: ", err, params); |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 34 | } |
| 35 | |
| 36 | static void warn_builtin(const char *warn, va_list params) |
| 37 | { |
Ingo Molnar | 716c69f | 2009-06-07 17:31:52 +0200 | [diff] [blame] | 38 | report(" Warning: ", warn, params); |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 39 | } |
| 40 | |
| 41 | /* If we are in a dlopen()ed .so write to a global variable would segfault |
| 42 | * (ugh), so keep things static. */ |
| 43 | static void (*usage_routine)(const char *err) NORETURN = usage_builtin; |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 44 | static void (*error_routine)(const char *err, va_list params) = error_builtin; |
| 45 | static void (*warn_routine)(const char *err, va_list params) = warn_builtin; |
| 46 | |
Namhyung Kim | 2690c73 | 2015-10-20 00:23:49 +0900 | [diff] [blame] | 47 | void set_warning_routine(void (*routine)(const char *err, va_list params)) |
| 48 | { |
| 49 | warn_routine = routine; |
| 50 | } |
| 51 | |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 52 | void usage(const char *err) |
| 53 | { |
| 54 | usage_routine(err); |
| 55 | } |
| 56 | |
| 57 | void die(const char *err, ...) |
| 58 | { |
| 59 | va_list params; |
| 60 | |
| 61 | va_start(params, err); |
Arnaldo Carvalho de Melo | e476343 | 2016-03-23 12:32:31 -0300 | [diff] [blame] | 62 | die_builtin(err, params); |
Ingo Molnar | 0780060 | 2009-04-20 15:00:56 +0200 | [diff] [blame] | 63 | va_end(params); |
| 64 | } |
| 65 | |
| 66 | int error(const char *err, ...) |
| 67 | { |
| 68 | va_list params; |
| 69 | |
| 70 | va_start(params, err); |
| 71 | error_routine(err, params); |
| 72 | va_end(params); |
| 73 | return -1; |
| 74 | } |
| 75 | |
| 76 | void warning(const char *warn, ...) |
| 77 | { |
| 78 | va_list params; |
| 79 | |
| 80 | va_start(params, warn); |
| 81 | warn_routine(warn, params); |
| 82 | va_end(params); |
| 83 | } |