* util.c (cstrcasestr): Added a function to search for a

substring ignoring case.
	* util.h: Added cstrcasestr.
	* find.c: Added plaintext search mode.
This commit is contained in:
Roland Illig 2004-12-02 20:08:06 +00:00
parent 639e150164
commit 2a9f3b6ce3
4 changed files with 56 additions and 7 deletions

View File

@ -6,6 +6,10 @@
* view.c: Cleaned up the code. Added error handling for the * view.c: Cleaned up the code. Added error handling for the
growing buffer case. growing buffer case.
* util.c (extension): Simplified the code. * util.c (extension): Simplified the code.
* util.c (cstrcasestr): Added a function to search for a
substring ignoring case.
* util.h: Added cstrcasestr.
* find.c: Added plaintext search mode.
2004-12-02 Andrew V. Samoilov <sav@bcs.zp.ua> 2004-12-02 Andrew V. Samoilov <sav@bcs.zp.ua>

View File

@ -44,7 +44,7 @@
#include "key.h" #include "key.h"
/* Size of the find parameters window */ /* Size of the find parameters window */
#define FIND_Y 14 #define FIND_Y 15
static int FIND_X = 50; static int FIND_X = 50;
/* Size of the find window */ /* Size of the find window */
@ -75,10 +75,13 @@ static WInput *in_start; /* Start path */
static WInput *in_name; /* Pattern to search */ static WInput *in_name; /* Pattern to search */
static WInput *in_with; /* Text inside filename */ static WInput *in_with; /* Text inside filename */
static WCheck *case_sense; /* "case sensitive" checkbox */ static WCheck *case_sense; /* "case sensitive" checkbox */
static WCheck *find_regex_cbox; /* [x] find regular expression */
static int running = 0; /* nice flag */ static int running = 0; /* nice flag */
static char *find_pattern; /* Pattern to search */ static char *find_pattern; /* Pattern to search */
static char *content_pattern; /* pattern to search inside files */ static char *content_pattern; /* pattern to search inside files; if
find_regex_flag is true, it contains the
regex pattern, else the search string. */
static int count; /* Number of files displayed */ static int count; /* Number of files displayed */
static int matches; /* Number of matches */ static int matches; /* Number of matches */
static int is_start; /* Status of the start/stop toggle button */ static int is_start; /* Status of the start/stop toggle button */
@ -135,6 +138,7 @@ static void get_list_info (char **file, char **dir) {
static regex_t *r; /* Pointer to compiled content_pattern */ static regex_t *r; /* Pointer to compiled content_pattern */
static int case_sensitive = 1; static int case_sensitive = 1;
static gboolean find_regex_flag = TRUE;
/* /*
* Callback for the parameter dialog. * Callback for the parameter dialog.
@ -147,7 +151,8 @@ find_parm_callback (struct Dlg_head *h, dlg_msg_t msg, int parm)
switch (msg) { switch (msg) {
case DLG_VALIDATE: case DLG_VALIDATE:
if ((h->ret_value != B_ENTER) || !in_with->buffer[0]) if ((h->ret_value != B_ENTER) || !in_with->buffer[0]
|| !(find_regex_cbox->state & C_BOOL))
return MSG_HANDLED; return MSG_HANDLED;
flags = REG_EXTENDED | REG_NOSUB; flags = REG_EXTENDED | REG_NOSUB;
@ -245,11 +250,14 @@ find_parameters (char **start_dir, char **pattern, char **content)
DLG_CENTER | DLG_REVERSE); DLG_CENTER | DLG_REVERSE);
add_widget (find_dlg, add_widget (find_dlg,
button_new (11, b2, B_CANCEL, NORMAL_BUTTON, buts[2], 0)); button_new (12, b2, B_CANCEL, NORMAL_BUTTON, buts[2], 0));
add_widget (find_dlg, add_widget (find_dlg,
button_new (11, b1, B_TREE, NORMAL_BUTTON, buts[1], 0)); button_new (12, b1, B_TREE, NORMAL_BUTTON, buts[1], 0));
add_widget (find_dlg, add_widget (find_dlg,
button_new (11, b0, B_ENTER, DEFPUSH_BUTTON, buts[0], 0)); button_new (12, b0, B_ENTER, DEFPUSH_BUTTON, buts[0], 0));
find_regex_cbox = check_new (10, 3, find_regex_flag, _("Regular expression"));
add_widget (find_dlg, find_regex_cbox);
case_sense = check_new (9, 3, case_sensitive, case_label); case_sense = check_new (9, 3, case_sensitive, case_label);
add_widget (find_dlg, case_sense); add_widget (find_dlg, case_sense);
@ -282,6 +290,7 @@ find_parameters (char **start_dir, char **pattern, char **content)
case B_TREE: case B_TREE:
temp_dir = g_strdup (in_start->buffer); temp_dir = g_strdup (in_start->buffer);
case_sensitive = case_sense->state & C_BOOL; case_sensitive = case_sense->state & C_BOOL;
find_regex_flag = find_regex_cbox->state & C_BOOL;
destroy_dlg (find_dlg); destroy_dlg (find_dlg);
g_free (in_start_dir); g_free (in_start_dir);
if (strcmp (temp_dir, ".") == 0) { if (strcmp (temp_dir, ".") == 0) {
@ -308,6 +317,7 @@ find_parameters (char **start_dir, char **pattern, char **content)
} }
case_sensitive = case_sense->state & C_BOOL; case_sensitive = case_sense->state & C_BOOL;
find_regex_flag = find_regex_cbox->state & C_BOOL;
return_value = 1; return_value = 1;
*start_dir = g_strdup (in_start->buffer); *start_dir = g_strdup (in_start->buffer);
*pattern = g_strdup (in_name->buffer); *pattern = g_strdup (in_name->buffer);
@ -517,6 +527,8 @@ search_content (Dlg_head *h, const char *directory, const char *filename)
int has_newline; int has_newline;
char *p; char *p;
int found = 0; int found = 0;
typedef const char * (*search_fn) (const char *, const char *);
search_fn search_func;
if (resuming) { if (resuming) {
/* We've been previously suspended, start from the previous position */ /* We've been previously suspended, start from the previous position */
@ -525,14 +537,24 @@ search_content (Dlg_head *h, const char *directory, const char *filename)
pos = last_pos; pos = last_pos;
} }
search_func = (case_sensitive) ? (search_fn) strstr : cstrcasestr;
while ((p = get_line_at (file_fd, buffer, &pos, &n_read, sizeof (buffer), &has_newline)) && (ret_val == 0)){ while ((p = get_line_at (file_fd, buffer, &pos, &n_read, sizeof (buffer), &has_newline)) && (ret_val == 0)){
if (found == 0){ /* Search in binary line once */ if (found == 0){ /* Search in binary line once */
if (find_regex_flag) {
if (regexec (r, p, 1, 0, 0) == 0){ if (regexec (r, p, 1, 0, 0) == 0){
g_free (p); g_free (p);
p = g_strdup_printf ("%d:%s", line, filename); p = g_strdup_printf ("%d:%s", line, filename);
find_add_match (h, directory, p); find_add_match (h, directory, p);
found = 1; found = 1;
} }
} else {
if (search_func (p, content_pattern) != NULL) {
char *match = g_strdup_printf("%d:%s", line, filename);
find_add_match (h, directory, match);
found = TRUE;
}
}
} }
if (has_newline){ if (has_newline){
line++; line++;
@ -1035,7 +1057,7 @@ do_find (void)
v = find_file (start_dir, pattern, content, &dirname, &filename); v = find_file (start_dir, pattern, content, &dirname, &filename);
g_free (start_dir); g_free (start_dir);
g_free (pattern); g_free (pattern);
if (r) if (find_regex_flag && r)
regfree (r); regfree (r);
if (v == B_ENTER){ if (v == B_ENTER){

View File

@ -1411,3 +1411,24 @@ save_file_position (const char *filename, long line, long column)
g_free (tmp); g_free (tmp);
g_free (fn); g_free (fn);
} }
extern const char *
cstrcasestr (const char *haystack, const char *needle)
{
const unsigned char *uhaystack = (const unsigned char *) haystack;
const unsigned char *uneedle = (const unsigned char *) needle;
const unsigned char *hptr;
size_t i, needle_len;
needle_len = strlen(needle);
for (hptr = uhaystack; *hptr != '\0'; hptr++) {
for (i = 0; i < needle_len; i++) {
if (toupper(hptr[i]) != toupper(uneedle[i]))
goto next_try;
}
return hptr;
next_try:
(void) 0;
}
return NULL;
}

View File

@ -6,6 +6,8 @@
/* String managing functions */ /* String managing functions */
extern const char *cstrcasestr (const char *haystack, const char *needle);
void str_replace(char *s, char from, char to); void str_replace(char *s, char from, char to);
int is_printable (int c); int is_printable (int c);
int msglen (const char *text, int *lines); int msglen (const char *text, int *lines);