diff options
author | Guy Harris <gharris@sonic.net> | 2021-03-15 11:29:43 -0700 |
---|---|---|
committer | Guy Harris <gharris@sonic.net> | 2021-03-15 12:17:59 -0700 |
commit | c33e2f7b51f9e14f99f6b6d9018ac41b7e97d5a6 (patch) | |
tree | 4e02fee80e16cfd08afc9d555e4612399c72d69b /dftest.c | |
parent | 89ae76d3008719f6b797eb201794dfe0de294640 (diff) |
Add more error-reporting routines that call through a function pointer.
Have routines to report capture-file errors, using libwireshark error
codes and strings, that call through a pointer, so they can pop up
dialogs in GUI apps, print a message to the standard error on
command-line apps, and possibly do something different on server
programs.
Have init_report_message() take a pointer to structure containing those
function pointers, rather than the function pointers themselves, as
arguments.
Make other API changes to make that work.
Diffstat (limited to 'dftest.c')
-rw-r--r-- | dftest.c | 61 |
1 files changed, 25 insertions, 36 deletions
@@ -33,21 +33,34 @@ #include <wiretap/wtap.h> #include "ui/util.h" +#include "ui/cmdarg_err.h" +#include "ui/failure_message.h" -static void failure_warning_message(const char *msg_format, va_list ap); -static void open_failure_message(const char *filename, int err, - gboolean for_writing); -static void read_failure_message(const char *filename, int err); -static void write_failure_message(const char *filename, int err); +static void dftest_cmdarg_err(const char *fmt, va_list ap); +static void dftest_cmdarg_err_cont(const char *fmt, va_list ap); int main(int argc, char **argv) { char *init_progfile_dir_error; + static const struct report_message_routines dftest_report_routines = { + failure_message, + failure_message, + open_failure_message, + read_failure_message, + write_failure_message, + cfile_open_failure_message, + cfile_dump_open_failure_message, + cfile_read_failure_message, + cfile_write_failure_message, + cfile_close_failure_message + }; char *text; dfilter_t *df; gchar *err_msg; + cmdarg_err_init(dftest_cmdarg_err, dftest_cmdarg_err_cont); + /* * Get credential information for later use. */ @@ -64,9 +77,7 @@ main(int argc, char **argv) g_free(init_progfile_dir_error); } - init_report_message(failure_warning_message, failure_warning_message, - open_failure_message, read_failure_message, - write_failure_message); + init_report_message("dftest", &dftest_report_routines); timestamp_set_type(TS_RELATIVE); timestamp_set_seconds_type(TS_SECONDS_DEFAULT); @@ -137,49 +148,27 @@ main(int argc, char **argv) } /* - * General errors and warnings are reported with an console message - * in "dftest". + * Report an error in command-line arguments. */ static void -failure_warning_message(const char *msg_format, va_list ap) +dftest_cmdarg_err(const char *fmt, va_list ap) { fprintf(stderr, "dftest: "); - vfprintf(stderr, msg_format, ap); + vfprintf(stderr, fmt, ap); fprintf(stderr, "\n"); } /* - * Open/create errors are reported with an console message in "dftest". + * Report additional information for an error in command-line arguments. */ static void -open_failure_message(const char *filename, int err, gboolean for_writing) +dftest_cmdarg_err_cont(const char *fmt, va_list ap) { - fprintf(stderr, "dftest: "); - fprintf(stderr, file_open_error_message(err, for_writing), filename); + vfprintf(stderr, fmt, ap); fprintf(stderr, "\n"); } /* - * Read errors are reported with an console message in "dftest". - */ -static void -read_failure_message(const char *filename, int err) -{ - fprintf(stderr, "dftest: An error occurred while reading from the file \"%s\": %s.\n", - filename, g_strerror(err)); -} - -/* - * Write errors are reported with an console message in "dftest". - */ -static void -write_failure_message(const char *filename, int err) -{ - fprintf(stderr, "dftest: An error occurred while writing to the file \"%s\": %s.\n", - filename, g_strerror(err)); -} - -/* * Editor modelines - https://www.wireshark.org/tools/modelines.html * * Local variables: |