BASH PATCH REPORT ================= Bash-Release: 3.2 Patch-ID: bash32-041 Bug-Reported-by: Dan Jacobson <jidanni@jidanni.org> Bug-Reference-ID: <873arjs11h.fsf@jidanni.org> Bug-Reference-URL: http://lists.gnu.org/archive/html/bug-bash/2008-02/msg00049.html Bug-Description: Bash saved and restored the value of `set -o history' while sourcing files, preventing users from turning off history with `set +o history' in .bashrc. Patch: *** ../bash-3.2-patched/bashhist.c 2005-12-26 13:31:16.000000000 -0500 --- bashhist.c 2008-08-17 13:07:40.000000000 -0400 *************** *** 81,84 **** --- 81,85 ---- becomes zero when we read lines from a file, for example. */ int remember_on_history = 1; + int enable_history_list = 1; /* value for `set -o history' */ /* The number of lines that Bash has added to this history session. The *************** *** 235,239 **** history_expansion_inhibited = 1; #endif ! remember_on_history = interact != 0; history_inhibit_expansion_function = bash_history_inhibit_expansion; } --- 236,240 ---- history_expansion_inhibited = 1; #endif ! remember_on_history = enable_history_list = interact != 0; history_inhibit_expansion_function = bash_history_inhibit_expansion; } *** ../bash-3.2-patched/builtins/set.def 2006-07-27 09:41:43.000000000 -0400 --- builtins/set.def 2008-08-14 16:33:41.000000000 -0400 *************** *** 190,194 **** #endif /* BANG_HISTORY */ #if defined (HISTORY) ! { "history", '\0', &remember_on_history, bash_set_history, (setopt_get_func_t *)NULL }, #endif { "ignoreeof", '\0', &ignoreeof, set_ignoreeof, (setopt_get_func_t *)NULL }, --- 198,202 ---- #endif /* BANG_HISTORY */ #if defined (HISTORY) ! { "history", '\0', &enable_history_list, bash_set_history, (setopt_get_func_t *)NULL }, #endif { "ignoreeof", '\0', &ignoreeof, set_ignoreeof, (setopt_get_func_t *)NULL }, *************** *** 382,385 **** --- 390,394 ---- if (on_or_off == FLAG_ON) { + enable_history_list = 1; bash_history_enable (); if (history_lines_this_session == 0) *************** *** 387,392 **** } else ! bash_history_disable (); ! return (1 - remember_on_history); } #endif --- 396,404 ---- } else ! { ! enable_history_list = 0; ! bash_history_disable (); ! } ! return (1 - enable_history_list); } #endif *************** *** 566,570 **** { #if defined (HISTORY) ! remember_on_history = 1; #endif ignoreeof = 0; --- 578,582 ---- { #if defined (HISTORY) ! remember_on_history = enable_history_list = 1; #endif ignoreeof = 0; *** ../bash-3.2-patched/builtins/evalstring.c 2006-07-28 15:12:16.000000000 -0400 --- builtins/evalstring.c 2008-11-10 21:17:16.000000000 -0500 *************** *** 68,71 **** --- 68,79 ---- static int cat_file __P((REDIRECT *)); + #if defined (HISTORY) + static void + set_history_remembering () + { + remember_on_history = enable_history_list; + } + #endif + /* How to force parse_and_execute () to clean up after itself. */ void *************** *** 116,120 **** #if defined (HISTORY) ! unwind_protect_int (remember_on_history); /* can be used in scripts */ # if defined (BANG_HISTORY) if (interactive_shell) --- 124,131 ---- #if defined (HISTORY) ! if (parse_and_execute_level == 0) ! add_unwind_protect (set_history_remembering, (char *)NULL); ! else ! unwind_protect_int (remember_on_history); /* can be used in scripts */ # if defined (BANG_HISTORY) if (interactive_shell) *** ../bash-3.2-patched/bashhist.h 2005-07-01 15:44:41.000000000 -0400 --- bashhist.h 2008-08-17 12:51:07.000000000 -0400 *************** *** 32,35 **** --- 32,38 ---- extern int remember_on_history; + extern int enable_history_list; /* value for `set -o history' */ + extern int literal_history; /* controlled by `shopt lithist' */ + extern int force_append_history; extern int history_lines_this_session; extern int history_lines_in_file; *** ../bash-3.2/patchlevel.h Thu Apr 13 08:31:04 2006 --- patchlevel.h Mon Oct 16 14:22:54 2006 *************** *** 26,30 **** looks for to find the patch level (for the sccs version string). */ ! #define PATCHLEVEL 40 #endif /* _PATCHLEVEL_H_ */ --- 26,30 ---- looks for to find the patch level (for the sccs version string). */ ! #define PATCHLEVEL 41 #endif /* _PATCHLEVEL_H_ */