diff options
author | jaseg <code@jaseg.net> | 2014-10-24 15:27:44 +0200 |
---|---|---|
committer | jaseg <code@jaseg.net> | 2014-10-24 15:27:44 +0200 |
commit | e9a8e1c85ad32e740cff9ab9ed1511871c39c510 (patch) | |
tree | c0c7e8fc50a3d6fdd1d50a704e249a3a8aaffd3b /lolcat.c | |
parent | 1a1eb5a5416a1557aa172b40b929de681f617983 (diff) | |
download | lolcat-e9a8e1c85ad32e740cff9ab9ed1511871c39c510.tar.gz lolcat-e9a8e1c85ad32e740cff9ab9ed1511871c39c510.tar.bz2 lolcat-e9a8e1c85ad32e740cff9ab9ed1511871c39c510.zip |
Fixed escape sequence pass-through
Diffstat (limited to 'lolcat.c')
-rw-r--r-- | lolcat.c | 49 |
1 files changed, 34 insertions, 15 deletions
@@ -20,10 +20,24 @@ #include <errno.h> #include <stdlib.h> #include <string.h> +#include <locale.h> #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)<argc){ - fprintf(stderr, "parsing arg %s\n", argv[i]); freq_h = strtod(argv[i], &endptr); if(*endptr) usage(); - fprintf(stderr, "parsed -h: %lF\n", freq_h); }else{ usage(); } @@ -50,19 +62,16 @@ int main(int argc, char **argv){ freq_v = strtod(argv[i], &endptr); if(*endptr) usage(); - fprintf(stderr, "parsed -v: %lF\n", freq_v); }else{ usage(); } }else{ if(!strcmp(argv[i], "--")) i++; - fprintf(stderr, "ending option parsing\n"); break; } } - fprintf(stderr, "commencing input parsing...\n"); char **inputs = argv+i; char **inputs_end = argv+argc; if(inputs == inputs_end){ @@ -71,26 +80,36 @@ int main(int argc, char **argv){ inputs_end = inputs+1; } + setlocale(LC_ALL, ""); + i=0; for(char **filename=inputs; filename<inputs_end; filename++){ FILE *f = stdin; - fprintf(stderr, "opening input \"%s\"\n", *filename); + int escape_state = 0; + if(strcmp(*filename, "-")) f = fopen(*filename, "r"); - fprintf(stderr, "reading data...\n"); - while((c = fgetwc(f)) > 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; |