summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCedric Berger <cedric@cvs.openbsd.org>2003-03-07 15:16:34 +0000
committerCedric Berger <cedric@cvs.openbsd.org>2003-03-07 15:16:34 +0000
commit237b1d84dd3703bf54dbb6bf8c62e8498e3d07d4 (patch)
tree0805bcf5fd13f4bd25bcb41ff069d61f20d62c30
parent658b91a300bbb62269d0f31a1f8648ae8755a167 (diff)
Only show non-active tables when the -g flag is given.
ok dhartmei@ henning@
-rw-r--r--sbin/pfctl/pfctl.86
-rw-r--r--sbin/pfctl/pfctl_table.c21
2 files changed, 14 insertions, 13 deletions
diff --git a/sbin/pfctl/pfctl.8 b/sbin/pfctl/pfctl.8
index 141a8d038c5..6269dedc2ad 100644
--- a/sbin/pfctl/pfctl.8
+++ b/sbin/pfctl/pfctl.8
@@ -1,4 +1,4 @@
-.\" $OpenBSD: pfctl.8,v 1.87 2003/03/07 13:27:12 henning Exp $
+.\" $OpenBSD: pfctl.8,v 1.88 2003/03/07 15:16:33 cedric Exp $
.\"
.\" Copyright (c) 2001 Kjell Wooding. All rights reserved.
.\"
@@ -461,8 +461,8 @@ For tables which are part of the
.Ar active
tableset.
Tables without this flag do not really exist, cannot contain addresses, and are
-not listed if no
-.Fl v
+only listed if the
+.Fl g
flag is given.
.It i
For tables which are part of the
diff --git a/sbin/pfctl/pfctl_table.c b/sbin/pfctl/pfctl_table.c
index 2b7b6424a71..7973167211b 100644
--- a/sbin/pfctl/pfctl_table.c
+++ b/sbin/pfctl/pfctl_table.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: pfctl_table.c,v 1.35 2003/02/14 17:17:27 henning Exp $ */
+/* $OpenBSD: pfctl_table.c,v 1.36 2003/03/07 15:16:33 cedric Exp $ */
/*
* Copyright (c) 2002 Cedric Berger
@@ -57,7 +57,7 @@
extern void usage(void);
static int pfctl_table(int, char *[], char *, char *, char *, int);
static void grow_buffer(size_t, int);
-static void print_table(struct pfr_table *, int);
+static void print_table(struct pfr_table *, int, int);
static void print_tstats(struct pfr_tstats *, int);
static void load_addr(int, char *[], char *, int);
static int next_token(char [], FILE *);
@@ -171,10 +171,11 @@ pfctl_table(int argc, char *argv[], char *tname, char *command,
for (i = 0; i < size; i++)
if (opts & PF_OPT_VERBOSE2)
print_tstats(buffer.tstats+i,
- opts & PF_OPT_VERBOSE);
+ opts & PF_OPT_DEBUG);
else
print_table(buffer.tables+i,
- opts & PF_OPT_VERBOSE);
+ opts & PF_OPT_VERBOSE,
+ opts & PF_OPT_DEBUG);
} else if (!strcmp(command, "kill")) {
if (argc || file != NULL)
usage();
@@ -330,11 +331,11 @@ grow_buffer(size_t bs, int minsize)
}
void
-print_table(struct pfr_table *ta, int all)
+print_table(struct pfr_table *ta, int verbose, int debug)
{
- if (!all && !(ta->pfrt_flags & PFR_TFLAG_ACTIVE))
+ if (!debug && !(ta->pfrt_flags & PFR_TFLAG_ACTIVE))
return;
- if (all) {
+ if (verbose) {
printf("%c%c%c%c%c\t%s\n",
(ta->pfrt_flags & PFR_TFLAG_CONST) ? 'c' : '-',
(ta->pfrt_flags & PFR_TFLAG_PERSIST) ? 'p' : '-',
@@ -347,14 +348,14 @@ print_table(struct pfr_table *ta, int all)
}
void
-print_tstats(struct pfr_tstats *ts, int all)
+print_tstats(struct pfr_tstats *ts, int debug)
{
time_t time = ts->pfrts_tzero;
int dir, op;
- if (!all && !(ts->pfrts_flags & PFR_TFLAG_ACTIVE))
+ if (!debug && !(ts->pfrts_flags & PFR_TFLAG_ACTIVE))
return;
- print_table(&ts->pfrts_t, all);
+ print_table(&ts->pfrts_t, 1, debug);
printf("\tAddresses: %d\n", ts->pfrts_cnt);
printf("\tReferences: %d\n", ts->pfrts_refcnt);
printf("\tCleared: %s", ctime(&time));