* ext.c (get_file_type_local): Return -1 for fatal errors.
(get_file_type_pipe): Likewise. (regex_command): Likewise. Adjust all callers. From Jindrich Makovicka <makovick@KMLinux.fjfi.cvut.cz>
Этот коммит содержится в:
родитель
3cdf930ea6
Коммит
7aec774638
@ -1,5 +1,10 @@
|
||||
2002-09-29 Pavel Roskin <proski@gnu.org>
|
||||
|
||||
* ext.c (get_file_type_local): Return -1 for fatal errors.
|
||||
(get_file_type_pipe): Likewise.
|
||||
(regex_command): Likewise. Adjust all callers.
|
||||
From Jindrich Makovicka <makovick@KMLinux.fjfi.cvut.cz>
|
||||
|
||||
* dlg.c (frontend_run_dlg): Allow terminating the dialog from
|
||||
the idle handler.
|
||||
From Jindrich Makovicka <makovick@KMLinux.fjfi.cvut.cz>
|
||||
|
38
src/cmd.c
38
src/cmd.c
@ -111,7 +111,9 @@ get_a_panel (WPanel *panel)
|
||||
* always invokes the internal viewer.
|
||||
* internal: If set uses the internal viewer, otherwise an external viewer.
|
||||
*/
|
||||
int view_file_at_line (char *filename, int plain_view, int internal, int start_line)
|
||||
int
|
||||
view_file_at_line (char *filename, int plain_view, int internal,
|
||||
int start_line)
|
||||
{
|
||||
static char *viewer = 0;
|
||||
int move_dir = 0;
|
||||
@ -144,31 +146,34 @@ int view_file_at_line (char *filename, int plain_view, int internal, int start_l
|
||||
repaint_screen ();
|
||||
return move_dir;
|
||||
}
|
||||
if (internal){
|
||||
char view_entry [BUF_TINY];
|
||||
if (internal) {
|
||||
char view_entry[BUF_TINY];
|
||||
|
||||
if (start_line != 0)
|
||||
g_snprintf (view_entry, sizeof (view_entry), "View:%d", start_line);
|
||||
g_snprintf (view_entry, sizeof (view_entry), "View:%d",
|
||||
start_line);
|
||||
else
|
||||
strcpy (view_entry, "View");
|
||||
|
||||
if (!regex_command (filename, view_entry, &move_dir)){
|
||||
if (regex_command (filename, view_entry, &move_dir) == 0) {
|
||||
view (0, filename, &move_dir, start_line);
|
||||
repaint_screen ();
|
||||
}
|
||||
} else {
|
||||
char *localcopy;
|
||||
|
||||
if (!viewer){
|
||||
if (!viewer) {
|
||||
viewer = getenv ("PAGER");
|
||||
if (!viewer)
|
||||
viewer = "view";
|
||||
}
|
||||
/* The file may be a non local file, get a copy */
|
||||
if (!vfs_file_is_local (filename)){
|
||||
if (!vfs_file_is_local (filename)) {
|
||||
localcopy = mc_getlocalcopy (filename);
|
||||
if (localcopy == NULL){
|
||||
message (1, MSG_ERROR, _(" Can not fetch a local copy of %s "), filename);
|
||||
if (localcopy == NULL) {
|
||||
message (1, MSG_ERROR,
|
||||
_(" Can not fetch a local copy of %s "),
|
||||
filename);
|
||||
return 0;
|
||||
}
|
||||
execute_internal (viewer, localcopy);
|
||||
@ -313,23 +318,26 @@ do_edit (const char *what)
|
||||
do_edit_at_line (what, 1);
|
||||
}
|
||||
|
||||
void edit_cmd (WPanel *panel)
|
||||
void
|
||||
edit_cmd (WPanel *panel)
|
||||
{
|
||||
panel = get_a_panel(panel);
|
||||
if (!regex_command (selection (panel)->fname, "Edit", 0))
|
||||
panel = get_a_panel (panel);
|
||||
if (regex_command (selection (panel)->fname, "Edit", 0) == 0)
|
||||
do_edit (selection (panel)->fname);
|
||||
}
|
||||
|
||||
void edit_cmd_new (WPanel *panel)
|
||||
void
|
||||
edit_cmd_new (WPanel *panel)
|
||||
{
|
||||
do_edit ("");
|
||||
}
|
||||
|
||||
/* Invoked by F5. Copy, default to the other panel. */
|
||||
void copy_cmd (void)
|
||||
void
|
||||
copy_cmd (void)
|
||||
{
|
||||
save_cwds_stat ();
|
||||
if (panel_operate (cpanel, OP_COPY, NULL, TRUE)){
|
||||
if (panel_operate (cpanel, OP_COPY, NULL, TRUE)) {
|
||||
update_panels (UP_OPTIMIZE, UP_KEEPSEL);
|
||||
repaint_screen ();
|
||||
}
|
||||
|
122
src/ext.c
122
src/ext.c
@ -53,30 +53,31 @@ static char *data = NULL;
|
||||
void
|
||||
flush_extension_file (void)
|
||||
{
|
||||
if (data){
|
||||
if (data) {
|
||||
g_free (data);
|
||||
data = NULL;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
typedef char *(*quote_func_t)(const char *name, int i);
|
||||
typedef char *(*quote_func_t) (const char *name, int i);
|
||||
|
||||
static void
|
||||
exec_extension (const char *filename, const char *data, int *move_dir, int start_line)
|
||||
exec_extension (const char *filename, const char *data, int *move_dir,
|
||||
int start_line)
|
||||
{
|
||||
char *file_name;
|
||||
int cmd_file_fd;
|
||||
FILE *cmd_file;
|
||||
int expand_prefix_found = 0;
|
||||
int parameter_found = 0;
|
||||
char prompt [80];
|
||||
char prompt[80];
|
||||
int run_view = 0;
|
||||
int def_hex_mode = default_hex_mode, changed_hex_mode = 0;
|
||||
int def_nroff_flag = default_nroff_flag, changed_nroff_flag = 0;
|
||||
int written_nonspace = 0;
|
||||
int is_cd = 0;
|
||||
char buffer [1024];
|
||||
char buffer[1024];
|
||||
char *p = 0;
|
||||
char *localcopy = NULL;
|
||||
int do_local_copy;
|
||||
@ -88,7 +89,7 @@ exec_extension (const char *filename, const char *data, int *move_dir, int start
|
||||
g_return_if_fail (data != NULL);
|
||||
|
||||
/* Avoid making a local copy if we are doing a cd */
|
||||
if (!vfs_file_is_local(filename))
|
||||
if (!vfs_file_is_local (filename))
|
||||
do_local_copy = 1;
|
||||
else
|
||||
do_local_copy = 0;
|
||||
@ -99,24 +100,25 @@ exec_extension (const char *filename, const char *data, int *move_dir, int start
|
||||
* Sometimes it's not needed (e.g. for %cd and %view commands),
|
||||
* but it's easier to create it anyway.
|
||||
*/
|
||||
cmd_file_fd = mc_mkstemps(&file_name, "mcext", SCRIPT_SUFFIX);
|
||||
cmd_file_fd = mc_mkstemps (&file_name, "mcext", SCRIPT_SUFFIX);
|
||||
|
||||
if (cmd_file_fd == -1){
|
||||
message (1, MSG_ERROR, _(" Cannot create temporary command file \n %s "),
|
||||
if (cmd_file_fd == -1) {
|
||||
message (1, MSG_ERROR,
|
||||
_(" Cannot create temporary command file \n %s "),
|
||||
unix_error_string (errno));
|
||||
return;
|
||||
}
|
||||
cmd_file = fdopen (cmd_file_fd, "w");
|
||||
fputs ("#! /bin/sh\n", cmd_file);
|
||||
|
||||
prompt [0] = 0;
|
||||
for (;*data && *data != '\n'; data++){
|
||||
if (parameter_found){
|
||||
if (*data == '}'){
|
||||
prompt[0] = 0;
|
||||
for (; *data && *data != '\n'; data++) {
|
||||
if (parameter_found) {
|
||||
if (*data == '}') {
|
||||
char *parameter;
|
||||
parameter_found = 0;
|
||||
parameter = input_dialog (_(" Parameter "), prompt, "");
|
||||
if (!parameter){
|
||||
if (!parameter) {
|
||||
/* User canceled */
|
||||
fclose (cmd_file);
|
||||
unlink (file_name);
|
||||
@ -132,12 +134,12 @@ exec_extension (const char *filename, const char *data, int *move_dir, int start
|
||||
} else {
|
||||
int len = strlen (prompt);
|
||||
|
||||
if (len < sizeof (prompt) - 1){
|
||||
prompt [len] = *data;
|
||||
prompt [len+1] = 0;
|
||||
if (len < sizeof (prompt) - 1) {
|
||||
prompt[len] = *data;
|
||||
prompt[len + 1] = 0;
|
||||
}
|
||||
}
|
||||
} else if (expand_prefix_found){
|
||||
} else if (expand_prefix_found) {
|
||||
expand_prefix_found = 0;
|
||||
if (*data == '{')
|
||||
parameter_found = 1;
|
||||
@ -145,7 +147,7 @@ exec_extension (const char *filename, const char *data, int *move_dir, int start
|
||||
int i = check_format_view (data);
|
||||
char *v;
|
||||
|
||||
if (i){
|
||||
if (i) {
|
||||
data += i - 1;
|
||||
run_view = 1;
|
||||
} else if ((i = check_format_cd (data)) > 0) {
|
||||
@ -154,19 +156,19 @@ exec_extension (const char *filename, const char *data, int *move_dir, int start
|
||||
do_local_copy = 0;
|
||||
p = buffer;
|
||||
data += i - 1;
|
||||
} else if ((i = check_format_var (data, &v)) > 0 && v){
|
||||
} else if ((i = check_format_var (data, &v)) > 0 && v) {
|
||||
fputs (v, cmd_file);
|
||||
g_free (v);
|
||||
data += i;
|
||||
} else {
|
||||
char *text;
|
||||
|
||||
if (*data == 'f'){
|
||||
if (do_local_copy){
|
||||
if (*data == 'f') {
|
||||
if (do_local_copy) {
|
||||
localcopy = mc_getlocalcopy (filename);
|
||||
if (localcopy == NULL) {
|
||||
fclose(cmd_file);
|
||||
unlink(file_name);
|
||||
fclose (cmd_file);
|
||||
unlink (file_name);
|
||||
g_free (file_name);
|
||||
return;
|
||||
}
|
||||
@ -214,7 +216,7 @@ exec_extension (const char *filename, const char *data, int *move_dir, int start
|
||||
chmod (file_name, S_IRWXU);
|
||||
}
|
||||
|
||||
if (run_view){
|
||||
if (run_view) {
|
||||
altered_hex_mode = 0;
|
||||
altered_nroff_flag = 0;
|
||||
if (def_hex_mode != default_hex_mode)
|
||||
@ -254,8 +256,9 @@ exec_extension (const char *filename, const char *data, int *move_dir, int start
|
||||
handle_console (CONSOLE_SAVE);
|
||||
if (output_lines && keybar_visible) {
|
||||
show_console_contents (output_start_y,
|
||||
LINES-keybar_visible-output_lines-1,
|
||||
LINES-keybar_visible-1);
|
||||
LINES - keybar_visible -
|
||||
output_lines - 1,
|
||||
LINES - keybar_visible - 1);
|
||||
|
||||
}
|
||||
}
|
||||
@ -265,7 +268,8 @@ exec_extension (const char *filename, const char *data, int *move_dir, int start
|
||||
}
|
||||
if (localcopy) {
|
||||
mc_stat (localcopy, &mystat);
|
||||
mc_ungetlocalcopy (filename, localcopy, localmtime != mystat.st_mtime);
|
||||
mc_ungetlocalcopy (filename, localcopy,
|
||||
localmtime != mystat.st_mtime);
|
||||
}
|
||||
}
|
||||
|
||||
@ -277,7 +281,7 @@ exec_extension (const char *filename, const char *data, int *move_dir, int start
|
||||
|
||||
/*
|
||||
* Run the "file" command on the local file.
|
||||
* Return 1 if the data is valid, 0 otherwise.
|
||||
* Return 1 if the data is valid, 0 otherwise, -1 for fatal errors.
|
||||
*/
|
||||
static int
|
||||
get_file_type_local (char *filename, char *buf, int buflen)
|
||||
@ -303,6 +307,8 @@ get_file_type_local (char *filename, char *buf, int buflen)
|
||||
*/
|
||||
waitpid (-1, NULL, WNOHANG);
|
||||
#endif /* SCO_FLAVOR */
|
||||
} else {
|
||||
return -1;
|
||||
}
|
||||
|
||||
return (read_bytes > 0);
|
||||
@ -312,7 +318,7 @@ get_file_type_local (char *filename, char *buf, int buflen)
|
||||
#ifdef FILE_STDIN
|
||||
/*
|
||||
* Read file through VFS and feed is to the "file" command.
|
||||
* Return 1 if the data is valid, 0 otherwise.
|
||||
* Return 1 if the data is valid, 0 otherwise, -1 for fatal errors.
|
||||
*/
|
||||
static int
|
||||
get_file_type_pipe (char *filename, char *buf, int buflen)
|
||||
@ -328,17 +334,21 @@ get_file_type_pipe (char *filename, char *buf, int buflen)
|
||||
* sources. Tell me if any other file uses larger
|
||||
* chunk from beginning
|
||||
*/
|
||||
pipehandle = mc_doublepopen
|
||||
(remotehandle, 8192, &p, "file", "file", "-", NULL);
|
||||
pipehandle =
|
||||
mc_doublepopen (remotehandle, 8192, &p, "file", "file", "-",
|
||||
NULL);
|
||||
if (pipehandle != -1) {
|
||||
int i;
|
||||
while ((i = read (pipehandle, buf
|
||||
+ read_bytes, buflen - 1 - read_bytes)) > 0)
|
||||
while ((i =
|
||||
read (pipehandle, buf + read_bytes,
|
||||
buflen - 1 - read_bytes)) > 0)
|
||||
read_bytes += i;
|
||||
mc_doublepclose (pipehandle, p);
|
||||
buf[read_bytes] = 0;
|
||||
}
|
||||
mc_close (remotehandle);
|
||||
} else {
|
||||
return -1;
|
||||
}
|
||||
|
||||
return (read_bytes > 0);
|
||||
@ -374,12 +384,14 @@ regex_check_type (char *filename, int file_len, char *ptr, int *have_type)
|
||||
*have_type = 1;
|
||||
|
||||
if (islocal) {
|
||||
got_data = get_file_type_local (filename, content_string,
|
||||
got_data =
|
||||
get_file_type_local (filename, content_string,
|
||||
sizeof (content_string));
|
||||
} else
|
||||
#ifdef FILE_STDIN
|
||||
{
|
||||
got_data = get_file_type_pipe (filename, content_string,
|
||||
got_data =
|
||||
get_file_type_pipe (filename, content_string,
|
||||
sizeof (content_string));
|
||||
}
|
||||
#else
|
||||
@ -387,7 +399,7 @@ regex_check_type (char *filename, int file_len, char *ptr, int *have_type)
|
||||
return 0;
|
||||
#endif /* !FILE_STDIN */
|
||||
|
||||
if (got_data) {
|
||||
if (got_data > 0) {
|
||||
char *pp;
|
||||
|
||||
/* Paranoid termination */
|
||||
@ -417,8 +429,13 @@ regex_check_type (char *filename, int file_len, char *ptr, int *have_type)
|
||||
}
|
||||
}
|
||||
|
||||
if (content_string && content_string[0] &&
|
||||
regexp_match (ptr, content_string + content_shift, match_normal)) {
|
||||
if (got_data == -1) {
|
||||
return -1;
|
||||
}
|
||||
|
||||
if (content_string && content_string[0]
|
||||
&& regexp_match (ptr, content_string + content_shift,
|
||||
match_normal)) {
|
||||
found = 1;
|
||||
}
|
||||
|
||||
@ -430,7 +447,9 @@ regex_check_type (char *filename, int file_len, char *ptr, int *have_type)
|
||||
*
|
||||
* This function returns:
|
||||
*
|
||||
* 1 if it ran some command or 0 otherwise.
|
||||
* -1 for a failure or user interrupt
|
||||
* 0 if no command was run
|
||||
* 1 if some command was run
|
||||
*
|
||||
* If action == "View" then a parameter is checked in the form of "View:%d",
|
||||
* if the value for %d exists, then the viewer is started up at that line number.
|
||||
@ -441,6 +460,7 @@ regex_command (char *filename, char *action, int *move_dir)
|
||||
char *p, *q, *r, c;
|
||||
int file_len = strlen (filename);
|
||||
int found = 0;
|
||||
int error_flag = 0;
|
||||
int ret = 0;
|
||||
int old_patterns;
|
||||
struct stat mystat;
|
||||
@ -475,8 +495,8 @@ regex_command (char *filename, char *action, int *move_dir)
|
||||
return 0;
|
||||
|
||||
if (!strstr (data, "default/")) {
|
||||
if (!strstr (data, "regex/") && !strstr (data, "shell/") &&
|
||||
!strstr (data, "type/")) {
|
||||
if (!strstr (data, "regex/") && !strstr (data, "shell/")
|
||||
&& !strstr (data, "type/")) {
|
||||
g_free (data);
|
||||
data = NULL;
|
||||
if (mc_user_ext) {
|
||||
@ -549,9 +569,9 @@ regex_command (char *filename, char *action, int *move_dir)
|
||||
c = *q;
|
||||
*q = 0;
|
||||
if (include_target) {
|
||||
if ((strncmp (p, "include/", 8) == 0) &&
|
||||
(strncmp (p + 8, include_target, include_target_len) ==
|
||||
0))
|
||||
if ((strncmp (p, "include/", 8) == 0)
|
||||
&& (strncmp (p + 8, include_target, include_target_len)
|
||||
== 0))
|
||||
found = 1;
|
||||
} else if (!strncmp (p, "regex/", 6)) {
|
||||
p += 6;
|
||||
@ -574,9 +594,13 @@ regex_command (char *filename, char *action, int *move_dir)
|
||||
found = 1;
|
||||
}
|
||||
} else if (!strncmp (p, "type/", 5)) {
|
||||
int res;
|
||||
p += 5;
|
||||
found =
|
||||
regex_check_type (filename, file_len, p, &have_type);
|
||||
res = regex_check_type (filename, file_len, p, &have_type);
|
||||
if (res == 1)
|
||||
found = 1;
|
||||
if (res == -1)
|
||||
error_flag = 1; /* leave it if file cannot be opened */
|
||||
} else if (!strncmp (p, "default/", 8)) {
|
||||
found = 1;
|
||||
}
|
||||
@ -589,7 +613,7 @@ regex_command (char *filename, char *action, int *move_dir)
|
||||
q = strchr (p, '\n');
|
||||
if (q == NULL)
|
||||
q = strchr (p, 0);
|
||||
if (found) {
|
||||
if (found && !error_flag) {
|
||||
r = strchr (p, '=');
|
||||
if (r != NULL) {
|
||||
c = *r;
|
||||
@ -645,5 +669,7 @@ regex_command (char *filename, char *action, int *move_dir)
|
||||
}
|
||||
}
|
||||
easy_patterns = old_patterns;
|
||||
if (error_flag)
|
||||
return -1;
|
||||
return ret;
|
||||
}
|
||||
|
13
src/screen.c
13
src/screen.c
@ -1910,7 +1910,7 @@ do_enter_on_file_entry (file_entry *fe)
|
||||
}
|
||||
|
||||
/* Try associated command */
|
||||
if (regex_command (fe->fname, "Open", 0))
|
||||
if (regex_command (fe->fname, "Open", 0) != 0)
|
||||
return 1;
|
||||
|
||||
/* Check if the file is executable */
|
||||
@ -1928,9 +1928,12 @@ do_enter_on_file_entry (file_entry *fe)
|
||||
char *tmp = name_quote (fe->fname, 0);
|
||||
char *cmd = g_strconcat (".", PATH_SEP_STR, tmp, NULL);
|
||||
g_free (tmp);
|
||||
if (!confirm_execute || (query_dialog (_(" The Midnight Commander "),
|
||||
_(" Do you really want to execute? "),
|
||||
0, 2, _("&Yes"), _("&No")) == 0))
|
||||
if (!confirm_execute
|
||||
||
|
||||
(query_dialog
|
||||
(_(" The Midnight Commander "),
|
||||
_(" Do you really want to execute? "), 0, 2, _("&Yes"),
|
||||
_("&No")) == 0))
|
||||
execute (cmd);
|
||||
g_free (cmd);
|
||||
}
|
||||
@ -1938,7 +1941,7 @@ do_enter_on_file_entry (file_entry *fe)
|
||||
else {
|
||||
char *tmp;
|
||||
|
||||
tmp = concat_dir_and_file (vfs_get_current_dir(), fe->fname);
|
||||
tmp = concat_dir_and_file (vfs_get_current_dir (), fe->fname);
|
||||
if (!mc_setctl (tmp, MCCTL_EXTFS_RUN, NULL))
|
||||
/* Execution on this filesysten is not implemented */
|
||||
message (1, _(" Warning "), _(" No action taken "));
|
||||
|
Загрузка…
x
Ссылка в новой задаче
Block a user