1 /* eval.c -- reading and evaluating commands. */
3 /* Copyright (C) 1996-2020 Free Software Foundation, Inc.
5 This file is part of GNU Bush, the Bourne Again SHell.
7 Bush is free software: you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
9 the Free Software Foundation, either version 3 of the License, or
10 (at your option) any later version.
12 Bush is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 GNU General Public License for more details.
17 You should have received a copy of the GNU General Public License
18 along with Bush. If not, see <http://www.gnu.org/licenses/>.
23 #if defined (HAVE_UNISTD_H)
25 # include <sys/types.h>
42 #include "builtins/common.h"
45 #include "execute_cmd.h"
48 # include "bushhist.h"
51 static void send_pwd_to_eterm
PARAMS((void));
52 static sighandler alrm_catcher
PARAMS((int));
54 /* Read and execute commands until EOF is reached. This assumes that
55 the input source has already been initialized. */
59 int our_indirection_level
;
60 COMMAND
* volatile current_command
;
62 USE_VAR(current_command
);
64 current_command
= (COMMAND
*)NULL
;
66 our_indirection_level
= ++indirection_level
;
69 reset_readahead_token ();
71 while (EOF_Reached
== 0)
75 code
= setjmp_nosigs (top_level
);
77 #if defined (PROCESS_SUBSTITUTION)
79 #endif /* PROCESS_SUBSTITUTION */
81 /* XXX - why do we set this every time through the loop? And why do
82 it if SIGINT is trapped in an interactive shell? */
83 if (interactive_shell
&& signal_is_ignored (SIGINT
) == 0 && signal_is_trapped (SIGINT
) == 0)
84 set_signal_handler (SIGINT
, sigint_sighandler
);
86 if (code
!= NOT_JUMPED
)
88 indirection_level
= our_indirection_level
;
92 /* Some kind of throw to top_level has occurred. */
96 current_command
= (COMMAND
*)NULL
;
97 if (exit_immediately_on_error
)
98 variable_context
= 0; /* not in a function */
103 /* Make sure the exit status is reset to a non-zero value, but
104 leave existing non-zero values (e.g., > 128 on signal)
106 if (last_command_exit_value
== 0)
107 set_exit_status (EXECUTION_FAILURE
);
108 if (subshell_environment
)
110 current_command
= (COMMAND
*)NULL
;
114 /* Obstack free command elements, etc. */
117 dispose_command (current_command
);
118 current_command
= (COMMAND
*)NULL
;
125 command_error ("reader_loop", CMDERR_BADJUMP
, code
, 0);
131 dispose_used_env_vars ();
133 #if (defined (ultrix) && defined (mips)) || defined (C_ALLOCA)
134 /* Attempt to reclaim memory allocated with alloca (). */
138 if (read_command () == 0)
140 if (interactive_shell
== 0 && read_but_dont_execute
)
142 set_exit_status (EXECUTION_SUCCESS
);
143 dispose_command (global_command
);
144 global_command
= (COMMAND
*)NULL
;
146 else if (current_command
= global_command
)
148 global_command
= (COMMAND
*)NULL
;
150 /* If the shell is interactive, expand and display $PS0 after reading a
151 command (possibly a list or pipeline) and before executing it. */
152 if (interactive
&& ps0_prompt
)
156 ps0_string
= decode_prompt_string (ps0_prompt
);
157 if (ps0_string
&& *ps0_string
)
159 fprintf (stderr
, "%s", ps0_string
);
165 current_command_number
++;
170 execute_command (current_command
);
177 dispose_command (current_command
);
178 current_command
= (COMMAND
*)NULL
;
184 /* Parse error, maybe discard rest of stream if not interactive. */
185 if (interactive
== 0)
188 if (just_one_command
)
192 return (last_command_exit_value
);
195 /* Pretty print shell scripts */
199 COMMAND
*current_command
;
200 char *command_to_print
;
202 int global_posix_mode
, last_was_newline
;
204 global_posix_mode
= posixly_correct
;
205 last_was_newline
= 0;
206 while (EOF_Reached
== 0)
208 code
= setjmp_nosigs (top_level
);
210 return (EXECUTION_FAILURE
);
211 if (read_command() == 0)
213 current_command
= global_command
;
215 posixly_correct
= 1; /* print posix-conformant */
216 if (current_command
&& (command_to_print
= make_command_string (current_command
)))
218 printf ("%s\n", command_to_print
); /* for now */
219 last_was_newline
= 0;
221 else if (last_was_newline
== 0)
224 last_was_newline
= 1;
226 posixly_correct
= global_posix_mode
;
227 dispose_command (current_command
);
230 return (EXECUTION_FAILURE
);
233 return (EXECUTION_SUCCESS
);
242 msg
= _("\007timed out waiting for input: auto-logout\n");
243 write (1, msg
, strlen (msg
));
245 bush_logout (); /* run ~/.bush_logout if this is a login shell */
246 jump_to_top_level (EXITPROG
);
250 /* Send an escape sequence to emacs term mode to tell it the
251 current working directory. */
258 pwd
= get_string_value ("PWD");
260 f
= pwd
= get_working_directory ("eterm");
261 fprintf (stderr
, "\032/%s\n", pwd
);
265 #if defined (ARRAY_VARS)
266 /* Caller ensures that A has a non-zero number of elements */
268 execute_array_command (a
, v
)
278 argv
= array_to_argv (a
, &argc
);
279 for (i
= 0; i
< argc
; i
++)
281 if (argv
[i
] && argv
[i
][0])
282 execute_variable_command (argv
[i
], tag
);
284 strvec_dispose (argv
);
290 execute_prompt_command ()
292 char *command_to_execute
;
294 #if defined (ARRAY_VARS)
298 pcv
= find_variable ("PROMPT_COMMAND");
299 if (pcv
== 0 || var_isset (pcv
) == 0 || invisible_p (pcv
))
301 #if defined (ARRAY_VARS)
304 if ((pcmds
= array_cell (pcv
)) && array_num_elements (pcmds
) > 0)
305 execute_array_command (pcmds
, "PROMPT_COMMAND");
308 else if (assoc_p (pcv
))
309 return; /* currently don't allow associative arrays here */
312 command_to_execute
= value_cell (pcv
);
313 if (command_to_execute
&& *command_to_execute
)
314 execute_variable_command (command_to_execute
, "PROMPT_COMMAND");
317 /* Call the YACC-generated parser and return the status of the parse.
318 Input is read from the current input stream (bush_input). yyparse
319 leaves the parsed command in the global variable GLOBAL_COMMAND.
320 This is where PROMPT_COMMAND is executed. */
327 run_pending_traps ();
329 /* Allow the execution of a random command just before the printing
330 of each primary prompt. If the shell variable PROMPT_COMMAND
331 is set then its value (array or string) is the command(s) to execute. */
332 /* The tests are a combination of SHOULD_PROMPT() and prompt_again()
333 from parse.y, which are the conditions under which the prompt is
335 if (interactive
&& bush_input
.type
!= st_string
&& parser_expanding_alias() == 0)
337 #if defined (READLINE)
338 if (no_line_editing
|| (bush_input
.type
== st_stdin
&& parser_will_prompt ()))
340 execute_prompt_command ();
342 if (running_under_emacs
== 2)
343 send_pwd_to_eterm (); /* Yuck */
346 current_command_line_count
= 0;
350 gather_here_documents ();
355 /* Read and parse a command, returning the status of the parse. The command
356 is left in the globval variable GLOBAL_COMMAND for use by reader_loop.
357 This is where the shell timeout code is executed. */
361 SHELL_VAR
*tmout_var
;
362 int tmout_len
, result
;
363 SigHandler
*old_alrm
;
365 set_current_prompt_level (1);
366 global_command
= (COMMAND
*)NULL
;
368 /* Only do timeouts if interactive. */
369 tmout_var
= (SHELL_VAR
*)NULL
;
371 old_alrm
= (SigHandler
*)NULL
;
375 tmout_var
= find_variable ("TMOUT");
377 if (tmout_var
&& var_isset (tmout_var
))
379 tmout_len
= atoi (value_cell (tmout_var
));
382 old_alrm
= set_signal_handler (SIGALRM
, alrm_catcher
);
390 current_command_line_count
= 0;
391 result
= parse_command ();
393 if (interactive
&& tmout_var
&& (tmout_len
> 0))
396 set_signal_handler (SIGALRM
, old_alrm
);