diff options
author | Oliver Eikemeier <eik@FreeBSD.org> | 2004-09-03 09:21:31 +0000 |
---|---|---|
committer | Oliver Eikemeier <eik@FreeBSD.org> | 2004-09-03 09:21:31 +0000 |
commit | a55fe984d507d48edec7bf81b69c6ec943d185b7 (patch) | |
tree | 6237bd1115eb50ffdf803493906bb7f654220532 /shells | |
parent | 3f4a478e617539c167e5b550956399749c836981 (diff) |
- add FAQ
- experimental shopt `implicitcd'
- fix `Tags out of Date' in texinfo pages
- fix line wrap bug in libreadline
- set LATEST_LINK to `bash', so that `pkg_add -r bash' works
Notes
Notes:
svn path=/head/; revision=118022
Diffstat (limited to 'shells')
-rw-r--r-- | shells/bash/Makefile | 28 | ||||
-rw-r--r-- | shells/bash/distinfo | 5 | ||||
-rw-r--r-- | shells/bash/files/patch-doc::Makefile.in | 18 | ||||
-rw-r--r-- | shells/bash/files/patch-doc::bashref.texi | 19 | ||||
-rw-r--r-- | shells/bash/files/patch-lib::readline::display.c | 23 | ||||
-rw-r--r-- | shells/bash/files/xpatch-implicitcd | 99 |
6 files changed, 181 insertions, 11 deletions
diff --git a/shells/bash/Makefile b/shells/bash/Makefile index f3fe985c9991..63b7619a537b 100644 --- a/shells/bash/Makefile +++ b/shells/bash/Makefile @@ -7,19 +7,25 @@ PORTNAME= bash PORTVERSION= 3.0 -PORTREVISION= 3 +PORTREVISION= 4 CATEGORIES= shells -MASTER_SITES= ${MASTER_SITE_GNU} \ - ftp://ftp.cwru.edu/pub/%SUBDIR%/ -MASTER_SITE_SUBDIR= bash +MASTER_SITES= ${MASTER_SITE_GNU:S/$/:bash/} \ + http://cnswww.cns.cwru.edu/~chet/%SUBDIR%/:faq \ + ftp://ftp.cwru.edu/pub/%SUBDIR%/:bash,faq +MASTER_SITE_SUBDIR= ${PORTNAME}/:bash,faq +DISTFILES= ${DISTNAME}${EXTRACT_SUFX}:bash +DIST_SUBDIR= ${PORTNAME} +EXTRACT_ONLY= ${DISTNAME}${EXTRACT_SUFX} MAINTAINER= eik@FreeBSD.org COMMENT= The GNU Project's Bourne Again SHell +IGNOREFILES= FAQ CONFLICTS= bash-[0-24-9].* -LATEST_LINK= ${PKGNAMEPREFIX}bash3${PKGNAMESUFFIX} -USE_REINPLACE= yes +.if !defined(WITHOUT_IMPLICITCD) +EXTRA_PATCHES= ${PATCHDIR}/xpatch-implicitcd +.endif MAN1= bash.1 bashbug.1 INFO= bash @@ -28,10 +34,13 @@ USE_REINPLACE= yes GNU_CONFIGURE= yes .if !defined(NOPORTDOCS) -PORTDOCS= CHANGES COMPAT NEWS POSIX RBASH +DISTFILES+= FAQ:faq +PORTDOCS= FAQ CHANGES COMPAT NEWS POSIX RBASH .endif -CONFIGURE_ARGS= --without-bash-malloc +CONFIGURE_ARGS= --without-bash-malloc \ + --disable-rpath \ + --enable-disabled-builtins .if defined(WITHOUT_HELP) CONFIGURE_ARGS+= --disable-help-builtin @@ -69,7 +78,8 @@ pre-install: post-install: .if !defined(NOPORTDOCS) @${MKDIR} ${DOCSDIR} - @for d in ${PORTDOCS}; do \ + @${INSTALL_DATA} ${DISTDIR}/${DIST_SUBDIR}/FAQ ${DESTDIR}${DOCSDIR} + @for d in ${PORTDOCS:NFAQ}; do \ ${INSTALL_DATA} ${WRKSRC}/$${d} ${DESTDIR}${DOCSDIR}; \ done .endif diff --git a/shells/bash/distinfo b/shells/bash/distinfo index a2436bdddd95..6a0e67fa20c2 100644 --- a/shells/bash/distinfo +++ b/shells/bash/distinfo @@ -1,2 +1,3 @@ -MD5 (bash-3.0.tar.gz) = 26c4d642e29b3533d8d754995bc277b3 -SIZE (bash-3.0.tar.gz) = 2418293 +MD5 (bash/bash-3.0.tar.gz) = 26c4d642e29b3533d8d754995bc277b3 +SIZE (bash/bash-3.0.tar.gz) = 2418293 +MD5 (bash/FAQ) = IGNORE diff --git a/shells/bash/files/patch-doc::Makefile.in b/shells/bash/files/patch-doc::Makefile.in new file mode 100644 index 000000000000..b14453a5e531 --- /dev/null +++ b/shells/bash/files/patch-doc::Makefile.in @@ -0,0 +1,18 @@ +--- doc/Makefile.in.orig Tue Aug 31 00:34:30 2004 ++++ doc/Makefile.in Tue Aug 31 00:36:03 2004 +@@ -161,14 +161,11 @@ + bashref.dvi: $(BASHREF_FILES) $(HSUSER) $(RLUSER) + ${SET_TEXINPUTS} $(TEXI2DVI) $(srcdir)/bashref.texi + +-bashref.info: $(BASHREF_FILES) $(HSUSER) $(RLUSER) ++bash.info: $(BASHREF_FILES) $(HSUSER) $(RLUSER) + $(MAKEINFO) --no-split -I$(TEXINPUTDIR) $(srcdir)/bashref.texi + + bashref.html: $(BASHREF_FILES) $(HSUSER) $(RLUSER) + $(TEXI2HTML) -menu -monolithic -I $(TEXINPUTDIR) $(srcdir)/bashref.texi +- +-bash.info: bashref.info +- ${SHELL} ${INFOPOST} < $(srcdir)/bashref.info > $@ ; \ + + bash.txt: bash.1 + bash.ps: bash.1 diff --git a/shells/bash/files/patch-doc::bashref.texi b/shells/bash/files/patch-doc::bashref.texi new file mode 100644 index 000000000000..e56d56bb9792 --- /dev/null +++ b/shells/bash/files/patch-doc::bashref.texi @@ -0,0 +1,19 @@ +--- doc/bashref.texi.orig Wed Sep 1 22:37:32 2004 ++++ doc/bashref.texi Wed Sep 1 22:30:57 2004 +@@ -1,6 +1,6 @@ + \input texinfo.tex @c -*- texinfo -*- + @c %**start of header +-@setfilename bashref.info ++@setfilename bash.info + @settitle Bash Reference Manual + @c %**end of header + +@@ -10,7 +10,7 @@ + + @copying + This text is a brief description of the features that are present in +-the Bash shell (version @value{VERSION}, @value{UPDATED}). ++the Bash shell (version @value{VERSION}, @value{UPDATED}) + + This is Edition @value{EDITION}, last updated @value{UPDATED}, + of @cite{The GNU Bash Reference Manual}, diff --git a/shells/bash/files/patch-lib::readline::display.c b/shells/bash/files/patch-lib::readline::display.c new file mode 100644 index 000000000000..578c5c166fd8 --- /dev/null +++ b/shells/bash/files/patch-lib::readline::display.c @@ -0,0 +1,23 @@ +# +# Fix line wraps +# http://lists.gnu.org/archive/html/bug-bash/2004-08/msg00325.html +# +--- lib/readline/display.c.orig Wed Sep 1 18:28:21 2004 ++++ lib/readline/display.c Wed Sep 1 18:29:18 2004 +@@ -351,14 +351,14 @@ + local_prompt = expand_prompt (p, &prompt_visible_length, + &prompt_last_invisible, + (int *)NULL, +- (int *)NULL); ++ &prompt_physical_chars); + c = *t; *t = '\0'; + /* The portion of the prompt string up to and including the + final newline is now null-terminated. */ + local_prompt_prefix = expand_prompt (prompt, &prompt_prefix_length, + (int *)NULL, + &prompt_invis_chars_first_line, +- &prompt_physical_chars); ++ (int *)NULL); + *t = c; + return (prompt_prefix_length); + } diff --git a/shells/bash/files/xpatch-implicitcd b/shells/bash/files/xpatch-implicitcd new file mode 100644 index 000000000000..bbd077cf6217 --- /dev/null +++ b/shells/bash/files/xpatch-implicitcd @@ -0,0 +1,99 @@ +# +# new shopt `implicitcd' +# http://lists.gnu.org/archive/html/bug-bash/2004-09/msg00024.html +# +--- execute_cmd.c.orig Sun Jul 4 20:12:58 2004 ++++ execute_cmd.c Wed Sep 1 22:28:29 2004 +@@ -190,6 +190,9 @@ + /* The line number that the currently executing function starts on. */ + static int function_line_number; + ++/* add an implicit `cd' if the command is the name of a directory */ ++int implicitcd = 0; ++ + /* Set to 1 if fd 0 was the subject of redirection to a subshell. Global + so that reader_loop can set it to zero before executing a command. */ + int stdin_redir; +@@ -2909,6 +2912,20 @@ + this_command_name = words->word->word; + + QUIT; ++ ++ if (implicitcd && interactive_shell && words->next == NULL && func == 0 && builtin == 0) ++ { ++ struct stat finfo; ++ ++ if ((stat (words->word->word, &finfo) == 0) && (S_ISDIR (finfo.st_mode))) ++ { ++ this_command_name = "cd"; ++ last_shell_builtin = this_shell_builtin; ++ this_shell_builtin = builtin_address (this_command_name); ++ result = (*this_shell_builtin) (words); ++ goto return_result; ++ } ++ } + + /* This command could be a shell builtin or a user-defined function. + We have already found special builtins by this time, so we do not +--- builtins/shopt.def.orig Wed Sep 1 22:32:59 2004 ++++ builtins/shopt.def Wed Sep 1 22:31:27 2004 +@@ -66,6 +66,7 @@ + extern int check_window_size; + extern int glob_ignore_case; + extern int hup_on_exit; ++extern int implicitcd; + extern int xpg_echo; + extern int gnu_error_format; + +@@ -145,6 +146,7 @@ + { "hostcomplete", &perform_hostname_completion, enable_hostname_completion }, + #endif + { "huponexit", &hup_on_exit, (shopt_set_func_t *)NULL }, ++ { "implicitcd", &implicitcd, (shopt_set_func_t *)NULL }, + { "interactive_comments", &interactive_comments, set_shellopts_after_change }, + #if defined (HISTORY) + { "lithist", &literal_history, (shopt_set_func_t *)NULL }, +@@ -252,6 +254,7 @@ + cdable_vars = mail_warning = 0; + no_exit_on_failed_exec = print_shift_error = 0; + check_hashed_filenames = cdspelling = expand_aliases = check_window_size = 0; ++ implicitcd = 0; + + source_uses_path = promptvars = 1; + +--- doc/bash.1.orig Mon Jul 12 17:27:08 2004 ++++ doc/bash.1 Wed Sep 1 22:21:44 2004 +@@ -7970,6 +7970,15 @@ + .B SIGHUP + to all jobs when an interactive login shell exits. + .TP 8 ++.B implicitcd ++If this is set, a directory name typed as a command is treated as a ++request to change to that directory. ++This behavior is inhibited in non-interactive mode or for command ++strings with more than one word. ++Changing directory takes precedence over executing a like-named ++command, but it is done after alias substitutions. ++Tilde and variable expansions work as expected. ++.TP 8 + .B interactive_comments + If set, allow a word beginning with + .B # +--- doc/bashref.texi.orig Wed Sep 1 22:37:32 2004 ++++ doc/bashref.texi Wed Sep 1 22:30:57 2004 +@@ -3661,6 +3661,15 @@ + @item huponexit + If set, Bash will send @code{SIGHUP} to all jobs when an interactive + login shell exits (@pxref{Signals}). ++ ++@item implicitcd ++If this is set, a directory name typed as a command is treated as a ++request to change to that directory. ++This behavior is inhibited in non-interactive mode or for command ++strings with more than one word. ++Changing directory takes precedence over executing a like-named ++command, but it is done after alias substitutions. ++Tilde and variable expansions work as expected. + + @item interactive_comments + Allow a word beginning with @samp{#} |