int nb_lines_max = 10000;
char pattern_separator = ';';
int output_to_vt_buffer = 0;
-int with_colors = 0;
+int with_colors = 1;
//////////////////////////////////////////////////////////////////////
char buffer[buffer_size];
char *lines[nb_lines_max];
int no_blink = 0;
- int theme = 0;
+ int color_theme = 0;
+
+ setlocale(LC_ALL, "");
char input_filename[buffer_size], output_filename[buffer_size];
strcpy(input_filename, "");
i++;
}
+ else if(strcmp(argv[i], "-m") == 0) {
+ with_colors = 0;
+ i++;
+ }
+
else if(strcmp(argv[i], "-f") == 0) {
check_opt(argc, argv, i, 1, "<input filename>");
strncpy(input_filename, argv[i+1], buffer_size);
else if(strcmp(argv[i], "-t") == 0) {
check_opt(argc, argv, i, 1, "<color theme number>");
- theme = atoi(argv[i+1]);
+ color_theme = atoi(argv[i+1]);
i += 2;
}
<< " [-h]"
<< " [-b]"
<< " [-v]"
+ << " [-m]"
<< " [-t <color theme number>]"
<< " [-o <output filename>]"
<< " [-s <pattern separator>]"
initscr();
- if(has_colors()) {
- with_colors = 1;
- start_color();
- switch(theme) {
- default:
- case 0:
- init_pair(1, COLOR_WHITE, COLOR_GREEN);
- init_pair(2, COLOR_BLACK, COLOR_YELLOW);
- break;
- case 1:
- init_pair(1, COLOR_BLACK, COLOR_GREEN);
- init_pair(2, COLOR_BLACK, COLOR_YELLOW);
- break;
+ if(with_colors) {
+ if(has_colors()) {
+ start_color();
+ switch(color_theme) {
+ default:
+ case 0:
+ init_pair(1, COLOR_WHITE, COLOR_GREEN);
+ init_pair(2, COLOR_BLACK, COLOR_YELLOW);
+ break;
+ case 1:
+ init_pair(1, COLOR_WHITE, COLOR_BLACK);
+ init_pair(2, COLOR_BLACK, COLOR_YELLOW);
+ break;
+ case 2:
+ init_pair(1, COLOR_BLACK, COLOR_GREEN);
+ init_pair(2, COLOR_BLACK, COLOR_YELLOW);
+ break;
+ case 3:
+ init_pair(1, COLOR_BLACK, COLOR_RED);
+ init_pair(2, COLOR_BLACK, COLOR_YELLOW);
+ break;
+ case 4:
+ init_pair(1, COLOR_WHITE, COLOR_BLACK);
+ init_pair(2, COLOR_BLACK, COLOR_BLUE);
+ break;
+ case 5:
+ init_pair(1, COLOR_BLACK, COLOR_MAGENTA);
+ init_pair(2, COLOR_BLACK, COLOR_CYAN);
+ break;
+ }
+ } else {
+ with_colors = 0;
}
}
int motion = 0;
- if(key >= ' ' && key <= 'z') {
+ if(key >= ' ' && key <= '~') {
patterns[patterns_point++] = key;
patterns[patterns_point] = '\0';
}
update_screen(¤t_line, &temporary_line, motion,
nb_lines, lines, patterns, no_blink);
+
} while(key != '\n' && key != KEY_ENTER && key != '\a');
echo();
if (fd >= 0) {
// Save current port settings
tcgetattr(fd,&oldtio);
- bzero(&newtio, sizeof(newtio));
+ memset(&newtio, 0, sizeof(newtio));
// Set input mode (non-canonical, *no echo*,...)
tcflush(fd, TCIFLUSH);
tcsetattr(fd,TCSANOW, &newtio);
delete[] lines[l];
}
- curs_set(1);
- endwin();
-
exit(0);
}