X-Git-Url: https://fleuret.org/cgi-bin/gitweb/gitweb.cgi?a=blobdiff_plain;f=selector.c;h=77ab6036921b9dfde551ef2b8f860d787b2994f0;hb=ca3e09ab0e4ffc59ba170094421571ada871adbb;hp=2d81071bc46e631a23b09923590df18a108b2bb2;hpb=7de2ff88a2c8ae9034202235ef20de8265f7d330;p=selector.git diff --git a/selector.c b/selector.c index 2d81071..77ab603 100644 --- a/selector.c +++ b/selector.c @@ -45,9 +45,9 @@ #include #include -#define VERSION "1.1.6" +#define VERSION "1.1.7" -#define BUFFER_SIZE 4096 +#define BUFFER_SIZE 16384 /* Yeah, global variables! */ @@ -206,6 +206,8 @@ void usage(FILE *out) { fprintf(out, " -- all following arguments are filenames\n"); fprintf(out, " -t , --title <title>\n"); fprintf(out, " add a title in the modeline\n"); + fprintf(out, " -r <pattern>, --pattern <pattern>\n"); + fprintf(out, " set an initial pattern\n"); fprintf(out, " -c <colors>, --colors <colors>\n"); fprintf(out, " set the display colors with an argument of the form\n"); fprintf(out, " <fg_modeline>,<bg_modeline>,<fg_highlight>,<bg_highlight>\n"); @@ -214,7 +216,8 @@ void usage(FILE *out) { fprintf(out, " -s <pattern separator>, --pattern-separator <pattern separator>\n"); fprintf(out, " set the symbol to separate substrings in the pattern\n"); fprintf(out, " -x <label separator>, --label-separator <label separator>\n"); - fprintf(out, " set the symbol to terminate the label\n"); + fprintf(out, " set the character to separate the label to show from the\n"); + fprintf(out, " string to return\n"); fprintf(out, " -l <max number of lines>, --number-of-lines <max number of lines>\n"); fprintf(out, " set the maximum number of lines to take into account\n"); fprintf(out, "\n"); @@ -921,6 +924,7 @@ void read_file(struct hash_table_t *hash_table, char raw_line[BUFFER_SIZE]; char *s; FILE *file; + int l; file = fopen(input_filename, "r"); @@ -929,11 +933,22 @@ void read_file(struct hash_table_t *hash_table, exit(EXIT_FAILURE); } - while(*nb_lines < nb_lines_max && fgets(raw_line, BUFFER_SIZE, file)) { - for(s = raw_line + strlen(raw_line) - 1; s > raw_line && *s == '\n'; s--) { - *s = '\0'; + if(label_separator == '\n') { + while(*nb_lines < nb_lines_max && fgets(raw_line, BUFFER_SIZE, file)) { + l = strlen(raw_line); + fgets(raw_line + l, BUFFER_SIZE - l, file); + for(s = raw_line + strlen(raw_line) - 1; s > raw_line && *s == '\n'; s--) { + *s = '\0'; + } + store_line(hash_table, raw_line, nb_lines, lines); + } + } else { + while(*nb_lines < nb_lines_max && fgets(raw_line, BUFFER_SIZE, file)) { + for(s = raw_line + strlen(raw_line) - 1; s > raw_line && *s == '\n'; s--) { + *s = '\0'; + } + store_line(hash_table, raw_line, nb_lines, lines); } - store_line(hash_table, raw_line, nb_lines, lines); } fclose(file); @@ -966,6 +981,7 @@ static struct option long_options[] = { { "show-hits", no_argument, 0, 'j'}, { "upper-case-makes-case-sensitive", no_argument, 0, 'u' }, { "title", 1, 0, 't' }, + { "pattern", 1, 0, 'r' }, { "number-of-lines", 1, 0, 'l' }, { "colors", 1, 0, 'c' }, { "bash", no_argument, 0, OPT_BASH_MODE }, @@ -997,6 +1013,8 @@ int main(int argc, char **argv) { exit(EXIT_FAILURE); } + pattern[0] = '\0'; + color_fg_modeline = COLOR_WHITE; color_bg_modeline = COLOR_BLACK; color_fg_highlight = COLOR_BLACK; @@ -1006,7 +1024,7 @@ int main(int argc, char **argv) { strcpy(output_filename, ""); - while ((c = getopt_long(argc, argv, "o:s:x:vwmqf:ibzdeajyunt:l:c:-h", + while ((c = getopt_long(argc, argv, "o:s:x:vwmqf:ibzdeajyunt:r:l:c:-h", long_options, NULL)) != -1) { switch(c) { @@ -1020,7 +1038,11 @@ int main(int argc, char **argv) { break; case 'x': - label_separator = optarg[0]; + if(strcmp(optarg, "\\n") == 0) { + label_separator = '\n'; + } else { + label_separator = optarg[0]; + } break; case 'v': @@ -1081,6 +1103,10 @@ int main(int argc, char **argv) { strcpy(title, optarg); break; + case 'r': + strcpy(pattern, optarg); + break; + case 'l': str_to_positive_integers(optarg, &nb_lines_max, 1); break; @@ -1199,8 +1225,6 @@ int main(int argc, char **argv) { *s = '\0'; } - pattern[0] = '\0'; - cursor_position = 0; /* Here we start to display with curse */ @@ -1246,6 +1270,7 @@ int main(int argc, char **argv) { current_focus_line = 0; displayed_focus_line = 0; + cursor_position = strlen(pattern); update_screen(¤t_focus_line, &displayed_focus_line, 0,