diff --git a/bash-5.0-patch12.patch b/bash-5.0-patch12.patch new file mode 100755 index 0000000000000000000000000000000000000000..770e52c145d10c80dc4c8e89a91dbd80382bd379 --- /dev/null +++ b/bash-5.0-patch12.patch @@ -0,0 +1,56 @@ +From b0852fb54efbcee630847fcfdc435133f82043b9 Mon Sep 17 00:00:00 2001 +From: Chet Ramey +Date: Fri, 7 Feb 2020 15:16:28 -0500 +Subject: [PATCH 1/5] Bash-5.0 patch 12: fix problems moving back beyond start + of history + +--- + lib/readline/misc.c | 5 ++++- + patchlevel.h | 2 +- + 2 files changed, 5 insertions(+), 2 deletions(-) + +diff --git a/lib/readline/misc.c b/lib/readline/misc.c +index 64b1457..42005b0 100644 +--- a/lib/readline/misc.c ++++ b/lib/readline/misc.c +@@ -576,6 +576,7 @@ int + rl_get_previous_history (int count, int key) + { + HIST_ENTRY *old_temp, *temp; ++ int had_saved_line; + + if (count < 0) + return (rl_get_next_history (-count, key)); +@@ -588,6 +589,7 @@ rl_get_previous_history (int count, int key) + _rl_history_saved_point = (rl_point == rl_end) ? -1 : rl_point; + + /* If we don't have a line saved, then save this one. */ ++ had_saved_line = _rl_saved_line_for_history != 0; + rl_maybe_save_line (); + + /* If the current line has changed, save the changes. */ +@@ -611,7 +613,8 @@ rl_get_previous_history (int count, int key) + + if (temp == 0) + { +- rl_maybe_unsave_line (); ++ if (had_saved_line == 0) ++ _rl_free_saved_history_line (); + rl_ding (); + } + else +diff --git a/patchlevel.h b/patchlevel.h +index 772676c..93dbe0d 100644 +--- a/patchlevel.h ++++ b/patchlevel.h +@@ -25,6 +25,6 @@ + regexp `^#define[ ]*PATCHLEVEL', since that's what support/mkversion.sh + looks for to find the patch level (for the sccs version string). */ + +-#define PATCHLEVEL 11 ++#define PATCHLEVEL 12 + + #endif /* _PATCHLEVEL_H_ */ +-- +1.8.3.1 + diff --git a/bash-5.0-patch13.patch b/bash-5.0-patch13.patch new file mode 100755 index 0000000000000000000000000000000000000000..571c1e823bac43c84cbab1fb72d9871fe986864d --- /dev/null +++ b/bash-5.0-patch13.patch @@ -0,0 +1,62 @@ +From f747f9ff4c8aed2d51fa54db3cb10e8118034753 Mon Sep 17 00:00:00 2001 +From: Chet Ramey +Date: Fri, 7 Feb 2020 15:17:29 -0500 +Subject: [PATCH 2/5] Bash-5.0 patch 13: reading history entries with + timestamps can result in joined entries + +--- + lib/readline/histfile.c | 15 ++++++++++++++- + patchlevel.h | 2 +- + 2 files changed, 15 insertions(+), 2 deletions(-) + +diff --git a/lib/readline/histfile.c b/lib/readline/histfile.c +index a8a92aa..6c3adc9 100644 +--- a/lib/readline/histfile.c ++++ b/lib/readline/histfile.c +@@ -369,9 +369,11 @@ read_history_range (const char *filename, int from, int to) + } + + has_timestamps = HIST_TIMESTAMP_START (buffer); +- history_multiline_entries += has_timestamps && history_write_timestamps; ++ history_multiline_entries += has_timestamps && history_write_timestamps; + + /* Skip lines until we are at FROM. */ ++ if (has_timestamps) ++ last_ts = buffer; + for (line_start = line_end = buffer; line_end < bufend && current_line < from; line_end++) + if (*line_end == '\n') + { +@@ -380,7 +382,18 @@ read_history_range (const char *filename, int from, int to) + line. We should check more extensively here... */ + if (HIST_TIMESTAMP_START(p) == 0) + current_line++; ++ else ++ last_ts = p; + line_start = p; ++ /* If we are at the last line (current_line == from) but we have ++ timestamps (has_timestamps), then line_start points to the ++ text of the last command, and we need to skip to its end. */ ++ if (current_line >= from && has_timestamps) ++ { ++ for (line_end = p; line_end < bufend && *line_end != '\n'; line_end++) ++ ; ++ line_start = (*line_end == '\n') ? line_end + 1 : line_end; ++ } + } + + /* If there are lines left to gobble, then gobble them now. */ +diff --git a/patchlevel.h b/patchlevel.h +index 93dbe0d..779671c 100644 +--- a/patchlevel.h ++++ b/patchlevel.h +@@ -25,6 +25,6 @@ + regexp `^#define[ ]*PATCHLEVEL', since that's what support/mkversion.sh + looks for to find the patch level (for the sccs version string). */ + +-#define PATCHLEVEL 12 ++#define PATCHLEVEL 13 + + #endif /* _PATCHLEVEL_H_ */ +-- +1.8.3.1 + diff --git a/bash-5.0-patch14.patch b/bash-5.0-patch14.patch new file mode 100755 index 0000000000000000000000000000000000000000..340fa7f88ee7ccd1b971f054301e347f44268a58 --- /dev/null +++ b/bash-5.0-patch14.patch @@ -0,0 +1,44 @@ +From 8b6524c482573ea12eb20be756cdb8ca31d945f3 Mon Sep 17 00:00:00 2001 +From: Chet Ramey +Date: Fri, 7 Feb 2020 15:18:41 -0500 +Subject: [PATCH 3/5] Bash-5.0 patch 14: edit-and-execute-command does not + handle empty command lines + +--- + bashline.c | 7 ++----- + patchlevel.h | 2 +- + 2 files changed, 3 insertions(+), 6 deletions(-) + +diff --git a/bashline.c b/bashline.c +index 824ea9d..97adaa0 100644 +--- a/bashline.c ++++ b/bashline.c +@@ -961,11 +961,8 @@ edit_and_execute_command (count, c, editing_mode, edit_command) + /* This breaks down when using command-oriented history and are not + finished with the command, so we should not ignore the last command */ + using_history (); +- if (rl_line_buffer[0]) +- { +- current_command_line_count++; /* for rl_newline above */ +- bash_add_history (rl_line_buffer); +- } ++ current_command_line_count++; /* for rl_newline above */ ++ bash_add_history (rl_line_buffer); + current_command_line_count = 0; /* for dummy history entry */ + bash_add_history (""); + history_lines_this_session++; +diff --git a/patchlevel.h b/patchlevel.h +index 779671c..09a3cc8 100644 +--- a/patchlevel.h ++++ b/patchlevel.h +@@ -25,6 +25,6 @@ + regexp `^#define[ ]*PATCHLEVEL', since that's what support/mkversion.sh + looks for to find the patch level (for the sccs version string). */ + +-#define PATCHLEVEL 13 ++#define PATCHLEVEL 14 + + #endif /* _PATCHLEVEL_H_ */ +-- +1.8.3.1 + diff --git a/bash-5.0-patch15.patch b/bash-5.0-patch15.patch new file mode 100755 index 0000000000000000000000000000000000000000..b40b54ebdc5f00daa4380da207272df339393d04 --- /dev/null +++ b/bash-5.0-patch15.patch @@ -0,0 +1,64 @@ +From ad1b3e68229273b4983b607c5eeb56551536c583 Mon Sep 17 00:00:00 2001 +From: Chet Ramey +Date: Fri, 7 Feb 2020 15:19:53 -0500 +Subject: [PATCH 4/5] Bash-5.0 patch 15: aliases and -c commands can cause + premature termination + +--- + builtins/evalstring.c | 6 ++++-- + patchlevel.h | 2 +- + 2 files changed, 5 insertions(+), 3 deletions(-) + +diff --git a/builtins/evalstring.c b/builtins/evalstring.c +index cadc9bc..2f13a66 100644 +--- a/builtins/evalstring.c ++++ b/builtins/evalstring.c +@@ -91,6 +91,7 @@ should_suppress_fork (command) + return (startup_state == 2 && parse_and_execute_level == 1 && + running_trap == 0 && + *bash_input.location.string == '\0' && ++ parser_expanding_alias () == 0 && + command->type == cm_simple && + signal_is_trapped (EXIT_TRAP) == 0 && + signal_is_trapped (ERROR_TRAP) == 0 && +@@ -105,6 +106,7 @@ can_optimize_connection (command) + COMMAND *command; + { + return (*bash_input.location.string == '\0' && ++ parser_expanding_alias () == 0 && + (command->value.Connection->connector == AND_AND || command->value.Connection->connector == OR_OR || command->value.Connection->connector == ';') && + command->value.Connection->second->type == cm_simple); + } +@@ -290,7 +292,7 @@ parse_and_execute (string, from_file, flags) + + with_input_from_string (string, from_file); + clear_shell_input_line (); +- while (*(bash_input.location.string)) ++ while (*(bash_input.location.string) || parser_expanding_alias ()) + { + command = (COMMAND *)NULL; + +@@ -545,7 +547,7 @@ parse_string (string, from_file, flags, endp) + ostring = string; + + with_input_from_string (string, from_file); +- while (*(bash_input.location.string)) ++ while (*(bash_input.location.string)) /* XXX - parser_expanding_alias () ? */ + { + command = (COMMAND *)NULL; + +diff --git a/patchlevel.h b/patchlevel.h +index 09a3cc8..6e9ed3f 100644 +--- a/patchlevel.h ++++ b/patchlevel.h +@@ -25,6 +25,6 @@ + regexp `^#define[ ]*PATCHLEVEL', since that's what support/mkversion.sh + looks for to find the patch level (for the sccs version string). */ + +-#define PATCHLEVEL 14 ++#define PATCHLEVEL 15 + + #endif /* _PATCHLEVEL_H_ */ +-- +1.8.3.1 + diff --git a/bash-5.0-patch16.patch b/bash-5.0-patch16.patch new file mode 100755 index 0000000000000000000000000000000000000000..9197910944b6553fb59878e610e1c948f0a55698 --- /dev/null +++ b/bash-5.0-patch16.patch @@ -0,0 +1,53 @@ +From 6c6454cb18d7cd30b3b26d5ba6479431e599f3ed Mon Sep 17 00:00:00 2001 +From: Chet Ramey +Date: Fri, 7 Feb 2020 15:20:38 -0500 +Subject: [PATCH 5/5] Bash-5.0 patch 16: bash waits too long to reap /dev/fd + process substitutions with loops and group commands + +--- + execute_cmd.c | 16 ++++++++++++++++ + patchlevel.h | 2 +- + 2 files changed, 17 insertions(+), 1 deletion(-) + +diff --git a/execute_cmd.c b/execute_cmd.c +index f1d74bf..3864986 100644 +--- a/execute_cmd.c ++++ b/execute_cmd.c +@@ -1103,6 +1103,22 @@ execute_command_internal (command, asynchronous, pipe_in, pipe_out, + free ((void *)ofifo_list); + discard_unwind_frame ("internal_fifos"); + } ++# if defined (HAVE_DEV_FD) ++ /* Reap process substitutions at the end of loops */ ++ switch (command->type) ++ { ++ case cm_while: ++ case cm_until: ++ case cm_for: ++ case cm_group: ++# if defined (ARITH_FOR_COMMAND) ++ case cm_arith_for: ++# endif ++ reap_procsubs (); ++ default: ++ break; ++ } ++# endif /* HAVE_DEV_FD */ + #endif + + /* Invert the return value if we have to */ +diff --git a/patchlevel.h b/patchlevel.h +index 6e9ed3f..9074f4d 100644 +--- a/patchlevel.h ++++ b/patchlevel.h +@@ -25,6 +25,6 @@ + regexp `^#define[ ]*PATCHLEVEL', since that's what support/mkversion.sh + looks for to find the patch level (for the sccs version string). */ + +-#define PATCHLEVEL 15 ++#define PATCHLEVEL 16 + + #endif /* _PATCHLEVEL_H_ */ +-- +1.8.3.1 + diff --git a/bash-5.0-patch17.patch b/bash-5.0-patch17.patch new file mode 100755 index 0000000000000000000000000000000000000000..26cde9bc5d34e57f5681f019a811e0a2c79fd7d9 --- /dev/null +++ b/bash-5.0-patch17.patch @@ -0,0 +1,213 @@ +From 9e49d343e3cd7e20dad1b86ebfb764e8027596a7 Mon Sep 17 00:00:00 2001 +From: Chet Ramey +Date: Fri, 24 Apr 2020 11:05:06 -0400 +Subject: [PATCH] Bash-5.0 patch 17: better fix for reaping process + substitution file descriptors + +--- + execute_cmd.c | 26 ++++++-------------------- + patchlevel.h | 2 +- + subst.c | 35 +++++++++++++++++++++-------------- + subst.h | 5 ++--- + 4 files changed, 30 insertions(+), 38 deletions(-) + +diff --git a/execute_cmd.c b/execute_cmd.c +index 3864986d..4a05758d 100644 +--- a/execute_cmd.c ++++ b/execute_cmd.c +@@ -564,7 +564,7 @@ execute_command_internal (command, asynchronous, pipe_in, pipe_out, + volatile int save_line_number; + #if defined (PROCESS_SUBSTITUTION) + volatile int ofifo, nfifo, osize, saved_fifo; +- volatile char *ofifo_list; ++ volatile void *ofifo_list; + #endif + + if (breaking || continuing) +@@ -750,12 +750,14 @@ execute_command_internal (command, asynchronous, pipe_in, pipe_out, + reap_procsubs (); + # endif + +- if (variable_context != 0) /* XXX - also if sourcelevel != 0? */ ++ /* XXX - also if sourcelevel != 0? */ ++ if (variable_context != 0) + { + ofifo = num_fifos (); + ofifo_list = copy_fifo_list ((int *)&osize); + begin_unwind_frame ("internal_fifos"); +- add_unwind_protect (xfree, ofifo_list); ++ if (ofifo_list) ++ add_unwind_protect (xfree, ofifo_list); + saved_fifo = 1; + } + else +@@ -1099,26 +1101,10 @@ execute_command_internal (command, asynchronous, pipe_in, pipe_out, + { + nfifo = num_fifos (); + if (nfifo > ofifo) +- close_new_fifos ((char *)ofifo_list, osize); ++ close_new_fifos ((void *)ofifo_list, osize); + free ((void *)ofifo_list); + discard_unwind_frame ("internal_fifos"); + } +-# if defined (HAVE_DEV_FD) +- /* Reap process substitutions at the end of loops */ +- switch (command->type) +- { +- case cm_while: +- case cm_until: +- case cm_for: +- case cm_group: +-# if defined (ARITH_FOR_COMMAND) +- case cm_arith_for: +-# endif +- reap_procsubs (); +- default: +- break; +- } +-# endif /* HAVE_DEV_FD */ + #endif + + /* Invert the return value if we have to */ +diff --git a/patchlevel.h b/patchlevel.h +index 9074f4dd..98e714da 100644 +--- a/patchlevel.h ++++ b/patchlevel.h +@@ -25,6 +25,6 @@ + regexp `^#define[ ]*PATCHLEVEL', since that's what support/mkversion.sh + looks for to find the patch level (for the sccs version string). */ + +-#define PATCHLEVEL 16 ++#define PATCHLEVEL 17 + + #endif /* _PATCHLEVEL_H_ */ +diff --git a/subst.c b/subst.c +index fd6db240..8884b487 100644 +--- a/subst.c ++++ b/subst.c +@@ -5336,13 +5336,13 @@ clear_fifo_list () + { + } + +-char * ++void * + copy_fifo_list (sizep) + int *sizep; + { + if (sizep) + *sizep = 0; +- return (char *)NULL; ++ return (void *)NULL; + } + + static void +@@ -5408,8 +5408,13 @@ unlink_fifo_list () + for (i = j = 0; i < nfifo; i++) + if (fifo_list[i].file) + { +- fifo_list[j].file = fifo_list[i].file; +- fifo_list[j].proc = fifo_list[i].proc; ++ if (i != j) ++ { ++ fifo_list[j].file = fifo_list[i].file; ++ fifo_list[j].proc = fifo_list[i].proc; ++ fifo_list[i].file = (char *)NULL; ++ fifo_list[i].proc = 0; ++ } + j++; + } + nfifo = j; +@@ -5425,10 +5430,11 @@ unlink_fifo_list () + case it's larger than fifo_list_size (size of fifo_list). */ + void + close_new_fifos (list, lsize) +- char *list; ++ void *list; + int lsize; + { + int i; ++ char *plist; + + if (list == 0) + { +@@ -5436,8 +5442,8 @@ close_new_fifos (list, lsize) + return; + } + +- for (i = 0; i < lsize; i++) +- if (list[i] == 0 && i < fifo_list_size && fifo_list[i].proc != -1) ++ for (plist = (char *)list, i = 0; i < lsize; i++) ++ if (plist[i] == 0 && i < fifo_list_size && fifo_list[i].proc != -1) + unlink_fifo (i); + + for (i = lsize; i < fifo_list_size; i++) +@@ -5559,22 +5565,22 @@ clear_fifo_list () + nfds = 0; + } + +-char * ++void * + copy_fifo_list (sizep) + int *sizep; + { +- char *ret; ++ void *ret; + + if (nfds == 0 || totfds == 0) + { + if (sizep) + *sizep = 0; +- return (char *)NULL; ++ return (void *)NULL; + } + + if (sizep) + *sizep = totfds; +- ret = (char *)xmalloc (totfds * sizeof (pid_t)); ++ ret = xmalloc (totfds * sizeof (pid_t)); + return (memcpy (ret, dev_fd_list, totfds * sizeof (pid_t))); + } + +@@ -5647,10 +5653,11 @@ unlink_fifo_list () + totfds (size of dev_fd_list). */ + void + close_new_fifos (list, lsize) +- char *list; ++ void *list; + int lsize; + { + int i; ++ pid_t *plist; + + if (list == 0) + { +@@ -5658,8 +5665,8 @@ close_new_fifos (list, lsize) + return; + } + +- for (i = 0; i < lsize; i++) +- if (list[i] == 0 && i < totfds && dev_fd_list[i]) ++ for (plist = (pid_t *)list, i = 0; i < lsize; i++) ++ if (plist[i] == 0 && i < totfds && dev_fd_list[i]) + unlink_fifo (i); + + for (i = lsize; i < totfds; i++) +diff --git a/subst.h b/subst.h +index 34763222..faf831bd 100644 +--- a/subst.h ++++ b/subst.h +@@ -273,9 +273,8 @@ extern int num_fifos __P((void)); + extern void unlink_fifo_list __P((void)); + extern void unlink_fifo __P((int)); + +-extern char *copy_fifo_list __P((int *)); +-extern void unlink_new_fifos __P((char *, int)); +-extern void close_new_fifos __P((char *, int)); ++extern void *copy_fifo_list __P((int *)); ++extern void close_new_fifos __P((void *, int)); + + extern void clear_fifo_list __P((void)); + +-- +2.26.2.windows.1 + diff --git a/bash.spec b/bash.spec index f3e1d61f3a0b7054a052d1351ad93efc3a5fa803..61bce9936468a7573ef49d7755c4775e5e532472 100644 --- a/bash.spec +++ b/bash.spec @@ -1,6 +1,6 @@ Name: bash Version: 5.0 -Release: 12 +Release: 13 Summary: It is the Bourne Again Shell License: GPLv3 URL: https://www.gnu.org/software/bash @@ -22,21 +22,29 @@ Patch8: bash-5.0-patch8.patch Patch9: bash-5.0-patch9.patch Patch10: bash-5.0-patch10.patch Patch11: bash-5.0-patch11.patch +Patch12: bash-5.0-patch12.patch +Patch13: bash-5.0-patch13.patch +Patch14: bash-5.0-patch14.patch +Patch15: bash-5.0-patch15.patch +Patch16: bash-5.0-patch16.patch +Patch17: bash-5.0-patch17.patch -Patch15: bash-2.05a-interpreter.patch -Patch18: bash-2.05b-pgrp_sync.patch -Patch25: bash-4.0-nobits.patch -Patch29: bash-4.2-coverity.patch + + +Patch115: bash-2.05a-interpreter.patch +Patch118: bash-2.05b-pgrp_sync.patch +Patch125: bash-4.0-nobits.patch +Patch129: bash-4.2-coverity.patch # rh1102815 -Patch33: bash-4.3-noecho.patch +Patch133: bash-4.3-noecho.patch # fix bash leaks memory when LC_ALL set-rh1241533,rh1224855 -Patch34: bash-4.3-memleak-lc_all.patch +Patch134: bash-4.3-memleak-lc_all.patch # https://git.savannah.gnu.org/cgit/bash.git/commit/?h=devel&id=951bdaad7a18cc0dc1036bba86b18b90874d39ff -Patch35: CVE-2019-18276.patch +Patch135: CVE-2019-18276.patch # https://github.com/bminor/bash/commit/db26b1cf58aab63c39fd5665590cad3cb75eab72.patch -Patch36: commit-bash-20190913-snapshot.patch -Patch37:bugfix-Forbidden-non-root-user-to-clear-history.patch -Patch38:enable-dot-logout-and-source-bashrc-through-ssh.patch +Patch136: commit-bash-20190913-snapshot.patch +Patch137:bugfix-Forbidden-non-root-user-to-clear-history.patch +Patch138:enable-dot-logout-and-source-bashrc-through-ssh.patch BuildRequires: gcc bison texinfo autoconf ncurses-devel @@ -123,6 +131,12 @@ make check %exclude %{_infodir}/dir %changelog +* Fri May 29 2020 openEuler licihua - 5.0-13 +- Type:enhancement +- ID:NA +- SUG:NA +- DESC:add upstream patches + * Thu Mar 19 2020 openEuler Buildteam - 5.0-12 - Type:enhancement - ID:NA diff --git a/bash.spec.bak b/bash.spec.bak new file mode 100755 index 0000000000000000000000000000000000000000..42f2b9dcb2364d8cc5936850ce34c429f4b5f38a --- /dev/null +++ b/bash.spec.bak @@ -0,0 +1,228 @@ +Name: bash +Version: 5.0 +Release: 14 +Summary: It is the Bourne Again Shell +License: GPLv3 +URL: https://www.gnu.org/software/bash +Source0: https://ftp.gnu.org/gnu/%{name}/%{name}-%{version}.tar.gz + +Source1: dot-bashrc +Source2: dot-bash_profile +Source3: dot-bash_logout + +# PATCH-FIX-UPSTREAM +Patch1: bash-5.0-patch1.patch +Patch2: bash-5.0-patch2.patch +Patch3: bash-5.0-patch3.patch +Patch4: bash-5.0-patch4.patch +Patch5: bash-5.0-patch5.patch +Patch6: bash-5.0-patch6.patch +Patch7: bash-5.0-patch7.patch +Patch8: bash-5.0-patch8.patch +Patch9: bash-5.0-patch9.patch +Patch10: bash-5.0-patch10.patch +Patch11: bash-5.0-patch11.patch +Patch12: bash-5.0-patch12.patch +Patch13: bash-5.0-patch13.patch +Patch14: bash-5.0-patch14.patch +Patch15: bash-5.0-patch15.patch +Patch16: bash-5.0-patch16.patch +Patch17: bash-5.0-patch17.patch + + + +Patch115: bash-2.05a-interpreter.patch +Patch118: bash-2.05b-pgrp_sync.patch +Patch125: bash-4.0-nobits.patch +Patch129: bash-4.2-coverity.patch +# rh1102815 +Patch133: bash-4.3-noecho.patch +# fix bash leaks memory when LC_ALL set-rh1241533,rh1224855 +Patch134: bash-4.3-memleak-lc_all.patch +# https://git.savannah.gnu.org/cgit/bash.git/commit/?h=devel&id=951bdaad7a18cc0dc1036bba86b18b90874d39ff +Patch135: CVE-2019-18276.patch +# https://github.com/bminor/bash/commit/db26b1cf58aab63c39fd5665590cad3cb75eab72.patch +Patch136: commit-bash-20190913-snapshot.patch +Patch137:bugfix-Forbidden-non-root-user-to-clear-history.patch +Patch138:enable-dot-logout-and-source-bashrc-through-ssh.patch + +BuildRequires: gcc bison texinfo autoconf ncurses-devel + +Requires: filesystem + +Provides: /bin/sh /bin/bash + +%description +Bash is the GNU Project's shell. Bash is the Bourne Again SHell. Bash is an sh-compatible +shell that incorporates useful features from the Korn shell (ksh) and C shell (csh). It is +intended to conform to the IEEE POSIX P1003.2/ISO 9945.2 Shell and Tools standard. It offers +functional improvements over sh for both programming and interactive use. In addition, most +sh scripts can be run by Bash without modification. + +%package devel +Summary: Development headers for %{name} +Requires: %{name} = %{version}-%{release} +Requires: pkgconf-pkg-config + +%description devel +This package contains development files for %{name}. + +%package help +Summary: Documents for %{name} +Buildarch: noarch +Requires: man info +Provides: %{name}-doc = %{version}-%{release} +Obsoletes: %{name}-doc < %{version}-%{release} + +%description help +Man pages and other related documents for %{name}. + +%prep +%autosetup -n %{name}-%{version} -p1 + +%build +autoconf +%configure --with-bash-malloc=no --with-afs +%make_build "CPPFLAGS=-D_GNU_SOURCE -DRECYCLES_PIDS -DDEFAULT_PATH_VALUE='\"/usr/local/bin:/usr/bin\"' `getconf LFS_CFLAGS`" + +%install +%make_install install-headers +ln -sf bash %{buildroot}%{_bindir}/sh +install -pD %SOURCE1 %{buildroot}/etc/skel/.bashrc +install -pD %SOURCE2 %{buildroot}/etc/skel/.bash_profile +install -pD %SOURCE3 %{buildroot}/etc/skel/.bash_logout + +# bug #820192, need to add execable alternatives for regular built-ins +for ea in alias bg cd command fc fg getopts hash jobs read type ulimit umask unalias wait +do + cat < "%{buildroot}"/%{_bindir}/"$ea" +#!/bin/sh +builtin $ea "\$@" +EOF +chmod +x "%{buildroot}"/%{_bindir}/"$ea" +done + +%find_lang %{name} + +%check +make check + +%files -f %{name}.lang +%defattr(-,root,root) +%license COPYING +%config(noreplace) /etc/skel/.* +%{_bindir}/{sh,bash,alias,bg,cd,command,fc,fg,wait,bashbug} +%{_bindir}/{hash,getopts,jobs,read,type,ulimit,umask,unalias} + +%files devel +%defattr(-,root,root) +%{_includedir}/%{name} +%{_libdir}/pkgconfig/*.pc +%{_libdir}/bash/* +%exclude %{_libdir}/bash/Makefile* + +%files help +%defattr(-,root,root) +%doc NOTES +%doc doc/*.ps doc/*.0 doc/*.html doc/*.txt +%doc %{_docdir}/%{name}/* +%{_infodir}/%{name}.info* +%{_mandir}/man1/*.gz +%exclude %{_infodir}/dir + +%changelog +* Thu Apr 30 2020 licihua - 5.0-14 +- Type:enhancement +- ID:NA +- SUG:NA +- DESC:add upstream patch + +* Wed Apr 8 2020 openEuler licihua - 5.0-13 +- Type:enhancement +- ID:NA +- SUG:NA +- DESC:add upstream patches + +* Thu Mar 19 2020 openEuler Buildteam - 5.0-12 +- Type:enhancement +- ID:NA +- SUG:NA +- DESC:remove comment in dot-bash_profile + +* Tue Mar 10 2020 openEuler Buildteam - 5.0-11 +- Type:enhancement +- ID:NA +- SUG:NA +- DESC:add build requires of ncurses-devel + +* Fri Feb 21 2020 openEuler Buildteam - 5.0-10 +- Type:CVE +- ID:NA +- SUG:NA +- DESC:CVE-2019-18276 + +* Wed Jan 22 2020 openEuler Buildteam - 5.0-9 +- resolve compile problems. + +* Mon Jan 6 2020 openEuler Buildteam - 5.0-8 +- Type:enhancement +- ID:NA +- SUG:NA +- DESC:delete redundant files + +* Wed Dec 25 2019 openEuler Buildteam - 5.0-7 +- Type:enhancement +- ID:NA +- SUG:NA +- DESC:add provides of bash-doc + +* Thu Oct 24 2019 shenyangyang - 5.0-6 +- Type:enhancement +- ID:NA +- SUG:NA +- DESC:add build requires of bison and texinfo + +* Fri Oct 11 2019 shenyangyang - 5.0-5 +- Type:enhancement +- ID:NA +- SUG:NA +- DESC:move the man files + +* Mon Sep 30 2019 shenyangyang - 5.0-4 +- Type:enhancement +- ID:NA +- SUG:NA +- DESC:modify requires + +* Sat Sep 21 2019 shenyangyang - 5.0-3 +- Type:enhancement +- ID:NA +- SUG:NA +- DESC:revise description + +* Wed Sep 4 2019 shenyangyang - 5.0-2 +- Type:enhancement +- ID:NA +- SUG:restart +- DESC:remove man to main package + +* Mon Sep 2 2019 shenyangyang - 5.0-1 +- Type:enhancement +- ID:NA +- SUG:restart +- DESC:strenthen spec + +* Sat Mar 16 2019 hanzhijun - 4.4.23-7 +- Type:bugfix +- ID:NA +- SUG:restart +- DESC:fix pathname expansion of directory + +* Fri Jan 25 2019 Xiaoqi Guo - 4.4.23-6 +- Type:bugfix +- ID:NA +- SUG:NA +- DESC:1000 Forbidden non root user to clear history + +* Mon Oct 08 2018 licunlong - 4.4.23-5 +- Package Initialization