summaryrefslogtreecommitdiff
path: root/accel-pppd/cli
diff options
context:
space:
mode:
authorKozlov Dmitry <dima@server>2011-06-03 13:23:11 +0400
committerKozlov Dmitry <dima@server>2011-06-03 13:23:11 +0400
commite63e5ac245edcbf43902dd1d248e15231c6c9191 (patch)
tree4d23135db9806aa22d801b1f9ce3835fbfd5b6bf /accel-pppd/cli
parentd83e9195896a826b6e16d9867c0b81292a384824 (diff)
downloadaccel-ppp-xebd-e63e5ac245edcbf43902dd1d248e15231c6c9191.tar.gz
accel-ppp-xebd-e63e5ac245edcbf43902dd1d248e15231c6c9191.zip
cli:show sessions: fixed bug when match or order key is not in field list to show
Diffstat (limited to 'accel-pppd/cli')
-rw-r--r--accel-pppd/cli/show_sessions.c34
1 files changed, 33 insertions, 1 deletions
diff --git a/accel-pppd/cli/show_sessions.c b/accel-pppd/cli/show_sessions.c
index 3fb3f0a..d7a8a82 100644
--- a/accel-pppd/cli/show_sessions.c
+++ b/accel-pppd/cli/show_sessions.c
@@ -29,6 +29,7 @@ struct col_t
struct list_head entry;
struct column_t *column;
int width;
+ int hidden;
};
struct row_t
@@ -131,6 +132,7 @@ static int show_ses_exec(const char *cmd, char * const *f, int f_cnt, void *cli)
int i, n, total_width, def_columns = 0;
struct ppp_t *ppp;
char *buf = NULL;
+ int match_key_f = 0, order_key_f = 0;
LIST_HEAD(c_list);
LIST_HEAD(r_list);
LIST_HEAD(t_list);
@@ -179,10 +181,15 @@ static int show_ses_exec(const char *cmd, char * const *f, int f_cnt, void *cli)
if (ptr2)
*ptr2 = 0;
column = find_column(ptr1);
+ if (column == match_key)
+ match_key_f = 1;
+ if (column == order_key)
+ order_key_f = 1;
if (column) {
col = _malloc(sizeof(*col));
col->column = column;
col->width = strlen(column->name);
+ col->hidden = 0;
list_add_tail(&col->entry, &c_list);
} else {
if (!def_columns) {
@@ -197,6 +204,22 @@ static int show_ses_exec(const char *cmd, char * const *f, int f_cnt, void *cli)
}
_free(columns);
+ if (match_key && !match_key_f) {
+ col = _malloc(sizeof(*col));
+ col->column = match_key;
+ col->width = 0;
+ col->hidden = 1;
+ list_add_tail(&col->entry, &c_list);
+ }
+
+ if (order_key && !order_key_f) {
+ col = _malloc(sizeof(*col));
+ col->column = order_key;
+ col->width = 0;
+ col->hidden = 1;
+ list_add_tail(&col->entry, &c_list);
+ }
+
pthread_rwlock_rdlock(&ppp_lock);
list_for_each_entry(ppp, &ppp_list, entry) {
row = _malloc(sizeof(*row));
@@ -244,8 +267,11 @@ static int show_ses_exec(const char *cmd, char * const *f, int f_cnt, void *cli)
}
total_width = -1;
- list_for_each_entry(col, &c_list, entry)
+ list_for_each_entry(col, &c_list, entry) {
+ if (col->hidden)
+ continue;
total_width += col->width + 3;
+ }
buf = _malloc(total_width + 3);
if (!buf)
@@ -253,6 +279,8 @@ static int show_ses_exec(const char *cmd, char * const *f, int f_cnt, void *cli)
ptr1 = buf;
list_for_each_entry(col, &c_list, entry) {
+ if (col->hidden)
+ continue;
n = strlen(col->column->name);
if (col->width > n + 1) {
ptr2 = ptr1;
@@ -278,6 +306,8 @@ static int show_ses_exec(const char *cmd, char * const *f, int f_cnt, void *cli)
ptr1 = buf;
list_for_each_entry(col, &c_list, entry) {
+ if (col->hidden)
+ continue;
memset(ptr1, '-', col->width + 2);
ptr1 += col->width + 2;
*ptr1 = '+';
@@ -291,6 +321,8 @@ static int show_ses_exec(const char *cmd, char * const *f, int f_cnt, void *cli)
row = list_entry(r_list.next, typeof(*row), entry);
ptr1 = buf;
list_for_each_entry(cell, &row->cell_list, entry) {
+ if (cell->col->hidden)
+ continue;
ptr2 = ptr1;
sprintf(ptr1, " %s ", cell->buf);
ptr1 = strchr(ptr1, 0);