From e9a8e1c85ad32e740cff9ab9ed1511871c39c510 Mon Sep 17 00:00:00 2001 From: jaseg Date: Fri, 24 Oct 2014 15:27:44 +0200 Subject: Fixed escape sequence pass-through --- lolcat.c | 49 ++++++++++++++++++++++++++++++++++--------------- 1 file changed, 34 insertions(+), 15 deletions(-) (limited to 'lolcat.c') diff --git a/lolcat.c b/lolcat.c index 11a8711..caf83df 100644 --- a/lolcat.c +++ b/lolcat.c @@ -20,10 +20,24 @@ #include #include #include +#include #define ARRAY_SIZE(foo) (sizeof(foo)/sizeof(foo[0])) char codes[] = {39,38,44,43,49,48,84,83,119,118,154,148,184,178,214,208,209,203,204,198,199,163,164,128,129,93,99,63,69,33}; +/* CAUTION! this function uses a function-static variable! */ +void find_escape_sequences(int c, int *state){ + if(c == '\033'){ /* Escape sequence YAY */ + *state = 1; + }else if(*state == 1){ + if(('a' <= c && c <= 'z') || ('A' <= c && c <= 'Z')) + *state = 2; + }else{ + *state = 0; + } +} + + void usage(){ printf("Usage: lolcat [-h horizontal_speed] [-v vertical_speed] [--] [FILES...]\n"); exit(1); @@ -37,11 +51,9 @@ int main(int argc, char **argv){ char *endptr; if(!strcmp(argv[i], "-h")){ if((++i) 0){ - if(c == '\n'){ - l++; - i = 0; - }else if(isprint(c)){ - int ncc = (int)((i++)*freq_h + l*freq_v); - if(ncc != cc) - printf("\033[38;5;%hhum", codes[(cc = ncc) % ARRAY_SIZE(codes)]); + find_escape_sequences(c, &escape_state); + + if(!escape_state){ + if(c == '\n'){ + l++; + i = 0; + }else if(!iscntrl(c)){ + int ncc = (int)((i++)*freq_h + l*freq_v); + if(cc != ncc) + printf("\033[38;5;%hhum", codes[(cc = ncc) % ARRAY_SIZE(codes)]); + } } + printf("%lc", c); + + if(escape_state == 2) + printf("\033[38;5;%hhum", codes[cc % ARRAY_SIZE(codes)]); } + if(c != WEOF){ fprintf(stderr, "Error reading input file \"%s\": %s (%d)\n", *filename, strerror(errno), errno); return 2; -- cgit