This makes num_columns always return valid number of columns, which is expected by print_packets function. This also fix garbage prints while using btmon via adb shell. --- monitor/display.c | 8 ++++---- monitor/display.h | 2 ++ 2 files changed, 6 insertions(+), 4 deletions(-) diff --git a/monitor/display.c b/monitor/display.c index b8dce1f..af4171f 100644 --- a/monitor/display.c +++ b/monitor/display.c @@ -58,10 +58,10 @@ int num_columns(void) if (__builtin_expect(!!(cached_num_columns < 0), 0)) { struct winsize ws; - if (ioctl(STDOUT_FILENO, TIOCGWINSZ, &ws) < 0) - return -1; - - if (ws.ws_col > 0) + if (ioctl(STDOUT_FILENO, TIOCGWINSZ, &ws) < 0 || + ws.ws_col == 0) + cached_num_columns = FALLBACK_TERMINAL_WIDTH; + else cached_num_columns = ws.ws_col; } diff --git a/monitor/display.h b/monitor/display.h index 6139cc2..885eb34 100644 --- a/monitor/display.h +++ b/monitor/display.h @@ -40,6 +40,8 @@ bool use_color(void); #define COLOR_ERROR "\x1B[1;31m" +#define FALLBACK_TERMINAL_WIDTH 80 + #define print_indent(indent, color1, prefix, title, color2, fmt, args...) \ do { \ printf("%*c%s%s%s%s" fmt "%s\n", (indent), ' ', \ -- 1.8.4.1 -- To unsubscribe from this list: send the line "unsubscribe linux-bluetooth" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html