From 62a7fdb81507a7c364c49db1361e6c7728764b17 Mon Sep 17 00:00:00 2001 From: Bart De Schuymer Date: Sat, 24 Aug 2002 21:01:21 +0000 Subject: *** empty log message *** --- communication.c | 6 ++++-- ebtables.c | 4 ++++ 2 files changed, 8 insertions(+), 2 deletions(-) diff --git a/communication.c b/communication.c index 184a4c1..887ee08 100644 --- a/communication.c +++ b/communication.c @@ -656,9 +656,11 @@ int get_table(struct ebt_u_replace *u_repl) struct ebt_u_entry **u_e; strcpy(repl.name, u_repl->name); - if (u_repl->filename != NULL) + if (u_repl->filename != NULL) { retrieve_from_file(u_repl->filename, &repl, u_repl->command); - else if (retrieve_from_kernel(&repl, u_repl->command) == -1) + // -L with a wrong table name should be dealt with silently + strcpy(u_repl->name, repl.name); + } else if (retrieve_from_kernel(&repl, u_repl->command) == -1) return -1; // translate the struct ebt_replace to a struct ebt_u_replace diff --git a/ebtables.c b/ebtables.c index 54fd2b0..2ace08c 100644 --- a/ebtables.c +++ b/ebtables.c @@ -1462,6 +1462,10 @@ static void get_kernel_table(const char *modprobe) print_error("The kernel doesn't support the ebtables " "%s table", replace.name); } + // when listing a table contained in a file, we don't expect the user + // to know what the table's name is + if ( !(table = find_table(replace.name)) ) + print_error("Bad table name"); } #define print_if_l_error print_error("Interface name length must be less " \ -- cgit v1.2.3