mirror of
https://github.com/MidnightCommander/mc
synced 2025-01-05 11:04:42 +03:00
* cmd.c (select_unselect_cmd): Collect repeated code from
(un)?select_cmd here. Fix rare off-by-one and memory leak if empty pattern passed. (select_cmd): Use select_unselect_cmd(). (unselect_cmd): Likewise.
This commit is contained in:
parent
2c8db2c43d
commit
bcaf2b272b
@ -1,3 +1,12 @@
|
|||||||
|
2004-10-25 Andrew V. Samoilov <sav@bcs.zp.ua>
|
||||||
|
|
||||||
|
* cmd.c (select_unselect_cmd): Collect repeated code from
|
||||||
|
(un)?select_cmd here. Fix rare off-by-one and memory leak if
|
||||||
|
empty pattern passed.
|
||||||
|
|
||||||
|
(select_cmd): Use select_unselect_cmd().
|
||||||
|
(unselect_cmd): Likewise.
|
||||||
|
|
||||||
2004-10-23 Roland Illig <roland.illig@gmx.de>
|
2004-10-23 Roland Illig <roland.illig@gmx.de>
|
||||||
|
|
||||||
* complete.c (environ): Don't declare environ on Cygwin.
|
* complete.c (environ): Don't declare environ on Cygwin.
|
||||||
|
77
src/cmd.c
77
src/cmd.c
@ -471,95 +471,66 @@ void reverse_selection_cmd (void)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void select_cmd (void)
|
static void
|
||||||
|
select_unselect_cmd (const char *title, int cmd)
|
||||||
{
|
{
|
||||||
char *reg_exp, *reg_exp_t;
|
char *reg_exp, *reg_exp_t;
|
||||||
int i;
|
int i;
|
||||||
int c;
|
int c;
|
||||||
int dirflag = 0;
|
int dirflag = 0;
|
||||||
|
|
||||||
reg_exp = input_dialog (_(" Select "), "", easy_patterns ? "*" : ".");
|
reg_exp = input_dialog (title, "", easy_patterns ? "*" : ".");
|
||||||
if (!reg_exp)
|
if (!reg_exp)
|
||||||
return;
|
return;
|
||||||
|
if (!*reg_exp) {
|
||||||
|
g_free (reg_exp);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
reg_exp_t = reg_exp;
|
reg_exp_t = reg_exp;
|
||||||
|
|
||||||
/* Check if they specified a directory */
|
/* Check if they specified a directory */
|
||||||
if (*reg_exp_t == PATH_SEP){
|
if (*reg_exp_t == PATH_SEP) {
|
||||||
dirflag = 1;
|
dirflag = 1;
|
||||||
reg_exp_t++;
|
reg_exp_t++;
|
||||||
}
|
}
|
||||||
if (reg_exp_t [strlen(reg_exp_t) - 1] == PATH_SEP){
|
if (reg_exp_t[strlen (reg_exp_t) - 1] == PATH_SEP) {
|
||||||
dirflag = 1;
|
dirflag = 1;
|
||||||
reg_exp_t [strlen(reg_exp_t) - 1] = 0;
|
reg_exp_t[strlen (reg_exp_t) - 1] = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
for (i = 0; i < current_panel->count; i++){
|
for (i = 0; i < current_panel->count; i++) {
|
||||||
if (!strcmp (current_panel->dir.list [i].fname, ".."))
|
if (!strcmp (current_panel->dir.list[i].fname, ".."))
|
||||||
continue;
|
continue;
|
||||||
if (S_ISDIR (current_panel->dir.list [i].st.st_mode)){
|
if (S_ISDIR (current_panel->dir.list[i].st.st_mode)) {
|
||||||
if (!dirflag)
|
if (!dirflag)
|
||||||
continue;
|
continue;
|
||||||
} else {
|
} else {
|
||||||
if (dirflag)
|
if (dirflag)
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
c = regexp_match (reg_exp_t, current_panel->dir.list [i].fname, match_file);
|
c = regexp_match (reg_exp_t, current_panel->dir.list[i].fname,
|
||||||
if (c == -1){
|
match_file);
|
||||||
|
if (c == -1) {
|
||||||
message (1, MSG_ERROR, _(" Malformed regular expression "));
|
message (1, MSG_ERROR, _(" Malformed regular expression "));
|
||||||
g_free (reg_exp);
|
g_free (reg_exp);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (c){
|
if (c) {
|
||||||
do_file_mark (current_panel, i, 1);
|
do_file_mark (current_panel, i, cmd);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
g_free (reg_exp);
|
g_free (reg_exp);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void select_cmd (void)
|
||||||
|
{
|
||||||
|
select_unselect_cmd (_(" Select "), 1);
|
||||||
|
}
|
||||||
|
|
||||||
void unselect_cmd (void)
|
void unselect_cmd (void)
|
||||||
{
|
{
|
||||||
char *reg_exp, *reg_exp_t;
|
select_unselect_cmd (_(" Unselect "), 0);
|
||||||
int i;
|
|
||||||
int c;
|
|
||||||
int dirflag = 0;
|
|
||||||
|
|
||||||
reg_exp = input_dialog (_(" Unselect "),"", easy_patterns ? "*" : ".");
|
|
||||||
if (!reg_exp)
|
|
||||||
return;
|
|
||||||
|
|
||||||
reg_exp_t = reg_exp;
|
|
||||||
|
|
||||||
/* Check if they specified directory matching */
|
|
||||||
if (*reg_exp_t == PATH_SEP){
|
|
||||||
dirflag = 1;
|
|
||||||
reg_exp_t ++;
|
|
||||||
}
|
|
||||||
if (reg_exp_t [strlen(reg_exp_t) - 1] == PATH_SEP){
|
|
||||||
dirflag = 1;
|
|
||||||
reg_exp_t [strlen(reg_exp_t) - 1] = 0;
|
|
||||||
}
|
|
||||||
for (i = 0; i < current_panel->count; i++){
|
|
||||||
if (!strcmp (current_panel->dir.list [i].fname, ".."))
|
|
||||||
continue;
|
|
||||||
if (S_ISDIR (current_panel->dir.list [i].st.st_mode)){
|
|
||||||
if (!dirflag)
|
|
||||||
continue;
|
|
||||||
} else {
|
|
||||||
if (dirflag)
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
c = regexp_match (reg_exp_t, current_panel->dir.list [i].fname, match_file);
|
|
||||||
if (c == -1){
|
|
||||||
message (1, MSG_ERROR, _(" Malformed regular expression "));
|
|
||||||
g_free (reg_exp);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
if (c){
|
|
||||||
do_file_mark (current_panel, i, 0);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
g_free (reg_exp);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Check if the file exists */
|
/* Check if the file exists */
|
||||||
|
Loading…
Reference in New Issue
Block a user