hush/libbb/printable.c
Bartosz Golaszewski 79c618c411 Refactor catv. Move visible() from stty to libbb.
Fixes the following TODO:

  stty's visible() function and catv's guts are identical. Merge them into
  an appropriate libbb function.

Also makes catv behave exactly like coreutils' cat -v e.g. it'll print 'M-^I'
instead of 'M-   '.

function                                             old     new   delta
visible                                                -      70     +70
do_display                                           431     379     -52
catv_main                                            306     250     -56
------------------------------------------------------------------------------
(add/remove: 1/0 grow/shrink: 0/2 up/down: 70/-108)           Total: -38 bytes

Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
2013-07-30 06:29:42 +02:00

59 lines
1000 B
C

/* vi: set sw=4 ts=4: */
/*
* Utility routines.
*
* Copyright (C) 2007 Denys Vlasenko
*
* Licensed under GPLv2, see file LICENSE in this source tree.
*/
#include "libbb.h"
void FAST_FUNC fputc_printable(int ch, FILE *file)
{
if ((ch & (0x80 + PRINTABLE_META)) == (0x80 + PRINTABLE_META)) {
fputs("M-", file);
ch &= 0x7f;
}
ch = (unsigned char) ch;
if (ch == 0x9b) {
/* VT100's CSI, aka Meta-ESC, is not printable on vt-100 */
ch = '{';
goto print_caret;
}
if (ch < ' ') {
ch += '@';
goto print_caret;
}
if (ch == 0x7f) {
ch = '?';
print_caret:
fputc('^', file);
}
fputc(ch, file);
}
void FAST_FUNC visible(unsigned ch, char *buf, int flags)
{
if (ch == '\t' && !(flags & VISIBLE_SHOW_TABS)) {
goto raw;
}
if (ch == '\n') {
if (flags & VISIBLE_ENDLINE)
*buf++ = '$';
} else {
if (ch >= 128) {
ch -= 128;
*buf++ = 'M';
*buf++ = '-';
}
if (ch < 32 || ch == 127) {
*buf++ = '^';
ch ^= 0x40;
}
}
raw:
*buf++ = ch;
*buf = '\0';
}