mirror of
https://github.com/MidnightCommander/mc
synced 2025-01-18 17:29:28 +03:00
Renamed global variable use_subshell into mc_args__use_subshell.
Signed-off-by: Slava Zanko <slavazanko@gmail.com>
This commit is contained in:
parent
f4b5ebabaf
commit
0046dbc336
15
src/args.c
15
src/args.c
@ -37,7 +37,6 @@
|
|||||||
/*** external variables **************************************************************************/
|
/*** external variables **************************************************************************/
|
||||||
|
|
||||||
extern int reset_hp_softkeys;
|
extern int reset_hp_softkeys;
|
||||||
extern int use_subshell;
|
|
||||||
|
|
||||||
extern char *mc_home;
|
extern char *mc_home;
|
||||||
extern char *mc_home_alt;
|
extern char *mc_home_alt;
|
||||||
@ -49,6 +48,14 @@ extern const char *edit_one_file;
|
|||||||
extern const char *view_one_file;
|
extern const char *view_one_file;
|
||||||
/*** global variables ****************************************************************************/
|
/*** global variables ****************************************************************************/
|
||||||
|
|
||||||
|
/* If using a subshell for evaluating commands this is true */
|
||||||
|
gboolean mc_args__use_subshell =
|
||||||
|
#ifdef SUBSHELL_OPTIONAL
|
||||||
|
FALSE;
|
||||||
|
#else
|
||||||
|
TRUE;
|
||||||
|
#endif
|
||||||
|
|
||||||
/* If true, show version info and exit */
|
/* If true, show version info and exit */
|
||||||
gboolean mc_args__version = FALSE;
|
gboolean mc_args__version = FALSE;
|
||||||
|
|
||||||
@ -124,7 +131,7 @@ static const GOptionEntry argument_main_table[] = {
|
|||||||
#ifdef HAVE_SUBSHELL_SUPPORT
|
#ifdef HAVE_SUBSHELL_SUPPORT
|
||||||
{
|
{
|
||||||
"subshell", 'U', G_OPTION_FLAG_IN_MAIN, G_OPTION_ARG_NONE,
|
"subshell", 'U', G_OPTION_FLAG_IN_MAIN, G_OPTION_ARG_NONE,
|
||||||
&use_subshell,
|
&mc_args__use_subshell,
|
||||||
N_("Enables subshell support (default)"),
|
N_("Enables subshell support (default)"),
|
||||||
NULL
|
NULL
|
||||||
},
|
},
|
||||||
@ -382,10 +389,10 @@ mc_args_process(void)
|
|||||||
|
|
||||||
#ifdef HAVE_SUBSHELL_SUPPORT
|
#ifdef HAVE_SUBSHELL_SUPPORT
|
||||||
if (mc_args__nouse_subshell)
|
if (mc_args__nouse_subshell)
|
||||||
use_subshell = 0;
|
mc_args__use_subshell = 0;
|
||||||
|
|
||||||
if (mc_args__nouse_subshell)
|
if (mc_args__nouse_subshell)
|
||||||
use_subshell = 0;
|
mc_args__use_subshell = 0;
|
||||||
#endif /* HAVE_SUBSHELL_SUPPORT */
|
#endif /* HAVE_SUBSHELL_SUPPORT */
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
|
@ -9,6 +9,12 @@
|
|||||||
|
|
||||||
/*** global variables defined in .c file *********************************************************/
|
/*** global variables defined in .c file *********************************************************/
|
||||||
|
|
||||||
|
#ifdef HAVE_SUBSHELL_SUPPORT
|
||||||
|
extern gboolean mc_args__use_subshell;
|
||||||
|
#else
|
||||||
|
#define mc_args__use_subshell FALSE
|
||||||
|
#endif /* not HAVE_SUBSHELL_SUPPORT */
|
||||||
|
|
||||||
extern gboolean mc_args__force_xterm;
|
extern gboolean mc_args__force_xterm;
|
||||||
extern gboolean mc_args__nomouse;
|
extern gboolean mc_args__nomouse;
|
||||||
extern gboolean mc_args__slow_terminal;
|
extern gboolean mc_args__slow_terminal;
|
||||||
|
@ -62,7 +62,7 @@
|
|||||||
#include "find.h" /* do_find() */
|
#include "find.h" /* do_find() */
|
||||||
#include "hotlist.h" /* hotlist_cmd() */
|
#include "hotlist.h" /* hotlist_cmd() */
|
||||||
#include "tree.h" /* tree_chdir() */
|
#include "tree.h" /* tree_chdir() */
|
||||||
#include "subshell.h" /* use_subshell */
|
#include "args.h" /* mc_args__use_subshell */
|
||||||
#include "cons.saver.h" /* console_flag */
|
#include "cons.saver.h" /* console_flag */
|
||||||
#include "dialog.h" /* Widget */
|
#include "dialog.h" /* Widget */
|
||||||
#include "wtools.h" /* message() */
|
#include "wtools.h" /* message() */
|
||||||
@ -903,7 +903,7 @@ view_other_cmd (void)
|
|||||||
{
|
{
|
||||||
static int message_flag = TRUE;
|
static int message_flag = TRUE;
|
||||||
|
|
||||||
if (!xterm_flag && !console_flag && !use_subshell && !output_starts_shell) {
|
if (!xterm_flag && !console_flag && !mc_args__use_subshell && !output_starts_shell) {
|
||||||
if (message_flag)
|
if (message_flag)
|
||||||
message (D_ERROR, MSG_ERROR,
|
message (D_ERROR, MSG_ERROR,
|
||||||
_(" Not an xterm or Linux console; \n"
|
_(" Not an xterm or Linux console; \n"
|
||||||
|
@ -33,6 +33,7 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
#include "global.h" /* home_dir */
|
#include "global.h" /* home_dir */
|
||||||
|
#include "args.h" /* mc_args__use_subshell */
|
||||||
#include "../src/tty/tty.h"
|
#include "../src/tty/tty.h"
|
||||||
#include "widget.h" /* WInput */
|
#include "widget.h" /* WInput */
|
||||||
#include "command.h"
|
#include "command.h"
|
||||||
@ -233,7 +234,7 @@ enter (WInput *cmdline)
|
|||||||
#ifdef HAVE_SUBSHELL_SUPPORT
|
#ifdef HAVE_SUBSHELL_SUPPORT
|
||||||
/* Check this early before we clean command line
|
/* Check this early before we clean command line
|
||||||
* (will be checked again by shell_execute) */
|
* (will be checked again by shell_execute) */
|
||||||
if (use_subshell && subshell_state != INACTIVE) {
|
if (mc_args__use_subshell && subshell_state != INACTIVE) {
|
||||||
message (D_ERROR, MSG_ERROR,
|
message (D_ERROR, MSG_ERROR,
|
||||||
_(" The shell is already running a command "));
|
_(" The shell is already running a command "));
|
||||||
return MSG_NOT_HANDLED;
|
return MSG_NOT_HANDLED;
|
||||||
@ -265,7 +266,7 @@ enter (WInput *cmdline)
|
|||||||
quiet_quit_cmd ();
|
quiet_quit_cmd ();
|
||||||
return MSG_HANDLED;
|
return MSG_HANDLED;
|
||||||
}
|
}
|
||||||
if (use_subshell)
|
if (mc_args__use_subshell)
|
||||||
load_prompt (0, 0);
|
load_prompt (0, 0);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
@ -34,6 +34,7 @@
|
|||||||
#include "main.h"
|
#include "main.h"
|
||||||
#include "cons.saver.h"
|
#include "cons.saver.h"
|
||||||
#include "subshell.h"
|
#include "subshell.h"
|
||||||
|
#include "args.h"
|
||||||
#include "layout.h"
|
#include "layout.h"
|
||||||
#include "dialog.h"
|
#include "dialog.h"
|
||||||
#include "wtools.h"
|
#include "wtools.h"
|
||||||
@ -130,12 +131,12 @@ do_execute (const char *shell, const char *command, int flags)
|
|||||||
if (console_flag)
|
if (console_flag)
|
||||||
handle_console (CONSOLE_RESTORE);
|
handle_console (CONSOLE_RESTORE);
|
||||||
|
|
||||||
if (!use_subshell && command && !(flags & EXECUTE_INTERNAL)) {
|
if (!mc_args__use_subshell && command && !(flags & EXECUTE_INTERNAL)) {
|
||||||
printf ("%s%s\n", prompt, command);
|
printf ("%s%s\n", prompt, command);
|
||||||
fflush (stdout);
|
fflush (stdout);
|
||||||
}
|
}
|
||||||
#ifdef HAVE_SUBSHELL_SUPPORT
|
#ifdef HAVE_SUBSHELL_SUPPORT
|
||||||
if (use_subshell && !(flags & EXECUTE_INTERNAL)) {
|
if (mc_args__use_subshell && !(flags & EXECUTE_INTERNAL)) {
|
||||||
do_update_prompt ();
|
do_update_prompt ();
|
||||||
|
|
||||||
/* We don't care if it died, higher level takes care of this */
|
/* We don't care if it died, higher level takes care of this */
|
||||||
@ -208,7 +209,7 @@ shell_execute (const char *command, int flags)
|
|||||||
}
|
}
|
||||||
|
|
||||||
#ifdef HAVE_SUBSHELL_SUPPORT
|
#ifdef HAVE_SUBSHELL_SUPPORT
|
||||||
if (use_subshell)
|
if (mc_args__use_subshell)
|
||||||
if (subshell_state == INACTIVE)
|
if (subshell_state == INACTIVE)
|
||||||
do_execute (shell, cmd ? cmd : command, flags | EXECUTE_AS_SHELL);
|
do_execute (shell, cmd ? cmd : command, flags | EXECUTE_AS_SHELL);
|
||||||
else
|
else
|
||||||
@ -258,7 +259,7 @@ toggle_panels (void)
|
|||||||
handle_console (CONSOLE_RESTORE);
|
handle_console (CONSOLE_RESTORE);
|
||||||
|
|
||||||
#ifdef HAVE_SUBSHELL_SUPPORT
|
#ifdef HAVE_SUBSHELL_SUPPORT
|
||||||
if (use_subshell) {
|
if (mc_args__use_subshell) {
|
||||||
new_dir_p = vfs_current_is_local ()? &new_dir : NULL;
|
new_dir_p = vfs_current_is_local ()? &new_dir : NULL;
|
||||||
if (invoke_subshell (NULL, VISIBLY, new_dir_p))
|
if (invoke_subshell (NULL, VISIBLY, new_dir_p))
|
||||||
quiet_quit_cmd (); /* User did `exit' or `logout': quit MC quietly */
|
quiet_quit_cmd (); /* User did `exit' or `logout': quit MC quietly */
|
||||||
@ -293,7 +294,7 @@ toggle_panels (void)
|
|||||||
application_keypad_mode ();
|
application_keypad_mode ();
|
||||||
|
|
||||||
#ifdef HAVE_SUBSHELL_SUPPORT
|
#ifdef HAVE_SUBSHELL_SUPPORT
|
||||||
if (use_subshell) {
|
if (mc_args__use_subshell) {
|
||||||
load_prompt (0, 0);
|
load_prompt (0, 0);
|
||||||
if (new_dir)
|
if (new_dir)
|
||||||
do_possible_cd (new_dir);
|
do_possible_cd (new_dir);
|
||||||
@ -315,7 +316,7 @@ do_suspend_cmd (void)
|
|||||||
{
|
{
|
||||||
pre_exec ();
|
pre_exec ();
|
||||||
|
|
||||||
if (console_flag && !use_subshell)
|
if (console_flag && !mc_args__use_subshell)
|
||||||
handle_console (CONSOLE_RESTORE);
|
handle_console (CONSOLE_RESTORE);
|
||||||
|
|
||||||
#ifdef SIGTSTP
|
#ifdef SIGTSTP
|
||||||
@ -334,7 +335,7 @@ do_suspend_cmd (void)
|
|||||||
}
|
}
|
||||||
#endif /* SIGTSTP */
|
#endif /* SIGTSTP */
|
||||||
|
|
||||||
if (console_flag && !use_subshell)
|
if (console_flag && !mc_args__use_subshell)
|
||||||
handle_console (CONSOLE_SAVE);
|
handle_console (CONSOLE_SAVE);
|
||||||
|
|
||||||
edition_post_exec ();
|
edition_post_exec ();
|
||||||
|
@ -61,7 +61,7 @@
|
|||||||
#include "command.h"
|
#include "command.h"
|
||||||
#include "main-widgets.h"
|
#include "main-widgets.h"
|
||||||
#include "main.h"
|
#include "main.h"
|
||||||
#include "subshell.h" /* For use_subshell and resize_subshell() */
|
#include "subshell.h" /* For resize_subshell() */
|
||||||
#include "tree.h"
|
#include "tree.h"
|
||||||
#include "menu.h"
|
#include "menu.h"
|
||||||
#include "strutil.h"
|
#include "strutil.h"
|
||||||
|
20
src/main.c
20
src/main.c
@ -456,7 +456,7 @@ quit_cmd_internal (int quiet)
|
|||||||
}
|
}
|
||||||
if (q) {
|
if (q) {
|
||||||
#ifdef HAVE_SUBSHELL_SUPPORT
|
#ifdef HAVE_SUBSHELL_SUPPORT
|
||||||
if (!use_subshell)
|
if (!mc_args__use_subshell)
|
||||||
stop_dialogs ();
|
stop_dialogs ();
|
||||||
else if ((q = exit_subshell ()))
|
else if ((q = exit_subshell ()))
|
||||||
#endif
|
#endif
|
||||||
@ -485,7 +485,7 @@ void
|
|||||||
subshell_chdir (const char *directory)
|
subshell_chdir (const char *directory)
|
||||||
{
|
{
|
||||||
#ifdef HAVE_SUBSHELL_SUPPORT
|
#ifdef HAVE_SUBSHELL_SUPPORT
|
||||||
if (use_subshell) {
|
if (mc_args__use_subshell) {
|
||||||
if (vfs_current_is_local ())
|
if (vfs_current_is_local ())
|
||||||
do_subshell_chdir (directory, 0, 1);
|
do_subshell_chdir (directory, 0, 1);
|
||||||
}
|
}
|
||||||
@ -1382,7 +1382,7 @@ setup_mc (void)
|
|||||||
setup_panels ();
|
setup_panels ();
|
||||||
|
|
||||||
#ifdef HAVE_SUBSHELL_SUPPORT
|
#ifdef HAVE_SUBSHELL_SUPPORT
|
||||||
if (use_subshell)
|
if (mc_args__use_subshell)
|
||||||
add_select_channel (subshell_pty, load_prompt, 0);
|
add_select_channel (subshell_pty, load_prompt, 0);
|
||||||
#endif /* !HAVE_SUBSHELL_SUPPORT */
|
#endif /* !HAVE_SUBSHELL_SUPPORT */
|
||||||
|
|
||||||
@ -1906,7 +1906,7 @@ sigchld_handler_no_subshell (int sig)
|
|||||||
|
|
||||||
/* COMMENT: if it were true that after the call to handle_console(..INIT)
|
/* COMMENT: if it were true that after the call to handle_console(..INIT)
|
||||||
the value of console_flag never changed, we could simply not install
|
the value of console_flag never changed, we could simply not install
|
||||||
this handler at all if (!console_flag && !use_subshell). */
|
this handler at all if (!console_flag && !mc_args__use_subshell). */
|
||||||
|
|
||||||
/* That comment is no longer true. We need to wait() on a sigchld
|
/* That comment is no longer true. We need to wait() on a sigchld
|
||||||
handler (that's at least what the tarfs code expects currently). */
|
handler (that's at least what the tarfs code expects currently). */
|
||||||
@ -1937,7 +1937,7 @@ init_sigchld (void)
|
|||||||
|
|
||||||
sigchld_action.sa_handler =
|
sigchld_action.sa_handler =
|
||||||
#ifdef HAVE_SUBSHELL_SUPPORT
|
#ifdef HAVE_SUBSHELL_SUPPORT
|
||||||
use_subshell ? sigchld_handler :
|
mc_args__use_subshell ? sigchld_handler :
|
||||||
#endif /* HAVE_SUBSHELL_SUPPORT */
|
#endif /* HAVE_SUBSHELL_SUPPORT */
|
||||||
sigchld_handler_no_subshell;
|
sigchld_handler_no_subshell;
|
||||||
|
|
||||||
@ -1955,7 +1955,7 @@ init_sigchld (void)
|
|||||||
* This may happen on QNX Neutrino 6, where SA_RESTART
|
* This may happen on QNX Neutrino 6, where SA_RESTART
|
||||||
* is defined but not implemented. Fallback to no subshell.
|
* is defined but not implemented. Fallback to no subshell.
|
||||||
*/
|
*/
|
||||||
use_subshell = 0;
|
mc_args__use_subshell = 0;
|
||||||
#endif /* HAVE_SUBSHELL_SUPPORT */
|
#endif /* HAVE_SUBSHELL_SUPPORT */
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -2099,9 +2099,9 @@ main (int argc, char *argv[])
|
|||||||
#ifdef HAVE_SUBSHELL_SUPPORT
|
#ifdef HAVE_SUBSHELL_SUPPORT
|
||||||
/* Don't use subshell when invoked as viewer or editor */
|
/* Don't use subshell when invoked as viewer or editor */
|
||||||
if (edit_one_file || view_one_file)
|
if (edit_one_file || view_one_file)
|
||||||
use_subshell = 0;
|
mc_args__use_subshell = 0;
|
||||||
|
|
||||||
if (use_subshell)
|
if (mc_args__use_subshell)
|
||||||
subshell_get_console_attributes ();
|
subshell_get_console_attributes ();
|
||||||
#endif /* HAVE_SUBSHELL_SUPPORT */
|
#endif /* HAVE_SUBSHELL_SUPPORT */
|
||||||
|
|
||||||
@ -2144,7 +2144,7 @@ main (int argc, char *argv[])
|
|||||||
#ifdef HAVE_SUBSHELL_SUPPORT
|
#ifdef HAVE_SUBSHELL_SUPPORT
|
||||||
/* Done here to ensure that the subshell doesn't */
|
/* Done here to ensure that the subshell doesn't */
|
||||||
/* inherit the file descriptors opened below, etc */
|
/* inherit the file descriptors opened below, etc */
|
||||||
if (use_subshell)
|
if (mc_args__use_subshell)
|
||||||
init_subshell ();
|
init_subshell ();
|
||||||
|
|
||||||
#endif /* HAVE_SUBSHELL_SUPPORT */
|
#endif /* HAVE_SUBSHELL_SUPPORT */
|
||||||
@ -2162,7 +2162,7 @@ main (int argc, char *argv[])
|
|||||||
application_keypad_mode ();
|
application_keypad_mode ();
|
||||||
|
|
||||||
#ifdef HAVE_SUBSHELL_SUPPORT
|
#ifdef HAVE_SUBSHELL_SUPPORT
|
||||||
if (use_subshell) {
|
if (mc_args__use_subshell) {
|
||||||
prompt = strip_ctrl_codes (subshell_prompt);
|
prompt = strip_ctrl_codes (subshell_prompt);
|
||||||
if (!prompt)
|
if (!prompt)
|
||||||
prompt = "";
|
prompt = "";
|
||||||
|
@ -50,6 +50,7 @@
|
|||||||
#endif /* HAVE_STROPTS_H */
|
#endif /* HAVE_STROPTS_H */
|
||||||
|
|
||||||
#include "global.h"
|
#include "global.h"
|
||||||
|
#include "args.h"
|
||||||
#include "../src/tty/tty.h" /* LINES */
|
#include "../src/tty/tty.h" /* LINES */
|
||||||
#include "panel.h" /* current_panel */
|
#include "panel.h" /* current_panel */
|
||||||
#include "wtools.h" /* query_dialog() */
|
#include "wtools.h" /* query_dialog() */
|
||||||
@ -90,14 +91,6 @@ static int resize_tty (int fd);
|
|||||||
# define STDERR_FILENO 2
|
# define STDERR_FILENO 2
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* If using a subshell for evaluating commands this is true */
|
|
||||||
int use_subshell =
|
|
||||||
#ifdef SUBSHELL_OPTIONAL
|
|
||||||
FALSE;
|
|
||||||
#else
|
|
||||||
TRUE;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* File descriptors of the pseudoterminal used by the subshell */
|
/* File descriptors of the pseudoterminal used by the subshell */
|
||||||
int subshell_pty = 0;
|
int subshell_pty = 0;
|
||||||
static int subshell_pty_slave = -1;
|
static int subshell_pty_slave = -1;
|
||||||
@ -369,7 +362,7 @@ check_sid (void)
|
|||||||
*
|
*
|
||||||
* Possibly modifies the global variables:
|
* Possibly modifies the global variables:
|
||||||
* subshell_type, subshell_alive, subshell_stopped, subshell_pid
|
* subshell_type, subshell_alive, subshell_stopped, subshell_pid
|
||||||
* use_subshell - Is set to FALSE if we can't run the subshell
|
* mc_args__use_subshell - Is set to FALSE if we can't run the subshell
|
||||||
* quit - Can be set to SUBSHELL_EXIT by the SIGCHLD handler
|
* quit - Can be set to SUBSHELL_EXIT by the SIGCHLD handler
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@ -383,10 +376,10 @@ init_subshell (void)
|
|||||||
#ifdef HAVE_GETSID
|
#ifdef HAVE_GETSID
|
||||||
switch (check_sid ()) {
|
switch (check_sid ()) {
|
||||||
case 1:
|
case 1:
|
||||||
use_subshell = FALSE;
|
mc_args__use_subshell = FALSE;
|
||||||
return;
|
return;
|
||||||
case 2:
|
case 2:
|
||||||
use_subshell = FALSE;
|
mc_args__use_subshell = FALSE;
|
||||||
midnight_shutdown = 1;
|
midnight_shutdown = 1;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -410,7 +403,7 @@ init_subshell (void)
|
|||||||
else if (strstr (shell, "/fish"))
|
else if (strstr (shell, "/fish"))
|
||||||
subshell_type = FISH;
|
subshell_type = FISH;
|
||||||
else {
|
else {
|
||||||
use_subshell = FALSE;
|
mc_args__use_subshell = FALSE;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -422,14 +415,14 @@ init_subshell (void)
|
|||||||
if (subshell_pty == -1) {
|
if (subshell_pty == -1) {
|
||||||
fprintf (stderr, "Cannot open master side of pty: %s\r\n",
|
fprintf (stderr, "Cannot open master side of pty: %s\r\n",
|
||||||
unix_error_string (errno));
|
unix_error_string (errno));
|
||||||
use_subshell = FALSE;
|
mc_args__use_subshell = FALSE;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
subshell_pty_slave = pty_open_slave (pty_name);
|
subshell_pty_slave = pty_open_slave (pty_name);
|
||||||
if (subshell_pty_slave == -1) {
|
if (subshell_pty_slave == -1) {
|
||||||
fprintf (stderr, "Cannot open slave side of pty %s: %s\r\n",
|
fprintf (stderr, "Cannot open slave side of pty %s: %s\r\n",
|
||||||
pty_name, unix_error_string (errno));
|
pty_name, unix_error_string (errno));
|
||||||
use_subshell = FALSE;
|
mc_args__use_subshell = FALSE;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -446,7 +439,7 @@ init_subshell (void)
|
|||||||
if (mkfifo (tcsh_fifo, 0600) == -1) {
|
if (mkfifo (tcsh_fifo, 0600) == -1) {
|
||||||
fprintf (stderr, "mkfifo(%s) failed: %s\r\n", tcsh_fifo,
|
fprintf (stderr, "mkfifo(%s) failed: %s\r\n", tcsh_fifo,
|
||||||
unix_error_string (errno));
|
unix_error_string (errno));
|
||||||
use_subshell = FALSE;
|
mc_args__use_subshell = FALSE;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -457,12 +450,12 @@ init_subshell (void)
|
|||||||
open (tcsh_fifo, O_RDWR)) == -1) {
|
open (tcsh_fifo, O_RDWR)) == -1) {
|
||||||
fprintf (stderr, _("Cannot open named pipe %s\n"), tcsh_fifo);
|
fprintf (stderr, _("Cannot open named pipe %s\n"), tcsh_fifo);
|
||||||
perror (__FILE__": open");
|
perror (__FILE__": open");
|
||||||
use_subshell = FALSE;
|
mc_args__use_subshell = FALSE;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
} else /* subshell_type is BASH or ZSH */ if (pipe (subshell_pipe)) {
|
} else /* subshell_type is BASH or ZSH */ if (pipe (subshell_pipe)) {
|
||||||
perror (__FILE__": couldn't create pipe");
|
perror (__FILE__": couldn't create pipe");
|
||||||
use_subshell = FALSE;
|
mc_args__use_subshell = FALSE;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -520,11 +513,11 @@ init_subshell (void)
|
|||||||
subshell_state = RUNNING_COMMAND;
|
subshell_state = RUNNING_COMMAND;
|
||||||
tty_enable_interrupt_key ();
|
tty_enable_interrupt_key ();
|
||||||
if (!feed_subshell (QUIETLY, TRUE)) {
|
if (!feed_subshell (QUIETLY, TRUE)) {
|
||||||
use_subshell = FALSE;
|
mc_args__use_subshell = FALSE;
|
||||||
}
|
}
|
||||||
tty_disable_interrupt_key ();
|
tty_disable_interrupt_key ();
|
||||||
if (!subshell_alive)
|
if (!subshell_alive)
|
||||||
use_subshell = FALSE; /* Subshell died instantly, so don't use it */
|
mc_args__use_subshell = FALSE; /* Subshell died instantly, so don't use it */
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -594,7 +587,7 @@ int invoke_subshell (const char *command, int how, char **new_dir)
|
|||||||
g_free (pcwd);
|
g_free (pcwd);
|
||||||
|
|
||||||
/* Restart the subshell if it has died by SIGHUP, SIGQUIT, etc. */
|
/* Restart the subshell if it has died by SIGHUP, SIGQUIT, etc. */
|
||||||
while (!subshell_alive && !quit && use_subshell)
|
while (!subshell_alive && !quit && mc_args__use_subshell)
|
||||||
init_subshell ();
|
init_subshell ();
|
||||||
|
|
||||||
prompt_pos = 0;
|
prompt_pos = 0;
|
||||||
@ -677,7 +670,7 @@ static int resize_tty (int fd)
|
|||||||
/* Resize subshell_pty */
|
/* Resize subshell_pty */
|
||||||
void resize_subshell (void)
|
void resize_subshell (void)
|
||||||
{
|
{
|
||||||
if (use_subshell == 0)
|
if (! mc_args__use_subshell)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
resize_tty (subshell_pty);
|
resize_tty (subshell_pty);
|
||||||
@ -879,7 +872,7 @@ subshell_get_console_attributes (void)
|
|||||||
if (tcgetattr (STDOUT_FILENO, &shell_mode)) {
|
if (tcgetattr (STDOUT_FILENO, &shell_mode)) {
|
||||||
fprintf (stderr, "Cannot get terminal settings: %s\r\n",
|
fprintf (stderr, "Cannot get terminal settings: %s\r\n",
|
||||||
unix_error_string (errno));
|
unix_error_string (errno));
|
||||||
use_subshell = FALSE;
|
mc_args__use_subshell = FALSE;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -12,9 +12,6 @@
|
|||||||
|
|
||||||
#ifdef HAVE_SUBSHELL_SUPPORT
|
#ifdef HAVE_SUBSHELL_SUPPORT
|
||||||
|
|
||||||
/* If using a subshell for evaluating commands this is true */
|
|
||||||
extern int use_subshell;
|
|
||||||
|
|
||||||
/* File descriptor of the pseudoterminal used by the subshell */
|
/* File descriptor of the pseudoterminal used by the subshell */
|
||||||
extern int subshell_pty;
|
extern int subshell_pty;
|
||||||
|
|
||||||
@ -38,8 +35,6 @@ void do_subshell_chdir (const char *directory, int update_prompt, int reset_prom
|
|||||||
void subshell_get_console_attributes (void);
|
void subshell_get_console_attributes (void);
|
||||||
void sigchld_handler (int sig);
|
void sigchld_handler (int sig);
|
||||||
|
|
||||||
#else
|
|
||||||
#define use_subshell 0
|
|
||||||
#endif /* not HAVE_SUBSHELL_SUPPORT */
|
#endif /* not HAVE_SUBSHELL_SUPPORT */
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
Loading…
Reference in New Issue
Block a user