migration from private to rsa 2.0alpha master 2.0_alpha
authorjooseok.park <jooseok.park@samsung.com>
Wed, 22 Aug 2012 00:02:15 +0000 (09:02 +0900)
committerjooseok.park <jooseok.park@samsung.com>
Wed, 22 Aug 2012 00:02:15 +0000 (09:02 +0900)
88 files changed:
debian/FAQ [new file with mode: 0644]
debian/README [new file with mode: 0644]
debian/README.abs-guide [new file with mode: 0644]
debian/README.bash_completion [new file with mode: 0644]
debian/README.bashdb [new file with mode: 0644]
debian/README.commands [new file with mode: 0644]
debian/bash-builtins.7 [new file with mode: 0644]
debian/bash-doc.doc-base.bash [new file with mode: 0644]
debian/bash-doc.doc-base.bashref [new file with mode: 0644]
debian/bash-static.postinst [new file with mode: 0644]
debian/bash-static.postrm [new file with mode: 0644]
debian/bash.menu [new file with mode: 0644]
debian/bash.postinst [new file with mode: 0644]
debian/bash.postrm [new file with mode: 0644]
debian/bash.preinst.c [new file with mode: 0644]
debian/bash.prerm [new file with mode: 0644]
debian/bashbug.1 [new file with mode: 0644]
debian/bashdb.copyright [new file with mode: 0644]
debian/bashdb.emacsen-install [new file with mode: 0644]
debian/bashdb.emacsen-remove [new file with mode: 0644]
debian/bashdb.emacsen-startup [new file with mode: 0644]
debian/bashdb.postinst [new file with mode: 0644]
debian/bashdb.prerm [new file with mode: 0644]
debian/changelog [new file with mode: 0644]
debian/changelog.saved [new file with mode: 0644]
debian/clear_console.1 [new file with mode: 0644]
debian/clear_console.c [new file with mode: 0644]
debian/compat [new file with mode: 0644]
debian/control [new file with mode: 0644]
debian/copyright [new file with mode: 0644]
debian/etc.bash.bashrc [new file with mode: 0644]
debian/etc.inputrc [new file with mode: 0644]
debian/etc.profile [new file with mode: 0644]
debian/inputrc.arrows [new file with mode: 0644]
debian/locale-gen [new file with mode: 0644]
debian/md5.c [new file with mode: 0644]
debian/md5.h [new file with mode: 0644]
debian/new/bash.postinst [new file with mode: 0644]
debian/new/bash.preinst.c [new file with mode: 0644]
debian/new/changelog-add [new file with mode: 0644]
debian/patches/bash-aliases-repeat.dpatch [new file with mode: 0644]
debian/patches/bash-default-editor.dpatch [new file with mode: 0644]
debian/patches/bash-minimal.dpatch [new file with mode: 0644]
debian/patches/bash-subst-param-length.dpatch [new file with mode: 0644]
debian/patches/bash41-001.dpatch [new file with mode: 0644]
debian/patches/bash41-002.dpatch [new file with mode: 0644]
debian/patches/bash41-003.dpatch [new file with mode: 0644]
debian/patches/bash41-004.dpatch [new file with mode: 0644]
debian/patches/bash41-005.dpatch [new file with mode: 0644]
debian/patches/bashbug-editor.dpatch [new file with mode: 0644]
debian/patches/bashdb-updates.dpatch [new file with mode: 0644]
debian/patches/bashdb.dpatch [new file with mode: 0644]
debian/patches/builtins-declare-fix.dpatch [new file with mode: 0644]
debian/patches/deb-bash-config.dpatch [new file with mode: 0644]
debian/patches/deb-examples.dpatch [new file with mode: 0644]
debian/patches/exec-redirections-man.dpatch [new file with mode: 0644]
debian/patches/exec-redirections-texi.dpatch [new file with mode: 0644]
debian/patches/input-err.dpatch [new file with mode: 0644]
debian/patches/man-arithmetic.dpatch [new file with mode: 0644]
debian/patches/man-bashlogout.dpatch [new file with mode: 0644]
debian/patches/man-bashrc.dpatch [new file with mode: 0644]
debian/patches/man-builtin.dpatch [new file with mode: 0644]
debian/patches/man-fignore.dpatch [new file with mode: 0644]
debian/patches/man-net-redirections-doc.dpatch [new file with mode: 0644]
debian/patches/man-net-redirections.dpatch [new file with mode: 0644]
debian/patches/man-nocaseglob.dpatch [new file with mode: 0644]
debian/patches/man-substring-exp-doc.dpatch [new file with mode: 0644]
debian/patches/man-substring-exp.dpatch [new file with mode: 0644]
debian/patches/man-test.dpatch [new file with mode: 0644]
debian/patches/man-test2-doc.dpatch [new file with mode: 0644]
debian/patches/man-test2.dpatch [new file with mode: 0644]
debian/patches/man-vx-opts.dpatch [new file with mode: 0644]
debian/patches/pgrp-pipe.dpatch [new file with mode: 0644]
debian/patches/privmode.dpatch [new file with mode: 0644]
debian/patches/random.dpatch [new file with mode: 0644]
debian/patches/rbash-manpage.dpatch [new file with mode: 0644]
debian/patches/rl-del-backspace-policy.dpatch [new file with mode: 0644]
debian/patches/rl-examples-bdb.dpatch [new file with mode: 0644]
debian/patches/rl-header.dpatch [new file with mode: 0644]
debian/patches/rl-setenv.dpatch [new file with mode: 0644]
debian/patches/template.dpatch [new file with mode: 0644]
debian/rules [new file with mode: 0755]
debian/run-my-gprof [new file with mode: 0644]
debian/skel.bash_logout [new file with mode: 0644]
debian/skel.bashrc [new file with mode: 0644]
debian/skel.profile [new file with mode: 0644]
debian/watch [new file with mode: 0644]
packaging/bash.spec

diff --git a/debian/FAQ b/debian/FAQ
new file mode 100644 (file)
index 0000000..a866068
--- /dev/null
@@ -0,0 +1,35 @@
+[ The original document has a license, which doesn't allow inclusion of the
+  FAQ in the main section of the Debian packages and therefore isn't
+  distributed in the Debian packages for bash. Pleae get it from the upstream
+  location.
+]
+
+-----------
+This is the Bash FAQ, version 3.20, for Bash version 2.05b.
+
+This document contains a set of frequently-asked questions concerning
+Bash, the GNU Bourne-Again Shell.  Bash is a freely-available command
+interpreter with advanced features for both interactive use and shell
+programming.
+
+Another good source of basic information about shells is the collection
+of FAQ articles periodically posted to comp.unix.shell.
+
+Questions and comments concerning this document should be sent to
+chet@po.cwru.edu.
+
+This document is available for anonymous FTP with the URL
+
+ftp://ftp.cwru.edu/pub/bash/FAQ
+
+The Bash home page is http://cnswww.cns.cwru.edu/~chet/bash/bashtop.html
+
+The original document has the following license:
+-----------
+This document is Copyright 1995-2002 by Chester Ramey.
+
+Permission is hereby granted, without written agreement and
+without license or royalty fees, to use, copy, and distribute
+this document for any purpose, provided that the above copyright
+notice appears in all copies of this document and that the
+contents of this document remain unaltered.
diff --git a/debian/README b/debian/README
new file mode 100644 (file)
index 0000000..c155efd
--- /dev/null
@@ -0,0 +1,128 @@
+Bash Configuration for Debian
+-----------------------------
+
+A number of patches for the bash sources is applied for the Debian build
+of bash.  See the details at the end of the file.
+
+The bash package was built using the following configuration options:
+
+        --with-curses \
+        --enable-largefile \
+
+bash-static additionally configured with --enable-static-link.
+
+The upstream ChangeLog can be found in the bash-doc package.
+
+
+A kind of FAQ for bash on Debian GNU/{Linux,Hurd}
+-------------------------------------------------
+
+0. symlinked directory completion behavior
+
+   Starting with readline-4.2a, completion on symlinks that point
+   to directories does not append the slash. To restore the behaviour
+   found in readline-4.2, add to /etc/inputrc or ~/.inputrc:
+
+       set mark-symlinked-directories on
+
+1. How can I make bash 8-bit clean so I can type hi-bit characters
+   directly?
+
+   Remove the comments from the indicated lines in /etc/inputrc.
+   It doesn't ship this way because otherwise the Meta bindings will not work.
+
+3. How to get rid off annoying beeps for ambiguous completions?
+
+   Put in /etc/inputrc (or in your ~/.inputrc):
+
+       set show-all-if-ambiguous on
+
+   Other people prefer:
+
+       set bell-style none
+
+4. bash doesn't display prompts correctly.
+
+   When using colors in prompts (or escape characters), then make sure
+   those characters are surrounded by \[ and \]. For more information
+   look at the man page bash(1) and search for PROMPTING.
+
+5. What is /etc/bash.bashrc? It doesn't seem to be documented.
+
+   The Debian version of bash is compiled with a special option
+   (-DSYS_BASHRC) that makes bash read /etc/bash.bashrc before ~/.bashrc
+   for interactive non-login shells. So, on Debian systems,
+   /etc/bash.bashrc is to ~/.bashrc as /etc/profile is to
+   ~/.bash_profile.
+
+6. bash does not check $PATH if hash fails
+
+   bash hashes the location of recently executed commands. When a command
+   is moved to a new location in the PATH, the command is still in the PATH
+   but the hash table still records the old location.
+
+   For performance reasons bash does not remove the command from the hash
+   and relook it up in PATH.
+
+   Use 'hash -r' manually or set a bash option: 'shopt -s checkhash'.
+
+7. Bourne-style shells have always accepted multiple directory name arguments 
+   to cd.  If the user doesn't like it, have him define a shell function: 
+   cd() 
+   { 
+        case $# in 
+        0|1)    ;; 
+        *)      echo "cd: too many arguments ; return 2 ;; 
+        esac 
+        builtin cd "$@" 
+   } 
+
+8. key bindings for ESC
+
+   Consider the following .inputrc:
+
+   set editing-mode vi
+
+   keymap vi
+       "\M-[D":        backward-char
+       "\M-[C":        forward-char
+       "\M-[A":        previous-history
+       "\M-[B":        next-history
+
+   And, just to be certain, set -o reports that vi is on.
+
+   However, ESC k does not send me to the previous line.
+
+   I'm guessing that this is a conflict between bash's concept of a meta
+   keymap and its concept of vi's command-mode character -- which is to
+   say that its data structures don't properly reflect its implementation.
+
+   Note that if I remove the meta prefix, leaving lines like:
+       "[A":        previous-history
+
+   That vi command mode keys work fine, and I can use the arrow keys in vi
+   mode, *provided I'm already in command mode already*.  In other words,
+   bash is doing something wrong here such that it doesn't see the escape
+   character at the beginning of the key sequence even when in vi insert mode.
+
+   Comment from the upstream author: "This guy destroyed the key binding for
+   ESC, which effectively disabled vi command mode.  It's not as simple as he
+   paints it to be -- the binding for ESC in the vi insertion keymap *must*
+   be a function because of the other things needed when switching
+   from insert mode to command mode.
+
+   If he wants to change something in vi's command mode, he needs
+   to use `set keymap vi-command' and enter key bindings without
+   the \M- prefix (as he discovered)."
+
+9. Why is bash configured with --disable-net-redirections?
+
+    It can produce completely unexpected results. This kind of
+    feature should not be part of a shell but a special tool. And
+    that tool has existed for years already, it's called netcat.
+
+
+Patches Applied to the Bash Sources
+-----------------------------------
+
diff --git a/debian/README.abs-guide b/debian/README.abs-guide
new file mode 100644 (file)
index 0000000..7a69558
--- /dev/null
@@ -0,0 +1,26 @@
+[ This is just a pointer to a document, which you might find helpful]
+
+                       Advanced Bash-Scripting Guide
+
+               A complete guide to shell scripting, using Bash
+
+                       Mendel Cooper - Brindlesoft
+
+                       thegrendel@theriver.com
+
+
+This tutorial assumes no previous knowledge of scripting or programming, but
+progresses rapidly toward an intermediate/advanced level of instruction
+(...all the while sneaking in little snippets of UNIX wisdom and lore). It
+serves as a textbook, a manual for self-study, and a reference and source
+of knowledge on shell scripting techniques. The exercises and heavily-
+commented examples invite active reader participation, under the premise that
+the only way to really learn scripting is to write scripts.
+
+The guide is availabe at http://tldp.org/LDP/abs/html/
+
+The latest update of this document, as an archived "tarball" including both
+the SGML source and rendered HTML, may be downloaded from the author's home
+site (http://personal.riverusers.com/~thegrendel/abs-guide-2.1.tar.bz2). See
+the change log for a revision history
+(http://personal.riverusers.com/~thegrendel/Change.log).
diff --git a/debian/README.bash_completion b/debian/README.bash_completion
new file mode 100644 (file)
index 0000000..e0a8e75
--- /dev/null
@@ -0,0 +1,17 @@
+                       Programmable Completion
+                       =======================
+
+[BUG REPORTING: Please direct all enhancement requests directly to the
+ bash_completion maintainer, the completion script won't be changed for
+ Debian specific enhancements. If you find a real bug, report it the usual
+ way. The bash_completion author can be reached at
+ http://freshmeat.net/projects/bashcompletion/
+
+ If you find a newer version on freshmeat, you can replace it, if you did
+ not change the Debian version.
+]
+
+To enable programmable completion for bash on Debian, uncomment the
+bash_completion lines in /etc/bash.bashrc to source /etc/bash_completion.
+/etc/bash_completion sources ~/.bash_completion, if it exists.
+
diff --git a/debian/README.bashdb b/debian/README.bashdb
new file mode 100644 (file)
index 0000000..de71180
--- /dev/null
@@ -0,0 +1,7 @@
+bashdb for Debian
+-----------------
+
+The debugger enhanced bash binary is installed under the name
+/usr/bin/bash-bashdb.
+
+ -- Matthias Klose <doko@debian.org>, Sun, 10 Aug 2003 23:10:38 +0200
diff --git a/debian/README.commands b/debian/README.commands
new file mode 100644 (file)
index 0000000..8e2aaf6
--- /dev/null
@@ -0,0 +1,189 @@
+   This is a jumping-off reference point for new users who may be
+   completely unfamiliar with Linux commands. It does not contain all
+   the information you need about using the Linux console, but instead
+   just gives you enough information to get started finding the
+   information you need.
+
+Linux Commands
+
+   To run a command, type the command at the prompt, followed by any
+   necessary options, and then press the Enter or Return key. 
+
+   Most commands operate silently unless they are specifically asked to
+   say what they are doing. If there is no error message, the command
+   should have worked.
+
+   The operation of most commands can be changed by putting command
+   options immediately after the command name. There are several styles
+   of options used, and you have to check the documentation for each
+   command to know what options it can take, and what they do.
+
+   Linux commands are case-sensitive, and almost always are all
+   lower-case. ls is a valid command; LS is not.
+
+   In most cases you can use the tab key to ask the command shell to
+   auto-complete the command, directory or filename you have started
+   to type. If a unique completion exists, the shell will type it. If
+   not, you can press tab a second time to obtain a list of the
+   possible auto-completions.
+
+Commands for Reading Documentation
+
+   In the following command examples, the [ ] characters are not
+   typed, they mean that whatever is enclosed is optional. For
+   example, you can also start `info' without any subject at all.
+
+   When a given keyboard shortcut is preceded by ctrl- or alt- , that
+   means hold the control or alt key down, and type the given key
+   while holding it down (the same way you use the shift key). A
+   shorthand notation for ctrl- is ^ (^C means ctrl-C).
+
+   man subject
+          man shows the manual page on the command (use q or ctrl-C to
+          get out of it if it doesn't terminate at the end of the
+          text).
+
+   info [subject]
+          A lot of Debian Linux documentation is provided in info
+          format. This is similar to a hypertext format, in that you
+          can jump to other sections of the documentation by following
+          links embedded in the text. An info tutorial is available
+          within info, using ctrl-h followed by h. 
+
+   help [subject]
+          Use help for on-line help about the shell's built-in commands.
+          help by itself prints a list of subjects for which you can
+          ask for help.
+
+   pager filename
+         pager displays a plain text file one screen at a time.
+          Additional screens can be displayed by pressing the space
+          bar, and previous screens can be displayed by pressing the b
+          key. When finished viewing the help, press q to return to
+          the prompt.
+
+   Using -h --help with | pager
+          Most commands offer very brief built-in help by typing the
+          command followed by 
+
+            -h or --help
+         
+          If the help scrolls up beyond the top of the screen before 
+          you can read it, add 
+
+            | pager 
+
+          to the end of the command.
+
+   zmore document.gz
+          zmore is a document pager -- it displays the contents of
+          compressed documentation on your disk, one screenful at a
+          time. Compression is signified by filenames ending in .gz .
+
+   lynx [document]  or  lynx [directory]  or  lynx [url]
+          lynx is a text-based web browser. It can display documents
+          (plain-text, compressed, or html), directory listings, and
+          urls such as www.google.com. It does not display images.
+
+Commands for Navigating Directories
+
+   pwd
+          Displays your current working directory. The p stands for
+          print, which is a carryover from when unix was designed,
+          before the advent of computer screens. Interactive computer
+          responses were printed on paper by a connected electric
+          typewriter instead of being displayed electronically.
+
+   cd [directory]
+          Change your current directory to the named directory. If you
+          don't specify directory, you will be returned to your home
+          directory. The `root' directory is signified by / at the
+          beginning of the directory path ( / also separates directory
+          and file names within the path). Thus paths beginning with /
+          are `absolute' paths; cd will take you to an absolute path
+          no matter what your current directory is. Paths not
+          beginning with / specify paths relative to your
+          current directory. cd .. means change to the parent
+          directory of your current working directory.
+
+   ls [directory]
+          ls lists the contents of directory. If you don't specify a
+          directory name, the current working directory's list is
+          displayed.
+
+   find directory -name filename
+          find tells you where filename is in the tree starting at
+          directory. This command has many other useful options.
+
+Documentation Indices
+
+   The standard doc-linux-text package installs compressed text linux
+   HOWTOs in
+
+        /usr/share/doc/HOWTO/en-txt/
+
+   Particularly helpful HOWTOs for new users are
+
+        /usr/share/doc/HOWTO/en-txt/Unix-and-Internet-Fundamentals-HOWTO.gz
+        /usr/share/doc/HOWTO/en-txt/mini/INDEX.gz
+        /usr/share/doc/HOWTO/en-txt/Reading-List-HOWTO.gz
+        /usr/share/doc/HOWTO/en-txt/META-FAQ.gz        
+
+   Individual package documentation is installed in
+
+        /usr/share/doc/<package-name> 
+
+   New user website references include
+
+       http://www.debian.org/doc/FAQ
+       http://www.linuxdoc.org/LDP/gs/gs.html
+
+Recording User Sessions
+
+   script filename
+          Use script to record everything that appears on the screen
+          (until the next exit) in filename. This is useful if you
+          need to record what's going on in order to include it in
+          your message when you ask for help. Use exit, logout or
+          ctrl-D to stop the recording session.
+
+Turning Echo On/Off
+
+   To turn off echoing of characters to the screen, you can use
+   ctrl-S. ctrl-Q starts the echo again. If your terminal suddenly
+   seems to become unresponsive, try ctrl-Q; you may have accidentally
+   typed ctrl-S which activated echo-off.
+
+Virtual Consoles
+
+   By default, six virtual consoles are provided. If you want to
+   execute another command without interrupting the operation of a
+   command you previously started, you can switch to another virtual
+   console (similar to a separate window). This is very handy for
+   displaying the documentation for a command in one console while
+   actually trying the command in another. Switch consoles 1 through 6
+   by using alt-F1 through alt-F6. 
+
+Logging Out
+
+   exit   or   logout
+
+          Use exit or logout to terminate your session and log
+          out. You should be returned to the log-in prompt.
+
+Turning Off the Computer
+
+   Turning the computer on and off is really a system administration
+   subject, but I include it here because it is something that every
+   user who is his own administrator needs to know.
+
+   halt   or   shutdown -t 0 -h now
+          This command shuts the computer down safely. You can also
+          use ctrl-alt-del if your system is set up for that. (If you
+          are in X, ctrl-alt-del will be intercepted by X. Get out of
+          X first by using ctrl-alt-backspace.)
+
+
+To display this file one screen at a time, type 
+
+pager /usr/share/doc/doc-linux-text/README.commands
diff --git a/debian/bash-builtins.7 b/debian/bash-builtins.7
new file mode 100644 (file)
index 0000000..69220eb
--- /dev/null
@@ -0,0 +1,18 @@
+.\" This is a hack to force bash builtins into the whatis database
+.\" and to get the list of builtins to come up with the man command.
+.TH BASH-BUILTINS 7 "2001 October 29" "GNU Bash-2.05a"
+.SH NAME
+bash-builtins \- bash built-in commands, see \fBbash\fR(1)
+.SH SYNOPSIS
+bash defines the following built-in commands: 
+:, ., [, alias, bg, bind, break, builtin, case, cd, command, compgen, complete, 
+continue, declare, dirs, disown, echo, enable, eval, exec, exit,
+export, fc, fg, getopts, hash, help, history, if, jobs, kill,
+let, local, logout, popd, printf, pushd, pwd, read, readonly, return, set,
+shift, shopt, source, suspend, test, times, trap, type, typeset,
+ulimit, umask, unalias, unset, until, wait, while.
+.SH BASH BUILTIN COMMANDS
+.nr zZ 1
+.so man1/bash.1
+.SH SEE ALSO
+bash(1), sh(1)
diff --git a/debian/bash-doc.doc-base.bash b/debian/bash-doc.doc-base.bash
new file mode 100644 (file)
index 0000000..d37255a
--- /dev/null
@@ -0,0 +1,14 @@
+Document: bash
+Title: Bash Manual Page
+Author: Chet Ramey
+Abstract:  Bash is an sh-compatible command language interpreter that executes
+ commands read from the standard input or from a file.  Bash also
+ incorporates useful features from the Korn and C shells (ksh and csh).
+Section: Shells
+
+Format: html
+Index: /usr/share/doc/bash/bash.html
+Files: /usr/share/doc/bash/bash.html
+
+Format: pdf
+Files: /usr/share/doc/bash/bash.pdf
diff --git a/debian/bash-doc.doc-base.bashref b/debian/bash-doc.doc-base.bashref
new file mode 100644 (file)
index 0000000..8567b57
--- /dev/null
@@ -0,0 +1,10 @@
+Document: bashref
+Title: Bash Reference Manual
+Author: Chet Ramey
+Abstract:  Bash is an sh-compatible command language interpreter that executes
+ commands read from the standard input or from a file.  Bash also
+ incorporates useful features from the Korn and C shells (ksh and csh).
+Section: Shells
+
+Format: pdf
+Files: /usr/share/doc/bash/bashref.pdf
diff --git a/debian/bash-static.postinst b/debian/bash-static.postinst
new file mode 100644 (file)
index 0000000..bb30da7
--- /dev/null
@@ -0,0 +1,13 @@
+#! /bin/sh
+
+set -e
+
+if [ "$1" = configure ] && dpkg --compare-versions "$2" le 3.2-4 \
+    && which add-shell >/dev/null
+then
+    add-shell /bin/bash-static
+fi
+
+#DEBHELPER#
+
+exit 0
diff --git a/debian/bash-static.postrm b/debian/bash-static.postrm
new file mode 100644 (file)
index 0000000..11c9ab4
--- /dev/null
@@ -0,0 +1,21 @@
+#! /bin/sh
+
+set -e
+
+case "$1" in
+    upgrade|failed-upgrade|abort-install|abort-upgrade)
+       ;;
+    remove|purge|disappear)
+       if which remove-shell >/dev/null && [ -f /etc/shells ]; then
+           remove-shell /bin/bash-static
+       fi
+       ;;
+    *)
+        echo "postrm called with unknown argument \`$1'" >&2
+        exit 1
+       ;;
+esac
+
+#DEBHELPER#
+
+exit 0
diff --git a/debian/bash.menu b/debian/bash.menu
new file mode 100644 (file)
index 0000000..eb84b2d
--- /dev/null
@@ -0,0 +1,2 @@
+?package(bash):needs="text" section="Applications/Shells" title="Bash" command="/bin/bash --login"
+?package(bash):needs="text" section="Applications/Shells" title="Sh" command="/bin/sh --login"
diff --git a/debian/bash.postinst b/debian/bash.postinst
new file mode 100644 (file)
index 0000000..02b2302
--- /dev/null
@@ -0,0 +1,26 @@
+#! /bin/bash
+
+set -e
+
+# the symlink is in the package now. So this should never happen ...
+if [ ! -e /bin/sh ]; then
+    ln -s bash /bin/sh
+fi
+
+update-alternatives --install \
+    /usr/share/man/man7/builtins.7.gz \
+    builtins.7.gz \
+    /usr/share/man/man7/bash-builtins.7.gz \
+    10 \
+  || true
+
+if [ "$1" = configure ] && dpkg --compare-versions "$2" le 3.2-3 \
+    && which add-shell >/dev/null
+then
+    add-shell /bin/bash
+    add-shell /bin/rbash
+fi
+
+#DEBHELPER#
+
+exit 0
diff --git a/debian/bash.postrm b/debian/bash.postrm
new file mode 100644 (file)
index 0000000..fcdbda8
--- /dev/null
@@ -0,0 +1,22 @@
+#! /bin/sh
+
+set -e
+
+case "$1" in
+    upgrade|failed-upgrade|abort-install|abort-upgrade)
+       ;;
+    remove|purge|disappear)
+       if which remove-shell >/dev/null && [ -f /etc/shells ]; then
+           remove-shell /bin/bash
+           remove-shell /bin/rbash
+       fi
+       ;;
+    *)
+        echo "postrm called with unknown argument \`$1'" >&2
+        exit 1
+       ;;
+esac
+
+#DEBHELPER#
+
+exit 0
diff --git a/debian/bash.preinst.c b/debian/bash.preinst.c
new file mode 100644 (file)
index 0000000..524e126
--- /dev/null
@@ -0,0 +1,250 @@
+/* Copyright (c) 1999 Anthony Towns
+ * Copyright (c) 2000, 2002 Matthias Klose
+ * Copyright (c) 2008 Canonical Ltd
+ *
+ * You may freely use, distribute, and modify this program.
+ */
+
+// Don't rely on /bin/sh and popen!
+
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include <unistd.h>
+#include <fcntl.h>
+#include <limits.h>
+#include <sys/types.h>
+#include <sys/wait.h>
+
+/* XXX: evil kludge, deal with arbitrary name lengths */
+#ifndef PATH_MAX
+#define PATH_MAX 4096
+#endif
+
+#include "md5.h"
+
+int check_predepends(void)
+{
+    pid_t child;
+
+    switch(child = fork()) {
+      case -1:
+        /* fork failed */
+        return EXIT_FAILURE;
+
+      case 0:
+        /* i'm the child */
+        {
+            execl( "/usr/bin/dpkg", "/usr/bin/dpkg",
+                   "--assert-support-predepends", NULL );
+           _exit(127);
+        }
+
+      default:
+        /* i'm the parent */
+        {
+            int status;
+            pid_t pid;
+            pid = wait(&status);
+            if (pid == child) {
+                if (WIFEXITED(status) && WEXITSTATUS(status) == 0) {
+                    return EXIT_SUCCESS;
+                }
+            }
+        }
+    }
+    return EXIT_FAILURE;
+}
+
+#define BUFSIZE 8192
+
+int md5sum_match(char *fn, char* fn_digest)
+{
+  md5_state_t md5;
+  md5_byte_t digest[16];
+  unsigned char hexdigest[33];
+  int i, j, fd;
+  size_t nbytes;
+  md5_byte_t buf[BUFSIZE];
+
+  // if not existant, md5sums don't match
+  if (access(fn, R_OK))
+    return 0;
+  if ((fd = open(fn, O_RDONLY)) == -1)
+    return 0;
+  
+  md5_init(&md5);
+  while (nbytes = read(fd, buf, BUFSIZE))
+    md5_append(&md5, buf, nbytes);
+  md5_finish(&md5, digest);
+  close(fd);
+
+  for (i = j = 0; i < 16; i++) {
+    unsigned char c;
+    c = (digest[i] >> 4) & 0xf;
+    c = (c > 9) ? c + 'a' - 10 : c + '0';
+    hexdigest[j++] = c;
+    c = (digest[i] & 0xf);
+    c = (c > 9) ? c + 'a' - 10 : c + '0';
+    hexdigest[j++] = c;
+  }
+  hexdigest[j] = '\0';
+#ifdef NDEBUG
+  fprintf(stderr, "fn=%s, md5sum=%s, expected=%s\n", fn, hexdigest, fn_digest);
+#endif
+  return !strcmp(fn_digest, hexdigest);
+}
+
+int unmodified_file(char *fn, int md5sumc, unsigned char* md5sumv[])
+{
+  int i;
+
+  // if not existant, pretend its unmodified
+  if (access(fn, R_OK))
+    return 1;
+  for (i = 0; i < md5sumc; i++) {
+    if (md5sum_match(fn, md5sumv[i]))
+      return 1;
+  }
+  return 0;
+}
+
+unsigned char *md5sumv_bash_profile[] = {
+  "d1a8c44e7dd1bed2f3e75d1343b6e4e1", // dapper, edgy, etch
+  "0bc1802860b758732b862ef973cd79ff", // feisty, gutsy
+};
+const int md5sumc_bash_profile = sizeof(md5sumv_bash_profile) / sizeof (char *);
+
+unsigned char *md5sumv_profile[] = {
+  "7d97942254c076a2ea5ea72180266420", // feisty, gutsy
+};
+const int md5sumc_profile = sizeof(md5sumv_profile) / sizeof (char *);
+
+#ifdef BC_CONFIG
+unsigned char *md5sumv_completion[] = {
+  "2bc0b6cf841eefd31d607e618f1ae29d", // dapper
+  "ae1d298e51ea7f8253eea8b99333561f", // edgy
+  "adc2e9fec28bd2d4a720e725294650f0", // feisty
+  "c8bce25ea68fb0312579a421df99955c", // gutsy, and last one in bash
+  "9da8d1c95748865d516764fb9af82af9", // etch, sid (last one in bash)
+};
+const int md5sumc_completion = sizeof(md5sumv_completion) / sizeof (char *);
+#endif
+
+char *check_diversion(void)
+{
+    pid_t child;
+    int pipedes[2];
+
+    if (pipe(pipedes))
+       return NULL;
+
+
+    switch(child = fork()) {
+      case -1:
+        /* fork failed */
+       close(pipedes[0]);
+       close(pipedes[1]);
+        return NULL;
+
+      case 0:
+        /* i'm the child */
+        {
+           if (dup2(pipedes[STDOUT_FILENO], STDOUT_FILENO) < 0)
+               _exit(127);
+           close(pipedes[STDIN_FILENO]);
+           close(pipedes[STDOUT_FILENO]);
+            execl( "/usr/sbin/dpkg-divert", "/usr/sbin/dpkg-divert",
+                   "--list", "/bin/sh", NULL );
+           _exit(127);
+        }
+
+      default:
+        /* i'm the parent */
+        {
+           static char line[1024];
+           FILE *fd;
+
+           close (pipedes[STDOUT_FILENO]);
+           fcntl (pipedes[STDIN_FILENO], F_SETFD, FD_CLOEXEC);
+           fd = fdopen (pipedes[STDIN_FILENO], "r");
+
+           while (fgets(line, 1024, fd) != NULL) {
+               line[strlen(line)-1] = '\0';
+               break;
+           }
+           fclose(fd);
+           return line;
+        }
+    }
+    return NULL;
+}
+
+const char *msg =
+  "As bash for Debian is destined to provide a working /bin/sh (pointing to\n"
+  "/bin/bash) your link will be overwritten by a default link.\n\n"
+  "If you don't want further upgrades to overwrite your customization, please\n"
+  "read /usr/share/doc/bash/README.Debian.gz for a more permanent solution.\n\n"
+  "[Press RETURN to continue]";
+
+int main(void) {
+    int targetlen;
+    char target[PATH_MAX+1], answer[1024], *fn;
+
+    fn = "/etc/skel/.bash_profile";
+    if (!access(fn, R_OK)) {
+      if (unmodified_file(fn, md5sumc_bash_profile, md5sumv_bash_profile)) {
+       printf("removing %s in favour of /etc/skel/.profile\n", fn);
+       unlink(fn);
+      }
+      else {
+       fn = "/etc/skel/.profile";
+       if (!access(fn, R_OK)) {
+         if (unmodified_file(fn, md5sumc_profile, md5sumv_profile)) {
+           printf("renaming /etc/skel/.bash_profile to %s\n", fn);
+           rename("/etc/skel/.bash_profile", fn);
+         }
+       }
+      }
+    }
+
+#ifdef BC_CONFIG
+    fn = "/etc/bash_completion";
+    if (!access(fn, R_OK)) {
+      if (unmodified_file(fn, md5sumc_completion, md5sumv_completion)) {
+       printf("removing unmodified %s, now in package bash-completion\n", fn);
+       unlink(fn);
+      }
+    }
+#endif
+
+    if (check_predepends() != EXIT_SUCCESS) {
+       printf("\nPlease upgrade to a new version of dpkg\n\n");
+       return EXIT_FAILURE;
+    }
+    targetlen = readlink("/bin/sh", target, PATH_MAX);
+    if (targetlen == -1) {
+       // error reading link. Will be overwritten.
+       puts("The bash upgrade discovered that something is wrong with your /bin/sh link.");
+       puts(msg);
+       fgets(answer, 1024, stdin);
+       return EXIT_SUCCESS;
+    }
+    target[targetlen] = '\0';
+    if (strcmp(target, "bash") != 0 && strcmp(target, "/bin/bash") != 0) {
+       char *diversion = check_diversion();
+
+       if (diversion == NULL)
+           return EXIT_FAILURE;
+       // printf("diversion: /%s/\n", diversion);
+       if (strcmp(diversion, "") != 0)
+           // link is diverted
+           return EXIT_SUCCESS;
+       printf("The bash upgrade discovered that your /bin/sh link points to %s.\n", target);
+       puts(msg);
+       fgets(answer, 1024, stdin);
+       return EXIT_SUCCESS;
+    }
+
+    return EXIT_SUCCESS;
+}
diff --git a/debian/bash.prerm b/debian/bash.prerm
new file mode 100644 (file)
index 0000000..52052a2
--- /dev/null
@@ -0,0 +1,22 @@
+#! /bin/bash
+
+set -e
+
+case "$1" in
+    upgrade)
+       update-alternatives --remove builtins.7.gz \
+           /usr/share/man/man7/bash-builtins.7.gz
+       ;;
+
+    remove|deconfigure)
+       ;;
+
+    failed-upgrade)
+       ;;
+    *)
+        echo "prerm called with unknown argument \`$1'" >&2
+        exit 1
+       ;;
+esac
+
+#DEBHELPER#
diff --git a/debian/bashbug.1 b/debian/bashbug.1
new file mode 100644 (file)
index 0000000..d620e63
--- /dev/null
@@ -0,0 +1,68 @@
+.TH "BASHBUG" "1" "11 December 2007" "GNU Bash 3\.1" "bashbug"
+.nh
+.ad l
+.SH "NAME"
+bashbug - report a bug in bash
+.SH "SYNOPSIS"
+.HP 8
+\fBbashbug\fR [\fB\-\-help\fR] [\fB\-\-version\fR] [\fB\fIbug\-report\-email\-addresses\fR\fR]
+.SH "DESCRIPTION"
+.PP
+
+\fBbashbug\fR
+is a utility for reporting bugs in Bash to the maintainers\.
+.PP
+
+\fBbashbug\fR
+will start up your preferred editor with a preformatted bug report template for you to fill in\. Save the file and quit the editor once you have completed the missing fields\.
+\fBbashbug\fR
+will notify you of any problems with the report and ask for confirmation before sending it\. By default the bug report is mailed to both the GNU developers and the Debian Bash maintainers\. The recipients can be changed by giving a comma separated list of
+\fIbug\-report\-email\-addresses\fR\.
+.PP
+If you invoke
+\fBbashbug\fR
+by accident, just quit your editor\. You will always be asked for confirmation before a bug report is sent\.
+.SH "OPTIONS"
+.PP
+.PP
+\fB\-\-help\fR
+.RS
+Show a brief usage message and exit\.
+.RE
+.PP
+\fB\-\-version\fR
+.RS
+Show the version of
+\fBbashbug\fR
+and exit\.
+.RE
+.PP
+\fBbug\-report\-email\-addresses\fR
+.RS
+Comma separated list of recipients\' email addresses\. By default the report is mailed to both the GNU developers and the Debian Bash maintainers\.
+.RE
+.SH "ENVIRONMENT"
+.PP
+.PP
+\fBDEFEDITOR\fR
+.RS
+Editor to use for editing the bug report\.
+.RE
+.PP
+\fBEDITOR\fR
+.RS
+Editor to use for editing the bug report (overridden by
+\fBDEFEDITOR\fR)\.
+.RE
+.SH "SEE ALSO"
+.PP
+
+\fBbash\fR(1),
+\fBreportbug\fR(1),
+\fBupdate-alternatives\fR(8)
+for preferred editor\.
+.SH "AUTHOR"
+.PP
+This manual page was written by Christer Andersson
+<klamm@comhem\.se>
+for the Debian project (but may be used by others)\.
diff --git a/debian/bashdb.copyright b/debian/bashdb.copyright
new file mode 100644 (file)
index 0000000..6b013cf
--- /dev/null
@@ -0,0 +1,430 @@
+This is Debian GNU/Linux's prepackaged version of the FSF's GNU Bash,
+the Bourne Again SHell.
+
+This package was put together by Matthias Klose <doko@debian.org>, from
+the following sources:
+
+  bash:                        ftp.gnu.org:/pub/gnu/bash/bash-2.05b.tar.gz
+  bash_completion:     http://freshmeat.net/projects/bashcompletion/
+  bashdb:              http://bashdb.sf.net/
+                       (CVS snapshot taken 20030908)
+
+Bash is free software; you can redistribute it and/or modify it under
+the terms of the GNU General Public License as published by the Free
+Software Foundation; either version 2, or (at your option) any later
+version.
+
+Bash is distributed in the hope that it will be useful, but WITHOUT
+ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+for more details.
+
+You should have received a copy of the GNU General Public License with
+your Debian GNU/Linux system, in /usr/share/common-licenses/GPL, or with
+the Debian GNU/Linux bash source package as the file COPYING.  If not,
+write to the Free Software Foundation, Inc., 59 Temple Place - Suite
+330, Boston, MA 02111-1307, USA.
+
+The Free Software Foundation has exempted Bash from the requirement of
+Paragraph 2c of the General Public License.  This is to say, there is
+no requirement for Bash to print a notice when it is started
+interactively in the usual way.  We made this exception because users
+and standards expect shells not to print such messages.  This
+exception applies to any program that serves as a shell and that is
+based primarily on Bash as opposed to other GNU software.
+
+
+bash_completion is free software; you can redistribute it and/or modify it
+under the terms of the GNU General Public License as published by the Free
+Software Foundation; either version 2, or (at your option) any later version.
+
+bashdb is free software; you can redistribute it and/or modify it
+under the terms of the GNU General Public License as published by the Free
+Software Foundation; either version 2, or (at your option) any later version.
+
+The bashdb manual is licensed under the GFDL (attached here):
+
+   This file documents the BASH debugger BASH.
+
+   This is the 2.05b rebash-0.43 Edition, April 2002, of `Debugging
+   with BASHDB: the GNU Source-Level Debugger' for REBASH
+
+   Copyright (C) 2002,2003 Rocky Bernstein for the Free Software
+   Foundation.
+
+   Permission is granted to copy, distribute and/or modify this document
+   under the terms of the GNU Free Documentation License, Version 1.1 or
+   any later version published by the Free Software Foundation; with no
+   Invariant Sections, no Front-Cover Texts, and no Back-Cover Texts.
+
+
+GNU Free Documentation License
+******************************
+
+                        Version 1.1, March 2000
+     Copyright (C) 2000  Free Software Foundation, Inc.
+     59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
+
+     Everyone is permitted to copy and distribute verbatim copies
+     of this license document, but changing it is not allowed.
+
+
+  0. PREAMBLE
+
+     The purpose of this License is to make a manual, textbook, or other
+     written document "free" in the sense of freedom: to assure everyone
+     the effective freedom to copy and redistribute it, with or without
+     modifying it, either commercially or noncommercially.  Secondarily,
+     this License preserves for the author and publisher a way to get
+     credit for their work, while not being considered responsible for
+     modifications made by others.
+
+     This License is a kind of "copyleft", which means that derivative
+     works of the document must themselves be free in the same sense.
+     It complements the GNU General Public License, which is a copyleft
+     license designed for free software.
+
+     We have designed this License in order to use it for manuals for
+     free software, because free software needs free documentation: a
+     free program should come with manuals providing the same freedoms
+     that the software does.  But this License is not limited to
+     software manuals; it can be used for any textual work, regardless
+     of subject matter or whether it is published as a printed book.
+     We recommend this License principally for works whose purpose is
+     instruction or reference.
+
+
+  1. APPLICABILITY AND DEFINITIONS
+
+     This License applies to any manual or other work that contains a
+     notice placed by the copyright holder saying it can be distributed
+     under the terms of this License.  The "Document", below, refers to
+     any such manual or work.  Any member of the public is a licensee,
+     and is addressed as "you."
+
+     A "Modified Version" of the Document means any work containing the
+     Document or a portion of it, either copied verbatim, or with
+     modifications and/or translated into another language.
+
+     A "Secondary Section" is a named appendix or a front-matter
+     section of the Document that deals exclusively with the
+     relationship of the publishers or authors of the Document to the
+     Document's overall subject (or to related matters) and contains
+     nothing that could fall directly within that overall subject.
+     (For example, if the Document is in part a textbook of
+     mathematics, a Secondary Section may not explain any mathematics.)
+     The relationship could be a matter of historical connection with
+     the subject or with related matters, or of legal, commercial,
+     philosophical, ethical or political position regarding them.
+
+     The "Invariant Sections" are certain Secondary Sections whose
+     titles are designated, as being those of Invariant Sections, in
+     the notice that says that the Document is released under this
+     License.
+
+     The "Cover Texts" are certain short passages of text that are
+     listed, as Front-Cover Texts or Back-Cover Texts, in the notice
+     that says that the Document is released under this License.
+
+     A "Transparent" copy of the Document means a machine-readable copy,
+     represented in a format whose specification is available to the
+     general public, whose contents can be viewed and edited directly
+     and straightforwardly with generic text editors or (for images
+     composed of pixels) generic paint programs or (for drawings) some
+     widely available drawing editor, and that is suitable for input to
+     text formatters or for automatic translation to a variety of
+     formats suitable for input to text formatters.  A copy made in an
+     otherwise Transparent file format whose markup has been designed
+     to thwart or discourage subsequent modification by readers is not
+     Transparent.  A copy that is not "Transparent" is called "Opaque."
+
+     Examples of suitable formats for Transparent copies include plain
+     ASCII without markup, Texinfo input format, LaTeX input format,
+     SGML or XML using a publicly available DTD, and
+     standard-conforming simple HTML designed for human modification.
+     Opaque formats include PostScript, PDF, proprietary formats that
+     can be read and edited only by proprietary word processors, SGML
+     or XML for which the DTD and/or processing tools are not generally
+     available, and the machine-generated HTML produced by some word
+     processors for output purposes only.
+
+     The "Title Page" means, for a printed book, the title page itself,
+     plus such following pages as are needed to hold, legibly, the
+     material this License requires to appear in the title page.  For
+     works in formats which do not have any title page as such, "Title
+     Page" means the text near the most prominent appearance of the
+     work's title, preceding the beginning of the body of the text.
+
+  2. VERBATIM COPYING
+
+     You may copy and distribute the Document in any medium, either
+     commercially or noncommercially, provided that this License, the
+     copyright notices, and the license notice saying this License
+     applies to the Document are reproduced in all copies, and that you
+     add no other conditions whatsoever to those of this License.  You
+     may not use technical measures to obstruct or control the reading
+     or further copying of the copies you make or distribute.  However,
+     you may accept compensation in exchange for copies.  If you
+     distribute a large enough number of copies you must also follow
+     the conditions in section 3.
+
+     You may also lend copies, under the same conditions stated above,
+     and you may publicly display copies.
+
+  3. COPYING IN QUANTITY
+
+     If you publish printed copies of the Document numbering more than
+     100, and the Document's license notice requires Cover Texts, you
+     must enclose the copies in covers that carry, clearly and legibly,
+     all these Cover Texts: Front-Cover Texts on the front cover, and
+     Back-Cover Texts on the back cover.  Both covers must also clearly
+     and legibly identify you as the publisher of these copies.  The
+     front cover must present the full title with all words of the
+     title equally prominent and visible.  You may add other material
+     on the covers in addition.  Copying with changes limited to the
+     covers, as long as they preserve the title of the Document and
+     satisfy these conditions, can be treated as verbatim copying in
+     other respects.
+
+     If the required texts for either cover are too voluminous to fit
+     legibly, you should put the first ones listed (as many as fit
+     reasonably) on the actual cover, and continue the rest onto
+     adjacent pages.
+
+     If you publish or distribute Opaque copies of the Document
+     numbering more than 100, you must either include a
+     machine-readable Transparent copy along with each Opaque copy, or
+     state in or with each Opaque copy a publicly-accessible
+     computer-network location containing a complete Transparent copy
+     of the Document, free of added material, which the general
+     network-using public has access to download anonymously at no
+     charge using public-standard network protocols.  If you use the
+     latter option, you must take reasonably prudent steps, when you
+     begin distribution of Opaque copies in quantity, to ensure that
+     this Transparent copy will remain thus accessible at the stated
+     location until at least one year after the last time you
+     distribute an Opaque copy (directly or through your agents or
+     retailers) of that edition to the public.
+
+     It is requested, but not required, that you contact the authors of
+     the Document well before redistributing any large number of
+     copies, to give them a chance to provide you with an updated
+     version of the Document.
+
+  4. MODIFICATIONS
+
+     You may copy and distribute a Modified Version of the Document
+     under the conditions of sections 2 and 3 above, provided that you
+     release the Modified Version under precisely this License, with
+     the Modified Version filling the role of the Document, thus
+     licensing distribution and modification of the Modified Version to
+     whoever possesses a copy of it.  In addition, you must do these
+     things in the Modified Version:
+
+     A. Use in the Title Page (and on the covers, if any) a title
+     distinct    from that of the Document, and from those of previous
+     versions    (which should, if there were any, be listed in the
+     History section    of the Document).  You may use the same title
+     as a previous version    if the original publisher of that version
+     gives permission.
+     B. List on the Title Page, as authors, one or more persons or
+     entities    responsible for authorship of the modifications in the
+     Modified    Version, together with at least five of the principal
+     authors of the    Document (all of its principal authors, if it
+     has less than five).
+     C. State on the Title page the name of the publisher of the
+     Modified Version, as the publisher.
+     D. Preserve all the copyright notices of the Document.
+     E. Add an appropriate copyright notice for your modifications
+     adjacent to the other copyright notices.
+     F. Include, immediately after the copyright notices, a license
+     notice    giving the public permission to use the Modified Version
+     under the    terms of this License, in the form shown in the
+     Addendum below.
+     G. Preserve in that license notice the full lists of Invariant
+     Sections    and required Cover Texts given in the Document's
+     license notice.
+     H. Include an unaltered copy of this License.
+     I. Preserve the section entitled "History", and its title, and add
+     to    it an item stating at least the title, year, new authors, and
+       publisher of the Modified Version as given on the Title Page.
+     If    there is no section entitled "History" in the Document,
+     create one    stating the title, year, authors, and publisher of
+     the Document as    given on its Title Page, then add an item
+     describing the Modified    Version as stated in the previous
+     sentence.
+     J. Preserve the network location, if any, given in the Document for
+       public access to a Transparent copy of the Document, and
+     likewise    the network locations given in the Document for
+     previous versions    it was based on.  These may be placed in the
+     "History" section.     You may omit a network location for a work
+     that was published at    least four years before the Document
+     itself, or if the original    publisher of the version it refers
+     to gives permission.
+     K. In any section entitled "Acknowledgements" or "Dedications",
+     preserve the section's title, and preserve in the section all the
+      substance and tone of each of the contributor acknowledgements
+     and/or dedications given therein.
+     L. Preserve all the Invariant Sections of the Document,
+     unaltered in their text and in their titles.  Section numbers
+     or the equivalent are not considered part of the section titles.
+     M. Delete any section entitled "Endorsements."  Such a section
+     may not be included in the Modified Version.
+     N. Do not retitle any existing section as "Endorsements"    or to
+     conflict in title with any Invariant Section.
+
+     If the Modified Version includes new front-matter sections or
+     appendices that qualify as Secondary Sections and contain no
+     material copied from the Document, you may at your option
+     designate some or all of these sections as invariant.  To do this,
+     add their titles to the list of Invariant Sections in the Modified
+     Version's license notice.  These titles must be distinct from any
+     other section titles.
+
+     You may add a section entitled "Endorsements", provided it contains
+     nothing but endorsements of your Modified Version by various
+     parties-for example, statements of peer review or that the text has
+     been approved by an organization as the authoritative definition
+     of a standard.
+
+     You may add a passage of up to five words as a Front-Cover Text,
+     and a passage of up to 25 words as a Back-Cover Text, to the end
+     of the list of Cover Texts in the Modified Version.  Only one
+     passage of Front-Cover Text and one of Back-Cover Text may be
+     added by (or through arrangements made by) any one entity.  If the
+     Document already includes a cover text for the same cover,
+     previously added by you or by arrangement made by the same entity
+     you are acting on behalf of, you may not add another; but you may
+     replace the old one, on explicit permission from the previous
+     publisher that added the old one.
+
+     The author(s) and publisher(s) of the Document do not by this
+     License give permission to use their names for publicity for or to
+     assert or imply endorsement of any Modified Version.
+
+  5. COMBINING DOCUMENTS
+
+     You may combine the Document with other documents released under
+     this License, under the terms defined in section 4 above for
+     modified versions, provided that you include in the combination
+     all of the Invariant Sections of all of the original documents,
+     unmodified, and list them all as Invariant Sections of your
+     combined work in its license notice.
+
+     The combined work need only contain one copy of this License, and
+     multiple identical Invariant Sections may be replaced with a single
+     copy.  If there are multiple Invariant Sections with the same name
+     but different contents, make the title of each such section unique
+     by adding at the end of it, in parentheses, the name of the
+     original author or publisher of that section if known, or else a
+     unique number.  Make the same adjustment to the section titles in
+     the list of Invariant Sections in the license notice of the
+     combined work.
+
+     In the combination, you must combine any sections entitled
+     "History" in the various original documents, forming one section
+     entitled "History"; likewise combine any sections entitled
+     "Acknowledgements", and any sections entitled "Dedications."  You
+     must delete all sections entitled "Endorsements."
+
+  6. COLLECTIONS OF DOCUMENTS
+
+     You may make a collection consisting of the Document and other
+     documents released under this License, and replace the individual
+     copies of this License in the various documents with a single copy
+     that is included in the collection, provided that you follow the
+     rules of this License for verbatim copying of each of the
+     documents in all other respects.
+
+     You may extract a single document from such a collection, and
+     distribute it individually under this License, provided you insert
+     a copy of this License into the extracted document, and follow
+     this License in all other respects regarding verbatim copying of
+     that document.
+
+  7. AGGREGATION WITH INDEPENDENT WORKS
+
+     A compilation of the Document or its derivatives with other
+     separate and independent documents or works, in or on a volume of
+     a storage or distribution medium, does not as a whole count as a
+     Modified Version of the Document, provided no compilation
+     copyright is claimed for the compilation.  Such a compilation is
+     called an "aggregate", and this License does not apply to the
+     other self-contained works thus compiled with the Document, on
+     account of their being thus compiled, if they are not themselves
+     derivative works of the Document.
+
+     If the Cover Text requirement of section 3 is applicable to these
+     copies of the Document, then if the Document is less than one
+     quarter of the entire aggregate, the Document's Cover Texts may be
+     placed on covers that surround only the Document within the
+     aggregate.  Otherwise they must appear on covers around the whole
+     aggregate.
+
+  8. TRANSLATION
+
+     Translation is considered a kind of modification, so you may
+     distribute translations of the Document under the terms of section
+     4.  Replacing Invariant Sections with translations requires special
+     permission from their copyright holders, but you may include
+     translations of some or all Invariant Sections in addition to the
+     original versions of these Invariant Sections.  You may include a
+     translation of this License provided that you also include the
+     original English version of this License.  In case of a
+     disagreement between the translation and the original English
+     version of this License, the original English version will prevail.
+
+  9. TERMINATION
+
+     You may not copy, modify, sublicense, or distribute the Document
+     except as expressly provided for under this License.  Any other
+     attempt to copy, modify, sublicense or distribute the Document is
+     void, and will automatically terminate your rights under this
+     License.  However, parties who have received copies, or rights,
+     from you under this License will not have their licenses
+     terminated so long as such parties remain in full compliance.
+
+ 10. FUTURE REVISIONS OF THIS LICENSE
+
+     The Free Software Foundation may publish new, revised versions of
+     the GNU Free Documentation License from time to time.  Such new
+     versions will be similar in spirit to the present version, but may
+     differ in detail to address new problems or concerns.  See
+     http://www.gnu.org/copyleft/.
+
+     Each version of the License is given a distinguishing version
+     number.  If the Document specifies that a particular numbered
+     version of this License "or any later version" applies to it, you
+     have the option of following the terms and conditions either of
+     that specified version or of any later version that has been
+     published (not as a draft) by the Free Software Foundation.  If
+     the Document does not specify a version number of this License,
+     you may choose any version ever published (not as a draft) by the
+     Free Software Foundation.
+
+
+ADDENDUM: How to use this License for your documents
+====================================================
+
+To use this License in a document you have written, include a copy of
+the License in the document and put the following copyright and license
+notices just after the title page:
+
+     Copyright (C)  YEAR  YOUR NAME.
+     Permission is granted to copy, distribute and/or modify this document
+     under the terms of the GNU Free Documentation License, Version 1.1
+     or any later version published by the Free Software Foundation;
+     with the Invariant Sections being LIST THEIR TITLES, with the
+     Front-Cover Texts being LIST, and with the Back-Cover Texts being LIST.
+     A copy of the license is included in the section entitled "GNU
+     Free Documentation License."
+
+   If you have no Invariant Sections, write "with no Invariant Sections"
+instead of saying which ones are invariant.  If you have no Front-Cover
+Texts, write "no Front-Cover Texts" instead of "Front-Cover Texts being
+LIST"; likewise for Back-Cover Texts.
+
+   If your document contains nontrivial examples of program code, we
+recommend releasing these examples in parallel under your choice of
+free software license, such as the GNU General Public License, to
+permit their use in free software.
diff --git a/debian/bashdb.emacsen-install b/debian/bashdb.emacsen-install
new file mode 100644 (file)
index 0000000..1b00b47
--- /dev/null
@@ -0,0 +1,50 @@
+#! /bin/sh -e
+# /usr/lib/emacsen-common/packages/install/bashdb
+
+# Written by Jim Van Zandt <jrv@vanzandt.mv.com>, borrowing heavily
+# from the install scripts for gettext by Santiago Vila
+# <sanvila@ctv.es> and octave by Dirk Eddelbuettel <edd@debian.org>.
+
+FLAVOR=$1
+PACKAGE=bashdb
+
+if [ ${FLAVOR} = emacs ]; then exit 0; fi
+
+# bashdb's gud.el doesn't support emacs20
+if [ ${FLAVOR} = emacs20 ]; then exit 0; fi
+
+FILES="bashdb.el gud.el"
+
+echo install/${PACKAGE}: Handling install for emacsen flavor ${FLAVOR}
+
+#FLAVORTEST=`echo $FLAVOR | cut -c-6`
+#if [ ${FLAVORTEST} = xemacs ] ; then
+#    SITEFLAG="-no-site-file"
+#else
+#    SITEFLAG="--no-site-file"
+#fi
+FLAGS="${SITEFLAG} -q -batch -l path.el -f batch-byte-compile"
+
+ELDIR=/usr/share/emacs/site-lisp/${PACKAGE}
+ELCDIR=/usr/share/${FLAVOR}/site-lisp/${PACKAGE}
+
+# Install-info-altdir does not actually exist.
+# Maybe somebody will write it.
+if test -x /usr/sbin/install-info-altdir; then
+    echo install/${PACKAGE}: install Info links for ${FLAVOR}
+    install-info-altdir --quiet --section "" "" --dirname=${FLAVOR} \
+       /usr/share/info/${PACKAGE}.info.gz
+fi
+
+install -m 755 -d ${ELCDIR}
+cd ${ELDIR}
+cp ${FILES} ${ELCDIR}
+cd ${ELCDIR}
+
+cat << EOF > path.el
+(setq load-path (cons "." load-path) byte-compile-warnings nil)
+EOF
+${FLAVOR} ${FLAGS} ${FILES}
+rm -f *.el path.el
+
+exit 0
diff --git a/debian/bashdb.emacsen-remove b/debian/bashdb.emacsen-remove
new file mode 100644 (file)
index 0000000..3a0ac72
--- /dev/null
@@ -0,0 +1,16 @@
+#!/bin/sh -e
+# /usr/lib/emacsen-common/packages/remove/bashdb
+
+FLAVOR=$1
+PACKAGE=bashdb
+
+if [ ${FLAVOR} != emacs ]; then
+    if test -x /usr/sbin/install-info-altdir; then
+        echo remove/${PACKAGE}: removing Info links for ${FLAVOR}
+        install-info-altdir --quiet --remove --dirname=${FLAVOR} \
+           /usr/share/info/${PACKAGE}.info.gz
+    fi
+
+    echo remove/${PACKAGE}: purging byte-compiled files for ${FLAVOR}
+    rm -rf /usr/share/${FLAVOR}/site-lisp/${PACKAGE}
+fi
diff --git a/debian/bashdb.emacsen-startup b/debian/bashdb.emacsen-startup
new file mode 100644 (file)
index 0000000..492c596
--- /dev/null
@@ -0,0 +1,20 @@
+;; -*-emacs-lisp-*-
+;;
+;; Emacs startup file for the Debian bashdb package
+;;
+;; Originally contributed by Nils Naumann <naumann@unileoben.ac.at>
+;; Modified by Dirk Eddelbuettel <edd@debian.org>
+;; Adapted for dh-make by Jim Van Zandt <jrv@vanzandt.mv.com>
+
+;; The bashdb package follows the Debian/GNU Linux 'emacsen' policy and
+;; byte-compiles its elisp files for each 'emacs flavor' (emacs19,
+;; xemacs19, emacs20, xemacs20...).  The compiled code is then
+;; installed in a subdirectory of the respective site-lisp directory.
+;; We have to add this to the load-path:
+(unless (eq flavor 'emacs20)
+  (let ((package-dir (concat "/usr/share/"
+                            (symbol-name flavor)
+                            "/site-lisp/bashdb")))
+    (when (file-directory-p package-dir)
+      (setq load-path (cons package-dir load-path))))
+  (autoload 'bashdb "bashdb" "Run the bash debugger." t))
diff --git a/debian/bashdb.postinst b/debian/bashdb.postinst
new file mode 100644 (file)
index 0000000..01bbd6a
--- /dev/null
@@ -0,0 +1,9 @@
+#! /bin/sh
+
+set -e
+
+install-info --quiet --section "Shells" "Shells"  \
+    --description="Debugging with the BASH debugger" \
+       /usr/share/info/bashdb.info.gz
+
+#DEBHELPER#
diff --git a/debian/bashdb.prerm b/debian/bashdb.prerm
new file mode 100644 (file)
index 0000000..f7aeb17
--- /dev/null
@@ -0,0 +1,5 @@
+#! /bin/sh -e
+
+install-info --quiet --remove bashdb
+
+#DEBHELPER#
diff --git a/debian/changelog b/debian/changelog
new file mode 100644 (file)
index 0000000..015ae15
--- /dev/null
@@ -0,0 +1,1958 @@
+bash (4.1-3slp2+s5) unstable; urgency=low
+
+  * Repackage for SLP, using Debian version as base and discarding
+    Maemo changes.
+  * Set myself as maintainer.
+  * Don't build packages: bash-static, bash-builtins, bash-doc, bashdb
+    and don't run tests.
+  * Configure with --without-bash-malloc.
+  * Drop pre-dependency on dash.
+  * Exclude preinst Debian script from building.
+  * Don't provide symlinks for /bin/sh and it's manual.
+
+ -- Rafal Krypa <r.krypa@samsung.com>  Mon, 21 Feb 2011 18:55:25 +0100
+
+bash (4.1-3) unstable; urgency=low
+
+  * Apply upstream patches 003, 004, 005.
+  * Fix crash in declare builtin.
+  * /etc/skel/.bashrc:
+    - Enable sourcing of ~/.bash_aliases by default. Closes: #569798.
+    - Find command-not-found script. Closes: #529313.
+  * README.Debian:
+    - Remove references to --disable-net-redirections, bash-minimal.
+    - Mention that the upstream changelog can be found in the bash-doc
+      package. Closes: #551019.
+
+ -- Matthias Klose <doko@debian.org>  Sat, 10 Apr 2010 10:35:29 +0200
+
+bash (4.1-2) unstable; urgency=low
+
+  * Apply upstream patches 001, 002.
+
+ -- Matthias Klose <doko@debian.org>  Fri, 12 Mar 2010 02:08:45 +0100
+
+bash (4.1-1) unstable; urgency=low
+
+  * New upstream version 4.1.
+  * Stop building the bash-minimal package, not needed anymore with
+    dash being the default shell.
+
+ -- Matthias Klose <doko@debian.org>  Sat, 02 Jan 2010 13:49:24 +0100
+
+bash (4.1~rc1-1) unstable; urgency=low
+
+  * New upstream version 4.1, release candidate 1.
+
+ -- Matthias Klose <doko@debian.org>  Wed, 30 Dec 2009 15:41:40 +0100
+
+bash (4.0-7) unstable; urgency=medium
+
+  * Re-add the sh and sh(1) symlinks. Closes: #546516.
+
+ -- Matthias Klose <doko@debian.org>  Mon, 14 Sep 2009 08:11:58 +0200
+
+bash (4.0-6) unstable; urgency=medium
+
+  * Pre-depend on dash, instead of just depending on it.
+    Closes: #546504, #546516, #546518.
+  * Update and set homepage attribute. Closes: #546377, #546381.
+
+ -- Matthias Klose <doko@debian.org>  Sun, 13 Sep 2009 13:35:38 +0200
+
+bash (4.0-5) unstable; urgency=low
+
+  * Re-add dependency on dash, lost with the upload of 4.0.
+  * Don't configure with --disable-net-redirections.
+  * Fix name of system wide bash_logout in bash(1). Closes: #546200.
+  * Stop shipping the sh and sh(1) symlinks. Closes: #545103.
+  * Apply upstream patches 029 - 033.
+
+ -- Matthias Klose <doko@debian.org>  Sun, 13 Sep 2009 12:55:54 +0200
+
+bash (4.0-4) unstable; urgency=low
+
+  * Apply upstream patches 024 - 028.
+    - patch 028 closes: #519165. bash-4.0 reverted to the historical
+      shell behavior of raising an error when $@ or $* was expanded
+      after `set -u' had been executed and there were no positional
+      parameters.  The Posix working group has since clarified the
+      standard's position on the issue, and $@ and $* are now the only
+      variables, parameters, or special parameters that do not raise an
+      error when unset if set -u is enabled.
+  * Enable net redirections, now that bash isn't the default shell
+    anymore.
+  * Changes to the skeleton .bashrc:
+    - Fix example lines in /etc/bash.bashrc to enable bash completion.
+      Closes: #523706, #522857.
+    - Don't export HISTCONTROL in bashrc. Closes: #540371.
+    - Support user dircolors settings in ~/.dircolors. Closes: #506213.
+
+ -- Matthias Klose <doko@debian.org>  Sun, 23 Aug 2009 16:09:36 +0200
+
+bash (4.0-3) experimental; urgency=low
+
+  * Apply upstream patches 011 - 024.
+
+ -- Matthias Klose <doko@debian.org>  Sun, 17 May 2009 15:29:21 +0200
+
+bash (4.0-2) experimental; urgency=low
+
+  * Apply upstream patches 001 - 010. Closes: #518289.
+  * Fix insecure temp file handling in examples scripts. Closes: #509279.
+  * /etc/skel.bashrc: Only source bash_completion, if posix mode is turned
+    off. Closes: #498474.
+
+ -- Matthias Klose <doko@debian.org>  Sat, 21 Mar 2009 15:06:46 +0100
+
+bash (4.0-1) experimental; urgency=low
+
+  * New upstream version 4.0.
+
+ -- Matthias Klose <doko@debian.org>  Sun, 01 Mar 2009 10:56:15 +0100
+
+bash (4.0-0ubuntu1) jaunty; urgency=low
+
+  * New upstream version 4.0 beta.
+
+ -- Matthias Klose <doko@ubuntu.com>  Sat, 29 Nov 2008 18:20:35 +0100
+
+bash (3.2-6) unstable; urgency=medium
+
+  * bash. Depend on dash to install dash as a required package.
+
+ -- Matthias Klose <doko@debian.org>  Mon, 20 Jul 2009 23:56:24 +0000
+
+bash (3.2-5) unstable; urgency=low
+
+  * Apply upstream fixes 040 - 048.
+
+ -- Matthias Klose <doko@debian.org>  Sun, 01 Mar 2009 10:20:52 +0100
+
+bash (3.2-4) unstable; urgency=low
+
+  * bash-minimal, bash-static: Only call `add-shell' on new installations.
+  * Only call remove-shell on package removal or purge.
+
+ -- Matthias Klose <doko@debian.org>  Mon, 12 May 2008 18:49:07 +0200
+
+bash (3.2-3) unstable; urgency=low
+
+  * /etc/skel/.bashrc: Overwrite SHELL for calling lesspipe. Closes: #385168.
+  * Only call `add-shell' on new installations. Closes: #477750.
+  * Apply upstream fixes 034 - 039.
+  * Add explicit copyright notice to clear_console(1).
+
+ -- Matthias Klose <doko@debian.org>  Sun, 20 Apr 2008 13:31:10 +0200
+
+bash (3.2-2) unstable; urgency=low
+
+  * Add a shopt option compat31 to fall back to the behaviour of bash-3.1 
+    and earlier versions, in that quoting the string argument to the [[ 
+    command's =~ +operator does not force string matching.
+
+  * Merge from Ubuntu:
+    - Remove /etc/skel/.bash_profile, if it is unmodified; if modified and
+      /etc/skel/.profile is unmodifed, move .bash_profile to .profile.
+    - /etc/skel/.bashrc: Add an option to blurt a terminal window with a
+      colored prompt.
+    - /etc/skel/.bashrc: Add color support for grep and friends (commented
+      out by default). Closes: #420659.
+    - /etc/skel/.profile: Avoid the use of `~'.
+    - Don't run command-not-found from the shell scripts when it has been
+      removed in the meantime.
+  * /etc/skel/.bashrc:
+    - Comment out the lesspipe settings. Closes: #470453.
+    - Don't use PROMPT_COMMAND to set the title of an xterm. Closes: #420656.
+    - Don't second-guess terminal handling in dircolors. Closes: #473870.
+    - Don't overwrite GNU Midnight Commander's setting of HISTCONTROL to
+      `ignorespace'. Closes: #440102.
+    - Add a comment about setting HISTSIZE and HISTFILESIZE. Closes: #449587.
+    - Append to the history file, don't overwrite it. Closes: #452459.
+    - Use dir and vdir commands for dir vdir aliases. Closes: #420661.
+  * /etc/skel/.profile:
+    - Add comment about setting the umask for ssh logins. Closes: #314533.
+
+  * Added code to defer the initialization of HISTSIZE until the history file
+    is loaded. Closes: #383762.
+  * Fix typos in README.Debian and preinst. Closes: #374452.
+  * Mention `exec' builtin in the section `redirection'. Closes: #378067.
+  * Add bashbug(1). Closes: #442477.
+  * Fix typos in bash(1). Closes: #390493, #426687.
+  * Fix bug in Bash_aliases example. Closes: #423488.
+  * Fix typo in help message for caller builtin. Closes: #452656.
+
+ -- Matthias Klose <doko@debian.org>  Sun, 20 Apr 2008 11:20:08 +0200
+
+bash (3.2-1) experimental; urgency=low
+
+  * New upstream version (including upstream patches 01 - 33). Closes: #431620.
+    - Added write error reporting to printf builtin. Closes: #414285.
+    - Fixed a bug that caused `unset LANG' to not properly reset the locale.
+      Closes: #364861.
+    - Describe expansion of pattern in case statement. Closes: #342225.
+    - Improved handling of non-printable characters in prompt. Closes: #352234,
+      #362010, #397086, #418961, #471490.
+    - Fix typos in documentation. Closes: #382892.
+
+    The syntax of regexes in Bash 3.2 was changed so that single quotes no
+    longer surround regexes. e.g, a regex of the form
+      if [[ "foo.tex" =~ '^(.*)\.tex$' ]]
+    becomes
+      if [[ "foo.tex" =~ ^(.*)\.tex$ ]]
+       
+  * Merge from Ubuntu:
+    - debian/skel.bashrc: Check for dircolors before using it.
+    - debian/skel.bashrc: Set HISTCONTROL to ignoreboth.
+    - Include correct bash.pot file.
+    - Move CWRU/changelog from the bash to the bash-doc package (we already
+      have the CHANGES files).
+    - debian/etc.bash.bashrc: Install command-not-found handler if available.
+
+ -- Matthias Klose <doko@debian.org>  Sun, 10 Feb 2008 23:49:35 +0100
+
+bash (3.1dfsg-9) unstable; urgency=low
+
+  * Remove bash-completion from the source.
+  * Remove the conflict with bash-completion, recommend bash-completion.
+  * Fix quotes in man page. Closes: #402845.
+  * clear_console: Don't segv if stdin isn't a tty. Closes: #451819.
+  * clear_console(1): Fix synopsis. Closes: #441242.
+  * Clarify bash-doc package description: Closes: #394275.
+
+ -- Matthias Klose <doko@debian.org>  Sat, 09 Feb 2008 10:14:22 +0100
+
+bash (3.1dfsg-8) unstable; urgency=high
+
+  * bash-doc: Install copyright file when building without the
+    gfdl'ed docs. Closes: #402471.
+
+ -- Matthias Klose <doko@debian.org>  Mon, 11 Dec 2006 22:08:10 +0100
+
+bash (3.1dfsg-7) unstable; urgency=medium
+
+  * Restore the bash(1) manual page. Closes: #392989.
+
+ -- Matthias Klose <doko@debian.org>  Sun, 22 Oct 2006 13:41:59 +0000
+
+bash (3.1dfsg-6) unstable; urgency=low
+
+  * Remove the texinfo documentation from the package. Closes: #357260.
+  * Remove the FAQ from the package.
+
+ -- Matthias Klose <doko@debian.org>  Thu, 12 Oct 2006 22:35:46 +0200
+
+bash (3.1-5) unstable; urgency=low
+
+  * Work around the broken remove-shell, not checking for the existance
+    of /etc/shells (closes: #337097).
+  * Force rebuild of bashref.info (closes: #354303, #357258).
+  * Apply upstream patches 015, 016, 017, fixing
+    - a problem with the extended globbing code prevented dots from matching
+      filenames when used in some extended matching patterns.
+    - core dumps when attempting to perform globbing in directories with
+      very large numbers of files.
+    - Array expansion failure with an arithmetic syntax error when the
+      subscript appears within double quotes. Closes: #358831.
+  * Add copyrights for contributed files (Joost van Baal). Closes: #357607.
+  * bash_completion:
+    - Add apt-cache madison completion: Closes: #342073, #359021.
+    - Complete files with spaces for bzip2. Closes: #356218.
+    - Complete whatis and apropos like man. Closes: #352145.
+    - Ignore stderr in apt-cache completion. Closes: #367198.
+    - Add flv|FLV files completion for mplayer. Closes: #364509, #373904.
+    - Add dvi|DVI files completion for evince. Ubuntu #49880.
+  * Fix typos in man page. Closes: #360543.
+
+  [ Ian Jackson ]
+  * Make bash die if it cannot read its input file.  Closes: #320036.
+    (This is not an ideal fix because, for example, the exit status is
+    still wrong - it should be 127, not 2.  Also, the filename is not
+    printed.  Unfortunately the code is badly tangled making this small
+    fix the most appropriate approach.)
+
+ -- Matthias Klose <doko@debian.org>  Wed,  5 Jul 2006 06:56:54 +0200
+
+bash (3.1-4) unstable; urgency=low
+
+  * Update upstream patch 010, apply upstream patches 012, 013, 014.
+  * bash-default-editor.dpatch: Fix typo (closes: #356308).
+  * clear_console: Add FreeBSD support (Aurelian Jarno). Closes: #355336.
+  * clear_console: Only get rid of any history in the scrollback, if
+    not running in a pseudo tty (closes: #355815).
+  * bash_completion:
+    - Fix error in minicom completion (closes: #357241).
+
+ -- Matthias Klose <doko@debian.org>  Thu, 23 Mar 2006 01:16:22 +0100
+
+bash (3.1-3) unstable; urgency=low
+
+  * Apply upstream patches 006, 007, 008, 009, 010 and 011.
+  * Define PGRP_PIPE to avoid race condition; monitor mode causes emacs as
+    $EDITOR to hang on kernel 2.6 (Jim Paris). Closes: #224543.
+  * Fix read memleak when reading from non-blocking fd (Tim Waugh).
+  * Recognize 'exec -l /bin/bash' as login shell (Tim Waugh).
+  * Fix parameter expansion: Array member length expansion fails with nested
+    index expression (Jan C. Nordholz). Closes: #345861.
+  * Add swedish translation of message strings. Closes: #349677.
+
+  Merge from Ubuntu:
+  * clear_console: New helper program to clear the console, including
+    the scrollback buffer.
+  * /etc/skel/.bash_logout: Install it again and use clear_console.
+    Ubuntu #29405. Closes: #331504.
+  * /etc/skel/.bashrc: Enable bash_completion.
+    Ubuntu #11414, #25096.
+  * bash_completion:
+    - Fix ssh completion to match lines starting with `Hostname' as well.
+      Closes: #343312.
+  * Add ulimit options -e and -r.
+
+  * Update bash_completion to 20060301:
+    - Completion for minicom(1), mtr(8), sysctl(8), smartctl(8), vncviewer(1),
+      invoke-rc.d, update-rc.d and dpkg-source has been added.
+      Closes: #323824, #327414.
+    - gdb completion of second parameter was broken when first parameter
+      contained white space.
+    - gdb completion wasn't completing second parameter correctly when it was
+      a file, rather than a PID.
+    - Ruby ri completion has been broken for some time. This is now fixed.
+    - Various fixes to work around change in how POSIX quoting is handled in
+      bash 3.1.
+    - subversion completion has been reimplemented from scratch and integrated
+      into the main file.
+    - iconv(1) completion has been improved.
+    - yum(8) completion has been updated for current version of yum.
+    - ant completion will now make use of complete-ant-cmd.pl, if available.
+    - cvs(1) completion has been improved with 'update' and 'stat' completion.
+    - 'aptitude show' now works in the same way as 'apt-cache show'.
+    - make(1) now also completes on file names.
+    - MPlayer will now also complete on .flac, .mpc and .3gp files.
+      Closes: #340452.
+    - wine will now also complete on .exe.so files.
+    - unzip will now also complete on oowriter's .ott files.
+    - xine et al will now complete on .mng files.
+    - The list of programs completing on .dvi files has been expanded.
+    - The range of files on which timidity and evince complete has been
+      expanded. Closes: #351848.
+    - mkisofs completion now defaults to treating results as file names.
+    - $DEBUG has been renamed $BASH_COMPLETION_DEBUG to avoid namespace clashes
+      with other software.
+    - man(1) completion now works correctly on OpenBSD.
+    - svk and Mercurial completion have been added to contribs. Closes: #324169.
+    - Many other small optimisations and fixes. Closes: #325056.
+
+ -- Matthias Klose <doko@debian.org>  Sat,  4 Mar 2006 01:54:25 +0100
+
+bash (3.1-2) unstable; urgency=low
+
+  * Apply upstream patches 002 - 005.
+
+ -- Matthias Klose <doko@debian.org>  Tue, 10 Jan 2006 00:19:25 +0100
+
+bash (3.1-0ubuntu3) dapper; urgency=low
+
+  * Document supported ulimit options.
+  * Fix parsing problems with compound assignments
+  * Fix readline callback interface.
+  * Fix ssh command completion (closes: #343312).
+
+ -- Matthias Klose <doko@ubuntu.com>  Fri, 23 Dec 2005 11:31:36 +0100
+
+bash (3.1-0ubuntu2) dapper; urgency=low
+
+  * command-not-found handler: Print error message, when command not found.
+    Ubuntu #5120.
+  * fix ssh command completion.
+
+ -- Matthias Klose <doko@ubuntu.com>  Sun, 11 Dec 2005 16:14:14 +0100
+
+bash (3.1-1) unstable; urgency=low
+
+  * New upstream version (final 3.1 release).
+    - Fixed a small memory leak in the programmable completion code.
+      Closes: #338822.
+  * Generate the locales needed for the testsuite, build-depend on locales.
+  * Improve check for existance of /dev/stdin during build. Closes: #333935.
+  * Fix bash_completion, sudo completion does not protect empty arguments.
+    Closes: #329148.
+  * /etc/bash.bashrc: Don't change the xterm title by default, keep the
+    default for /etc/skel/.bashrc. Closes: #313617, #314614.
+
+ -- Matthias Klose <doko@debian.org>  Sat, 10 Dec 2005 00:56:28 +0100
+
+bash (3.0+3.1rc1-1) unstable; urgency=low
+
+  * New upstream version (3.1-rc1).
+  * Remove patches applied upstream: rl-del-backspace-policy, bad-interp.
+
+ -- Matthias Klose <doko@debian.org>  Fri, 11 Nov 2005 12:59:32 +0000
+
+bash (3.0+3.1b1-1) unstable; urgency=low
+
+  * New upstream version (3.1-beta1).
+  * Remove bash's dependency on passwd, add one to debianutils (>= 2.15).
+
+ -- Matthias Klose <doko@debian.org>  Thu, 13 Oct 2005 15:49:49 +0200
+
+bash (3.0+3.1a1-1) unstable; urgency=low
+
+  * New upstream version (3.1-alpha1).
+    - Fix "cd -P" hanging (closes: #316407).
+    - Fixed exit status code so that a suspended job returns 128+signal as its
+      exit status (preventing commands after it in `&&' lists from being
+      executed). Closes: #288319.
+    - The globbing code now uses malloc, with its better failure properties,
+      rather than alloca(). Closes: #238226.
+    - In POSIX mode, if `xpg_echo' option is enabled, the `echo' builtin
+      doesn't try to interpret any options at all, as POSIX requires.
+      Closes: #303649.
+    - Some changes to the display code to improve display and redisplay of
+      multibyte characters. Closes: #309654.
+    - Fixed a bug that caused bash to close fd 2 if an `exec' failed and the
+      shell didn't exit. Closes: #310308.
+    - Fix segmentation fault if execve'd with NULL argv. Closes: #316206.
+    - Fix segfault, if free is called with already freed block argument.
+      Closes: #317324.
+    - Fix garbage in bash(1), section SIGNALS. Closes: #327035.
+    - Fixed vi-mode searching so that failure preserves the current line rather
+      than the last line in the history list. Closes: #297330.
+    - Fix segfault on variable assignment. Closes: #291840.
+    - Fixed parser to generate an error when the pipeline `argument'
+      to `!' or `time' is NULL. Closes: #273324, #342228.
+    - A bare `%' once again expands to the current job when used as a job
+      specifier, updated the help for `%'. Closes: #262095.
+    - Fix tilde expansion for some cases where it was performed
+      inappropriately. Closes: #263023.
+    - Replicate first character of $PS4, not only the first byte.
+      Closes: #288125.
+    - bashref.texi: Remove blank lines from contents. Closes: #307264.
+  * Remove patches applied upstream:
+    - bash30*, wcontinued, man-cdpath, update-multibyte-ifs, histtimeformat,
+      spelingm.
+    - rl-examples, rl-setenv, rl-display, rl-self-insert.
+  * Update patches:
+    - deb-bash-config, man-test, man-test2.
+  * bash(1): Fix /etc/bash.logout file name (closes: #289355).
+  * Document, that bash is configured using --disable-net-redirections.
+    Closes: #313538.
+  * Use `command -v editor`, as an editor, if available. Closes: #296603.
+
+ -- Matthias Klose <doko@debian.org>  Fri,  9 Sep 2005 21:09:46 +0200
+
+bash (3.0-17) unstable; urgency=low
+
+  * Check that the device files /dev/std{in,out,err} are present at
+    build time. Closes: #327477.
+  * Remove html completion for w3m, users claim w3m to be a general viewer.
+  * /etc/bash.bashrc: Avoid stat on /etc/debian_chroot, if not necessary.
+    Closes: #303712.
+  * debian/patches/wcontinued.dpatch: Update, fixing hangs in
+    bash_completion (Junichi Uekawa). Closes: #318301.
+  * Build-depend on texinfo (>= 4.8). Closes: #316066.
+
+ -- Matthias Klose <doko@debian.org>  Thu, 13 Oct 2005 11:24:21 +0000
+
+bash (3.0-16ubuntu3) breezy; urgency=low
+
+  * Don't install .bash_logout again, doesn't clear the buffer and
+    ps is not in required.
+
+ -- Matthias Klose <doko@ubuntu.com>  Wed,  5 Oct 2005 13:29:22 +0200
+
+bash (3.0-16ubuntu2) breezy; urgency=low
+
+  * Fix segmentation fault due to gcc optimization and longjmp. Patch
+    by Jim Paris. Debian #331381.
+  * Don't overwrite PROMPT_COMMAND in /etc/bash.bashrc. Ubuntu #15122.
+    Closes #330889.
+  * Install skeleton .bash_logout to clear the screen, when logging out
+    from the console. Ubuntu #10149.
+
+ -- Matthias Klose <doko@ubuntu.com>  Tue,  4 Oct 2005 18:01:26 +0200
+
+bash (3.0-16ubuntu1) breezy; urgency=low
+
+  * bash_completion changes:
+    - Add completion for evince.
+    - Fix completion for aptitude (Ubuntu 12549).
+      Closes: #293979, #325045, #327413.
+    - Add completion for *.flac files in mplayer (closes: #304778).
+    - Add completion for *.ott files for unzip and zipinfo (closes: #322481).
+    - Add html completion for w3m.
+
+ -- Matthias Klose <doko@ubuntu.com>  Fri,  9 Sep 2005 20:33:31 +0200
+
+bash (3.0-16) unstable; urgency=low
+
+  * Update to bash_completion 20050721 (v1.827).
+    - Fix function name in aptitude completion (closes: #304624, #320390).
+  * In PROMPT_COMMAND, use ~ instead of the complete path.
+  * Adjust for dpkg-dev (>= 1.13.9). Closes: #313546.
+
+ -- Matthias Klose <doko@debian.org>  Mon,  5 Sep 2005 18:37:19 +0200
+
+bash (3.0-15) unstable; urgency=low
+
+  * glibc-2.3.5 defines WCONTINUED, which is available only since
+    Linux 2.6.10.  On older kernels waitpid() returns -1 with errno
+    set to EINVAL if WCONTINUED is supplied in options. Retry without
+    WCONTINUED set in that case.
+
+ -- Matthias Klose <doko@debian.org>  Wed, 25 May 2005 12:38:09 +0000
+
+bash (3.0-14ubuntu1) breezy; urgency=low
+
+  * Configure the static build --without-bash-malloc.
+
+ -- Matthias Klose <doko@ubuntu.com>  Sat, 21 May 2005 07:28:25 +0000
+
+bash (3.0-15) unstable; urgency=low
+
+  * Print out bad interpreter names with trailing ^M (DOS line endings).
+    Closes: #282762.
+
+ -- Matthias Klose <doko@debian.org>  Sun, 23 Jan 2005 20:24:58 +0100
+
+bash (3.0-14) unstable; urgency=low
+
+  * Fix re-read-init-file (C-xC-r) not to read /etc/inputrc twice,
+    but /etc/inputrc and ~/.inputrc. Thanks to Vasco Pedro.
+  * Fix bug in readline's self-insert command (closes: #290103).
+  * Fix bash-builtins package description (closes: #290258).
+  * Add cross build support (closes: #283732).
+  * Update to bash_completion 20050121 (v1.786).
+    - Improve ssh2 known hosts completion. (closes: #282767).
+    - Pass over switches to metacommands like sudo, nice, exec, etc.
+      (closes: #289847)
+    - Trivial fix to allow python to be called with a path component without
+      bash displaying a bad subscript error. (closes: #290748)
+    - unzip should also work on .sxw files. (closes: #286738).
+    - Lots of commands that use _longopts() don't use filenames at all, so
+      these shouldn't be mapped with '-o filenames'. (closes: #283069, which
+      related only to wget).
+    - Make dd treat completions as filenames, which is bad for options, but
+      good for filename arguments to 'if' and 'of'. (closes: #287286).
+    - Fix lvresize errors when running as non-root (closes: #285604).
+
+ -- Matthias Klose <doko@debian.org>  Sat, 22 Jan 2005 23:08:57 +0100
+
+bash (3.0-13) unstable; urgency=low
+
+  * Update to bash_completion 20050103 (v1.772).
+  * Fix segfault in the ``reverse-search-history'' feature of the readline
+    library, if the search string matches a previously entered command (ie
+    history) and must overflow the current screen width. Closes: #288940.
+
+ -- Matthias Klose <doko@debian.org>  Wed, 12 Jan 2005 08:11:36 +0100
+
+bash (3.0-12) unstable; urgency=low
+
+  * debian/skel.bashrc: Quote dircolors invocation (closes: #285840).
+
+ -- Matthias Klose <doko@debian.org>  Sun, 19 Dec 2004 17:48:17 +0100
+
+bash (3.0-11) unstable; urgency=low
+
+  * Adjustments to the skeleton files.
+  * Fix spelling errors in the docs (closes: #281842).
+
+ -- Matthias Klose <doko@debian.org>  Wed, 17 Nov 2004 06:37:48 +0100
+
+bash (3.0-10) unstable; urgency=low
+
+  * Apply upstream patch 015-016.
+
+ -- Matthias Klose <doko@debian.org>  Thu, 11 Nov 2004 07:15:34 +0100
+
+bash (3.0-9) unstable; urgency=low
+
+  * Apply upstream patch 001-014.
+  * Document handling of parameters of the test builtin (closes: #173273).
+
+ -- Matthias Klose <doko@debian.org>  Fri, 29 Oct 2004 23:57:19 +0200
+
+bash (3.0-8) unstable; urgency=low
+
+  * Add a comment to /etc/bash.bashrc that the file is not read by
+    login shells (closes: #271413).
+  * Sync builtin CDPATH documentation with man page (closes: #259767).
+  * Document conditional file expressions acting on the target of
+    symbolic links as well (except -h, -L). Closes: #231267.
+  * Update to bash_completion 20041017 (v1.758).
+    - Unset `have' variable at end of sourcing (closes: #273809).
+    - Fix scp completion breakage when filenames contained an ampersand.
+      Closes: #262354.
+
+ -- Matthias Klose <doko@debian.org>  Sun, 17 Oct 2004 09:31:03 +0200
+
+bash (3.0-7) unstable; urgency=low
+
+  * Apply upstream patches 001-013, remove patches collected from the net.
+  * Patch bash30-003 restores a measure of backwards compatibility for the
+    `trap signum' syntax (closes: #261948).
+  * Trim skeleton files.
+
+ -- Matthias Klose <doko@debian.org>  Sun, 19 Sep 2004 09:06:36 +0200
+
+bash (3.0-6) unstable; urgency=low
+
+  * Fixed in bash-3.0:
+    - New option pipefail. If set, the return value of a pipeline is the
+      value of the last (rightmost) command to exit with a non-zero status,
+      or zero if all commands in the pipeline exit successfully.  This option
+      is disabled by default. The two oldest outstanding bash reports are
+      gone (closes: #7047, #10494).
+    - "$( substitution strangeness (closes: #187983).
+    - timestamp support in history (closes: #161057).
+  * Various updates from the net:
+    - Fix a bug in array expansion.
+    - Fix a bug in brace expansion.
+    - Handle multibyte characters in IFS values.
+    - Fix a bug, when pipefail option is set.
+    - History saved-line handling (closes: #253766, #268922).
+    - Fix parameter expansion with UTF-8 and ${#var} or ${var: -1}.
+  * Apply patch to fix non POSIX function name and avoid use of global
+    variables (Stephen Gildea). Closes: #262105.
+  * Add command_not_found_handle in non POSIX interactive shells.
+    Closes: #243015.
+  * Check for /usr/sbin/remove-shell before using it (closes: #265982).
+  * bash-builtins: Install missing header files (closes: #265259).
+  * Clarify documentation about substring expansion (closes: #192831, #203767).
+  * Fix completion on ~/../``/<tab> (closes: #261142).
+  * Clarify documentation about case-insensitive pathname expansion.
+    Closes: #141292.
+  * Apply patch to fix the display of UTF-8 characters.
+    Closes: #224916, #257540.
+
+ -- Matthias Klose <doko@debian.org>  Sat,  4 Sep 2004 10:21:23 +0200
+
+bash (3.0-5) unstable; urgency=medium
+
+  * Fix segfault and wrong behaviour running the firehol script.
+    Closes: #262438, #262642.
+  * Add  history scrolling patch patch (closes: #263064).
+  * Strip bash binary, leftover from debugging (closes: #263451).
+  * `cd -' printing the directory in non-interactive mode, non-POSIX mode
+    is new behaviour, not a bug (closes: #262619).
+  * Address build failure calling the 'binary' target directly instead of
+    dpkg-buildpackage (closes: #263797).
+  * Remove kfreebsd-gnu hack to disable bash malloc (closes: #263005).
+
+ -- Matthias Klose <doko@debian.org>  Fri,  6 Aug 2004 07:10:24 +0200
+
+bash (3.0-4) unstable; urgency=low
+
+  * Revert substitution patch trying to fix completion on ~/../``/<tab>.
+    Reopens: #261142. Closes: #261955, #262338, #262602.
+
+ -- Matthias Klose <doko@debian.org>  Sun,  1 Aug 2004 12:36:57 +0200
+
+bash (3.0-3) unstable; urgency=high
+
+  * Revert the following upstream change (until sarge is released):
+    The historical behavior of `trap' that allows a missing `action' argument
+    to cause each specified signal's handling to be reset to its default is
+    now only supported when `trap' is given a single non-option argument.
+    Addresses: #261948.
+  * Fix line wrapping (closes: #261957).
+
+ -- Matthias Klose <doko@debian.org>  Fri, 30 Jul 2004 16:17:22 +0200
+
+bash (3.0-2) unstable; urgency=medium
+
+  * Fix typo in bash-minimal's postinst. Closes: #260506.
+  * Fixed in bash-3.0:
+    - pwd builtin exiting with write error. Closes: #243872.
+
+ -- Matthias Klose <doko@debian.org>  Thu, 29 Jul 2004 07:13:13 +0200
+
+bash (3.0-1) unstable; urgency=medium
+
+  * New upstream release.
+  * Bugs fixed in this release (and the alpha/beta releases and release
+    candidates):
+    - Fixed a bug that caused the prompt to overwrite previous output when the
+      output doesn't contain a newline and the locale supports multibyte
+      characters.  This same change fixes the problem of readline redisplay
+      slowing down dramatically as the line gets longer in multibyte locales.
+      Closed: #179883.
+    - The shell no longer seg faults if the expanded value of $PS4 is null
+      and `set -x' is enabled. Closes: #165533.
+    - Don't define a default DEFAULT_MAIL_DIRECTORY, because it can cause
+      a timeout on NFS mounts. Closes: #211426.
+    - Fixed a bad interaction between alias and completion. Closes: #186218.
+    - Fix initialization of local variables with "$@". Closes: #180290.
+    - Fixed segfault in "read -a foo <<< $(echo)". Closes: #167003.
+    - Fixed the history word tokenizer to handle <( and >( better when used as
+      part of bash. Closes: #165212.
+    - Fixed EINTR signal killing redirection. Closes: #164134.
+    - Fixed infinite loop with IFS="<non-ws-char>" and compgen -W.
+      Closes: #162952.
+    - Fixed the internal logout code so that shells that time out waiting for
+      input (using $TMOUT) run ~/.bash_logout. Closes: #152847.
+    - Speedups to the multibyte character redisplay code. Closes: #197965.
+    - Better error message on wrong kill arguments. Closes: #193570.
+    - Overwriting of prompt. Closes: #176968.
+    - The shell now reports on processes that dump core due to signals when
+      invoked as `-c command'. Closes: #211693.
+    - Fixed ferror beeing called w/o always first calling clearerr
+      results in spurious errors reported. Closes: #195116.
+    - Add missing trailing slash on directory completion. Closes: #178828.
+    - Fix different behaviour for builtin and external commands together
+      with arithmetic expansion. Closes: #173744.
+    - Fixed a bug that caused redirections accompanying a null command
+      to persist in the current shell. Closes: #173148.
+    - Fixed a bug that caused a leading `-' in the shell's name to cause it to
+      not be recognized as a restricted shell. Closes: #170298.
+    - Fix segfault in ill formed paramter expansion. Closes: #162773.
+    - Fixed a bug in brace expansion that caused a quoted `$' preceding an
+      open brace to inhibit brace expansion. Closes: #157954.
+    - Removed the attempts to avoid adding a slash at the end of a completed
+      executable name if there was a directory with the same name in the
+      current directory. Closes: #155134, #189006.
+    - Fix error message for circular alias expansions. Closes: #173588.
+    - Fixed a bug that caused some key bindings set in an inputrc to be ignored
+      at shell startup. Closes: #110969.
+    - Fix segfault on bad array subscripts. Closes: #232653.
+    - Fix "set completion-ignore-case on" breaking some tab completion.
+      Closes: #224303.
+    - Flag an error when a user uses "% DIGITS" instead of "%DIGITS", and
+      don't give him a different job instead. Closes: #173854.
+    - For 'cd filename' say 'not a directory', not 'no such file or directory'
+      when filename exists and is not a directory. Closes: #219958.
+    - Expansion results are the same for ${1:+"$@"} and "$@" if IFS is not
+      the default.
+    - The locale code does a better job of recomputing the various locale
+      variable values when LC_ALL is unset. Closes: #160932.
+    - Fix substitution error triggering an assertion. Closes: #251801.
+  * Documentation updated in this release (and the alpha/beta releases):
+    - Fix documentation about exit status of unset builtin. Closes: #183352.
+    - Clarify documentation for arguments of wait builtin. Closes: #174133.
+    - Document ${!prefix@} expansion. Closes: #168318.
+    - Fix documentation of GLOBIGNORE behaviour. Closes: #168267.
+    - Document the use of $EMACS. Closes: #174744.
+    - Improve documentation of the value of arithmetic expressions.
+      Closes: #168321.
+    - Make docs more explicit about variable indirection in shell parameter
+      expansion. Closes: #167002.
+    - Documentation for values of various assignments updated. Closes: #168331.
+    - In section "Shell Functions", add documentation for syntax,
+      which bash accepts. Closes: #172971.
+    - Fix documentation of the PATH variable. Closes: #155369.
+    - Document SHELL variable in section "Shell Variables". Closes: #249657.
+    - Remove reference to missing section in rbash(1). Closes: #249219.
+  * Fix another segfault in completion code. Closes: #261142.
+
+ -- Matthias Klose <doko@debian.org>  Tue, 27 Jul 2004 21:23:42 +0200
+
+bash (2.05b-2-22) unstable; urgency=low
+
+  * Brown paperbag ... Fix typo in bash-minimal's postinst.
+
+ -- Matthias Klose <doko@debian.org>  Tue, 20 Jul 2004 23:04:56 +0200
+
+bash (2.05b-2-21) unstable; urgency=low
+
+  * Remove the pre-dependency on passwd.
+  * Explicitely check for the existance of /usr/sbin/add-shell.
+  * Reassign #257744 to debootstrap to correctly handle the installation.
+
+ -- Matthias Klose <doko@debian.org>  Mon, 19 Jul 2004 22:57:19 +0200
+
+bash (2.05b-2-20) unstable; urgency=medium
+
+  * Make passwd a pre-dependency (closes: #257744).
+
+ -- Matthias Klose <doko@debian.org>  Sat, 17 Jul 2004 06:56:38 +0200
+
+bash (2.05b-2-19) unstable; urgency=low
+
+  * Build using gcc, not gcc-3.4 (closes: #259208).
+
+ -- Matthias Klose <doko@debian.org>  Tue, 13 Jul 2004 21:25:28 +0200
+
+bash (2.05b-2-18) unstable; urgency=low
+
+  * Tighten dependency on passwd (closes: #257717).
+  * Update to bash_completion 20040711 (v1.737).
+    - Fix mutt folder completion (closes: #248635).
+  * Fix tab completion on relative path directories (closes: #189006).
+  * Modify lib/malloc/malloc.c to make it compile with gcc-3.4 (Andreas
+    Jochens). Closes: #258456.
+
+ -- Matthias Klose <doko@debian.org>  Tue, 13 Jul 2004 06:15:46 +0200
+
+bash (2.05b-2-17) unstable; urgency=low
+
+  * Add dependencies on passwd (closes: #257630).
+
+ -- Matthias Klose <doko@debian.org>  Sun,  4 Jul 2004 22:56:17 +0200
+
+bash (2.05b-2-16) unstable; urgency=low
+
+  * Handle shells using add-shell/remove-shell (closes: #254476).
+  * Update to bash_completion 20040704 (v1.731).
+    - Add autocompletion for dpkg -P, --purge (closes: #241042, #249934).
+    - Fix mutt folder completion (closes: #248635).
+    - Add autossh to ssh completions (closes: #252090).
+    - Emacs completion does not discard .tar* archives (closes: #252347).
+    - Add MS filename extensions to OpenOffice (closes: #252635).
+    - Add completion for tar.Z files (closes: #254896).
+    - Fix problems with sed-4.1 (closes: #256000).
+    - Fix dpkg completion with multiple arguments (closes: #257544).
+  * Fix formatting in bash(1). Closes: #248344.
+
+ -- Matthias Klose <doko@debian.org>  Sun,  4 Jul 2004 16:07:24 +0200
+
+bash (2.05b-2-15) unstable; urgency=low
+
+  * Fix a bug that caused a leading `-' in the shell's name to cause it to
+    not be recognized as a restricted shell (closes: #170298).
+  * Fix option in menu file (closes: #162152).
+  * Backout patches/random patch (closes: #242111).
+  * Update to bash_completion 20040331 (v1.700).
+  * Update skeleton files and /etc/bash.bashrc to include the contents
+    of /etc/debian_chroot in the prompt, if the file exists.
+  * Add openoffice completions (closes: #244611).
+  * Remove ee (eeyes) completion (closes: #240668). eeyes isn't distributed
+    anymore.
+  * bash(1): Document ~/.bash_login and ~/.profile in FILES section.
+    Closes: #204766.
+  * Apply patch from http://www.savarese.org/posix/ to improve the mail
+    checking code so it won't check (and possibly cause an NFS file system
+    mount) until MAILPATH or MAIL is given a value. Closes: #211426.
+  * Add missing dependency in debian/rules (closes: #247413).
+
+ -- Matthias Klose <doko@debian.org>  Sat,  8 May 2004 18:36:41 +0200
+
+bash (2.05b-2-14) unstable; urgency=low
+
+  * Add bash reference manual in PDF format (closes: #202849).
+  * Remove FAQ; the license doesn't allow modification (closes: #231157).
+  * debian/copyright: Name the copyright holders (closes: #233716).
+  * Update to bash_completion 20040214 (v1.690).
+    - Make xspec parsing immune to comments (closes: #226812).
+    - Another fix to sudo completion: "sudo completion is virtually
+      impossible to get right. It's just a question of choosing what
+      aspect of it is the least annoying to leave broken. :-("
+      Closes: #223094.
+    - xine can also complete on .asx files (closes: #231356).
+    - Speedup dpkg completion (closes: #232585).
+    - Fix chsh completion (closes: #232214).
+  * Disable the GNU/kFreeBSD kludge (--without-bash-malloc). Closes: #234137.
+
+ -- Matthias Klose <doko@debian.org>  Sun, 22 Feb 2004 13:31:03 +0100
+
+bash (2.05b-2-13) unstable; urgency=medium
+
+  * Apply patch to speedup display of characters under multibyte locales.
+    Thanks to Denis Barbier. Closes: #197965.
+  * Update to bash_completion 20040101 (v1.672).
+    - Closes: #215030, #224981.
+    - Include completion for sitecopy in contrib directory (closes: #223294).
+  * Fix typo in man page (closes: #224477).
+  * Don't build bashdb anymore. Not ready for use. Closes: #224573, #224566.
+  * Document /etc/bash.bashrc in bash man page (closes: #216403).
+
+ -- Matthias Klose <doko@debian.org>  Sat, 24 Jan 2004 21:20:25 +0100
+
+bash (2.05b-2-12) unstable; urgency=low
+
+  * Update to bash_completion 20031022 (v1.644).
+  * Fix "suspend" segfaults in non-interactive shells (closes: #217188).
+  * Rename bashdb's gud.el to gud-bashdb.el (closes: #220002).
+
+ -- Matthias Klose <doko@debian.org>  Mon, 10 Nov 2003 23:53:35 +0100
+
+bash (2.05b-2-11) unstable; urgency=medium
+
+  * Tighten automake build dependency (closes: #215350).
+  * Add dependency line for bashdb (closes: #215634).
+  * /etc/skel/.bashrc: set xterm's title as we do for PS1 (closes: #176734).
+  * Remove build dependency on readline (closes: #215165).
+  * Update to bash_completion 20031007 (v1.630).
+
+ -- Matthias Klose <doko@debian.org>  Tue, 14 Oct 2003 20:37:23 +0200
+
+bash (2.05b-2-10) unstable; urgency=low
+
+  * Update to bash_completion 20030911 (v1.624).
+
+ -- Matthias Klose <doko@debian.org>  Mon, 22 Sep 2003 11:43:39 +0200
+
+bash (2.05b-2-9.1) unstable; urgency=low
+
+  * Added build dependency on texi2html (closes: #211151).
+  * Create site-lisp directory in bashdb target.
+
+ -- Herbert Xu <herbert@debian.org>  Thu, 18 Sep 2003 18:39:51 +1000
+
+bash (2.05b-2-9) unstable; urgency=low
+
+  * Recompilation fixes segfaults in bash-static (closes: #205185).
+  * Build debugger enabled bash binary (bash-bashdb). Closes: #195877.
+  * Update to bash_completion 20030821 (v1.617). Closes: #203859, #205741.
+  * Adjust config.guess triplet for GNU/FreeBSD (closes: #194182).
+  * Fix package description (closes: #202344).
+
+ -- Matthias Klose <doko@debian.org>  Mon,  8 Sep 2003 23:34:50 +0200
+
+bash (2.05b-2-8.1) unstable; urgency=low
+
+  * Fixed versioned dependency of bash-builtins (closes: #196421).
+  * Call dh_fixperms in bash-minimal.
+
+ -- Herbert Xu <herbert@debian.org>  Sat,  7 Jun 2003 12:44:18 +1000
+
+bash (2.05b-2-8) unstable; urgency=low
+
+  * Apply upstream patches 005, 006, 007.
+    006 addresses the LSB 1.3 test suite failures (closes: #184888).
+    007 addresses ~ command working with UTF-8 locales (closes: #179946).
+  * Build a minimal shell in package bash-minimal (closes: #176164).
+    Sort of fix for reports complaining that /bin/sh does have
+    additional features compiled in (closes: #183185).
+  * Build a static shell in package bash-static (closes: #138089).
+  * Update to bash_completion 20030527 (v1.571) (closes: #167852, #171523,
+    #184738, #185711, #189535, #192282).
+  * /etc/skel.profile: Export MANPATH (commented out). Closes: #180717.
+  * Add menu entry for bash (closes: #187596).
+  *
+  * Install info docs as bashref.info, symlink to bash.info (closes: #174674).
+  * Fix segfault with builtin shift, no arguments and "shopt -s shift_verbose".
+    Closes: #159996.
+  * Update config.{sub,guess} (closes: #179737).
+  * Fix apt-cache search completion (closes: #184144).
+  * Configure --without-bash-malloc on GNU/FreeBSD (closes: #194182).
+
+ -- Matthias Klose <doko@debian.org>  Thu, 29 May 2003 17:00:53 +0200
+
+bash (2.05b-7) unstable; urgency=medium
+
+  * Fix rbash man page (closes: #181248).
+  * On m68k-linux, bash is miscompiled using gcc-3.2 and gcc-snapshot.
+    Revert back to gcc-2.95.
+
+ -- Matthias Klose <doko@debian.org>  Fri, 28 Feb 2003 00:54:22 +0100
+
+bash (2.05b-6) unstable; urgency=low
+
+  * First upload compiled using gcc-3.2 as the default compiler.
+  * Update to bash_completion 20030126 (v1.520) (closes: #168478, #145481,
+    #150628, #158039, #168700, #169232, #169586, #171161, #171420, #171523,
+    #173096, #177654).
+
+ -- Matthias Klose <doko@debian.org>  Mon, 27 Jan 2003 21:08:19 +0100
+
+bash (2.05b-5) unstable; urgency=high
+
+  * Build-depend on bison-1.35 (closes: #167635).
+
+ -- Matthias Klose <doko@debian.org>  Mon,  4 Nov 2002 09:30:39 +0100
+
+bash (2.05b-4) unstable; urgency=low
+
+  * Ignore *~ and *.bak files in /etc/bash_completion.d/ (closes: #161027).
+  * debian/patches/rl-mbutil.dpatch: Fix segfault in mbutil.c.
+  * Update to bash_completion 20021026 (v1.462) (closes: #161671, #162161,
+    #163096, #163097, #164890, #165937).
+  * Apply fix for debian/bash.preinst.c (closes: #162424).
+  * Avoid warning in s390 build (closes: #160731).
+  * /etc/skel.bashrc: Add commented example to set the `checkwinsize'
+    option (maybe closes: #161984).
+  * Install builtins manpage as bash-builtins(7), add an alternative
+    builtins(7) with priority 10 (closes: #166082).
+  * Fix typo in documentation of deprecated arithmethic expansion.
+    Closes: #161386.
+  * rl-8bit-init.dpatch: Apply (closes: #164809).
+  * README.Debian: Removed invalid entry about ssh (closes: #159754).
+
+ -- Matthias Klose <doko@debian.org>  Tue, 24 Sep 2002 12:40:35 +0200
+
+bash (2.05b-3) unstable; urgency=low
+
+  * Apply upstream patch 003 (Fix completing executable names).
+    Closes: #155134, #159466.
+  * Apply upstream patch 004.
+  * Fix completion by TAB in quoted sequence(`...`) with Multibyte Locale.
+    Patch from Satoshi Koike (closes: #155436).
+  * Update to bash_completion 20020909 (v1.410) (closes: #154595, #155211,
+    #155706).
+  * Don't set umask in /etc/skel/.bash_profile (closes: #155973).
+  * Drop suggestion of grep-dctrl (closes: #156351).
+
+ -- Matthias Klose <doko@debian.org>  Fri,  9 Aug 2002 05:30:24 +0200
+
+bash (2.05b-2) unstable; urgency=medium
+
+  * Apply upstream patches:
+    - Fix a command completion problem (closes: #154273).
+    - Fix a segfault (closes: #154123).
+    - Fix for repeating an edit in vi mode.
+  * Fix typo in /etc/skel/.bashrc (closes: #153856).
+  * Update to bash_completion 20020727 (v1.390) (closes: #148873, #153045).
+  * Install info docs in "Shells" section (closes: #154618).
+
+ -- Matthias Klose <doko@debian.org>  Fri,  2 Aug 2002 19:24:28 +0200
+
+bash (2.05b-1) unstable; urgency=low
+
+  * New upstream version:
+    - Fixed a problem with process substitution that resulted in incorrect
+      behavior when the number of process substitutions in an individual
+      command approached 64 (closes: #149229).
+    - Added putenv, setenv, unsetenv to getenv replacement (closes: #149262).
+    - Fixed bug, where bash incorrectly reports failure to execute a script.
+      Closes: #126620, #140819.
+    - Fixes an `out of memmory in pipe' error (closes: #134004).
+    - Fixed a bug that could cause the -O expand_aliases invocation option
+      to not take effect (closes: #122362).
+    - New code to handle multibyte characters (obsoletes and closes: #25131,
+      #118724).
+    - Fixed the /= and %= arithmetic operators to catch division by zero.
+      Closes: #148950.
+    - Fixed abort in completion of absolute filenames (closes: #136625).
+    - Fixed "declare -f"'s handling of here-documents (closes: #127452).
+    - Documentation for `==' adds hint for POSIX compliance (closes: #137741).
+    - Not reproducible anymore with new upstream version. Upstream regards
+      these as fixed (closes: #142906, #143811, #144375).
+    - Fix bug in `compgen -W' (closes: #143518).
+    - Fix memory corruption error printing error message (closes: #145229).
+    - Unreproducible with the new upstream version (closes: #135062).
+    - Fixed a bug that caused a syntax error when a command was terminated by
+      EOF (closes: #147258).
+    - Fixed a problem which caused the display to be messed up when the last
+      line of a multi-line prompt (possibly containing invisible characters)
+      was longer than the screen width (closes: #137268).
+    - The `home' and `end' keys are now bound to beginning-of-line and
+      end-of-line, respectively, if the corresponding termcap capabilities
+      are present (closes: #89026, #89034, #98029, #107453, #107897, #116943,
+      #119491, #128687, #130029).
+    - Fixed a bug that could cause the -O expand_aliases invocation option
+      to not take effect (closes: 148505).
+    - Bash now correctly honors setting LANG to some value when LC_ALL does not
+      already have a value (closes: #145597).
+    - The `unset' builtin no longer returns a failure status when asked to
+      unset a previously-unset variable or function (closes: #98743).
+    - Changes to make reading and writing the history file a little faster, and
+      to cope with huge history files without calling abort(3) from xmalloc.
+      Closes: #61006.
+  * Fixed in earlier versions of bash:
+    - Fixed a bug that caused SIGINT to kill shell scripts after the script
+      called `wait' (closes: #14658).
+    - Handling of ANSI sequences in PS1 (closes: #60914).
+    - ctrl+z when running while-loop puts bash in broken state (closes: #98521).
+  * Fix build error (closes: #151681).
+  * bash suggests bash-doc (closes: #152353).
+  * /etc/skel/.bashrc: Only enable color support for ls, when $TERM != dumb.
+    Closes: #143361.
+  * Report is missing any information. Bug submitter didn't respond.
+    Closes: #130051.
+  * Close a report for a sefault in bash-2.03, which cannot be reproduced
+    anymore in newer versions (2.05) (closes: #58404).
+  * Add the README.commands document to the doc directory. Reassign #106170
+    to doc-linux-text.
+  * Update to bash_completion 20020716 (v1.383) (closes: #145938).
+
+ -- Matthias Klose <doko@debian.org>  Fri, 19 Jul 2002 22:33:25 +0200
+
+bash (2.05a-12) unstable; urgency=low
+
+  * Update to bash_completion 20020528 (v1.335) (closes: #141970, #142015,
+    #142859, #144335, #146152, #146309, #146693).
+    Put the the contributed completion files into /usr/share/doc.
+  * Suggest grep-dctrl, which is called by the completion code. Added
+    note to README.bash_completion, that the completion code depends on it.
+    Closes: #146152.
+  * Mention bash_completion in the package description (closes: #146878).
+  * Fix brace expansion (Fix by Richard Kettlewell <rjk@greenend.org.uk>).
+    Forwarded. Closes: #144983.
+
+ -- Matthias Klose <doko@debian.org>  Thu, 30 May 2002 23:50:40 +0200
+
+bash (2.05a-11) unstable; urgency=medium
+
+  * Don't mishandle negative pid in `kill' builtin (closes: #133927, #137742).
+  * builtins(1) doesn't document `for' (closes: #118755).
+  * Add /usr/share/bash_completion directory to source package specific
+    completion files.
+  * Update to bash_completion 20020408 (v1.264).
+    Closes: #133109, #139375, #139675, #134713, #141134.
+  * Add completion to /etc/skel/.bashrc (commented out). Closes: #138921.
+
+ -- Matthias Klose <doko@debian.org>  Mon,  8 Apr 2002 20:51:41 +0200
+
+bash (2.05a-10) unstable; urgency=medium
+
+  * Init seed of random generator in subshells (patch from Miha Tomsic).
+  * Update to bash_completion 20020330 (v1.237).
+    Closes: #138673, #138707, #139110 and #139675.
+  * Strip bash(1) again (closes: #138902).
+
+ -- Matthias Klose <doko@debian.org>  Sun, 31 Mar 2002 08:08:26 +0200
+
+bash (2.05a-9) unstable; urgency=low
+
+  * Fix bug reading /etc/bash_completion.d files.
+
+ -- Matthias Klose <doko@debian.org>  Sat, 16 Mar 2002 00:54:28 +0100
+
+bash (2.05a-8) unstable; urgency=low
+
+  * A last bash_completion bug fix upload (updated to v1.195,
+    see changelog.bash_completion.gz for details).
+    All files in /etc/bash_completion.d are read before ~/.bash_completion
+    is read. Files containing a dot are ignored.
+    Included completion extensions (closes: #129661, #137725, #137732).
+
+ -- Matthias Klose <doko@debian.org>  Tue, 12 Mar 2002 23:25:21 +0100
+
+bash (2.05a-7) unstable; urgency=low
+
+  * A bash_completion bug fix upload (updated to v1.180,
+    see changelog.bash_completion.gz for details). Really closes: #133825.
+
+ -- Matthias Klose <doko@debian.org>  Thu,  7 Mar 2002 00:06:14 +0100
+
+bash (2.05a-6) unstable; urgency=medium
+
+  * Configure --without-bash-malloc. At least on hppa, this fixes an error,
+    which shows up when building gcc or kernels:
+    malloc: /build/buildd/bash-2.05a/unwind_prot.c:284: assertion botched
+    free: called with unallocated block argument
+  * A bash_completion bug fix upload (updated to v1.163,
+    see changelog.bash_completion.gz for details).
+    Closes: #133111, #133112, #133116, #133825, #134296.
+  * Updated service completion patch (Ian Macdonald).
+
+ -- Matthias Klose <doko@debian.org>  Sat,  2 Mar 2002 00:27:22 +0100
+
+bash (2.05a-5) unstable; urgency=medium
+
+  * A bash_completion bug fix upload (updated to v1.93,
+    see changelog.bash_completion.gz for details).
+    Closes: #129106, #130167, #129033, #129228, #129451, #129884, #132309,
+    #132529, #132552, #132553.
+    Ian even added completion for Quake! Horrible ...
+  * Include service completion patch.
+  * README.bash_completion: Fix reference to /etc/bash.bashrc (closes: #129816).
+
+ -- Matthias Klose <doko@debian.org>  Wed,  6 Feb 2002 22:22:09 +0100
+
+bash (2.05a-4) unstable; urgency=high
+
+  * Fix for causing a segmentation fault when some special shell variables
+    are declared as array (therefore urgency high).
+  * Apply patch for function prototypes (closes: #124004, #124362).
+  * Capitalize `POSIX' in package description (closes: #124439).
+  * Add (commented) setting of MANPATH to /etc/skel/.bash_profile
+    (closes: #123792).
+  * Update builtins(1) (closes: #125673).
+  * Taken from the current upstream sources: Make the symlinked directory
+    completion behavior introduced in readline-4.2a a user-settable option.
+    If `mark-symlinked-directories' is set to `on', the symlinked directory
+    completion behavior is disabled, and symlinks that point to directories
+    have a slash appended.
+  * Add a script for programmable bash completion (version 1.53) from
+    http://www.caliban.org/bash/index.shtml#completion. Add commented
+    code into /etc/bash.bashrc and (closes: #127645).
+  * Install the changelog _and_ the CHANGES file to the doc dir.
+  * bash(1): mention quoting when assigning to FIGNORE (closes: #115290).
+
+ -- Matthias Klose <doko@debian.org>  Sat, 12 Jan 2002 16:00:08 +0100
+
+bash (2.05a-3) unstable; urgency=low
+
+  * Include version.h in /usr/include/bash (closes: #120069).
+  * Link statically with readline and history to speed up link time
+    (and was done in bash-2.03). Closes: #107160.
+  * Add comment to set HISTCONTROL in /etc/skel/.bashrc (closes: #118132).
+
+ -- Matthias Klose <doko@debian.org>  Sat,  8 Dec 2001 12:29:28 +0100
+
+bash (2.05a-2) unstable; urgency=high
+
+  * Update config.{sub,guess} from ftp://ftp.gnu.org/pub/gnu/config/.
+
+ -- Matthias Klose <doko@debian.org>  Fri, 16 Nov 2001 19:07:06 +0100
+
+bash (2.05a-1) unstable; urgency=medium
+
+  * New upstream release.
+  * This is mainly a bugfix and code cleanup release (as you can see
+    from the version number as well). Fixes 64bit issues and index
+    overflow errors. Fixes the following Debian reports:
+    - Segmentation fault in script from report (closes: #119250).
+    - Extensions to the printf command (closes: #72320).
+    - Accept an empty list of items in a for loop (as ash does).
+      Closes: #91983.
+    - A bug that caused redirections with (...) subshells to be performed in
+      the wrong order was fixed (closes: #97551).
+    - Correctly handle errors from pipelines in andor lists (closes: #102196).
+    - Subshells of login shells no longer source ~/.bash_logout when they exit
+      (closes: #117701).
+    - Don't pass unset shell variable in the environment (closes: #117673).
+  * Upstream integrates the following Debian patches:
+    - debian/patches/mailcheck.dpatch: check for mail in the maildir format.
+    - debian/patches/gnu-source.dpatch: define GNU_SOURCE and include
+      strsignal prototype.
+    - Don't include -I/usr/include in CFLAGS.
+    - debian/patches/print-cmd.dpatch: Fixed an unassigned variable problem
+      in the redirection printing code.
+    - debian/patches/64bit.dpatch: 64-bit uncleanliness.
+  * Unable to reproduce behaviour with beta1, rc1 and final version from
+    report (closes: #110483, #110484).
+  * Point to the bash-doc package for example startup files (closes: #117642).
+  * The man page is precises: comments start with a word beginning with a `#'.
+    With '\ #', the doesn't start a word. Closes: #115118.
+
+ -- Matthias Klose <doko@debian.org>  Wed, 14 Nov 2001 22:13:21 +0100
+
+bash (2.05a-0rc1) unstable; urgency=low
+
+  * New upstream (bugfix) release (release candidate).
+  * Add README.abs-guide, a pointer to the `Advanced Bash Scripting Guide'.
+
+ -- Matthias Klose <doko@debian.org>  Fri,  2 Nov 2001 10:59:11 +0100
+
+bash (2.05a-0beta1) unstable; urgency=low
+
+  * New upstream (bugfix) release.
+  * Configured with --enable-largefile.
+  * Bugs fixed in this version. Closes: #72320, #91983, #97551, #102196,
+    #105231, #110483, #110484.
+  * Remove debian/patches/mailcheck.dpatch, included upstream.
+  * Closes: #61006. Logging history commands in the history cannot work.
+  * Not a bug (closes: #100743, #110604).
+
+ -- Matthias Klose <doko@debian.org>  Thu, 11 Oct 2001 23:05:20 +0200
+
+bash (2.05-10) unstable; urgency=medium
+
+  * Rebuild with released libreadline library (closes: #113182).
+
+ -- Matthias Klose <doko@debian.org>  Sun, 23 Sep 2001 01:16:48 +0200
+
+bash (2.05-9) unstable; urgency=medium
+
+  * Remove files left from test build (closes: #110307, #109807).
+  * Apply patches from reports (closes: #110275, #110276).
+  * Fix include of rbash man page (closes: #113111).
+
+ -- Matthias Klose <doko@debian.org>  Sat, 22 Sep 2001 11:26:44 +0200
+
+bash (2.05-8) unstable; urgency=low
+
+  * Apply patch (Eric Gillespie) to define GNU_SOURCE and include
+    strsignal prototype (closes: #109807).
+  * Fix include of builtins man page (closes: #109917).
+
+ -- Matthias Klose <doko@debian.org>  Sun, 26 Aug 2001 08:35:47 +0200
+
+bash (2.05-7) unstable; urgency=high
+
+  * Remove config.{cache,status} from source package (#107679).
+    (high urgency for hurd).
+  * /etc/skel/.bashrc: Fix dircolors invocation (closes: #107373).
+    Add commented code to set xterm's title to the prompt.
+
+ -- Matthias Klose <doko@debian.org>  Mon,  6 Aug 2001 23:33:41 +0200
+
+bash (2.05-6) unstable; urgency=low
+
+  * Apply upstream patches p5, p6.
+  * Include missing header files in builtins package (closes: #105302).
+  * Don't list names of built-in commands in NAME section of builtins(1).
+    (closes: #99532).
+  * Document deprecated syntax of arithmetic evaluation (closes: #94266,
+    #95502).
+  * README.Debian: Document unsetting of SSH_CLIENT (closes: #88032).
+
+ -- Matthias Klose <doko@debian.org>  Sat, 21 Jul 2001 18:41:10 +0200
+
+bash (2.05-5) unstable; urgency=low
+
+  * The behavior of range specificiers within bracket matching expressions
+    in the pattern matcher (e.g., [A-Z]) depends on the current locale,
+    specifically the value of the LC_COLLATE environment variable.
+    See /usr/share/doc/COMPAT.gz, 14. Closes #95285.
+  * Tagging reports as 'wontfix' and closing reports:
+    - exit status of pipes (#7047, #10494).
+    - completion behaviour on ':' (#78991).
+    - */text* completion (#21645).
+  * Documentation of command hashing is documented (#76135).
+
+ -- Matthias Klose <doko@debian.org>  Thu, 26 Apr 2001 09:03:37 +0200
+
+bash (2.05-4) unstable; urgency=low
+
+  * Apply upstream patches p1-p4 (closes #92455).
+  * Fixed in bash-2.05-alpha1: closes #47588.
+
+ -- Matthias Klose <doko@debian.org>  Wed, 25 Apr 2001 19:32:36 +0200
+
+bash (2.05-3) unstable; urgency=low
+
+  * Add 'Replaces: bash-doc (<= 2.05-1)' (closes: #93799).
+
+ -- Matthias Klose <doko@debian.org>  Fri, 13 Apr 2001 01:15:19 +0200
+
+bash (2.05-2) unstable; urgency=medium
+
+  * Tighten build dependency (fixes #93509). Only an issue for upgrades
+    from bash-2.05-0, therefore urgency=medium.
+  * Remove changelog from bash package (also in bash-doc). Reported as
+    #93446, #93454, #93455.
+  * Fixed in bash-2.04, wrong example in report (#33822).
+  * Documented behaviour (ulimit, #72898).
+  * Use of redirection for #92324.
+  * sed, awk, ... builtins should be provided by the specific package.
+    there are other ways to make system scripts faster (ash, perl,
+    python, ...) (#61648).
+  * Unable to reproduce #34977 submitted for version 2.02.1, bug submitter
+    didn't respond to inquiries. Closing ...
+  * http://metalab.unc.edu/pub/Linux/docs/HOWTO/other-formats/html_single/Text-Terminal-HOWTO.html
+    as explanation for C-s behaviour (#68387, not sure why I missed this
+    for so long).
+  * Part one of the report is Posix.2 behaviour; part 2 (cd-ing relatively
+    from a subdirectory into a specified root-level directory) already
+    fixed in bash-2.04. #65316.
+  * Closing #13645. "The `-l' option should never have been documented, and it
+    was a mistake to include it in the first place -- it screws up the grammar.
+    Old Bourne shells and test commands had it because there was no other
+    way to find the length of a variable's value.  Since bash has
+    ${#variable}, there's no need for it.  POSIX.2 says, in the rationale,
+    that implementation is irregular and that the shell supports it directly
+  * Unable to reproduce #19211 submitted for version 2.01 in current
+    versions (2.04, 2.05).
+  * Close #2301, safe creation of temp files is documented in bash(1):
+    "If the redirection operator is >, and the noclobber option to the set
+    builtin has been enabled, the redirection will fail if the file whose
+    name results from the expansion of word exists and is a regular file.
+    If the redirection operator is >|, or the redirection operator is > and
+    the noclobber option to the set builtin command is not enabled, the
+    redirection is attempted even if the file named by word exists."
+  * Fixed upstream in 2.05: #84743.
+  * #76596: Bourne-style shells have always accepted multiple directory name
+    arguments to cd.  If the user doesn't like it, have him define a shell
+    function (see README.Debian).
+  * bash already has enabled the system wide /etc/bash.bashrc (#82117).
+  * #88223: Starting bash with --posix, or -o posix, or as `sh', does make
+    the entire bash session posix-compliant (with the caveats noted in the
+    info manual).  Posix-compliant does not mean `behaves exactly like
+    historical versions of sh', nor does it mean `does only what is in
+    the standard and nothing more'.
+
+    Posix says nothing about brace expansion, so whether or not bash does
+    brace expansion in posix mode has no bearing on posix compliance.
+
+    If you don't want brace expansion, use `set +o braceexpand' or
+    `set +B' or start bash with the `+B' option.
+
+  * Lower temporarily severity of #92455, so that this version can move
+    to testing. This bug exists in 2.04 as well, so we don't make things
+    worse.
+  * Apply upstream patch 1.
+
+ -- Matthias Klose <doko@debian.org>  Mon,  9 Apr 2001 23:29:24 +0200
+
+bash (2.05-1) unstable; urgency=low
+
+  * New upstream release.
+  * /etc/skel/.bashrc: fix alias (#92440).
+
+ -- Matthias Klose <doko@debian.org>  Mon,  9 Apr 2001 18:24:10 +0200
+
+bash (2.05-0beta2) unstable; urgency=low
+
+  * New upstream release 2.05-beta2.
+  * Fixed upstream: #85234.
+
+ -- Matthias Klose <doko@debian.org>  Thu, 29 Mar 2001 23:57:12 +0200
+
+bash (2.05-0beta1) unstable; urgency=low
+
+  * New upstream release 2.05-beta1.
+  * Fixed upstream: #66891, #67519, #68931, #72898, #75104, #75315, #75957,
+    #76603, #84906.
+    Reverted behaviour: #60375, #75540.
+  * /etc/skel/.bash_logout: Removed. Submitted bug report to util-linux.
+    Fixes #63025, #72327, #83609.
+  * Depend on makeinfo (fixes #87688).
+
+ -- Matthias Klose <doko@debian.org>  Tue,  6 Feb 2001 18:46:40 +0100
+
+bash (2.05-0alpha) unstable; urgency=low
+
+  * New upstream release.
+
+ -- Matthias Klose <doko@debian.org>  Sun, 26 Nov 2000 17:32:16 +0100
+
+bash (2.04-9) unstable; urgency=low
+
+  * Fix build bug.
+
+ -- Matthias Klose <doko@debian.org>  Mon, 20 Nov 2000 23:35:03 +0100
+
+bash (2.04-8) unstable; urgency=low
+
+  * debian/control: Add bison to Build-Depends (fixes #73667).
+  * debian/rules: Add config.h to bash-builtins package (fixes #69802).
+    Strip bash binary (fixes #71252).
+
+ -- Matthias Klose <doko@debian.org>  Sat, 18 Nov 2000 14:01:54 +0100
+
+bash (2.04-7) unstable; urgency=low
+
+  * debian/skel.bash_logout: Fix to clear all ttys (fixes #67772).
+  * debian/skel.bash_profile: Fix to include expanded ~/bin in path
+    (fixes #67714).
+  * Fix builtins.1 include (fixes #67094, #70007, #71848).
+  * debian/README.Debian: Document that bash is compiled with
+    -DSYS_BASHRC (fixes #66939).
+  * Fix hsuser doc (fixes #69392).
+
+ -- Matthias Klose <doko@debian.org>  Mon,  2 Oct 2000 01:26:45 +0200
+
+bash (2.04-6) unstable; urgency=low
+
+  * debian/skel.bash_profile: Clarify where to look for for example files
+    (package bash-doc). Fixes #64311.
+  * debian/README.Debian: Explain, why bash is configured without
+    '--enable-net-redirections' (fixes #66352).
+
+ -- Matthias Klose <doko@debian.org>  Wed, 28 Jun 2000 19:47:25 +0200
+
+bash (2.04-5) unstable; urgency=low
+
+  * debian/patches/alpha-unwind.dpatch: Patch from "Mikolaj J. Habryn"
+    <fe78734e@eris.rcpt.to>. Should fix #62170, #62690, #65053.
+  * debian/rules: Configure with --disable-net-redirections (as suggested
+    in #65172). The patch submitted in the report can be found in
+    debian/patches/tcp-udp-service-names.dpatch.
+  * debian/patches/getcwd-error: Fix error message for two levels of
+    unreadable directories (#64659).
+
+ -- Matthias Klose <doko@debian.org>  Mon,  5 Jun 2000 05:59:59 +0200
+
+bash (2.04-4) unstable; urgency=low
+
+  * debian/patches/p[5-7].dpatch: Upstream patches.
+
+ -- Matthias Klose <doko@debian.org>  Wed,  3 May 2000 01:05:23 +0200
+
+bash (2.04-3) unstable; urgency=low
+
+  * debian/patches/p[1-4].dpatch: Upstream patches.
+  * debian/bash.preinst.c: s/MAX_PATH/PATH_MAX/g (fixes #62323).
+
+ -- Matthias Klose <doko@debian.org>  Wed, 26 Apr 2000 19:53:16 +0200
+
+bash (2.04-2) unstable; urgency=low
+
+  * debian/patches/pattern-operator.dpatch: Fix pattern operator bug.
+  * debian/README.Debian: Add FAQ how to get rid off beeps for ambiguous
+    completions (fixes #59550).
+
+ -- Matthias Klose <doko@debian.org>  Sat,  8 Apr 2000 22:06:34 +0200
+
+bash (2.04-1) unstable; urgency=low
+
+  * Final release.
+  * Don't strip bash (debugging #58404 ...).
+
+ -- Matthias Klose <doko@debian.org>  Mon, 20 Mar 2000 19:37:44 +0100
+
+bash (2.04-0beta5db1) unstable; urgency=low
+
+  * New upstream version, beta 5, Debian build 1.
+  * Remove six dpatch files with patches now integrated upstream.
+  * Bugs fixed with this upstream version: #5703, #15165, #21363, #21901,
+    #33900, #36652, #38804, #41916, #47179, #47990, #50353, #56209, #57544.
+  * Compiled with NON_INTERACTIVE_LOGIN_SHELLS to run the startup files when
+    not in posix mode. Fixes #11938, #14287, #25245.
+  * Still in this version: #27090.
+  * The `-l' option to test is not included by intent (fixes #13645).
+    Comment from upstream: "The `-l' option should never have been documented,
+    and it was a mistake to include it in the first place -- it screws up the
+    grammar. Old Bourne shells and test commands had it because there was no
+    other way to find the length of a variable's value.  Since bash has
+    ${#variable}, there's no need for it.  POSIX.2 says, in the rationale,
+    that implementation is irregular and that the shell supports it directly.
+  * Report #26720: perl -e 'print ":;" x 100000' > foo; . ./foo   dumps core.
+    Comment from upstream: This is not a bash bug; it is a process resource
+    problem.  The default resource limit for stack size is 8M on my version of
+    Linux. The call tree created by the parser for the script (100000 calls
+    to `:') is 99999 nodes deep, and requires that many recursive calls to the
+    command execution routines.  This overflows the stack, and bash segfaults.
+    I couldn't reproduce it anywhere but Linux, because the machines I tested
+    on all have reasonable default stack sizes.  Raising the limit to 16M is
+    sufficient to cause the script to run successfully (I didn't try anything
+    between 8M and 16M).
+  * Report #30460: redirection is different from standard: bash --posix
+    $ mkdir foo; cd foo; echo anything goes > "this file"
+    $ for f in *; do tr ay \ o < $f | cat; done
+    sh: $f: ambiguous redirect
+    This is POSIX.2 behaviour.
+  * debian/bash.preinst.c: Check if /bin/sh points to something other than
+    bash and is not diverted and point to README.Debian how to divert
+    a file (fixes #34717, #45656).
+  * debian/patches/random.dpatch: Fix bug in patch (closes #38804).
+  * debian/README.Debian: Commented behaviour from report #50853.
+
+ -- Matthias Klose <doko@debian.org>  Thu, 24 Feb 2000 19:34:10 +0100
+
+bash (2.03-6) frozen unstable; urgency=medium
+
+  * debian/bash.preinst.c: Evil kludge, deal with arbitrary name lengths
+    (fixes #54876).
+  * Apply NMU (fixes #55887).
+  * debian/rules: Install debian/bash.conffiles (fixes #57963, #58541).
+
+ -- Matthias Klose <doko@debian.org>  Sun, 20 Feb 2000 19:50:48 +0100
+
+bash (2.03-5.1) unstable; urgency=low
+
+  * debian/patches/job-control-segfault.dpatch: Patch from Eric Weigel
+    <ericw@bestnet.org>.  Closes: #55887
+
+ -- Adam Heath <doogie@debian.org>  Sat, 22 Jan 2000 15:10:50 -0600
+
+bash (2.03-5) unstable; urgency=low
+
+  * Update rl.ctrl-char patch from Dan Jacobowitz.
+    Fixes #54805, #54639, #54612.
+  * Add autoconf to Build-Depends (finally, Roman ...)
+
+ -- Matthias Klose <doko@debian.org>  Tue, 11 Jan 2000 20:50:31 +0100
+
+bash (2.03-4) unstable; urgency=low
+
+  * debian/control: Fix build dependencies (fixes #52777).
+  * debian/rules: Cleanup.
+  * debian/patches/rl-ctrl-char.dpatch: Don't assume char is signed by
+    default (fixes #53252).
+  * Build with libncurses5-dev (fixes #54165).
+  * Fix changelog symlink in bash-doc package (fixes #54240).
+  * debian/README.Debian: Add paragraph for writing prompts.
+  * debian/README.Debian: Add paragraph about hashing of moved commands
+    (and closing #36877).
+  * Install more verbose skeleton files (closes #39728).
+  * The `-l' option to test is not included by intent (fixes #13645).
+    Comment from upstream: "The `-l' option should never have been documented,
+    and it was a mistake to include it in the first place -- it screws up the
+    grammar. Old Bourne shells and test commands had it because there was no
+    other way to find the length of a variable's value.  Since bash has
+    ${#variable}, there's no need for it.  POSIX.2 says, in the rationale,
+    that implementation is irregular and that the shell supports it directly.
+  * Report #26720: perl -e 'print ":;" x 100000' > foo; . ./foo   dumps core.
+    Comment from upstream: This is not a bash bug; it is a process resource
+    problem.  The default resource limit for stack size is 8M on my version of
+    Linux. The call tree created by the parser for the script (100000 calls
+    to `:') is 99999 nodes deep, and requires that many recursive calls to the
+    command execution routines.  This overflows the stack, and bash segfaults.
+    I couldn't reproduce it anywhere but Linux, because the machines I tested
+    on all have reasonable default stack sizes.  Raising the limit to 16M is
+    sufficient to cause the script to run successfully (I didn't try anything
+    between 8M and 16M).
+  * Report #30460: redirection is different from standard: bash --posix
+    $ mkdir foo; cd foo; echo anything goes > "this file"
+    $ for f in *; do tr ay \ o < $f | cat; done
+    sh: $f: ambiguous redirect
+    This is POSIX.2 behaviour.
+  * debian/bash.preinst.c: Check if /bin/sh points to something other than
+    bash and is not diverted and point to README.Debian how to divert
+    a file (fixes #34717, #45656).
+
+ -- Matthias Klose <doko@debian.org>  Fri,  7 Jan 2000 07:19:00 +0100
+
+bash (2.03-3) unstable; urgency=low
+
+  * Moved /etc/profile to base-files package (closes #52987).
+  * debian/skel.bash_profile: Use umask 022 as in debian/etc.profile
+    (closes #53020).
+  * debian/patches/secure-build.dpatch: Build bash without using guessable
+    file names in /tmp (closes #36027).
+  * debian/patches/bashbug-editor.dpatch: Use editor command, not emacs
+    (closes #32576, #32577).
+  * Fixed in 2.03 or before: #16013, #20455, #30803 (according to upstream
+    author, bug submitter does not respond).
+  * #44015 not a bug. Bash is more liberal than POSIX specifies, but function
+    names that are not identifiers is something that may go away in the future.
+  * #40242 not a bug: Non-interactive bash shells have always unset PS1,
+    so scripts and so on can test for it.
+  * Report #21645: */text* completion doesn't work anymore. According to the
+    upstream author, this feature was removed in bash-2.01.1.  The TAB
+    completion only succeeds with globbing characters if there is a single
+    completion.  It caused too many problems otherwise.
+  * Define DONT_REPORT_SIGPIPE: We don't want to see `Broken pipe' messages
+    when a job like `cat jobs.c | exit 1' is executed. Fixes part of #7047,
+    #10259, #10433 and #10494. Comment from the upstream author: "The default
+    bash behavior with respect to the exit status of a pipeline will not
+    change.  Changing it as suggested in the discussion of #10494 would render
+    bash incompatible with every other shell out there.". Closed these reports.
+  * debian/etc.bash.bashrc: Set checkwinsize.
+
+ -- Matthias Klose <doko@debian.org>  Sun, 19 Dec 1999 15:58:43 +0100
+
+bash (2.03-2) unstable; urgency=low
+
+  * Apply privmode patch (do not drop privileges, if called as /sh.
+    Closes #52586).
+
+ -- Matthias Klose <doko@debian.org>  Mon, 13 Dec 1999 22:25:22 +0100
+
+bash (2.03-1) unstable; urgency=low
+
+  * New maintainer.
+  * New upstream version (closes: #34077, #35642, #46916). For a terse
+    description of new features and bug fixes see /usr/share/doc/bash/NEWS.gz.
+  * Fixed in upstream release (closes: #14229, #16856, #21363, #22498, #28849,
+    #29863, #37971, #38411, #40930, #49702). #37971 either here or in libc6.
+    #30803.
+  * Separate out documentation and examples to bash-doc package.
+  * Do not build shared readline libs from this source. According to the
+    upstream author: "It's not appropriate to build shared libraries from
+    the readline shipped with bash.  That is designed to be linked directly
+    into bash."
+  * Link statically with included libreadline. It's intended, because
+    potato does not have a libreadline4 yet. Wait for bash-2.04 and
+    it's version of libreadline.
+  * debian/README.Debian: Sort of FAQ suggested by Guy Maor.
+  * debian/copyright: Updated URL.
+  * debian/rules: Introduced some variables for packages and directories.
+  * debian/control: Updated package names. Add Build-Depends.
+  * Point to /usr/doc/share in man pages (rbash.1, builtins.1).
+  * Make /usr/doc compatibility links (all but libreadline.postinst, which
+    is a C file).
+  * debian/patches/conf-update.dpatch: New config files from automake
+    (closes #33745).
+  * debian/patches/bashbug-editor.dpatch: Use EDITOR variable
+    (closes #32576, #32577).
+  * debian/etc.profile: Fixed comment that /etc/profile is used for Bourne
+    shell and Bourne compatible shells (closes: #3459).
+  * debian/patches/tempnam.dpatch: Applied patch from report #35975
+    (closes: #35975).
+  * bash is not responsible for setting $USER in login shells (closes: #36103).
+  * Compile with -DSYS_BASHRC defined. /etc/bash.bashrc is empty by default
+    (closes #27055).
+  * Fixed with boot-floppies 2.1.3 (closes: #22517).
+  * debian/patches/mailcheck.dpatch: Add maildir support. Patch from
+    Miquel van Smoorenburg <miquels@cistron.nl> (closes #38794).
+  * Patches from NMU are applied (should close #43096).
+  * debian/control: Make builtins depend on source version of bash.
+  * Build for i386, not i486.
+  * Report #28811: "dpkg segfaults trying to install bash. Logging in then
+    produces segfault. Still having to run 2.00.0(1)". Not reproducable.
+  * Report #15165: "If the last command in the pipeline is killed by a signal,
+    bash does not report it even though $? contains the correct value".
+    Not reproducable.
+  * Report #21645: "If you type `rm */text*<TAB>', previous versions would
+    complete text given that they're under the same directory. 2.01.1-1
+    doesn't do that anymore.". Not documented anywhere. It seems, this was
+    a bug disguised as a feature ;-)
+  * Report #36027: "During compiling bash package, files with hardcoded names
+    are created in /tmp. In a malicious multi-user environment, this allows
+    attacks to the user's files and possibly allow creating trojan packages.
+    If the compiling user is root...".
+    Submitter cannot be reached. autoconf/automake issues? Reassign to general?
+  * Report #16700: "bash terminated when I asked it "mailq -v", while in an
+    xterm, with a sysload of approx 1"; not reproducable. Submitter offers
+    core file.
+  * Report #37637: Not reproduceable (should close #37637).
+  * Report #37275: A dpkg error? Or just another reason to completely link
+    bash statically?
+  * Report #34978, #42858: The prerm now is a binary pragram.
+    #34977 as well? #36016 (patch)?
+  * Report #43737: Non bug. Behaviour changed from 1.4 to 2.0 (closes: #43737).
+  * Report #36459: Non bug (closes #36459).
+  * Report #19211: Wanted behaviour?
+  * Report #11938: The included patch is applied upstream (closes: #11938).
+  * Report #10699, #45656: Todo: See #34717 ...
+  * Report #35127: Apply included patch. TODO: test and forward upstream.
+  * Report #41082: Obsoleted patches (closes: #35130, #41802).
+  * Reports tested and still in this version (should be forwarded ...):
+    #2301, #21901, #26619, #26720, #27090, #30460, #33900, #34833,
+    #36877
+    #38804, #41916 (update docs?),
+    #46901, #47990.
+  * Report #47849: You *must* reset OPTIND to 1 before reusing getopts.
+  * Report #45841: This is a POSIX.2/XPG5 requirement.
+  * Report #35979, #45379: set -e works on simple commands only.
+    (command) is not a simple command.
+  * Report #38244: -x and -v and all of the rest of the options are documented
+    in the `set' builtin section.  The OPTIONS section of the man page refers
+    to `set'.
+  * Report #37654: When in a pipeline, `tty' prints `not a tty'.  This is why
+    grep is looking for `not' in file `a'.  Try `w | echo $(tty)'.
+  * Report #33822: This is a locale problem.  The de_DE locale gives lower case
+    and upper case letters the same collating weight.  POSIX.2 warns that
+    range expressions are not portable across locales.
+  * Report #28789, #22291: resizing xterm bash doesn' t update window limits.
+    Use `shopt -s checkwinsize'. (closes: #28789, #22291).
+  * Report #39728: Suggestion to add something to /etc/skel files. A matter
+    of taste. Added comments where to find `fancy' startup files.
+
+  * Work needed: #33822 (huh?), #42916 and #44015 (update docs, dashs in
+    identifiers).
+
+  * Not tested: (#7047, #10259, #10433, #10494), #14287 (how to test?),
+    #14658 (how to test?), #16013, #16797, #20455 (alpha arch), #20821,
+    #22632, #26571, #29610, #35994 (powerpc arch),
+    #36652, #40242, #47179.
+
+ -- Matthias Klose <doko@debian.org>  Sat,  4 Dec 1999 17:03:47 +0100
+
+bash (2.02.1-1.8) unstable; urgency=low
+
+  * Applied Anthonies patch and recompiled as the libc5 version did
+    not compile for him (closes: #34717, #43050, #43096, #10699).
+  * Bumped the version number of libreadline and recompiled,
+    hopefully in time before the dinstall run ;)
+
+ -- Torsten Landschoff <torsten@debian.org>  Sat, 18 Sep 1999 19:26:20 +0200
+
+bash (2.02.1-1.7) unstable; urgency=low
+
+  * Non-maintainer release.
+  * Make bash not Pre-Depend on itself. That is, make bash's preinst
+    something other than a /bin/sh script; in this case a reasonably
+    simple binary.
+  * Remove /bin/sh from the .deb, and reinstate it in the postinst if
+    it's not already present. Hence make the postinst a /bin/bash script
+    instead of a /bin/sh script.
+
+ -- Anthony Towns <ajt@debian.org>  Sat, 28 Aug 1999 01:09:08 +1000
+
+bash (2.02.1-1.6) unstable; urgency=low
+
+  * Non-maintainer release.
+  * Link bash statically with libreadline. Closes: #42858.
+
+ -- Thomas Quinot <thomas@debian.org>  Fri, 13 Aug 1999 21:47:35 +0200
+
+bash (2.02.1-1.5) unstable; urgency=low
+
+  * Non-maintainer release.
+  * Updated to standards version 3.0.0.
+  * Fixed dependency on libreadlineg2. Closes: #35130, #39280, #41802.
+
+ -- Thomas Quinot <thomas@debian.org>  Thu, 29 Jul 1999 13:05:26 +0200
+
+bash (2.02.1-1.4) unstable; urgency=low
+
+  * Non-maintainer release.
+  * Make libreadlineg2 conflict with bash (<< 2.02.1-1.2)
+
+ -- Joel Klecker <espy@debian.org>  Thu, 25 Mar 1999 09:40:39 -0800
+
+bash (2.02.1-1.3) unstable; urgency=low
+
+  * Non-maintainer release.
+  * Recompile against ncurses 4.2-3.2 for versioned dependency.
+  * Add (>= 2.1-13.1) depend to readline shlibs.
+
+ -- Joel Klecker <espy@debian.org>  Thu, 18 Mar 1999 12:33:28 -0800
+
+bash (2.02.1-1.2) unstable; urgency=low
+
+  * Non-maintainer release.
+  * Recompile against glibc 2.1 for libreadline.
+
+ -- Joel Klecker <espy@debian.org>  Fri,  5 Mar 1999 09:36:54 -0800
+
+bash (2.02.1-1.1) unstable; urgency=low
+
+  * Non-maintainer upload.
+  * Replaced config.{sub,guess} with newer ones for ARM.
+
+ -- Jim Pick <jim@jimpick.com>  Mon, 22 Feb 1999 23:57:53 -0800
+
+bash (2.02.1-1) unstable; urgency=low
+
+  * libreadline 2.1-13
+  * Upstream upgrade, closes: #26582
+  * Bugs fixed upstream: closes: #21511, #24004.
+  * Rules, control fixes for hurd, powerpc, alpha closes: #29123, #29395,
+    #24931, #31289.
+  * Included paren-matching feature in readline, closes: #27707.
+  * Removed convert-meta comment from etc/inputrc, closes: #23035.
+  * Use system random instead of lousy builtin one, closes: #22104.
+
+ -- Guy Maor <maor@debian.org>  Mon, 15 Feb 1999 12:57:53 -0800
+
+bash (2.01.1-4.1) unstable; urgency=low
+
+  * Non-maintainer upload.
+  * libreadline 2.1-12
+  * Rebuild with ncurses4.0 to avoid packages linked with libreadline
+    depending on two versions of ncurses; reported by Martin Mitchell
+    <martin@debian.org>. [#27762]
+  * debian/rl.shlibs: bump versioned dependency to >= 2.1-12.
+  * debian/rules (build): add --with-curses to avoid ever linking with
+    termcap; reported by, ehm, Guy Maor <maor@debian.org>. [#25118]
+
+ -- James Troup <james@nocrew.org>  Tue, 20 Oct 1998 03:24:03 +0100
+
+bash (2.01.1-3.1) frozen unstable; urgency=low
+
+  * Non-maintainer release.
+  * Build with ncurses3.0-altdev, so libreadline2 doesn't depend on libc6.
+  * Use <architecture>-linux instead of <arch>-debian-linux.
+
+ -- Joel Klecker <jk@espy.org>  Tue, 14 July 1998 16:26:43 -0700
+
+bash (2.01.1-3) unstable frozen; urgency=medium
+
+  * libreadline 2.1-10
+  * Make libreadlineg2's postinst a c program, like libreadline2.
+  * Check return code from tempfile in bashbug, closes: #22349.
+  * glibc 2.1 patch, closes #22532.
+  * remove . from /etc/profile PATH, closes #22738.
+
+ -- Guy Maor <maor@ece.utexas.edu>  Mon, 25 May 1998 22:41:06 -0700
+
+bash (2.01.1-2) unstable frozen; urgency=high
+
+  * libreadline 2.1-9.
+  * Predepend on libreadlineg2 >= 2.1-8, closes: #20572.
+
+ -- Guy Maor <maor@ece.utexas.edu>  Wed,  8 Apr 1998 01:07:10 -0700
+
+bash (2.01.1-1) frozen unstable; urgency=low
+
+  * libreadline 2.1-8.
+  * Upstream upgrade, closes: #13762, #14446, #18296.
+  * Fixed /etc/inputrc, closes: #19745, #19075, #13643, #18004, #17256,
+    #15345, #14672, #15213, #15345, #15638, #18004, #16797, #15638, #19241.
+  * Applied patch to read End, Delete, closes: #20053.
+  * Don't build libc5 packages on alpha & powerpc, closes: #13761, #15538,
+    #15829.
+  * Add sh(1) - symlink to bash(1), close: #15659.
+  * Fix unsafe requests in rbash(1), builtins(1), closes: #19086.
+  * bashbug uses tempfile, closes: #19781.
+  * fixed fc -l segfault, closes: #13726.
+
+ -- Guy Maor <maor@ece.utexas.edu>  Sat, 28 Mar 1998 19:34:15 -0800
+
+bash (2.01-5) unstable; urgency=low
+
+  * libreadline 2.1-7
+  * libreadline tries INPUTRC if it's set, else _both_ /etc/inputrc and
+    ~/.inputrc
+  * A better /etc/inputrc.
+
+ -- Guy Maor <maor@ece.utexas.edu>  Thu, 25 Sep 1997 11:38:41 -0500
+
+bash (2.01-4) unstable; urgency=low
+
+  * libreadline 2.1-6
+  * bash-builtin examples moved to correct place.
+  * libreadline tries /etc/inputrc if ~/.inputrc doesn't exist.
+  * set -a; set +a problem seems to be fixed (8390)
+
+ -- Guy Maor <maor@ece.utexas.edu>  Wed, 24 Sep 1997 14:36:02 -0500
+
+bash (2.01-3) unstable; urgency=low
+
+  * libreadline 2.1-5
+  * Bash depended on wrong version of libreadlineg2. (#12150, #12316)
+  * Put current version in libreadlineg2 shlibs file.
+  * Honor TMPDIR by using tempnam(3) (#9201).
+
+ -- Guy Maor <maor@ece.utexas.edu>  Sun, 24 Aug 1997 23:31:19 -0500
+
+bash (2.01-2) unstable; urgency=low
+
+  * libreadline 2.1-4
+  * Make bash predepend on libreadlineg2 (>=2.01-1) so as not to break
+    systems which installed James's releases.
+  * Fix references to shell runtime code in libreadline.so and libhistory.so.
+  * Fix declare -p dumping core on empty temp variable (#12017).
+  * make_quoted_replacement() checks for empty rl_filename_quote_characters
+    (12051).
+  * readline/readline.h - rl_dispatching should be extern (#11049).
+  * Added libreadline2g-dbg.
+
+ -- Guy Maor <maor@ece.utexas.edu>  Sat, 16 Aug 1997 13:38:37 -0500
+
+bash (2.01-1) unstable; urgency=low
+
+  * libreadline 2.1-3
+  * Maintainer release of 2.01.  (2.01 fixes 3815, 4783, 7782, 8439, 10416,
+    10598, 10604, 11806).
+  * Cleaned and corrected rules, Makefiles, control files. (7580, 11406).
+  * Reimplemented SHELL compile time as runtime check.  Backward compatible
+    with old bash (10916).
+  * Added rbash man page (8645).
+  * ldconfig run in postinst, compiled as libc5 (10176)
+  * :( set -a;set +a problem still there, but acts differently.
+
+ -- Guy Maor <maor@ece.utexas.edu>  Thu, 14 Aug 1997 15:35:23 -0500
+
+bash (2.01-0.1) unstable; urgency=high
+
+  * libreadline 2.1-2.2
+  * libreadline2 now has a preinst script which ensures that ld.so.1
+    knows about /lib/libc5-compat and /usr/lib/libc5-compat.  Before this
+    change, trying to install with a libc (< 5.4.23-4) broke bash.
+  * libreadlineg2 no longer has version dependant shlibs file [#10742].
+
+ -- James Troup <jjtroup@comp.brad.ac.uk>  Mon, 23 Jun 1997 22:00:18 +0100
+
+bash (2.01-0) unstable; urgency=medium
+
+  * libreadline 2.1-2.1
+  * Non-maintainer release
+  * New upstream version [#10416, #10598, #10604, #8390]
+  * Rebuilt for glibc; now provides libreadline2g{,-dev} and
+    libreadline2{,-altdev}.
+  * Not all of Guy's changes are implemented, noticeably a security
+    improvement in execute-cmds.c and his alteration of libreadline's
+    compile time dependance on -DSHELL to run time dependance.
+
+ -- James Troup <jjtroup@comp.brad.ac.uk>  Thur, 19 June 1997 19:13:34 +0100
+
+bash (2.0-3) unstable; urgency=medium
+
+  * libreadline 2.1-2
+  * #include <sys/types.h> in general.h needed for alpha build (#7658)
+  * Don't drop suid/sgid bits if invoked as sh (#7796)
+  * Applied patch to fix time in for loop (#7436)
+  * Split off bash-builtins with examples & necessary headers
+  * Juggled libreadline2 documentation around (#7275)
+
+ -- Guy Maor <maor@ece.utexas.edu>  Mon, 10 Mar 1997 12:45:06 -0600
+
+bash (2.0-2) unstable; urgency=low
+
+  * Added NEWS, COMPAT to /usr/doc/bash
+
+ -- Guy Maor <maor@ece.utexas.edu>  Fri, 7 Feb 1997 17:35:21 -0600
+
+bash (2.0-1) unstable; urgency=low
+
+  * Upstream upgrade.
+  * .bash_history created 600 by default.
+  * Security improvements when creating files in /tmp
+  * Reimplemented SHELL run-time check with backward 2.0 compatibility
+
+ -- Guy Maor <maor@ece.utexas.edu>  Wed, 29 Jan 1997 03:31:47 -0600
+
+bash (1.14.7-2) frozen unstable; urgency=low
+
+  * libhistory.so had wrong soname (fixes bug 5381).
+
+ -- Guy Maor <maor@ece.utexas.edu>  Sat, 16 Nov 1996 11:07:08 -0600
+
+bash (1.14.7-1) frozen unstable; urgency=low
+
+  * New upstream version converted to new source format.
+    libreadline2, libreadline2-dev produced from bash source.
+  * Made libreadline SHELL define into a runtime check with rl_shell,
+    history_shell flags, 4 hooks.
+  * echo checks write errors (fixes 818).
+  * default unreadable .bash_history in /etc/skel (fixes 1549).
+
+ -- Guy Maor <maor@ece.utexas.edu>  Sat, 9 Nov 1996 05:07:31 -0600
diff --git a/debian/changelog.saved b/debian/changelog.saved
new file mode 100644 (file)
index 0000000..b996994
--- /dev/null
@@ -0,0 +1,8 @@
+
+    - 014: Bash mishandles word splitting under certain circumstances
+      when IFS is null (IFS=).  Constructs affected include ${param/pat/sub}
+      and others when expanding arrays (array[@]).
+    - 015: Under certain circumstances, when using FIFOs for process
+      substitution, bash fails to unlink the FIFOs.  This leaves open
+      file descriptors that can cause the shell to hang and litters
+      the file system.
diff --git a/debian/clear_console.1 b/debian/clear_console.1
new file mode 100644 (file)
index 0000000..dc189a6
--- /dev/null
@@ -0,0 +1,50 @@
+.\"***************************************************************************
+.\" Copyright (c) 1998,2000 Free Software Foundation, Inc.                   *
+.\"                                                                          *
+.\" Permission is hereby granted, free of charge, to any person obtaining a  *
+.\" copy of this software and associated documentation files (the            *
+.\" "Software"), to deal in the Software without restriction, including      *
+.\" without limitation the rights to use, copy, modify, merge, publish,      *
+.\" distribute, distribute with modifications, sublicense, and/or sell       *
+.\" copies of the Software, and to permit persons to whom the Software is    *
+.\" furnished to do so, subject to the following conditions:                 *
+.\"                                                                          *
+.\" The above copyright notice and this permission notice shall be included  *
+.\" in all copies or substantial portions of the Software.                   *
+.\"                                                                          *
+.\" THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS  *
+.\" OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF               *
+.\" MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.   *
+.\" IN NO EVENT SHALL THE ABOVE COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,   *
+.\" DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR    *
+.\" OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR    *
+.\" THE USE OR OTHER DEALINGS IN THE SOFTWARE.                               *
+.\"                                                                          *
+.\" Except as contained in this notice, the name(s) of the above copyright   *
+.\" holders shall not be used in advertising or otherwise to promote the     *
+.\" sale, use or other dealings in this Software without prior written       *
+.\" authorization.                                                           *
+.\"***************************************************************************
+.\"
+.\" $Id: clear.1,v 1.3 2000/07/15 23:59:35 china Exp $
+.TH clear_console 1 ""
+.ds n 5
+.SH NAME
+\fBclear_console\fR - clear the console
+.SH SYNOPSIS
+\fBclear_console\fR
+.br
+.SH DESCRIPTION
+\fBclear_console\fR clears your console if this is possible.  It looks in the
+environment for the terminal type and then in the \fBterminfo\fR database to
+figure out how to clear the screen. To clear the buffer, it then changes the
+foreground virtual terminal to another terminal and then back to the original
+terminal.
+.SH SEE ALSO
+\fBclear\fR(1), \fBchvt\fR(1)
+.\"#
+.\"# The following sets edit modes for GNU EMACS
+.\"# Local Variables:
+.\"# mode:nroff
+.\"# fill-column:79
+.\"# End:
diff --git a/debian/clear_console.c b/debian/clear_console.c
new file mode 100644 (file)
index 0000000..c6b3969
--- /dev/null
@@ -0,0 +1,285 @@
+/*
+Copyright (C) 2006-2008 Canonical Ltd.
+
+clear_console and it's man page are free software; you can redistribute it
+and/or modify it under the terms of the GNU General Public License as
+published by the Free Software Foundation; either version 2, or (at your
+option) any later version.
+*/
+
+#include <stdlib.h>
+#include <stdio.h>
+#include <fcntl.h>
+#include <string.h>
+#include <getopt.h>
+#include <errno.h>
+#include <unistd.h>
+#include <sys/ioctl.h>
+#if defined(__linux)
+#include <linux/kd.h>
+#include <linux/vt.h>
+#elif defined(__FreeBSD_kernel__)
+#include <sys/consio.h>
+#include <sys/kbio.h>
+#endif
+
+#include <curses.h>
+#include <term.h>
+
+#define VERSION "0.1"
+
+char* progname;
+int quiet = 0;
+
+void usage()
+{
+  fprintf(stderr, "Usage: %s [option]\n", progname);
+  fprintf(stderr, "valid options are:\n");
+  fprintf(stderr, "\t-q  --quiet    don't print error messages\n");
+  fprintf(stderr, "\t-h --help      display this help text and exit\n");
+  fprintf(stderr, "\t-V --version   display version information and exit\n");
+}
+
+const struct option opts[] =
+{
+  /* operations */
+    {"help", no_argument, 0, 'h'},
+    {"version", no_argument, 0, 'V'},
+    {"quiet", no_argument, 0, 'q'},
+    {0, 0, 0, 0}
+};
+
+static int putch(int c)
+{
+        return putchar(c);
+}
+
+
+/* taken from console-utils, lib/misc-console-utils.c */
+
+int is_a_console(int fd)
+{
+#if defined(__linux__)
+  char arg;
+#elif defined(__FreeBSD_kernel__)
+  int arg;
+#endif
+
+  arg = 0;
+  return (ioctl(fd, KDGKBTYPE, &arg) == 0
+          && ((arg == KB_OTHER) || (arg == KB_101) || (arg == KB_84)));
+}
+
+static int open_a_console(char *fnam)
+{
+  int fd;
+
+  /* try read-only */
+  fd = open(fnam, O_RDWR);
+
+  /* if failed, try read-only */
+  if (fd < 0 && errno == EACCES)
+      fd = open(fnam, O_RDONLY);
+
+  /* if failed, try write-only */
+  if (fd < 0 && errno == EACCES)
+      fd = open(fnam, O_WRONLY);
+
+  /* if failed, fail */
+  if (fd < 0)
+      return -1;
+
+  /* if not a console, fail */
+  if (! is_a_console(fd))
+    {
+      close(fd);
+      return -1;
+    }
+
+  /* success */
+  return fd;
+}
+
+/*
+ * Get an fd for use with kbd/console ioctls.
+ * We try several things because opening /dev/console will fail
+ * if someone else used X (which does a chown on /dev/console).
+ *
+ * if tty_name is non-NULL, try this one instead.
+ */
+
+int get_console_fd(char* tty_name)
+{
+  int fd;
+
+  if (tty_name)
+    {
+      if (-1 == (fd = open_a_console(tty_name)))
+        return -1;
+      else
+        return fd;
+    }
+
+  fd = open_a_console("/dev/tty");
+  if (fd >= 0)
+    return fd;
+
+  fd = open_a_console("/dev/tty0");
+  if (fd >= 0)
+    return fd;
+
+  fd = open_a_console("/dev/console");
+  if (fd >= 0)
+    return fd;
+
+  for (fd = 0; fd < 3; fd++)
+    if (is_a_console(fd))
+      return fd;
+
+#if 0
+  fprintf(stderr,
+          _("Couldnt get a file descriptor referring to the console\n"));
+#endif
+  return -1;            /* total failure */
+}
+
+
+int is_pseudo_tty(int fd)
+{
+  char *tty = ttyname(fd);
+
+  if (!tty)
+    {
+      if (!quiet)
+       perror("ttyname");
+      return 0;
+    }
+
+  if (strlen(tty) >= 9 && !strncmp(tty, "/dev/pts/", 9))
+    return 1;
+
+  if (strlen(tty) >= 8 && !strncmp(tty, "/dev/tty", 8)
+      && tty[8] >= 'a' && tty[8] <= 'z')
+    return 1;
+
+  return 0;
+}
+
+int clear_console(int fd)
+{
+  int num, tmp_num;
+#if defined(__linux__)
+  struct vt_stat vtstat;
+#endif
+
+  /* clear screen */
+  setupterm((char *) 0, 1, (int *) 0);
+  if (tputs(clear_screen, lines > 0 ? lines : 1, putch) == ERR)
+    {
+      exit(1);
+    }
+
+  if (is_pseudo_tty(STDIN_FILENO))
+    return 0;
+
+  if (!strcmp(getenv("TERM"), "screen"))
+      return 0;
+
+  /* get current vt */
+#if defined(__linux__)
+  if (ioctl(fd, VT_GETSTATE, &vtstat) < 0)
+#elif defined(__FreeBSD_kernel__)
+  if (ioctl(fd, VT_ACTIVATE, &num) < 0)
+#endif
+    {
+      if (!quiet)
+       fprintf(stderr, "%s: cannot get VTstate\n", progname);
+      exit(1);
+    }
+#if defined(__linux__)
+  num = vtstat.v_active;
+#endif
+  tmp_num = (num == 1 ? 2 : 1);
+
+  /* switch vt to clear the scrollback buffer */
+  if (ioctl(fd, VT_ACTIVATE, tmp_num))
+    {
+      if (!quiet)
+       perror("chvt: VT_ACTIVATE");
+      exit(1);
+    }
+
+  if (ioctl(fd, VT_WAITACTIVE, tmp_num))
+    {
+      if (!quiet)
+       perror("VT_WAITACTIVE");
+      exit(1);
+    }
+
+  /* switch back */
+  if (ioctl(fd, VT_ACTIVATE, num))
+    {
+      if (!quiet)
+       perror("chvt: VT_ACTIVATE");
+      exit(1);
+    }
+
+  if (ioctl(fd, VT_WAITACTIVE, num))
+    {
+      if (!quiet)
+       perror("VT_WAITACTIVE");
+      exit(1);
+    }
+  return 0;
+}
+
+int main (int argc, char* argv[])
+{
+  int fd;
+  int result;                          /* option handling */
+  int an_option;
+
+  if ((progname = strrchr(argv[0], '/')) == NULL)
+    progname = argv[0];
+  else
+    progname++;
+
+  while (1)
+    {
+      result = getopt_long(argc, argv, "Vhq", opts, &an_option);
+      
+      if (result == EOF)
+       break;
+
+      switch (result)
+        {
+        case 'V':
+         fprintf(stdout, "%s: Version %s\n", progname, VERSION);
+          exit (0);
+        case 'h':
+          usage();
+          exit (0);
+         
+        case 'q':
+          quiet = 1;
+        }
+    }
+
+  if (optind < argc)
+    {
+      if (!quiet)
+       fprintf(stderr, "%s: no non-option arguments are valid", progname);
+      exit(1);
+    }
+
+  if ((fd = get_console_fd(NULL)) == -1)
+    {
+      if (!quiet)
+       fprintf(stderr, "%s: terminal is not a console\n", progname);
+      exit(1);
+    }
+
+  clear_console(fd);
+
+  return 0;
+}
diff --git a/debian/compat b/debian/compat
new file mode 100644 (file)
index 0000000..7ed6ff8
--- /dev/null
@@ -0,0 +1 @@
+5
diff --git a/debian/control b/debian/control
new file mode 100644 (file)
index 0000000..4e14341
--- /dev/null
@@ -0,0 +1,77 @@
+Source: bash
+Section: base
+Priority: required
+Maintainer: Rafal Krypa <r.krypa@samsung.com>
+X-Original-Maintainer: Matthias Klose <doko@debian.org>
+Standards-Version: 3.8.3
+Build-Depends: autoconf, autotools-dev, patch, bison, libncurses5-dev,
+ texinfo, debhelper (>= 5), texi2html, locales, gettext, sharutils, time, xz-utils
+Homepage: http://tiswww.case.edu/php/chet/bash/bashtop.html
+
+Package: bash
+Architecture: any
+Pre-Depends: ${shlibs:Pre-Depends}, ${misc:Depends}
+Depends: base-files (>= 2.1.12), debianutils (>= 2.15)
+Recommends: bash-completion (>= 20060301-0)
+Conflicts: bash-completion (<< 20060301-0)
+Replaces: bash-doc (<= 2.05-1), bash-completion (<< 20060301-0)
+Suggests: bash-doc
+Essential: yes
+Section: shells
+Priority: required
+Description: The GNU Bourne Again SHell
+ Bash is an sh-compatible command language interpreter that executes
+ commands read from the standard input or from a file.  Bash also
+ incorporates useful features from the Korn and C shells (ksh and csh).
+ .
+ Bash is ultimately intended to be a conformant implementation of the
+ IEEE POSIX Shell and Tools specification (IEEE Working Group 1003.2).
+ .
+ The Programmable Completion Code, by Ian Macdonald, is now found in
+ the bash-completion package.
+
+Package: bash-static
+Architecture: any
+Depends: passwd (>= 1:4.0.3-10), ${misc:Depends}
+Suggests: bash-doc
+Section: shells
+Priority: optional
+Description: The GNU Bourne Again SHell (static version)
+ Bash is an sh-compatible command language interpreter that executes
+ commands read from the standard input or from a file.  Bash also
+ incorporates useful features from the Korn and C shells (ksh and csh).
+ .
+ Statically linked.
+
+Package: bash-builtins
+Architecture: any
+Depends: bash (= ${binary:Version}), ${misc:Depends}
+Section: utils
+Priority: optional
+Description: Bash loadable builtins - headers & examples
+ Bash can dynamically load new builtin commands.  Included are the
+ necessary headers to compile your own builtins and lots of examples.
+
+Package: bash-doc
+Architecture: all
+Depends: ${misc:Depends}, dpkg (>= 1.15.4) | install-info
+Section: doc
+Priority: optional
+Replaces: bash (<< 3.2-1)
+Description: Documentation and examples for the The GNU Bourne Again SHell
+ Bash is an sh-compatible command language interpreter that executes
+ commands read from the standard input or from a file.  Bash also
+ incorporates useful features from the Korn and C shells (ksh and csh).
+ .
+ This package contains the distributable documentation, all the
+ examples and the main changelog.
+
+Package: bashdb
+Architecture: any
+Depends: ${shlibs:Depends}, ${misc:Depends}
+Suggests: bash-doc
+Section: shells
+Priority: optional
+Description: The GNU Bourne Again SHell Debugger
+ The bash debugger is a patched version of bash 2.05b to provide
+ debugging support and better error reporting.
diff --git a/debian/copyright b/debian/copyright
new file mode 100644 (file)
index 0000000..681ecd3
--- /dev/null
@@ -0,0 +1,435 @@
+This is Debian GNU/Linux's prepackaged version of the FSF's GNU Bash,
+the Bourne Again SHell.
+
+This package was put together by Matthias Klose <doko@debian.org>, from
+the following sources:
+
+  bash:                        ftp.gnu.org:/pub/gnu/bash/bash-4.0.tar.gz
+  bashdb:              http://bashdb.sf.net/
+
+Bash homepage:          http://tiswww.case.edu/php/chet/bash/bashtop.html
+
+Copyright (C) 1989-2006 Free Software Foundation, Inc.
+
+Bash is free software; you can redistribute it and/or modify it under
+the terms of the GNU General Public License as published by the Free
+Software Foundation; either version 2, or (at your option) any later
+version.
+
+Bash is distributed in the hope that it will be useful, but WITHOUT
+ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+for more details.
+
+You should have received a copy of the GNU General Public License with
+your Debian GNU/Linux system, in /usr/share/common-licenses/GPL, or with
+the Debian GNU/Linux bash source package as the file COPYING.  If not,
+write to the Free Software Foundation, Inc., 51 Franklin St, Fifth Floor,
+Boston, MA 02110-1301, USA.
+
+The Free Software Foundation has exempted Bash from the requirement of
+Paragraph 2c of the General Public License.  This is to say, there is
+no requirement for Bash to print a notice when it is started
+interactively in the usual way.  We made this exception because users
+and standards expect shells not to print such messages.  This
+exception applies to any program that serves as a shell and that is
+based primarily on Bash as opposed to other GNU software.
+
+
+bashdb is free software; you can redistribute it and/or modify it
+under the terms of the GNU General Public License as published by the Free
+Software Foundation; either version 2, or (at your option) any later version.
+
+Files with other copyright statement than: Copyright FSF, License GPL
+---------------------------------------------------------------------
+
+doc/FAQ ("the Bash FAQ")
+
+ This document is Copyright 1995-2005 by Chester Ramey.
+
+ Permission is hereby granted, without written agreement and
+ without license or royalty fees, to use, copy, and distribute
+ this document for any purpose, provided that the above copyright
+ notice appears in all copies of this document and that the
+ contents of this document remain unaltered.
+
+
+doc/bashref.texi ("Bash Reference Manual"):
+
+ Copyright (c) 1988-2005 Free Software Foundation, Inc.
+
+ Permission is granted to make and distribute verbatim copies of
+ this manual provided the copyright notice and this permission notice
+ are preserved on all copies.
+
+ Permission is granted to copy, distribute and/or modify this document
+ under the terms of the GNU Free Documentation License, Version 1.1 or
+ any later version published by the Free Software Foundation; with no
+ Invariant Sections, with the Front-Cover texts being ``A GNU Manual,''
+ and with the Back-Cover Texts as in (a) below.  A copy of the license is
+ included in the section entitled ``GNU Free Documentation License.''
+
+ (a) The FSF's Back-Cover Text is: ``You have freedom to copy and modify
+ this GNU Manual, like GNU software.  Copies published by the Free
+ Software Foundation raise funds for GNU development.''
+
+
+examples/bashdb/bashdb (Bash shell debugger)
+
+ # Adapted from an idea in O'Reilly's `Learning the Korn Shell'
+ # Copyright (C) 1993-1994 O'Reilly and Associates, Inc.
+ # Copyright (C) 1998, 1999, 2001 Gary V. Vaughan <gvv@techie.com>>
+
+ # This program is free software; you can redistribute it and/or modify
+ # it under the terms of the GNU General Public License [...]
+
+
+examples/functions/pathfuncs (add dir to path)
+
+ #       @(#)Copyright (c) 1991 Simon J. Gerraty
+ #
+ #       This file is provided in the hope that it will
+ #       be of use.  There is absolutely NO WARRANTY.
+ #       Permission to copy, redistribute or otherwise
+ #       use this file is hereby granted provided that
+ #       the above copyright notice and this notice are
+ #       left intact.
+
+
+examples/functions/recurse (Recursive Directory Traverser)
+
+ # Author: Kaz Kylheku
+ # Copyright 1999
+
+
+examples/scripts/bcsh.sh (Bourne shell cshell-emulator)
+
+ #       "Copyright (c) Chris Robertson, December 1985"
+ #
+ #       This software may be used for any purpose provided the original
+ #       copyright notice and this notice are affixed thereto.  No warranties of
+ #       any kind whatsoever are provided with this software, and it is hereby
+ #       understood that the author is not liable for any damagages arising
+ #       from the use of this software.
+
+
+examples/scripts/websrv.sh (WWW server in sh)
+
+ #copyright chris ulrich; This software may be used or modified
+ #in any way so long as this notice remains intact.
+
+
+examples/loadables/getconf.c (POSIX.2 getconf utility)
+
+ /*
+  * ORIGINAL COPYRIGHT STATEMENT:
+  *
+  * Copyright (c) 1994 Winning Strategies, Inc.
+  * All rights reserved.
+  *
+  * Redistribution and use in source and binary forms, with or without
+  * modification, are permitted provided that the following conditions
+  * are met:
+  * 1. Redistributions of source code must retain the above copyright
+  *    notice, this list of conditions and the following disclaimer.
+  * 2. Redistributions in binary form must reproduce the above copyright
+  *    notice, this list of conditions and the following disclaimer in the
+  *    documentation and/or other materials provided with the distribution.
+  * 3. All advertising materials mentioning features or use of this software
+  *    must display the following acknowledgement:
+  *      This product includes software developed by Winning Strategies, Inc.
+  * 4. The name of the author may not be used to endorse or promote products
+  *    derived from this software without specific prior written permission.
+  *
+  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
+  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
+  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
+  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
+  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
+  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
+  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+  */
+
+ /*
+  * POSIX.2 getconf utility
+  *
+  * Originally Written by:
+  *      J.T. Conklin (jtc@wimsey.com), Winning Strategies, Inc.
+  *
+  * Heavily modified for inclusion in bash by
+  *      Chet Ramey <chet@po.cwru.edu>
+  */
+
+
+examples/loadables/cut.c:
+
+ /*
+  * Copyright (c) 1989, 1993
+  *      The Regents of the University of California.  All rights reserved.
+  *
+  * This code is derived from software contributed to Berkeley by
+  * Adam S. Moskowitz of Menlo Consulting and Marciano Pitargue.
+  *
+  * Redistribution and use in source and binary forms, with or without
+  * modification, are permitted provided that the following conditions
+  * are met:
+  * 1. Redistributions of source code must retain the above copyright
+  *    notice, this list of conditions and the following disclaimer.
+  * 2. Redistributions in binary form must reproduce the above copyright
+  *    notice, this list of conditions and the following disclaimer in the
+  *    documentation and/or other materials provided with the distribution.
+  * 3. All advertising materials mentioning features or use of this software
+  *    must display the following acknowledgement:
+  *      This product includes software developed by the University of
+  *      California, Berkeley and its contributors.
+  * 4. Neither the name of the University nor the names of its contributors
+  *    may be used to endorse or promote products derived from this software
+  *    without specific prior written permission.
+  *
+  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
+  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
+  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
+  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
+  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
+  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
+  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+  * SUCH DAMAGE.
+  */
+
+
+lib/readline/doc/rlman.texi (part of the GNU Readline Library manual)
+
+ Copyright (c) 1988-2004 Free Software Foundation, Inc.
+
+ Permission is granted to make and distribute verbatim copies of
+ this manual provided the copyright notice and this permission notice
+ are preserved on all copies.
+
+ Permission is granted to copy, distribute and/or modify this document
+ under the terms of the GNU Free Documentation License, Version 1.1 or
+ any later version published by the Free Software Foundation; with no
+ Invariant Sections, with the Front-Cover texts being ``A GNU Manual,''
+ and with the Back-Cover Texts as in (a) below.  A copy of the license is
+ included in the section entitled ``GNU Free Documentation License.''
+
+ (a) The FSF's Back-Cover Text is: ``You have freedom to copy and modify
+ this GNU Manual, like GNU software.  Copies published by the Free
+ Software Foundation raise funds for GNU development.''
+
+
+lib/readline/doc/rltech.texi (part of the GNU Readline Library manual)
+
+ Copyright (C) 1988-2005 Free Software Foundation, Inc.
+
+ Permission is granted to make and distribute verbatim copies of
+ this manual provided the copyright notice and this permission notice
+ pare preserved on all copies.
+
+ Permission is granted to process this file through TeX and print the
+ results, provided the printed document carries copying permission
+ notice identical to this one except for the removal of this paragraph
+ (this paragraph not being relevant to the printed manual).
+
+ Permission is granted to copy and distribute modified versions of this
+ manual under the conditions for verbatim copying, provided that the entire
+ resulting derived work is distributed under the terms of a permission
+ notice identical to this one.
+
+ Permission is granted to copy and distribute translations of this manual
+ into another language, under the above conditions for modified versions,
+ except that this permission notice may be stated in a translation approved
+ by the Foundation.
+
+
+lib/readline/doc/rluser.texi (part of the GNU Readline Library manual)
+
+ Copyright (C) 1988-2005 Free Software Foundation, Inc.
+
+ Authored by Brian Fox and Chet Ramey.
+
+ Permission is granted to process this file through Tex and print the
+ results, provided the printed document carries copying permission notice
+ identical to this one except for the removal of this paragraph (this
+ paragraph not being relevant to the printed manual).
+
+ Permission is granted to make and distribute verbatim copies of this manual
+ provided the copyright notice and this permission notice are preserved on
+ all copies.
+
+ Permission is granted to copy and distribute modified versions of this
+ manual under the conditions for verbatim copying, provided also that the
+ GNU Copyright statement is available to the distributee, and provided that
+ the entire resulting derived work is distributed under the terms of a
+ permission notice identical to this one.
+
+ Permission is granted to copy and distribute translations of this manual
+ into another language, under the above conditions for modified versions.
+
+
+readline/doc/{history,hstech,hsuser}.texi (GNU History Library Manual)
+
+ Copyright (C) 1988-2002 Free Software Foundation, Inc.
+ Authored by Brian Fox and Chet Ramey.
+
+ Permission is granted to make and distribute verbatim copies of this manual
+ provided the copyright notice and this permission notice are preserved on
+ all copies.
+
+ Permission is granted to process this file through Tex and print the
+ results, provided the printed document carries copying permission notice
+ identical to this one except for the removal of this paragraph (this
+ paragraph not being relevant to the printed manual).
+
+ Permission is granted to copy and distribute modified versions of this
+ manual under the conditions for verbatim copying, provided also that the
+ GNU Copyright statement is available to the distributee, and provided that
+ the entire resulting derived work is distributed under the terms of a
+ permission notice identical to this one.
+
+ Permission is granted to copy and distribute translations of this manual
+ into another language, under the above conditions for modified versions.
+
+
+lib/sh/inet_aton.c:
+
+ * Copyright (c) 1983, 1990, 1993
+ *    The Regents of the University of California.  All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ *    notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ *    notice, this list of conditions and the following disclaimer in the
+ *    documentation and/or other materials provided with the distribution.
+ * 3. All advertising materials mentioning features or use of this software
+ *    must display the following acknowledgement:
+ *      This product includes software developed by the University of
+ *      California, Berkeley and its contributors.
+ * 4. Neither the name of the University nor the names of its contributors
+ *    may be used to endorse or promote products derived from this software
+ *    without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
+ * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
+ * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
+ * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
+ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
+ * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
+ * -
+ * Portions Copyright (c) 1993 by Digital Equipment Corporation.
+ *
+ * Permission to use, copy, modify, and distribute this software for any
+ * purpose with or without fee is hereby granted, provided that the above
+ * copyright notice and this permission notice appear in all copies, and that
+ * the name of Digital Equipment Corporation not be used in advertising or
+ * publicity pertaining to distribution of the document or software without
+ * specific, written prior permission.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS" AND DIGITAL EQUIPMENT CORP. DISCLAIMS ALL
+ * WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES
+ * OF MERCHANTABILITY AND FITNESS.   IN NO EVENT SHALL DIGITAL EQUIPMENT
+ * CORPORATION BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
+ * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
+ * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS
+ * ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS
+ * SOFTWARE.
+
+
+lib/termcap/grot/termcap.info (GNU termcap library manual)
+
+ Copyright (C) 1988 Free Software Foundation, Inc.
+
+ Permission is granted to make and distribute verbatim copies of
+ this manual provided the copyright notice and this permission notice
+ are preserved on all copies.
+
+ Permission is granted to process this file through TeX and print the
+ results, provided the printed document carries copying permission
+ notice identical to this one except for the removal of this paragraph
+ (this paragraph not being relevant to the printed manual).
+
+ Permission is granted to copy and distribute modified versions of this
+ manual under the conditions for verbatim copying, provided that the entire
+ resulting derived work is distributed under the terms of a permission
+ notice identical to this one.
+
+ Permission is granted to copy and distribute translations of this manual
+ into another language, under the above conditions for modified versions,
+ except that this permission notice may be stated in a translation approved
+ by the Foundation.
+
+
+support/man2html.c
+
+ * This program was written by Richard Verhoeven (NL:5482ZX35)
+ * at the Eindhoven University of Technology. Email: rcb5@win.tue.nl
+ *
+ * Permission is granted to distribute, modify and use this program as long
+ * as this comment is not removed or changed.
+ *
+ * THIS IS A MODIFIED VERSION.  IT WAS MODIFIED BY chet@po.cwru.edu FOR
+ * USE BY BASH.
+
+debian/md5.[ch]
+
+/*
+  Copyright (C) 1999, 2002 Aladdin Enterprises.  All rights reserved.
+
+  This software is provided 'as-is', without any express or implied
+  warranty.  In no event will the authors be held liable for any damages
+  arising from the use of this software.
+
+  Permission is granted to anyone to use this software for any purpose,
+  including commercial applications, and to alter it and redistribute it
+  freely, subject to the following restrictions:
+
+  1. The origin of this software must not be misrepresented; you must not
+     claim that you wrote the original software. If you use this software
+     in a product, an acknowledgment in the product documentation would be
+     appreciated but is not required.
+  2. Altered source versions must be plainly marked as such, and must not be
+     misrepresented as being the original software.
+  3. This notice may not be removed or altered from any source distribution.
+
+  L. Peter Deutsch
+  ghost@aladdin.com
+
+ */
+/* $Id: md5.h 43594 2006-04-03 16:27:50Z matthias.klose $ */
+/*
+  Independent implementation of MD5 (RFC 1321).
+
+  This code implements the MD5 Algorithm defined in RFC 1321, whose
+  text is available at
+       http://www.ietf.org/rfc/rfc1321.txt
+  The code is derived from the text of the RFC, including the test suite
+  (section A.5) but excluding the rest of Appendix A.  It does not include
+  any code or documentation that is identified in the RFC as being
+  copyrighted.
+
+  The original and principal author of md5.h is L. Peter Deutsch
+  <ghost@aladdin.com>.  Other authors are noted in the change history
+  that follows (in reverse chronological order):
+
+  2002-04-13 lpd Removed support for non-ANSI compilers; removed
+       references to Ghostscript; clarified derivation from RFC 1321;
+       now handles byte order either statically or dynamically.
+  1999-11-04 lpd Edited comments slightly for automatic TOC extraction.
+  1999-10-18 lpd Fixed typo in header comment (ansi2knr rather than md5);
+       added conditionalization for C++ compilation from Martin
+       Purschke <purschke@bnl.gov>.
+  1999-05-03 lpd Original version.
+ */
diff --git a/debian/etc.bash.bashrc b/debian/etc.bash.bashrc
new file mode 100644 (file)
index 0000000..9ba3cac
--- /dev/null
@@ -0,0 +1,50 @@
+# System-wide .bashrc file for interactive bash(1) shells.
+
+# To enable the settings / commands in this file for login shells as well,
+# this file has to be sourced in /etc/profile.
+
+# If not running interactively, don't do anything
+[ -z "$PS1" ] && return
+
+# check the window size after each command and, if necessary,
+# update the values of LINES and COLUMNS.
+shopt -s checkwinsize
+
+# set variable identifying the chroot you work in (used in the prompt below)
+if [ -z "$debian_chroot" ] && [ -r /etc/debian_chroot ]; then
+    debian_chroot=$(cat /etc/debian_chroot)
+fi
+
+# set a fancy prompt (non-color, overwrite the one in /etc/profile)
+PS1='${debian_chroot:+($debian_chroot)}\u@\h:\w\$ '
+
+# Commented out, don't overwrite xterm -T "title" -n "icontitle" by default.
+# If this is an xterm set the title to user@host:dir
+#case "$TERM" in
+#xterm*|rxvt*)
+#    PROMPT_COMMAND='echo -ne "\033]0;${USER}@${HOSTNAME}: ${PWD}\007"'
+#    ;;
+#*)
+#    ;;
+#esac
+
+# enable bash completion in interactive shells
+#if [ -f /etc/bash_completion ] && ! shopt -oq posix; then
+#    . /etc/bash_completion
+#fi
+
+# if the command-not-found package is installed, use it
+if [ -x /usr/lib/command-not-found -o -x /usr/share/command-not-found ]; then
+       function command_not_found_handle {
+               # check because c-n-f could've been removed in the meantime
+                if [ -x /usr/lib/command-not-found ]; then
+                  /usr/bin/python /usr/lib/command-not-found -- $1
+                   return $?
+                elif [ -x /usr/share/command-not-found ]; then
+                  /usr/bin/python /usr/share/command-not-found -- $1
+                   return $?
+               else
+                  return 127
+               fi
+       }
+fi
diff --git a/debian/etc.inputrc b/debian/etc.inputrc
new file mode 100644 (file)
index 0000000..2c993cb
--- /dev/null
@@ -0,0 +1,17 @@
+# /etc/inputrc - global inputrc for libreadline
+# See readline(3readline) and `info readline' for more information.
+
+# Be 8 bit clean.
+set input-meta on
+set output-meta on
+
+# To allow the use of german 8bit-characters like the german umlauts, comment
+# out the two lines below. However this makes the meta key not work as a meta
+# key, which is annoying to those which don't need to type in 8-bit characters.
+
+#set meta-flag on
+#set convert-meta off
+
+# use a visible bell if one is available
+#set bell-style none
+#set bell-style visible
diff --git a/debian/etc.profile b/debian/etc.profile
new file mode 100644 (file)
index 0000000..b67da47
--- /dev/null
@@ -0,0 +1,27 @@
+# /etc/profile: system-wide .profile file for the Bourne shell (sh(1))
+# and Bourne compatible shells (bash(1), ksh(1), ash(1), ...).
+
+PATH="/usr/local/bin:/usr/bin:/bin:/usr/bin/X11:/usr/games"
+
+if [ -f /etc/debian_chroot ]; then
+  debian_chroot=$(cat /etc/debian_chroot)
+fi
+
+if [ "$PS1" ]; then
+  if [ "$BASH" ]; then
+    PS1='${debian_chroot:+($debian_chroot)}\u@\h:\w\$ '
+    if [ -f /etc/bash.bashrc ]; then
+        . /etc/bash.bashrc
+    fi
+  else
+    if [ "`id -u`" -eq 0 ]; then
+      PS1='# '
+    else
+      PS1='$ '
+    fi
+  fi
+fi
+
+export PATH
+
+umask 022
diff --git a/debian/inputrc.arrows b/debian/inputrc.arrows
new file mode 100644 (file)
index 0000000..21aed08
--- /dev/null
@@ -0,0 +1,30 @@
+# This file controls the behaviour of line input editing for
+# programs that use the Gnu Readline library.
+#
+# Arrow keys in keypad mode
+#
+"\C-[OD"        backward-char
+"\C-[OC"        forward-char
+"\C-[OA"        previous-history
+"\C-[OB"        next-history
+#
+# Arrow keys in ANSI mode
+#
+"\C-[[D"        backward-char
+"\C-[[C"        forward-char
+"\C-[[A"        previous-history
+"\C-[[B"        next-history
+#
+# Arrow keys in 8 bit keypad mode
+#
+"\C-M-OD"       backward-char
+"\C-M-OC"       forward-char
+"\C-M-OA"       previous-history
+"\C-M-OB"       next-history
+#
+# Arrow keys in 8 bit ANSI mode
+#
+"\C-M-[D"       backward-char
+"\C-M-[C"       forward-char
+"\C-M-[A"       previous-history
+"\C-M-[B"       next-history
diff --git a/debian/locale-gen b/debian/locale-gen
new file mode 100644 (file)
index 0000000..091a50e
--- /dev/null
@@ -0,0 +1,30 @@
+#!/bin/sh
+
+LOCPATH=`pwd`/locales
+export LOCPATH
+
+[ -d $LOCPATH ] || mkdir -p $LOCPATH
+
+umask 022
+
+echo "Generating locales..."
+while read locale charset; do
+       case $locale in \#*) continue;; esac
+       [ -n "$locale" -a -n "$charset" ] || continue
+       echo -n "  `echo $locale | sed 's/\([^.\@]*\).*/\1/'`"
+       echo -n ".$charset"
+       echo -n `echo $locale | sed 's/\([^\@]*\)\(\@.*\)*/\2/'`
+       echo -n '...'
+        if [ -f $LOCPATH/$locale ]; then
+           input=$locale
+       else
+            input=`echo $locale | sed 's/\([^.]*\)[^@]*\(.*\)/\1\2/'`
+       fi
+       localedef -i $input -c -f $charset $LOCPATH/$locale #-A /etc/locale.alias
+       echo ' done'; \
+done <<EOF
+# This file lists locales that the bash testsuite depends on
+en_US.UTF-8            UTF-8
+EOF
+
+echo "Generation complete."
diff --git a/debian/md5.c b/debian/md5.c
new file mode 100644 (file)
index 0000000..0e1058f
--- /dev/null
@@ -0,0 +1,394 @@
+/*
+  Copyright (C) 1999, 2000, 2002 Aladdin Enterprises.  All rights reserved.
+
+  This software is provided 'as-is', without any express or implied
+  warranty.  In no event will the authors be held liable for any damages
+  arising from the use of this software.
+
+  Permission is granted to anyone to use this software for any purpose,
+  including commercial applications, and to alter it and redistribute it
+  freely, subject to the following restrictions:
+
+  1. The origin of this software must not be misrepresented; you must not
+     claim that you wrote the original software. If you use this software
+     in a product, an acknowledgment in the product documentation would be
+     appreciated but is not required.
+  2. Altered source versions must be plainly marked as such, and must not be
+     misrepresented as being the original software.
+  3. This notice may not be removed or altered from any source distribution.
+
+  L. Peter Deutsch
+  ghost@aladdin.com
+
+ */
+/* $Id: md5.c,v 1.6 2002/04/13 19:20:28 lpd Exp $ */
+/*
+  Independent implementation of MD5 (RFC 1321).
+
+  This code implements the MD5 Algorithm defined in RFC 1321, whose
+  text is available at
+       http://www.ietf.org/rfc/rfc1321.txt
+  The code is derived from the text of the RFC, including the test suite
+  (section A.5) but excluding the rest of Appendix A.  It does not include
+  any code or documentation that is identified in the RFC as being
+  copyrighted.
+
+  The original and principal author of md5.c is L. Peter Deutsch
+  <ghost@aladdin.com>.  Other authors are noted in the change history
+  that follows (in reverse chronological order):
+
+  2002-04-13 lpd Clarified derivation from RFC 1321; now handles byte order
+       either statically or dynamically; added missing #include <string.h>
+       in library.
+  2002-03-11 lpd Corrected argument list for main(), and added int return
+       type, in test program and T value program.
+  2002-02-21 lpd Added missing #include <stdio.h> in test program.
+  2000-07-03 lpd Patched to eliminate warnings about "constant is
+       unsigned in ANSI C, signed in traditional"; made test program
+       self-checking.
+  1999-11-04 lpd Edited comments slightly for automatic TOC extraction.
+  1999-10-18 lpd Fixed typo in header comment (ansi2knr rather than md5).
+  1999-05-03 lpd Original version.
+ */
+
+#include "md5.h"
+#include <string.h>
+#include <limits.h>
+
+#undef BYTE_ORDER      /* 1 = big-endian, -1 = little-endian, 0 = unknown */
+#ifdef ARCH_IS_BIG_ENDIAN
+#  define BYTE_ORDER (ARCH_IS_BIG_ENDIAN ? 1 : -1)
+#else
+#  define BYTE_ORDER 0
+#endif
+
+#define T_MASK ((md5_word_t)~0)
+#define T1 /* 0xd76aa478 */ (T_MASK ^ 0x28955b87)
+#define T2 /* 0xe8c7b756 */ (T_MASK ^ 0x173848a9)
+#define T3    0x242070db
+#define T4 /* 0xc1bdceee */ (T_MASK ^ 0x3e423111)
+#define T5 /* 0xf57c0faf */ (T_MASK ^ 0x0a83f050)
+#define T6    0x4787c62a
+#define T7 /* 0xa8304613 */ (T_MASK ^ 0x57cfb9ec)
+#define T8 /* 0xfd469501 */ (T_MASK ^ 0x02b96afe)
+#define T9    0x698098d8
+#define T10 /* 0x8b44f7af */ (T_MASK ^ 0x74bb0850)
+#define T11 /* 0xffff5bb1 */ (T_MASK ^ 0x0000a44e)
+#define T12 /* 0x895cd7be */ (T_MASK ^ 0x76a32841)
+#define T13    0x6b901122
+#define T14 /* 0xfd987193 */ (T_MASK ^ 0x02678e6c)
+#define T15 /* 0xa679438e */ (T_MASK ^ 0x5986bc71)
+#define T16    0x49b40821
+#define T17 /* 0xf61e2562 */ (T_MASK ^ 0x09e1da9d)
+#define T18 /* 0xc040b340 */ (T_MASK ^ 0x3fbf4cbf)
+#define T19    0x265e5a51
+#define T20 /* 0xe9b6c7aa */ (T_MASK ^ 0x16493855)
+#define T21 /* 0xd62f105d */ (T_MASK ^ 0x29d0efa2)
+#define T22    0x02441453
+#define T23 /* 0xd8a1e681 */ (T_MASK ^ 0x275e197e)
+#define T24 /* 0xe7d3fbc8 */ (T_MASK ^ 0x182c0437)
+#define T25    0x21e1cde6
+#define T26 /* 0xc33707d6 */ (T_MASK ^ 0x3cc8f829)
+#define T27 /* 0xf4d50d87 */ (T_MASK ^ 0x0b2af278)
+#define T28    0x455a14ed
+#define T29 /* 0xa9e3e905 */ (T_MASK ^ 0x561c16fa)
+#define T30 /* 0xfcefa3f8 */ (T_MASK ^ 0x03105c07)
+#define T31    0x676f02d9
+#define T32 /* 0x8d2a4c8a */ (T_MASK ^ 0x72d5b375)
+#define T33 /* 0xfffa3942 */ (T_MASK ^ 0x0005c6bd)
+#define T34 /* 0x8771f681 */ (T_MASK ^ 0x788e097e)
+#define T35    0x6d9d6122
+#define T36 /* 0xfde5380c */ (T_MASK ^ 0x021ac7f3)
+#define T37 /* 0xa4beea44 */ (T_MASK ^ 0x5b4115bb)
+#define T38    0x4bdecfa9
+#define T39 /* 0xf6bb4b60 */ (T_MASK ^ 0x0944b49f)
+#define T40 /* 0xbebfbc70 */ (T_MASK ^ 0x4140438f)
+#define T41    0x289b7ec6
+#define T42 /* 0xeaa127fa */ (T_MASK ^ 0x155ed805)
+#define T43 /* 0xd4ef3085 */ (T_MASK ^ 0x2b10cf7a)
+#define T44    0x04881d05
+#define T45 /* 0xd9d4d039 */ (T_MASK ^ 0x262b2fc6)
+#define T46 /* 0xe6db99e5 */ (T_MASK ^ 0x1924661a)
+#define T47    0x1fa27cf8
+#define T48 /* 0xc4ac5665 */ (T_MASK ^ 0x3b53a99a)
+#define T49 /* 0xf4292244 */ (T_MASK ^ 0x0bd6ddbb)
+#define T50    0x432aff97
+#define T51 /* 0xab9423a7 */ (T_MASK ^ 0x546bdc58)
+#define T52 /* 0xfc93a039 */ (T_MASK ^ 0x036c5fc6)
+#define T53    0x655b59c3
+#define T54 /* 0x8f0ccc92 */ (T_MASK ^ 0x70f3336d)
+#define T55 /* 0xffeff47d */ (T_MASK ^ 0x00100b82)
+#define T56 /* 0x85845dd1 */ (T_MASK ^ 0x7a7ba22e)
+#define T57    0x6fa87e4f
+#define T58 /* 0xfe2ce6e0 */ (T_MASK ^ 0x01d3191f)
+#define T59 /* 0xa3014314 */ (T_MASK ^ 0x5cfebceb)
+#define T60    0x4e0811a1
+#define T61 /* 0xf7537e82 */ (T_MASK ^ 0x08ac817d)
+#define T62 /* 0xbd3af235 */ (T_MASK ^ 0x42c50dca)
+#define T63    0x2ad7d2bb
+#define T64 /* 0xeb86d391 */ (T_MASK ^ 0x14792c6e)
+
+
+static void
+md5_process(md5_state_t *pms, const md5_byte_t *data /*[64]*/)
+{
+    md5_word_t
+       a = pms->abcd[0], b = pms->abcd[1],
+       c = pms->abcd[2], d = pms->abcd[3];
+    md5_word_t t;
+#if BYTE_ORDER > 0
+    /* Define storage only for big-endian CPUs. */
+    md5_word_t X[16];
+#else
+    /* Define storage for little-endian or both types of CPUs. */
+    md5_word_t xbuf[16];
+    const md5_word_t *X;
+#endif
+
+    {
+#if BYTE_ORDER == 0
+       /*
+        * Determine dynamically whether this is a big-endian or
+        * little-endian machine, since we can use a more efficient
+        * algorithm on the latter.
+        */
+       static const int w = 1;
+
+       if (*((const md5_byte_t *)&w)) /* dynamic little-endian */
+#endif
+#if BYTE_ORDER <= 0            /* little-endian */
+       {
+           /*
+            * On little-endian machines, we can process properly aligned
+            * data without copying it.
+            */
+           if (!((data - (const md5_byte_t *)0) & 3)) {
+               /* data are properly aligned */
+               X = (const md5_word_t *)data;
+           } else {
+               /* not aligned */
+               memcpy(xbuf, data, 64);
+               X = xbuf;
+           }
+       }
+#endif
+#if BYTE_ORDER == 0
+       else                    /* dynamic big-endian */
+#endif
+#if BYTE_ORDER >= 0            /* big-endian */
+       {
+           /*
+            * On big-endian machines, we must arrange the bytes in the
+            * right order.
+            */
+           const md5_byte_t *xp = data;
+           int i;
+
+#  if BYTE_ORDER == 0
+           X = xbuf;           /* (dynamic only) */
+#  else
+#    define xbuf X             /* (static only) */
+#  endif
+           for (i = 0; i < 16; ++i, xp += 4)
+               xbuf[i] = xp[0] + (xp[1] << 8) + (xp[2] << 16) + (xp[3] << 24);
+       }
+#endif
+    }
+
+#define ROTATE_LEFT(x, n) (((x) << (n)) | ((x) >> (32 - (n))))
+
+    /* Round 1. */
+    /* Let [abcd k s i] denote the operation
+       a = b + ((a + F(b,c,d) + X[k] + T[i]) <<< s). */
+#define F(x, y, z) (((x) & (y)) | (~(x) & (z)))
+#define SET(a, b, c, d, k, s, Ti)\
+  t = a + F(b,c,d) + X[k] + Ti;\
+  a = ROTATE_LEFT(t, s) + b
+    /* Do the following 16 operations. */
+    SET(a, b, c, d,  0,  7,  T1);
+    SET(d, a, b, c,  1, 12,  T2);
+    SET(c, d, a, b,  2, 17,  T3);
+    SET(b, c, d, a,  3, 22,  T4);
+    SET(a, b, c, d,  4,  7,  T5);
+    SET(d, a, b, c,  5, 12,  T6);
+    SET(c, d, a, b,  6, 17,  T7);
+    SET(b, c, d, a,  7, 22,  T8);
+    SET(a, b, c, d,  8,  7,  T9);
+    SET(d, a, b, c,  9, 12, T10);
+    SET(c, d, a, b, 10, 17, T11);
+    SET(b, c, d, a, 11, 22, T12);
+    SET(a, b, c, d, 12,  7, T13);
+    SET(d, a, b, c, 13, 12, T14);
+    SET(c, d, a, b, 14, 17, T15);
+    SET(b, c, d, a, 15, 22, T16);
+#undef SET
+
+     /* Round 2. */
+     /* Let [abcd k s i] denote the operation
+          a = b + ((a + G(b,c,d) + X[k] + T[i]) <<< s). */
+#define G(x, y, z) (((x) & (z)) | ((y) & ~(z)))
+#define SET(a, b, c, d, k, s, Ti)\
+  t = a + G(b,c,d) + X[k] + Ti;\
+  a = ROTATE_LEFT(t, s) + b
+     /* Do the following 16 operations. */
+    SET(a, b, c, d,  1,  5, T17);
+    SET(d, a, b, c,  6,  9, T18);
+    SET(c, d, a, b, 11, 14, T19);
+    SET(b, c, d, a,  0, 20, T20);
+    SET(a, b, c, d,  5,  5, T21);
+    SET(d, a, b, c, 10,  9, T22);
+    SET(c, d, a, b, 15, 14, T23);
+    SET(b, c, d, a,  4, 20, T24);
+    SET(a, b, c, d,  9,  5, T25);
+    SET(d, a, b, c, 14,  9, T26);
+    SET(c, d, a, b,  3, 14, T27);
+    SET(b, c, d, a,  8, 20, T28);
+    SET(a, b, c, d, 13,  5, T29);
+    SET(d, a, b, c,  2,  9, T30);
+    SET(c, d, a, b,  7, 14, T31);
+    SET(b, c, d, a, 12, 20, T32);
+#undef SET
+
+     /* Round 3. */
+     /* Let [abcd k s t] denote the operation
+          a = b + ((a + H(b,c,d) + X[k] + T[i]) <<< s). */
+#define H(x, y, z) ((x) ^ (y) ^ (z))
+#define SET(a, b, c, d, k, s, Ti)\
+  t = a + H(b,c,d) + X[k] + Ti;\
+  a = ROTATE_LEFT(t, s) + b
+     /* Do the following 16 operations. */
+    SET(a, b, c, d,  5,  4, T33);
+    SET(d, a, b, c,  8, 11, T34);
+    SET(c, d, a, b, 11, 16, T35);
+    SET(b, c, d, a, 14, 23, T36);
+    SET(a, b, c, d,  1,  4, T37);
+    SET(d, a, b, c,  4, 11, T38);
+    SET(c, d, a, b,  7, 16, T39);
+    SET(b, c, d, a, 10, 23, T40);
+    SET(a, b, c, d, 13,  4, T41);
+    SET(d, a, b, c,  0, 11, T42);
+    SET(c, d, a, b,  3, 16, T43);
+    SET(b, c, d, a,  6, 23, T44);
+    SET(a, b, c, d,  9,  4, T45);
+    SET(d, a, b, c, 12, 11, T46);
+    SET(c, d, a, b, 15, 16, T47);
+    SET(b, c, d, a,  2, 23, T48);
+#undef SET
+
+     /* Round 4. */
+     /* Let [abcd k s t] denote the operation
+          a = b + ((a + I(b,c,d) + X[k] + T[i]) <<< s). */
+#define I(x, y, z) ((y) ^ ((x) | ~(z)))
+#define SET(a, b, c, d, k, s, Ti)\
+  t = a + I(b,c,d) + X[k] + Ti;\
+  a = ROTATE_LEFT(t, s) + b
+     /* Do the following 16 operations. */
+    SET(a, b, c, d,  0,  6, T49);
+    SET(d, a, b, c,  7, 10, T50);
+    SET(c, d, a, b, 14, 15, T51);
+    SET(b, c, d, a,  5, 21, T52);
+    SET(a, b, c, d, 12,  6, T53);
+    SET(d, a, b, c,  3, 10, T54);
+    SET(c, d, a, b, 10, 15, T55);
+    SET(b, c, d, a,  1, 21, T56);
+    SET(a, b, c, d,  8,  6, T57);
+    SET(d, a, b, c, 15, 10, T58);
+    SET(c, d, a, b,  6, 15, T59);
+    SET(b, c, d, a, 13, 21, T60);
+    SET(a, b, c, d,  4,  6, T61);
+    SET(d, a, b, c, 11, 10, T62);
+    SET(c, d, a, b,  2, 15, T63);
+    SET(b, c, d, a,  9, 21, T64);
+#undef SET
+
+     /* Then perform the following additions. (That is increment each
+        of the four registers by the value it had before this block
+        was started.) */
+    pms->abcd[0] += a;
+    pms->abcd[1] += b;
+    pms->abcd[2] += c;
+    pms->abcd[3] += d;
+}
+
+void
+md5_init(md5_state_t *pms)
+{
+    pms->count[0] = pms->count[1] = 0;
+    pms->abcd[0] = 0x67452301;
+    pms->abcd[1] = /*0xefcdab89*/ T_MASK ^ 0x10325476;
+    pms->abcd[2] = /*0x98badcfe*/ T_MASK ^ 0x67452301;
+    pms->abcd[3] = 0x10325476;
+}
+
+void
+md5_append(md5_state_t *pms, const md5_byte_t *data, int nbytes)
+{
+    const md5_byte_t *p = data;
+    int left = nbytes;
+    int offset = (pms->count[0] >> 3) & 63;
+    md5_word_t nbits = (md5_word_t)(nbytes << 3);
+
+    if (nbytes <= 0)
+       return;
+
+    /* this special case is handled recursively */
+    if (nbytes > INT_MAX - offset) {
+        int overlap;
+
+        /* handle the append in two steps to prevent overflow */
+        overlap = 64 - offset;
+
+        md5_append(pms, data, overlap);
+        md5_append(pms, data + overlap, nbytes - overlap); 
+        return;
+    }
+
+    /* Update the message length. */
+    pms->count[1] += nbytes >> 29;
+    pms->count[0] += nbits;
+    if (pms->count[0] < nbits)
+       pms->count[1]++;
+
+    /* Process an initial partial block. */
+    if (offset) {
+       int copy = (offset + nbytes > 64 ? 64 - offset : nbytes);
+
+       memcpy(pms->buf + offset, p, copy);
+       if (offset + copy < 64)
+           return;
+       p += copy;
+       left -= copy;
+       md5_process(pms, pms->buf);
+    }
+
+    /* Process full blocks. */
+    for (; left >= 64; p += 64, left -= 64)
+       md5_process(pms, p);
+
+    /* Process a final partial block. */
+    if (left)
+       memcpy(pms->buf, p, left);
+}
+
+void
+md5_finish(md5_state_t *pms, md5_byte_t digest[16])
+{
+    static const md5_byte_t pad[64] = {
+       0x80, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+       0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+       0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+       0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0
+    };
+    md5_byte_t data[8];
+    int i;
+
+    /* Save the length before padding. */
+    for (i = 0; i < 8; ++i)
+       data[i] = (md5_byte_t)(pms->count[i >> 2] >> ((i & 3) << 3));
+    /* Pad to 56 bytes mod 64. */
+    md5_append(pms, pad, ((55 - (pms->count[0] >> 3)) & 63) + 1);
+    /* Append the length. */
+    md5_append(pms, data, 8);
+    for (i = 0; i < 16; ++i)
+       digest[i] = (md5_byte_t)(pms->abcd[i >> 2] >> ((i & 3) << 3));
+}
diff --git a/debian/md5.h b/debian/md5.h
new file mode 100644 (file)
index 0000000..1718401
--- /dev/null
@@ -0,0 +1,91 @@
+/*
+  Copyright (C) 1999, 2002 Aladdin Enterprises.  All rights reserved.
+
+  This software is provided 'as-is', without any express or implied
+  warranty.  In no event will the authors be held liable for any damages
+  arising from the use of this software.
+
+  Permission is granted to anyone to use this software for any purpose,
+  including commercial applications, and to alter it and redistribute it
+  freely, subject to the following restrictions:
+
+  1. The origin of this software must not be misrepresented; you must not
+     claim that you wrote the original software. If you use this software
+     in a product, an acknowledgment in the product documentation would be
+     appreciated but is not required.
+  2. Altered source versions must be plainly marked as such, and must not be
+     misrepresented as being the original software.
+  3. This notice may not be removed or altered from any source distribution.
+
+  L. Peter Deutsch
+  ghost@aladdin.com
+
+ */
+/* $Id: md5.h 43594 2006-04-03 16:27:50Z matthias.klose $ */
+/*
+  Independent implementation of MD5 (RFC 1321).
+
+  This code implements the MD5 Algorithm defined in RFC 1321, whose
+  text is available at
+       http://www.ietf.org/rfc/rfc1321.txt
+  The code is derived from the text of the RFC, including the test suite
+  (section A.5) but excluding the rest of Appendix A.  It does not include
+  any code or documentation that is identified in the RFC as being
+  copyrighted.
+
+  The original and principal author of md5.h is L. Peter Deutsch
+  <ghost@aladdin.com>.  Other authors are noted in the change history
+  that follows (in reverse chronological order):
+
+  2002-04-13 lpd Removed support for non-ANSI compilers; removed
+       references to Ghostscript; clarified derivation from RFC 1321;
+       now handles byte order either statically or dynamically.
+  1999-11-04 lpd Edited comments slightly for automatic TOC extraction.
+  1999-10-18 lpd Fixed typo in header comment (ansi2knr rather than md5);
+       added conditionalization for C++ compilation from Martin
+       Purschke <purschke@bnl.gov>.
+  1999-05-03 lpd Original version.
+ */
+
+#ifndef md5_INCLUDED
+#  define md5_INCLUDED
+
+/*
+ * This package supports both compile-time and run-time determination of CPU
+ * byte order.  If ARCH_IS_BIG_ENDIAN is defined as 0, the code will be
+ * compiled to run only on little-endian CPUs; if ARCH_IS_BIG_ENDIAN is
+ * defined as non-zero, the code will be compiled to run only on big-endian
+ * CPUs; if ARCH_IS_BIG_ENDIAN is not defined, the code will be compiled to
+ * run on either big- or little-endian CPUs, but will run slightly less
+ * efficiently on either one than if ARCH_IS_BIG_ENDIAN is defined.
+ */
+
+typedef unsigned char md5_byte_t; /* 8-bit byte */
+typedef unsigned int md5_word_t; /* 32-bit word */
+
+/* Define the state of the MD5 Algorithm. */
+typedef struct md5_state_s {
+    md5_word_t count[2];       /* message length in bits, lsw first */
+    md5_word_t abcd[4];                /* digest buffer */
+    md5_byte_t buf[64];                /* accumulate block */
+} md5_state_t;
+
+#ifdef __cplusplus
+extern "C" 
+{
+#endif
+
+/* Initialize the algorithm. */
+void md5_init(md5_state_t *pms);
+
+/* Append a string to the message. */
+void md5_append(md5_state_t *pms, const md5_byte_t *data, int nbytes);
+
+/* Finish the message and return the digest. */
+void md5_finish(md5_state_t *pms, md5_byte_t digest[16]);
+
+#ifdef __cplusplus
+}  /* end extern "C" */
+#endif
+
+#endif /* md5_INCLUDED */
diff --git a/debian/new/bash.postinst b/debian/new/bash.postinst
new file mode 100644 (file)
index 0000000..003220c
--- /dev/null
@@ -0,0 +1,29 @@
+#! /bin/bash -e
+
+exit 0
+
+if [ "$1" = configure ] && [ -n "$2" ] && dpkg --compare-versions "$2" lt 2.05b-4; \
+then
+    div=$(dpkg-divert --list /bin/sh)
+    if [ -n "$div" ] && [ -z "${div%%* by bash}" ]; then
+       # paranoia
+       ln -sf dash /bin/sh
+        rm -f /bin/sh.distrib
+
+        dpkg-divert --remove /bin/sh
+    fi
+
+    div=$(dpkg-divert --list /usr/share/man/man1/sh.1.gz)
+    if [ -n "$div" ] && [ -z "${div%%* by bash}" ]; then
+        # paranoia
+        ln -sf dash.1.gz /usr/share/man/man1/sh.1.gz
+        rm -f /usr/share/man/man1/sh.1.gz.distrib
+
+        dpkg-divert --remove /usr/share/man/man1/sh.1.gz
+    fi
+fi
+
+# the symlink is in the package now. So this should never happen ...
+if [ ! -e /bin/sh ]; then
+  ln -s dash /bin/sh
+fi
diff --git a/debian/new/bash.preinst.c b/debian/new/bash.preinst.c
new file mode 100644 (file)
index 0000000..10d43c6
--- /dev/null
@@ -0,0 +1,229 @@
+/* Copyright (c) 1999 Anthony Towns
+ * Copyright (c) 2000 Matthias Klose
+ *
+ * You may freely use, distribute, and modify this program.
+ */
+
+// Don't rely on /bin/sh and popen!
+
+#include <stdio.h>
+#include <stdlib.h>
+#include <stdarg.h>
+#include <string.h>
+#include <unistd.h>
+#include <fcntl.h>
+#include <limits.h>
+#include <sys/types.h>
+#include <sys/wait.h>
+
+/* XXX: evil kludge, deal with arbitrary name lengths */
+#ifndef PATH_MAX
+#define PATH_MAX 4096
+#endif
+
+int myexec(char *cmd, ...)
+{
+    va_list ap;
+    pid_t child;
+
+    char *new_argv[10];
+    int new_argc = 0, i;
+
+    new_argv[new_argc++] = cmd;
+    va_start(ap, cmd);
+    while ((new_argv[new_argc++] = va_arg(ap, char *)));
+    va_end(ap);
+
+    switch(child = fork()) {
+      case -1:
+        /* fork failed */
+        return EXIT_FAILURE;
+
+      case 0:
+        /* i'm the child */
+        {
+            execv(cmd, new_argv);
+           _exit(127);
+        }
+
+      default:
+        /* i'm the parent */
+        {
+            int status;
+            pid_t pid;
+            pid = wait(&status);
+            if (pid == child) {
+                if (WIFEXITED(status) && WEXITSTATUS(status) == 0) {
+                    return EXIT_SUCCESS;
+                }
+            }
+        }
+    }
+    return EXIT_FAILURE;
+}
+
+int check_predepends(void)
+{
+    return myexec("/usr/bin/dpkg", "--assert-support-predepends", NULL);
+}
+
+int dpkg_compare_versions(char *v1, char *op, char *v2)
+{
+    return myexec("/usr/bin/dpkg", "--compare-versions", v1, op, v2, NULL);
+}
+
+int dpkg_divert_add(char *pkg, char *file)
+{
+    return myexec("/usr/sbin/dpkg-divert", "--package", pkg, "--add", file, NULL);
+}
+
+char *check_diversion(char *diversion_name)
+{
+    pid_t child;
+    int pipedes[2];
+
+    if (pipe(pipedes))
+       return NULL;
+
+
+    switch(child = fork()) {
+      case -1:
+        /* fork failed */
+       close(pipedes[0]);
+       close(pipedes[1]);
+        return NULL;
+
+      case 0:
+        /* i'm the child */
+        {
+           if (dup2(pipedes[STDOUT_FILENO], STDOUT_FILENO) < 0)
+               _exit(127);
+           close(pipedes[STDIN_FILENO]);
+           close(pipedes[STDOUT_FILENO]);
+            execl( "/usr/sbin/dpkg-divert", "/usr/sbin/dpkg-divert",
+                   "--list", diversion_name, NULL );
+           _exit(127);
+        }
+
+      default:
+        /* i'm the parent */
+        {
+           static char line[1024];
+           FILE *fd;
+
+           close (pipedes[STDOUT_FILENO]);
+           fcntl (pipedes[STDIN_FILENO], F_SETFD, FD_CLOEXEC);
+           fd = fdopen (pipedes[STDIN_FILENO], "r");
+
+           while (fgets(line, 1024, fd) != NULL) {
+               line[strlen(line)-1] = '\0';
+               break;
+           }
+           fclose(fd);
+           return line;
+        }
+    }
+    return NULL;
+}
+
+#define FIRST_WITHOUT_SHLINK "2.05b-4"
+
+const char *msg =
+  "As bash for Debian is destined to provide a working /bin/sh (pointing to\n"
+  "/bin/bash) your link will be overwritten by a default link.\n\n"
+  "If you don't want further upgrades to overwrite your customization,\n"
+  "please read /usr/share/doc/bash/README.Debian for a more permanent solution.\n\n"
+  "[Press RETURN to continue]";
+
+int main(int argc, char *argv[]) {
+    int targetlen;
+    char target[PATH_MAX+1], answer[1024];
+
+    if (argc < 2) {
+       printf("\nbash/preinst: expected at least one argument\n\n");
+       return EXIT_FAILURE;
+    }
+
+    if (check_predepends() != EXIT_SUCCESS) {
+       printf("\nPlease upgrade to a new version of dpkg\n\n");
+       return EXIT_FAILURE;
+    }
+
+/*
+    if [ "$1" = upgrade ] && dpkg --compare-versions "$2" lt FIRST_WITHOUT_SHLINK; then
+        div=$(dpkg-divert --list /bin/sh)
+        if [ -z "$div" ]; then
+                dpkg-divert --package bash --add /bin/sh
+                ln -sf dash /bin/sh
+        fi
+        div=$(dpkg-divert --list /usr/share/man/man1/sh.1.gz)
+        if [ -z "$div" ]; then
+                dpkg-divert --package bash --add /usr/share/man/man1/sh.1.gz
+                ln -sf dash.1.gz /usr/share/man/man1/sh.1.gz
+        fi
+     fi
+*/
+
+    if (strcmp(argv[1], "upgrade") == 0) {
+       if (argc < 3) {
+           printf("\nbash/preinst upgrade: expected at least two arguments\n\n");
+           return EXIT_FAILURE;
+       }
+       if (dpkg_compare_versions(argv[2], "lt", FIRST_WITHOUT_SHLINK) == EXIT_SUCCESS) {
+           char *diversion = check_diversion("/bin/sh");
+
+           if (diversion == NULL)
+               return EXIT_FAILURE;
+           // printf("diversion: /%s/\n", diversion);
+           if (strcmp(diversion, "") == 0) {
+               // link is not diverted
+               dpkg_divert_add("bash", "/bin/sh");
+
+               unlink("/bin/sh");
+               symlink("dash", "/bin/sh");
+           }
+
+           diversion = check_diversion("/usr/share/man/man1/sh.1.gz");
+
+           if (diversion == NULL)
+               return EXIT_FAILURE;
+           // printf("diversion: /%s/\n", diversion);
+           if (strcmp(diversion, "") == 0) {
+               // link is not diverted
+               dpkg_divert_add("bash", "/usr/share/man/man1/sh.1.gz");
+
+               unlink("/usr/share/man/man1/sh.1.gz");
+               symlink("dash.1.gz", "/usr/share/man/man1/sh.1.gz");
+           }
+
+       }
+    }
+
+#if 0
+    targetlen = readlink("/bin/sh", target, PATH_MAX);
+    if (targetlen == -1) {
+       // error reading link. Will be overwritten.
+       puts("The bash upgrade discovered that something is wrong with your /bin/sh link.");
+       puts(msg);
+       fgets(answer, 1024, stdin);
+       return EXIT_SUCCESS;
+    }
+    target[targetlen] = '\0';
+    if (strcmp(target, "bash") != 0 && strcmp(target, "/bin/bash") != 0) {
+       char *diversion = check_diversion("/bin/sh");
+
+       if (diversion == NULL)
+           return EXIT_FAILURE;
+       // printf("diversion: /%s/\n", diversion);
+       if (strcmp(diversion, "") != 0)
+           // link is diverted
+           return EXIT_SUCCESS;
+       printf("The bash upgrade discovered that your /bin/sh link points to %s.\n", target);
+       puts(msg);
+       fgets(answer, 1024, stdin);
+       return EXIT_SUCCESS;
+    }
+#endif
+
+    return EXIT_SUCCESS;
+}
diff --git a/debian/new/changelog-add b/debian/new/changelog-add
new file mode 100644 (file)
index 0000000..b68f795
--- /dev/null
@@ -0,0 +1,4 @@
+bash (2.05b-4) unstable; urgency=low
+
+  * Remove /bin/sh symlink from package.
+  * Pre-Depend on base-files (>= 3.0.5), which contains the symlink.
diff --git a/debian/patches/bash-aliases-repeat.dpatch b/debian/patches/bash-aliases-repeat.dpatch
new file mode 100644 (file)
index 0000000..ae1ac9b
--- /dev/null
@@ -0,0 +1,45 @@
+#! /bin/sh -e
+
+if [ $# -eq 3 -a "$2" = '-d' ]; then
+    pdir="-d $3"
+elif [ $# -ne 1 ]; then
+    echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+    exit 1
+fi
+case "$1" in
+    -patch) patch $pdir -f --no-backup-if-mismatch -p0 < $0;;
+    -unpatch) patch $pdir -f --no-backup-if-mismatch -R -p0 < $0;;
+    *)
+       echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+       exit 1
+esac
+exit 0
+
+# DP: Fix bug in Bash_aliases example.
+
+--- examples/startup-files/Bash_aliases~       2008-04-19 21:57:24.000000000 +0200
++++ examples/startup-files/Bash_aliases        2008-04-19 21:59:43.000000000 +0200
+@@ -41,20 +41,20 @@
+ { 
+     local count="$1" i;
+     shift;
+-    for i in $(seq 1 "$count");
++    for i in $(_seq 1 "$count");
+     do
+         eval "$@";
+     done
+ }
+ # Subfunction needed by `repeat'.
+-seq ()
++_seq ()
+ { 
+     local lower upper output;
+     lower=$1 upper=$2;
+     if [ $lower -ge $upper ]; then return; fi
+-    while [ $lower -le $upper ];
++    while [ $lower -lt $upper ];
+     do
+       echo -n "$lower "
+         lower=$(($lower + 1))
diff --git a/debian/patches/bash-default-editor.dpatch b/debian/patches/bash-default-editor.dpatch
new file mode 100644 (file)
index 0000000..1d0f44c
--- /dev/null
@@ -0,0 +1,48 @@
+#! /bin/sh -e
+
+if [ $# -eq 3 -a "$2" = '-d' ]; then
+    pdir="-d $3"
+elif [ $# -ne 1 ]; then
+    echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+    exit 1
+fi
+case "$1" in
+    -patch) patch $pdir -f --no-backup-if-mismatch -p1 < $0;;
+    -unpatch) patch $pdir -f --no-backup-if-mismatch -R -p1 < $0;;
+    *)
+       echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+       exit 1
+esac
+exit 0
+
+# DP: Use `command -v editor`, as an editor, if available.
+
+--- bash/builtins/fc.def~      2005-10-13 18:11:24.798452832 +0200
++++ bash/builtins/fc.def       2005-10-13 19:36:11.956087320 +0200
+@@ -156,11 +156,11 @@
+ #endif
+ /* String to execute on a file that we want to edit. */
+-#define FC_EDIT_COMMAND "${FCEDIT:-${EDITOR:-vi}}"
++#define FC_EDIT_COMMAND "${FCEDIT:-${EDITOR:-$(command -v editor || echo vi)}}"
+ #if defined (STRICT_POSIX)
+ #  define POSIX_FC_EDIT_COMMAND "${FCEDIT:-ed}"
+ #else
+-#  define POSIX_FC_EDIT_COMMAND "${FCEDIT:-${EDITOR:-ed}}"
++#  define POSIX_FC_EDIT_COMMAND "${FCEDIT:-${EDITOR:-$(command -v editor || echo ed)}}"
+ #endif
+ int
+--- bash/bashline.c~   2005-10-13 18:11:24.827448424 +0200
++++ bash/bashline.c    2005-10-13 19:37:35.382404592 +0200
+@@ -800,8 +800,8 @@
+    command being entered (if no explicit argument is given), otherwise on
+    a command from the history file. */
+-#define VI_EDIT_COMMAND               "fc -e \"${VISUAL:-${EDITOR:-vi}}\""
+-#define EMACS_EDIT_COMMAND    "fc -e \"${VISUAL:-${EDITOR:-emacs}}\""
++#define VI_EDIT_COMMAND               "fc -e \"${VISUAL:-${EDITOR:-$(command -v editor || echo vi)}}\""
++#define EMACS_EDIT_COMMAND    "fc -e \"${VISUAL:-${EDITOR:-$(command -v editor || echo emacs)}}\""
+ #define POSIX_VI_EDIT_COMMAND "fc -e vi"
+ static int
diff --git a/debian/patches/bash-minimal.dpatch b/debian/patches/bash-minimal.dpatch
new file mode 100644 (file)
index 0000000..c6b0039
--- /dev/null
@@ -0,0 +1,62 @@
+#! /bin/sh -e
+
+if [ $# -eq 3 -a "$2" = '-d' ]; then
+    pdir="-d $3"
+elif [ $# -ne 1 ]; then
+    echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+    exit 1
+fi
+case "$1" in
+    -patch) patch $pdir -f --no-backup-if-mismatch -p1 < $0;;
+    -unpatch) patch $pdir -f --no-backup-if-mismatch -R -p1 < $0;;
+    *)
+       echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+       exit 1
+esac
+exit 0
+
+# DP: Build fixes for minimal bash
+
+--- bash/parse.y~      2009-11-02 23:34:15.000000000 +0100
++++ bash/parse.y       2009-12-30 17:08:12.341085169 +0100
+@@ -2772,12 +2772,14 @@
+   dstack.delimiter_depth = 0; /* No delimiters found so far. */
+   open_brace_count = 0;
++#if defined (EXTENDED_GLOB)
+   /* Reset to global value of extended glob */
+   if (parser_state & PST_EXTPAT)
+ {
+ /*itrace("reset_parser: parser_state includes PST_EXTPAT");*/
+     extended_glob = global_extglob;
+ }
++#endif
+   parser_state = 0;
+--- bash/execute_cmd.c~        2009-11-29 03:29:34.000000000 +0100
++++ bash/execute_cmd.c 2009-12-30 17:13:36.041085541 +0100
+@@ -4196,7 +4196,9 @@
+   if (variable_context == 0 || this_shell_function == 0)
+     {
+       make_funcname_visible (0);
++#if defined (PROCESS_SUBSTITUTION)
+       unlink_fifo_list ();
++#endif
+     }
+   
+   return (result);
+--- bash/lib/glob/glob.c~      2009-11-15 00:39:30.000000000 +0100
++++ bash/lib/glob/glob.c       2009-12-30 17:34:56.802336552 +0100
+@@ -640,7 +640,11 @@
+             continue;
+           }
++#ifdef MACOS
+         convfn = fnx_fromfs (dp->d_name, D_NAMLEN (dp));
++#else
++        convfn = dp->d_name;
++#endif
+         if (strmatch (pat, convfn, mflags) != FNM_NOMATCH)
+           {
+             if (nalloca < ALLOCA_MAX)
diff --git a/debian/patches/bash-subst-param-length.dpatch b/debian/patches/bash-subst-param-length.dpatch
new file mode 100644 (file)
index 0000000..836a18c
--- /dev/null
@@ -0,0 +1,32 @@
+#! /bin/sh -e
+
+if [ $# -eq 3 -a "$2" = '-d' ]; then
+    pdir="-d $3"
+elif [ $# -ne 1 ]; then
+    echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+    exit 1
+fi
+case "$1" in
+    -patch) patch $pdir -f --no-backup-if-mismatch -p0 < $0;;
+    -unpatch) patch $pdir -f --no-backup-if-mismatch -R -p0 < $0;;
+    *)
+        echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+        exit 1
+esac
+exit 0
+
+DP: ignore array subscript while determining variable name for length
+DP: substitution
+DP: (#345861)
+
+--- ../bash-3.1/subst.c     2006-01-14 01:12:02.000000000 +0100
++++ subst.c     2006-01-14 01:12:39.000000000 +0100
+@@ -5814,7 +5814,7 @@
+     {
+       t_index++;
+       free (name);
+-      temp1 = string_extract (string, &t_index, "#%:-=?+/}", 0);
++      temp1 = string_extract (string, &t_index, "#%:-=?+/}", SX_VARNAME);
+       name = (char *)xmalloc (3 + (strlen (temp1)));
+       *name = string[sindex];
+       if (string[sindex] == '!')
diff --git a/debian/patches/bash41-001.dpatch b/debian/patches/bash41-001.dpatch
new file mode 100644 (file)
index 0000000..a6d2d07
--- /dev/null
@@ -0,0 +1,67 @@
+#! /bin/sh -e
+
+if [ $# -eq 3 -a "$2" = '-d' ]; then
+    pdir="-d $3"
+elif [ $# -ne 1 ]; then
+    echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+    exit 1
+fi
+case "$1" in
+    -patch) patch $pdir -f --no-backup-if-mismatch -p1 < $0;;
+    -unpatch) patch $pdir -f --no-backup-if-mismatch -R -p1 < $0;;
+    *)
+       echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+       exit 1
+esac
+exit 0
+
+# DP: bash-4.1 upstream patch 001
+
+                            BASH PATCH REPORT
+                            =================
+
+Bash-Release:  4.1
+Patch-ID:      bash41-001
+
+Bug-Reported-by:       Yann Rouillard <yann@pleiades.fr.eu.org>
+Bug-Reference-ID:      <4B44A410.4070107@pleiades.fr.eu.org>
+Bug-Reference-URL:     http://lists.gnu.org/archive/html/bug-bash/2010-01/msg00018.html
+
+Bug-Description:
+
+A prototype for vsnprintf was incorrect, and caused compilation failures
+on systems that did not have a suitable vsnprintf, but had a declaration in
+one of the system header files.
+
+Patch (apply with `patch -p0'):
+
+*** ../bash-4.1-patched/builtins/printf.def    2009-11-20 15:31:23.000000000 -0500
+--- ./builtins/printf.def      2010-01-07 08:50:06.000000000 -0500
+***************
+*** 173,177 ****
+  
+  #if !HAVE_VSNPRINTF
+! extern int vsnprintf __P((char *, size_t, const char *, ...)) __attribute__((__format__ (printf, 3, 4)));
+  #endif
+  
+--- 173,177 ----
+  
+  #if !HAVE_VSNPRINTF
+! extern int vsnprintf __P((char *, size_t, const char *, va_list)) __attribute__((__format__ (printf, 3, 0)));
+  #endif
+  
+*** ../bash-4.1-patched/patchlevel.h   2009-10-01 16:39:22.000000000 -0400
+--- ./patchlevel.h     2010-01-14 09:38:08.000000000 -0500
+***************
+*** 26,30 ****
+     looks for to find the patch level (for the sccs version string). */
+  
+! #define PATCHLEVEL 0
+  
+  #endif /* _PATCHLEVEL_H_ */
+--- 26,30 ----
+     looks for to find the patch level (for the sccs version string). */
+  
+! #define PATCHLEVEL 1
+  
+  #endif /* _PATCHLEVEL_H_ */
diff --git a/debian/patches/bash41-002.dpatch b/debian/patches/bash41-002.dpatch
new file mode 100644 (file)
index 0000000..4b0eca2
--- /dev/null
@@ -0,0 +1,83 @@
+#! /bin/sh -e
+
+if [ $# -eq 3 -a "$2" = '-d' ]; then
+    pdir="-d $3"
+elif [ $# -ne 1 ]; then
+    echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+    exit 1
+fi
+case "$1" in
+    -patch) patch $pdir -f --no-backup-if-mismatch -p1 < $0;;
+    -unpatch) patch $pdir -f --no-backup-if-mismatch -R -p1 < $0;;
+    *)
+       echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+       exit 1
+esac
+exit 0
+
+# DP: <your description>
+                            BASH PATCH REPORT
+                            =================
+
+Bash-Release:  4.1
+Patch-ID:      bash41-002
+
+Bug-Reported-by:       guillaume.outters@free.fr
+Bug-Reference-ID:      <20100105230441.70D171AA7F52@asterix.local>
+Bug-Reference-URL:     http://lists.gnu.org/archive/html/bug-bash/2010-01/msg00017.html
+
+Bug-Description:
+
+Bash-4.1/Readline-6.1 introduced a hook function that allows applications
+to rewrite or modify filenames read from the file system before comparing
+them with a word to be completed.  The converted filename, if it matches,
+needs to be inserted into the line buffer, replacing the original contents.
+
+This fixes a completion bug on Mac OS X involving filenames containing
+UTF-8 characters.
+
+Patch (apply with `patch -p0'):
+
+*** ../bash-4.1-patched/lib/readline/complete.c        2009-11-29 18:39:30.000000000 -0500
+--- ./lib/readline/complete.c  2010-01-06 08:30:23.000000000 -0500
+***************
+*** 2139,2143 ****
+        if (filename_len == 0)
+       {
+!        if (_rl_match_hidden_files == 0 && HIDDEN_FILE (entry->d_name))
+           continue;
+  
+--- 2139,2143 ----
+        if (filename_len == 0)
+       {
+!        if (_rl_match_hidden_files == 0 && HIDDEN_FILE (convfn))
+           continue;
+  
+***************
+*** 2220,2224 ****
+           }
+  
+!        strcpy (temp + dirlen, entry->d_name);
+       }
+        else
+--- 2220,2224 ----
+           }
+  
+!        strcpy (temp + dirlen, convfn);
+       }
+        else
+*** ../bash-4.1-patched/patchlevel.h   2009-10-01 16:39:22.000000000 -0400
+--- ./patchlevel.h     2010-01-14 09:38:08.000000000 -0500
+***************
+*** 26,30 ****
+     looks for to find the patch level (for the sccs version string). */
+  
+! #define PATCHLEVEL 1
+  
+  #endif /* _PATCHLEVEL_H_ */
+--- 26,30 ----
+     looks for to find the patch level (for the sccs version string). */
+  
+! #define PATCHLEVEL 2
+  
+  #endif /* _PATCHLEVEL_H_ */
diff --git a/debian/patches/bash41-003.dpatch b/debian/patches/bash41-003.dpatch
new file mode 100644 (file)
index 0000000..c916ba1
--- /dev/null
@@ -0,0 +1,67 @@
+#! /bin/sh -e
+
+if [ $# -eq 3 -a "$2" = '-d' ]; then
+    pdir="-d $3"
+elif [ $# -ne 1 ]; then
+    echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+    exit 1
+fi
+case "$1" in
+    -patch) patch $pdir -f --no-backup-if-mismatch -p1 < $0;;
+    -unpatch) patch $pdir -f --no-backup-if-mismatch -R -p1 < $0;;
+    *)
+       echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+       exit 1
+esac
+exit 0
+
+# DP: bash-4.1 upstream patch 003
+
+                            BASH PATCH REPORT
+                            =================
+
+Bash-Release:  4.1
+Patch-ID:      bash41-003
+
+Bug-Reported-by:       coyote@wariat.org.pl
+Bug-Reference-ID:      <4b64a1f8.06e2660a.60af.4bfb@mx.google.com>
+Bug-Reference-URL:     http://lists.gnu.org/archive/html/bug-bash/2010-01/msg00135.html
+
+Bug-Description:
+
+If command completion is attempted on a word with a quoted globbing
+character (e.g., `*' or `?'), bash can reference a NULL pointer and
+dump core.
+
+Patch (apply with `patch -p0'):
+
+*** ../bash-4.1-patched/bashline.c     2009-10-24 14:10:19.000000000 -0400
+--- ./bashline.c       2010-01-30 21:53:49.000000000 -0500
+***************
+*** 1681,1685 ****
+       characters in the common prefix are bad) will ever be returned on
+       regular completion. */
+!   if (glob_pattern_p (hint))
+      {
+        if (state == 0)
+--- 1681,1685 ----
+       characters in the common prefix are bad) will ever be returned on
+       regular completion. */
+!   if (globpat)
+      {
+        if (state == 0)
+*** ../bash-4.1-patched/patchlevel.h   2009-10-01 16:39:22.000000000 -0400
+--- ./patchlevel.h     2010-01-14 09:38:08.000000000 -0500
+***************
+*** 26,30 ****
+     looks for to find the patch level (for the sccs version string). */
+  
+! #define PATCHLEVEL 2
+  
+  #endif /* _PATCHLEVEL_H_ */
+--- 26,30 ----
+     looks for to find the patch level (for the sccs version string). */
+  
+! #define PATCHLEVEL 3
+  
+  #endif /* _PATCHLEVEL_H_ */
diff --git a/debian/patches/bash41-004.dpatch b/debian/patches/bash41-004.dpatch
new file mode 100644 (file)
index 0000000..51e9154
--- /dev/null
@@ -0,0 +1,66 @@
+#! /bin/sh -e
+
+if [ $# -eq 3 -a "$2" = '-d' ]; then
+    pdir="-d $3"
+elif [ $# -ne 1 ]; then
+    echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+    exit 1
+fi
+case "$1" in
+    -patch) patch $pdir -f --no-backup-if-mismatch -p1 < $0;;
+    -unpatch) patch $pdir -f --no-backup-if-mismatch -R -p1 < $0;;
+    *)
+       echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+       exit 1
+esac
+exit 0
+
+# DP: bash-4.1 upstream patch 004
+
+                            BASH PATCH REPORT
+                            =================
+
+Bash-Release:  4.1
+Patch-ID:      bash41-004
+
+Bug-Reported-by:       Crestez Dan Leonard <cdleonard@gmail.com>
+Bug-Reference-ID:      <1265592839.30682.21.camel@deskbox>
+Bug-Reference-URL:     http://lists.gnu.org/archive/html/bug-bash/2010-02/msg00034.html
+
+Bug-Description:
+
+When running in Posix mode and executing a shell function without local
+variables, bash will not propagate a variable in a special builtin's temporary
+environment to have global scope.
+
+Patch (apply with `patch -p0'):
+
+*** ../bash-4.1-patched/variables.c    2009-11-03 14:13:58.000000000 -0500
+--- ./variables.c      2010-02-08 17:36:18.000000000 -0500
+***************
+*** 3809,3812 ****
+--- 3809,3817 ----
+    if (tempvar_p (var) && (posixly_correct || (var->attributes & att_propagate)))
+      {
++       /* Make sure we have a hash table to store the variable in while it is
++       being propagated down to the global variables table.  Create one if
++       we have to */
++       if ((vc_isfuncenv (shell_variables) || vc_istempenv (shell_variables)) && shell_variables->table == 0)
++      shell_variables->table = hash_create (0);
+        /* XXX - should we set v->context here? */
+        v = bind_variable_internal (var->name, value_cell (var), shell_variables->table, 0, 0);
+*** ../bash-4.1-patched/patchlevel.h   2009-10-01 16:39:22.000000000 -0400
+--- ./patchlevel.h     2010-01-14 09:38:08.000000000 -0500
+***************
+*** 26,30 ****
+     looks for to find the patch level (for the sccs version string). */
+  
+! #define PATCHLEVEL 3
+  
+  #endif /* _PATCHLEVEL_H_ */
+--- 26,30 ----
+     looks for to find the patch level (for the sccs version string). */
+  
+! #define PATCHLEVEL 4
+  
+  #endif /* _PATCHLEVEL_H_ */
diff --git a/debian/patches/bash41-005.dpatch b/debian/patches/bash41-005.dpatch
new file mode 100644 (file)
index 0000000..ff40c34
--- /dev/null
@@ -0,0 +1,75 @@
+#! /bin/sh -e
+
+if [ $# -eq 3 -a "$2" = '-d' ]; then
+    pdir="-d $3"
+elif [ $# -ne 1 ]; then
+    echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+    exit 1
+fi
+case "$1" in
+    -patch) patch $pdir -f --no-backup-if-mismatch -p1 < $0;;
+    -unpatch) patch $pdir -f --no-backup-if-mismatch -R -p1 < $0;;
+    *)
+       echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+       exit 1
+esac
+exit 0
+
+# DP: bash-4.1 upstream patch 005
+
+                            BASH PATCH REPORT
+                            =================
+
+Bash-Release:  4.1
+Patch-ID:      bash41-005
+
+Bug-Reported-by:       werner@suse.de
+Bug-Reference-ID:      <201002251238.o1PCcYcg016893@boole.suse.de>
+Bug-Reference-URL:     http://lists.gnu.org/archive/html/bug-bash/2010-02/msg00132.html
+
+Bug-Description:
+
+When the `read' builtin times out after the timeout specified with -t is
+exceeded, it does not reset the flags that tell signal handlers to process
+signals immediately instead of deferring their handling.  This can result
+in unsafe functions being called from signal handlers, which can cause bash
+to hang or dump core.
+
+Patch (apply with `patch -p0'):
+
+*** ../bash-4.1-patched/builtins/read.def      2009-10-08 11:35:46.000000000 -0400
+--- ./builtins/read.def        2010-03-17 17:35:39.000000000 -0400
+***************
+*** 616,621 ****
+      zsyncfd (fd);
+  
+-   interrupt_immediately--;
+-   terminate_immediately--;
+    discard_unwind_frame ("read_builtin");
+  
+--- 616,619 ----
+***************
+*** 624,627 ****
+--- 622,628 ----
+  assign_vars:
+  
++   interrupt_immediately--;
++   terminate_immediately--;
++ 
+  #if defined (ARRAY_VARS)
+    /* If -a was given, take the string read, break it into a list of words,
+*** ../bash-4.1-patched/patchlevel.h   2009-10-01 16:39:22.000000000 -0400
+--- ./patchlevel.h     2010-01-14 09:38:08.000000000 -0500
+***************
+*** 26,30 ****
+     looks for to find the patch level (for the sccs version string). */
+  
+! #define PATCHLEVEL 4
+  
+  #endif /* _PATCHLEVEL_H_ */
+--- 26,30 ----
+     looks for to find the patch level (for the sccs version string). */
+  
+! #define PATCHLEVEL 5
+  
+  #endif /* _PATCHLEVEL_H_ */
diff --git a/debian/patches/bashbug-editor.dpatch b/debian/patches/bashbug-editor.dpatch
new file mode 100644 (file)
index 0000000..cb52ebd
--- /dev/null
@@ -0,0 +1,31 @@
+#! /bin/sh -e
+
+if [ $# -eq 3 -a "$2" = '-d' ]; then
+    pdir="-d $3"
+elif [ $# -ne 1 ]; then
+    echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+    exit 1
+fi
+case "$1" in
+    -patch) patch $pdir -f --no-backup-if-mismatch -p1 < $0;;
+    -unpatch) patch $pdir -f --no-backup-if-mismatch -R -p1 < $0;;
+    *)
+       echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+       exit 1
+esac
+exit 0
+
+# DP: send bug reports to Debian bash maintainer too.
+
+diff -urb bash.orig/support/bashbug.sh bash/support/bashbug.sh
+--- bash.orig/support/bashbug.sh       2002-04-16 23:15:15.000000000 +0200
++++ bash/support/bashbug.sh    2003-09-27 23:35:04.000000000 +0200
+@@ -134,6 +134,7 @@
+               esac ;;
+ esac
++BUGBASH="${BUGBASH},bash@packages.debian.org"
+ BUGADDR="${1-$BUGBASH}"
+ if [ -z "$DEFEDITOR" ] && [ -z "$EDITOR" ]; then
+Only in bash/support: bashbug.sh.orig
diff --git a/debian/patches/bashdb-updates.dpatch b/debian/patches/bashdb-updates.dpatch
new file mode 100644 (file)
index 0000000..13a6b24
--- /dev/null
@@ -0,0 +1,24 @@
+#! /bin/sh -e
+
+dir=.
+if [ $# -eq 3 -a "$2" = '-d' ]; then
+    pdir="-d $3"
+    dir=$3
+elif [ $# -ne 1 ]; then
+    echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+    exit 1
+fi
+case "$1" in
+    -patch)
+       patch $pdir -f --no-backup-if-mismatch -p1 < $0
+       cd $dir && autoconf
+       ;;
+    -unpatch) patch $pdir -f --no-backup-if-mismatch -R -p1 < $0;;
+    *)
+       echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+       exit 1
+esac
+exit 0
+
+# DP: Debian updates to bashdb
+
diff --git a/debian/patches/bashdb.dpatch b/debian/patches/bashdb.dpatch
new file mode 100644 (file)
index 0000000..7a330d1
--- /dev/null
@@ -0,0 +1,56 @@
+#! /bin/sh -e
+
+dir=.
+if [ $# -eq 3 -a "$2" = '-d' ]; then
+    pdir="-d $3"
+    dir=$3
+elif [ $# -ne 1 ]; then
+    echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+    exit 1
+fi
+case "$1" in
+    -patch)
+       patch $pdir -f --no-backup-if-mismatch -p1 < $0
+       rm -f $dir/aclocal.m4
+       rm -f $dir/configure
+       rm -f $dir/doc/bashref.info
+       rm -f $dir/examples/bashdb/bashdb.el
+       rm -f $dir/lib/readline/doc/Makefile
+       rm -f $dir/parser-built
+       rm -f $dir/pathnames.h
+       rm -f $dir/y.tab.[ch]
+       (cd $dir && aclocal -I . -I debugger)
+       (cd $dir && autoconf)
+       for i in config.guess config.sub elisp-comp install-sh \
+                missing mkinstalldirs
+       do
+           cp -p /usr/share/automake-1.7/$i $dir/debugger/
+       done
+       for i in mdate-sh texinfo.tex; do
+           cp -p /usr/share/automake-1.7/$i $dir/debugger/doc/
+       done
+       (cd $dir/debugger && aclocal -I ..)
+       cp -p $dir/debugger/elisp-comp $dir/debugger/emacs/.
+       (cd $dir/debugger && automake)
+       (cd $dir/debugger && autoconf)
+       ;;
+    -unpatch)
+       patch $pdir -f --no-backup-if-mismatch -R -p1 < $0
+       ;;
+    *)
+       echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+       exit 1
+esac
+exit 0
+
+# how to construct this file:
+# - unpack the upstream bash source
+# - unpack the bashdb source
+# - apply bash the seven bash upstream patches
+# - diff -ur --unidirectional-new-file \
+         --exclude CVS --exclude=.cvsignore --exclude=/db/ \
+#        bash-2.05b bashdb
+
+# DP: bashdb changes
+
+diff -ur --unidirectional-new-file --exclude CVS --exclude=.cvsignore bash-2.05b/ChangeLog cvs/ChangeLog
diff --git a/debian/patches/builtins-declare-fix.dpatch b/debian/patches/builtins-declare-fix.dpatch
new file mode 100644 (file)
index 0000000..87edfc2
--- /dev/null
@@ -0,0 +1,37 @@
+#! /bin/sh -e
+
+if [ $# -eq 3 -a "$2" = '-d' ]; then
+    pdir="-d $3"
+elif [ $# -ne 1 ]; then
+    echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+    exit 1
+fi
+case "$1" in
+    -patch) patch $pdir -f --no-backup-if-mismatch -p1 < $0;;
+    -unpatch) patch $pdir -f --no-backup-if-mismatch -R -p1 < $0;;
+    *)
+       echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+       exit 1
+esac
+exit 0
+
+# DP: <your description>
+Andreas Schwab <schwab@linux-m68k.org> writes:
+
+> $ declare -A a=b; unset a
+> *** glibc detected *** /bin/bash: free(): invalid pointer: 0x10091644 ***
+
+And the obvious patch:
+
+--- bash-4.1/builtins/declare.def.~1~  2009-11-26 01:42:00.000000000 +0100
++++ bash-4.1/builtins/declare.def      2010-04-09 19:20:51.000000000 +0200
+@@ -512,7 +512,7 @@ declare_internal (list, local_var)
+           {
+             /* let bind_{array,assoc}_variable take care of this. */
+             if (assoc_p (var))
+-              bind_assoc_variable (var, name, "0", value, aflags);
++              bind_assoc_variable (var, name, savestring ("0"), value, aflags);
+             else
+               bind_array_variable (name, 0, value, aflags);
+           }
+
diff --git a/debian/patches/deb-bash-config.dpatch b/debian/patches/deb-bash-config.dpatch
new file mode 100644 (file)
index 0000000..24360d0
--- /dev/null
@@ -0,0 +1,86 @@
+#! /bin/sh -e
+
+if [ $# -eq 3 -a "$2" = '-d' ]; then
+    pdir="-d $3"
+elif [ $# -ne 1 ]; then
+    echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+    exit 1
+fi
+case "$1" in
+    -patch) patch $pdir -f --no-backup-if-mismatch -p1 < $0;;
+    -unpatch) patch $pdir -f --no-backup-if-mismatch -R -p1 < $0;;
+    *)
+       echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+       exit 1
+esac
+exit 0
+
+# DP: Changed compile time configuration options:
+# DP: 
+# DP: - Set the default path to comply with Debian policy
+# DP: 
+# DP: - Enable System-wide .bashrc file for interactive shells.
+# DP: 
+# DP: - Enable System-wide .bash.logout  file for interactive shells.
+# DP: 
+# DP: - make non-interactive shells begun with argv[0][0] == '-'
+# DP:   run the startup files when not in posix mode.
+# DP: 
+# DP: - try to check whether bash is being run by sshd and source
+# DP:   the .bashrc if so (like the rshd behavior).
+# DP: 
+# DP: - don't define a default DEFAULT_MAIL_DIRECTORY, because it
+# DP:   can cause a timeout on NFS mounts.
+
+--- bash/config-top.h.orig     2008-08-17 16:52:25.000000000 +0000
++++ bash/config-top.h  2008-11-29 17:35:03.000000000 +0000
+@@ -54,14 +54,14 @@
+ /* The default value of the PATH variable. */
+ #ifndef DEFAULT_PATH_VALUE
+ #define DEFAULT_PATH_VALUE \
+-  "/usr/gnu/bin:/usr/local/bin:/bin:/usr/bin:."
++  "/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin"
+ #endif
+ /* The value for PATH when invoking `command -p'.  This is only used when
+    the Posix.2 confstr () function, or CS_PATH define are not present. */
+ #ifndef STANDARD_UTILS_PATH
+ #define STANDARD_UTILS_PATH \
+-  "/bin:/usr/bin:/sbin:/usr/sbin:/etc:/usr/etc"
++  "/bin:/usr/bin:/sbin:/usr/sbin"
+ #endif
+ /* Default primary and secondary prompt strings. */
+@@ -75,20 +75,20 @@
+ #define KSH_COMPATIBLE_SELECT
+ /* System-wide .bashrc file for interactive shells. */
+-/* #define SYS_BASHRC "/etc/bash.bashrc" */
++#define SYS_BASHRC "/etc/bash.bashrc"
+ /* System-wide .bash_logout for login shells. */
+-/* #define SYS_BASH_LOGOUT "/etc/bash.bash_logout" */
++#define SYS_BASH_LOGOUT "/etc/bash.bash_logout"
+ /* Define this to make non-interactive shells begun with argv[0][0] == '-'
+    run the startup files when not in posix mode. */
+-/* #define NON_INTERACTIVE_LOGIN_SHELLS */
++#define NON_INTERACTIVE_LOGIN_SHELLS
+ /* Define this if you want bash to try to check whether it's being run by
+    sshd and source the .bashrc if so (like the rshd behavior).  This checks
+    for the presence of SSH_CLIENT or SSH2_CLIENT in the initial environment,
+    which can be fooled under certain not-uncommon circumstances. */
+-/* #define SSH_SOURCE_BASHRC */
++#define SSH_SOURCE_BASHRC
+ /* Define if you want the case-capitalizing operators (~[~]) and the
+    `capcase' variable attribute (declare -c). */
+--- bash/config-bot.h.orig     2008-08-17 16:52:02.000000000 +0000
++++ bash/config-bot.h  2008-11-29 17:32:42.000000000 +0000
+@@ -192,4 +192,4 @@
+ /******************************************************************/
+ /* If you don't want bash to provide a default mail file to check. */
+-/* #undef DEFAULT_MAIL_DIRECTORY */
++#undef DEFAULT_MAIL_DIRECTORY
diff --git a/debian/patches/deb-examples.dpatch b/debian/patches/deb-examples.dpatch
new file mode 100644 (file)
index 0000000..f951fa5
--- /dev/null
@@ -0,0 +1,31 @@
+#! /bin/sh -e
+
+if [ $# -eq 3 -a "$2" = '-d' ]; then
+    pdir="-d $3"
+elif [ $# -ne 1 ]; then
+    echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+    exit 1
+fi
+case "$1" in
+    -patch) patch $pdir -f --no-backup-if-mismatch -p1 < $0;;
+    -unpatch) patch $pdir -f --no-backup-if-mismatch -R -p1 < $0;;
+    *)
+       echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+       exit 1
+esac
+exit 0
+
+# DP: document readline header location on Debian systems
+
+--- bash/examples/loadables/README~    2006-12-04 10:21:13.000000000 +0000
++++ bash/examples/loadables/README     2006-12-04 10:23:05.000000000 +0000
+@@ -32,6 +32,9 @@
+ guide'.  The file template.c provides a template to use for creating
+ new loadable builtins.
++On Debian GNU/Linux systems, the bash headers are in /usr/include/bash.
++The appropriate options are already set in the example Makefile.
++
+ basename.c    Return non-directory portion of pathname.
+ cat.c         cat(1) replacement with no options - the way cat was intended.
+ cut.c         cut(1) replacement.
diff --git a/debian/patches/exec-redirections-man.dpatch b/debian/patches/exec-redirections-man.dpatch
new file mode 100644 (file)
index 0000000..95b4d70
--- /dev/null
@@ -0,0 +1,31 @@
+#! /bin/sh -e
+
+if [ $# -eq 3 -a "$2" = '-d' ]; then
+    pdir="-d $3"
+elif [ $# -ne 1 ]; then
+    echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+    exit 1
+fi
+case "$1" in
+    -patch) patch $pdir -f --no-backup-if-mismatch -p1 < $0;;
+    -unpatch) patch $pdir -f --no-backup-if-mismatch -R -p1 < $0;;
+    *)
+       echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+       exit 1
+esac
+exit 0
+
+--- bash/doc/bash.1~   2006-07-12 20:16:36.000000000 -0400
++++ bash/doc/bash.1    2006-07-12 20:26:49.000000000 -0400
+@@ -3014,6 +3014,10 @@
+ Redirections using file descriptors greater than 9 should be used with
+ care, as they may conflict with file descriptors the shell uses
+ internally.
++.PP
++Note that the
++.B exec
++builtin command can make redirections take effect in the current shell.
+ .SS Redirecting Input
+ .PP
+ Redirection of input causes the file whose name results from
+
diff --git a/debian/patches/exec-redirections-texi.dpatch b/debian/patches/exec-redirections-texi.dpatch
new file mode 100644 (file)
index 0000000..97a9ea2
--- /dev/null
@@ -0,0 +1,29 @@
+#! /bin/sh -e
+
+if [ $# -eq 3 -a "$2" = '-d' ]; then
+    pdir="-d $3"
+elif [ $# -ne 1 ]; then
+    echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+    exit 1
+fi
+case "$1" in
+    -patch) patch $pdir -f --no-backup-if-mismatch -p1 < $0;;
+    -unpatch) patch $pdir -f --no-backup-if-mismatch -R -p1 < $0;;
+    *)
+       echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+       exit 1
+esac
+exit 0
+
+--- bash/doc/bashref.texi~     2005-10-03 15:07:21.000000000 -0400
++++ bash/doc/bashref.texi      2006-07-12 21:26:57.000000000 -0400
+@@ -2030,6 +2030,9 @@
+ care, as they may conflict with file descriptors the shell uses
+ internally.
++Note that the @code{exec} builtin command can make redirections take
++effect in the current shell.
++
+ @subsection Redirecting Input
+ Redirection of input causes the file whose name results from
+ the expansion of @var{word}
diff --git a/debian/patches/input-err.dpatch b/debian/patches/input-err.dpatch
new file mode 100644 (file)
index 0000000..8fb93d7
--- /dev/null
@@ -0,0 +1,30 @@
+#! /bin/sh -e
+
+if [ $# -eq 3 -a "$2" = '-d' ]; then
+    pdir="-d $3"
+elif [ $# -ne 1 ]; then
+    echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+    exit 1
+fi
+case "$1" in
+    -patch) patch $pdir -f --no-backup-if-mismatch -p0 < $0;;
+    -unpatch) patch $pdir -f --no-backup-if-mismatch -R -p0 < $0;;
+    *)
+       echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+       exit 1
+esac
+exit 0
+
+# DP: Define PGRP_PIPE to avoid race condition.
+
+--- input.c~   2005-07-14 13:29:08.000000000 +0100
++++ input.c    2006-04-05 14:51:50.000000000 +0100
+@@ -454,7 +454,7 @@
+       if (nr == 0)
+       bp->b_flag |= B_EOF;
+       else
+-      bp->b_flag |= B_ERROR;
++      fatal_error("error reading input file: %s", strerror(errno));
+       return (EOF);
+     }
diff --git a/debian/patches/man-arithmetic.dpatch b/debian/patches/man-arithmetic.dpatch
new file mode 100644 (file)
index 0000000..1178ce8
--- /dev/null
@@ -0,0 +1,32 @@
+#! /bin/sh -e
+
+if [ $# -eq 3 -a "$2" = '-d' ]; then
+    pdir="-d $3"
+elif [ $# -ne 1 ]; then
+    echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+    exit 1
+fi
+case "$1" in
+    -patch) patch $pdir -f --no-backup-if-mismatch -p1 < $0;;
+    -unpatch) patch $pdir -f --no-backup-if-mismatch -R -p1 < $0;;
+    *)
+       echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+       exit 1
+esac
+exit 0
+
+# DP: document deprecated syntax for arithmetic evaluation.
+
+diff -urb bash.orig/doc/bash.1 bash/doc/bash.1
+--- bash.orig/doc/bash.1       2003-09-25 21:42:45.000000000 +0200
++++ bash/doc/bash.1    2003-09-28 00:24:17.000000000 +0200
+@@ -2533,6 +2533,9 @@
+ \fB$((\fP\fIexpression\fP\fB))\fP
+ .RE
+ .PP
++The old format \fB$[\fP\fIexpression\fP\fB]\fP is deprecated and will
++be removed in upcoming versions of bash.
++.PP
+ The
+ .I expression
+ is treated as if it were within double quotes, but a double quote
diff --git a/debian/patches/man-bashlogout.dpatch b/debian/patches/man-bashlogout.dpatch
new file mode 100644 (file)
index 0000000..75871e5
--- /dev/null
@@ -0,0 +1,31 @@
+#! /bin/sh -e
+
+if [ $# -eq 3 -a "$2" = '-d' ]; then
+    pdir="-d $3"
+elif [ $# -ne 1 ]; then
+    echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+    exit 1
+fi
+case "$1" in
+    -patch) patch $pdir -f --no-backup-if-mismatch -p1 < $0;;
+    -unpatch) patch $pdir -f --no-backup-if-mismatch -R -p1 < $0;;
+    *)
+       echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+       exit 1
+esac
+exit 0
+
+# DP: document /etc/bash.bashrc in bash man page
+
+--- bash/doc/bash.1~   2004-06-19 15:53:01.000000000 +0200
++++ bash/doc/bash.1    2004-06-19 15:53:57.000000000 +0200
+@@ -8283,6 +8283,9 @@
+ .FN /etc/bash.bashrc
+ The systemwide per-interactive-shell startup file
+ .TP
++.FN /etc/bash.bash.logout
++The systemwide login shell cleanup file, executed when a login shell exits
++.TP
+ .FN ~/.bash_profile
+ The personal initialization file, executed for login shells
+ .TP
diff --git a/debian/patches/man-bashrc.dpatch b/debian/patches/man-bashrc.dpatch
new file mode 100644 (file)
index 0000000..f303854
--- /dev/null
@@ -0,0 +1,81 @@
+#! /bin/sh -e
+
+if [ $# -eq 3 -a "$2" = '-d' ]; then
+    pdir="-d $3"
+elif [ $# -ne 1 ]; then
+    echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+    exit 1
+fi
+case "$1" in
+    -patch) patch $pdir -f --no-backup-if-mismatch -p1 < $0;;
+    -unpatch) patch $pdir -f --no-backup-if-mismatch -R -p1 < $0;;
+    *)
+       echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+       exit 1
+esac
+exit 0
+
+# DP: document /etc/bash.bashrc in bash man page
+
+--- bash/doc/bash.1.orig       2008-11-29 17:37:14.000000000 +0000
++++ bash/doc/bash.1    2008-11-29 17:40:07.000000000 +0000
+@@ -184,7 +184,9 @@
+ .PD
+ Execute commands from
+ .I file
+-instead of the standard personal initialization file
++instead of the system wide initialization file
++.I /etc/bash.bashrc
++and the standard personal initialization file
+ .I ~/.bashrc
+ if the shell is interactive (see
+ .SM
+@@ -215,7 +217,9 @@
+ below).
+ .TP
+ .B \-\-norc
+-Do not read and execute the personal initialization file
++Do not read and execute the system wide initialization file
++.I /etc/bash.bashrc
++and the personal initialization file
+ .I ~/.bashrc
+ if the shell is interactive.
+ This option is on by default if the shell is invoked as
+@@ -323,13 +327,15 @@
+ .PP
+ When an interactive shell that is not a login shell is started,
+ .B bash
+-reads and executes commands from \fI~/.bashrc\fP, if that file exists.
++reads and executes commands from \fI/etc/bash.bashrc\fP and \fI~/.bashrc\fP,
++if these files exist.
+ This may be inhibited by using the
+ .B \-\-norc
+ option.
+ The \fB\-\-rcfile\fP \fIfile\fP option will force
+ .B bash
+-to read and execute commands from \fIfile\fP instead of \fI~/.bashrc\fP.
++to read and execute commands from \fIfile\fP instead of
++\fI/etc/bash.bashrc\fP and \fI~/.bashrc\fP.
+ .PP
+ When
+ .B bash
+@@ -415,7 +421,8 @@
+ If
+ .B bash
+ determines it is being run in this fashion, it reads and executes
+-commands from \fI~/.bashrc\fP, if that file exists and is readable.
++commands from \fI~/.bashrc\fP and \fI~/.bashrc\fP, if these files
++exist and are readable.
+ It will not do this if invoked as \fBsh\fP.
+ The
+ .B \-\-norc
+@@ -9293,6 +9300,9 @@
+ .FN /etc/profile
+ The systemwide initialization file, executed for login shells
+ .TP
++.FN /etc/bash.bashrc
++The systemwide per-interactive-shell startup file
++.TP
+ .FN ~/.bash_profile
+ The personal initialization file, executed for login shells
+ .TP
diff --git a/debian/patches/man-builtin.dpatch b/debian/patches/man-builtin.dpatch
new file mode 100644 (file)
index 0000000..6abaef8
--- /dev/null
@@ -0,0 +1,29 @@
+#! /bin/sh -e
+
+if [ $# -eq 3 -a "$2" = '-d' ]; then
+    pdir="-d $3"
+elif [ $# -ne 1 ]; then
+    echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+    exit 1
+fi
+case "$1" in
+    -patch) patch $pdir -f --no-backup-if-mismatch -p0 < $0;;
+    -unpatch) patch $pdir -f --no-backup-if-mismatch -R -p0 < $0;;
+    *)
+       echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+       exit 1
+esac
+exit 0
+
+# DP: fix man page include
+
+--- doc/builtins.1~    Mon Nov 29 22:30:13 1999
++++ doc/builtins.1     Tue Aug  1 21:54:06 2000
+@@ -10,6 +10,6 @@
+ ulimit, umask, unalias, unset, until, wait, while \- bash built-in commands, see \fBbash\fR(1)
+ .SH BASH BUILTIN COMMANDS
+ .nr zZ 1
+-.so bash.1
++.so /usr/share/man/man1/bash.1
+ .SH SEE ALSO
+ bash(1), sh(1)
diff --git a/debian/patches/man-fignore.dpatch b/debian/patches/man-fignore.dpatch
new file mode 100644 (file)
index 0000000..cd005bc
--- /dev/null
@@ -0,0 +1,33 @@
+#! /bin/sh -e
+
+if [ $# -eq 3 -a "$2" = '-d' ]; then
+    pdir="-d $3"
+elif [ $# -ne 1 ]; then
+    echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+    exit 1
+fi
+case "$1" in
+    -patch) patch $pdir -f --no-backup-if-mismatch -p1 < $0;;
+    -unpatch) patch $pdir -f --no-backup-if-mismatch -R -p1 < $0;;
+    *)
+       echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+       exit 1
+esac
+exit 0
+
+# DP: bash(1): mention quoting when assigning to FIGNORE
+
+diff -urb bash.orig/doc/bash.1 bash/doc/bash.1
+--- bash.orig/doc/bash.1       2003-09-25 21:42:45.000000000 +0200
++++ bash/doc/bash.1    2003-09-28 00:25:21.000000000 +0200
+@@ -1584,7 +1584,9 @@
+ is excluded from the list of matched filenames.
+ A sample value is
+ .if t \f(CW".o:~"\fP.
+-.if n ".o:~".
++.if n ".o:~"
++(Quoting is needed when assigning a value to this variable,
++which contains tildes).
+ .TP
+ .B GLOBIGNORE
+ A colon-separated list of patterns defining the set of filenames to
diff --git a/debian/patches/man-net-redirections-doc.dpatch b/debian/patches/man-net-redirections-doc.dpatch
new file mode 100644 (file)
index 0000000..3cc49de
--- /dev/null
@@ -0,0 +1,31 @@
+#! /bin/sh -e
+
+if [ $# -eq 3 -a "$2" = '-d' ]; then
+    pdir="-d $3"
+elif [ $# -ne 1 ]; then
+    echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+    exit 1
+fi
+case "$1" in
+    -patch) patch $pdir -f --no-backup-if-mismatch -p1 < $0;;
+    -unpatch) patch $pdir -f --no-backup-if-mismatch -R -p1 < $0;;
+    *)
+       echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+       exit 1
+esac
+exit 0
+
+# DP: Document, that bash is configured using --disable-net-redirections.
+
+--- bash/doc/bashref.texi~     2005-09-09 22:08:10.865192816 +0200
++++ bash/doc/bashref.texi      2005-09-10 11:42:51.805867224 +0200
+@@ -2025,6 +2025,9 @@
+ is an integer port number or service name, Bash attempts to open a UDP
+ connection to the corresponding socket.
++NOTE: @code{Bash}, as packaged for Debian, does not support using the
++@file{/dev/tcp} and @file{/dev/udp} files.
++
+ @end table
+ A failure to open or create a file causes the redirection to fail.
diff --git a/debian/patches/man-net-redirections.dpatch b/debian/patches/man-net-redirections.dpatch
new file mode 100644 (file)
index 0000000..1bee4b1
--- /dev/null
@@ -0,0 +1,31 @@
+#! /bin/sh -e
+
+if [ $# -eq 3 -a "$2" = '-d' ]; then
+    pdir="-d $3"
+elif [ $# -ne 1 ]; then
+    echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+    exit 1
+fi
+case "$1" in
+    -patch) patch $pdir -f --no-backup-if-mismatch -p1 < $0;;
+    -unpatch) patch $pdir -f --no-backup-if-mismatch -R -p1 < $0;;
+    *)
+       echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+       exit 1
+esac
+exit 0
+
+# DP: Document, that bash is configured using --disable-net-redirections.
+
+--- bash/doc/bash.1~   2005-09-09 22:08:10.833197680 +0200
++++ bash/doc/bash.1    2005-09-10 11:47:57.694365104 +0200
+@@ -3033,6 +3033,9 @@
+ .PD
+ .RE
+ .PP
++\fBNOTE:\fP Bash, as packaged for Debian, does \fBnot\fP support using
++the \fB/dev/tcp\fP and \fB/dev/udp\fP files.
++.PP
+ A failure to open or create a file causes the redirection to fail.
+ .PP
+ Redirections using file descriptors greater than 9 should be used with
diff --git a/debian/patches/man-nocaseglob.dpatch b/debian/patches/man-nocaseglob.dpatch
new file mode 100644 (file)
index 0000000..6176a53
--- /dev/null
@@ -0,0 +1,32 @@
+#! /bin/sh -e
+
+if [ $# -eq 3 -a "$2" = '-d' ]; then
+    pdir="-d $3"
+elif [ $# -ne 1 ]; then
+    echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+    exit 1
+fi
+case "$1" in
+    -patch) patch $pdir -f --no-backup-if-mismatch -p1 < $0;;
+    -unpatch) patch $pdir -f --no-backup-if-mismatch -R -p1 < $0;;
+    *)
+       echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+       exit 1
+esac
+exit 0
+
+# DP: Clarify documentation about case-insensitive pathname expansion
+
+--- bash/doc/bash.1~   2004-08-28 18:25:23.000000000 +0200
++++ bash/doc/bash.1    2004-08-28 19:13:24.000000000 +0200
+@@ -2690,6 +2690,10 @@
+ .B nocaseglob
+ is enabled, the match is performed without regard to the case
+ of alphabetic characters.
++Note that when using range expressions like
++[a-z] (see below), letters of the other case may be included,
++depending on the setting of
++.B LC_COLLATE.
+ When a pattern is used for pathname expansion,
+ the character
+ .B ``.''
diff --git a/debian/patches/man-substring-exp-doc.dpatch b/debian/patches/man-substring-exp-doc.dpatch
new file mode 100644 (file)
index 0000000..c6cdf58
--- /dev/null
@@ -0,0 +1,31 @@
+#! /bin/sh -e
+
+if [ $# -eq 3 -a "$2" = '-d' ]; then
+    pdir="-d $3"
+elif [ $# -ne 1 ]; then
+    echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+    exit 1
+fi
+case "$1" in
+    -patch) patch $pdir -f --no-backup-if-mismatch -p1 < $0;;
+    -unpatch) patch $pdir -f --no-backup-if-mismatch -R -p1 < $0;;
+    *)
+       echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+       exit 1
+esac
+exit 0
+
+# DP: Clarify documentation about substring expansion
+
+--- bash/doc/bashref.texi~     2004-08-28 15:10:17.000000000 +0200
++++ bash/doc/bashref.texi      2004-08-28 18:27:16.000000000 +0200
+@@ -1575,6 +1575,9 @@
+ @var{length} must evaluate to a number greater than or equal to zero.
+ If @var{offset} evaluates to a number less than zero, the value
+ is used as an offset from the end of the value of @var{parameter}.
++Arithmetic expressions starting with a - must be separated by whitespace
++from the preceding : to be
++distinguished from the $@{@var{parameter}:@minus{}@var{word}@} expansion.
+ If @var{parameter} is @samp{@@}, the result is @var{length} positional
+ parameters beginning at @var{offset}.
+ If @var{parameter} is an array name indexed by @samp{@@} or @samp{*},
diff --git a/debian/patches/man-substring-exp.dpatch b/debian/patches/man-substring-exp.dpatch
new file mode 100644 (file)
index 0000000..8cfaece
--- /dev/null
@@ -0,0 +1,31 @@
+#! /bin/sh -e
+
+if [ $# -eq 3 -a "$2" = '-d' ]; then
+    pdir="-d $3"
+elif [ $# -ne 1 ]; then
+    echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+    exit 1
+fi
+case "$1" in
+    -patch) patch $pdir -f --no-backup-if-mismatch -p1 < $0;;
+    -unpatch) patch $pdir -f --no-backup-if-mismatch -R -p1 < $0;;
+    *)
+       echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+       exit 1
+esac
+exit 0
+
+# DP: Clarify documentation about substring expansion
+
+--- bash/doc/bash.1~   2004-08-28 15:10:17.000000000 +0200
++++ bash/doc/bash.1    2004-08-28 18:25:23.000000000 +0200
+@@ -2356,6 +2356,9 @@
+ \fIlength\fP must evaluate to a number greater than or equal to zero.
+ If \fIoffset\fP evaluates to a number less than zero, the value
+ is used as an offset from the end of the value of \fIparameter\fP.
++Arithmetic expressions starting with a - must be separated by whitespace
++from the preceding : to be
++distinguished from the \fBUse Default Values\fP expansion.
+ If \fIparameter\fP is \fB@\fP, the result is \fIlength\fP positional
+ parameters beginning at \fIoffset\fP.
+ If \fIparameter\fP is an array name indexed by @ or *,
diff --git a/debian/patches/man-test.dpatch b/debian/patches/man-test.dpatch
new file mode 100644 (file)
index 0000000..9382b35
--- /dev/null
@@ -0,0 +1,32 @@
+#! /bin/sh -e
+
+if [ $# -eq 3 -a "$2" = '-d' ]; then
+    pdir="-d $3"
+elif [ $# -ne 1 ]; then
+    echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+    exit 1
+fi
+case "$1" in
+    -patch) patch $pdir -f --no-backup-if-mismatch -p0 < $0;;
+    -unpatch) patch $pdir -f --no-backup-if-mismatch -R -p0 < $0;;
+    *)
+       echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+       exit 1
+esac
+exit 0
+
+# DP: document conditional file expressions acting on the target of
+# DP: symbolic links as well (except -h, -L).
+
+--- builtins/test.def~ 2002-04-04 21:48:17.000000000 +0200
++++ builtins/test.def  2004-10-16 19:51:24.000000000 +0200
+@@ -60,6 +60,9 @@
+   FILE1 -ef FILE2  True if file1 is a hard link to file2.
++All file operators except -h and -L are acting on the target of a symbolic
++link, not on the symlink itself, if FILE is a symbolic link.
++
+ String operators:
+     -z STRING      True if string is empty.
diff --git a/debian/patches/man-test2-doc.dpatch b/debian/patches/man-test2-doc.dpatch
new file mode 100644 (file)
index 0000000..ef981a7
--- /dev/null
@@ -0,0 +1,32 @@
+#! /bin/sh -e
+
+if [ $# -eq 3 -a "$2" = '-d' ]; then
+    pdir="-d $3"
+elif [ $# -ne 1 ]; then
+    echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+    exit 1
+fi
+case "$1" in
+    -patch) patch $pdir -f --no-backup-if-mismatch -p0 < $0;;
+    -unpatch) patch $pdir -f --no-backup-if-mismatch -R -p0 < $0;;
+    *)
+       echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+       exit 1
+esac
+exit 0
+
+# DP: Document handling of parameters of the test builtin.
+
+--- doc/bashref.texi~  2005-09-09 19:51:31.150172600 +0000
++++ doc/bashref.texi   2005-09-09 19:52:12.693857000 +0000
+@@ -5264,6 +5264,10 @@
+ Unless otherwise specified, primaries that operate on files follow symbolic
+ links and operate on the target of the link, rather than the link itself.
++See the description of the @code{test} builtin command (section
++@pxref{Bash Builtins} below) for the handling of parameters
++(i.e. missing parameters).
++
+ @table @code
+ @item -a @var{file}
+ True if @var{file} exists.
diff --git a/debian/patches/man-test2.dpatch b/debian/patches/man-test2.dpatch
new file mode 100644 (file)
index 0000000..f2cc08a
--- /dev/null
@@ -0,0 +1,44 @@
+#! /bin/sh -e
+
+if [ $# -eq 3 -a "$2" = '-d' ]; then
+    pdir="-d $3"
+elif [ $# -ne 1 ]; then
+    echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+    exit 1
+fi
+case "$1" in
+    -patch) patch $pdir -f --no-backup-if-mismatch -p1 < $0;;
+    -unpatch) patch $pdir -f --no-backup-if-mismatch -R -p1 < $0;;
+    *)
+       echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+       exit 1
+esac
+exit 0
+
+# DP: Document handling of parameters of the test builtin.
+
+--- bash/builtins/test.def.orig        2008-11-29 17:41:32.000000000 +0000
++++ bash/builtins/test.def     2008-11-29 17:44:25.000000000 +0000
+@@ -94,6 +94,9 @@
+ less-than, less-than-or-equal, greater-than, or greater-than-or-equal
+ than ARG2.
++See the bash manual page bash(1) for the handling of parameters (i.e.
++missing parameters).
++
+ Exit Status:
+ Returns success if EXPR evaluates to true; fails if EXPR evaluates to
+ false or an invalid argument is given.
+--- bash/doc/bash.1.~3~        2009-12-30 15:45:17.063586386 +0100
++++ bash/doc/bash.1    2009-12-30 15:53:33.021085355 +0100
+@@ -3843,6 +3843,10 @@
+ .if n .sp 1
+ When used with \fB[[\fP, The \fB<\fP and \fB>\fP operators sort
+ lexicographically using the current locale.
++.PP
++See the description of the \fItest\fP builtin command (section SHELL
++BUILTIN COMMANDS below) for the handling of parameters (i.e.
++missing parameters).
+ .sp 1
+ .PD 0
+ .TP
diff --git a/debian/patches/man-vx-opts.dpatch b/debian/patches/man-vx-opts.dpatch
new file mode 100644 (file)
index 0000000..e85b350
--- /dev/null
@@ -0,0 +1,34 @@
+#! /bin/sh -e
+
+if [ $# -eq 3 -a "$2" = '-d' ]; then
+    pdir="-d $3"
+elif [ $# -ne 1 ]; then
+    echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+    exit 1
+fi
+case "$1" in
+    -patch) patch $pdir -f --no-backup-if-mismatch -p1 < $0;;
+    -unpatch) patch $pdir -f --no-backup-if-mismatch -R -p1 < $0;;
+    *)
+       echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+       exit 1
+esac
+exit 0
+
+# DP: document -v / -x options
+
+--- ./doc/bash.1~      Wed Jan 20 22:48:04 1999
++++ ./doc/bash.1       Sun Nov 14 13:26:59 1999
+@@ -104,6 +104,12 @@
+ This option allows the positional parameters to be set
+ when invoking an interactive shell.
+ .TP
++.B \-v
++Print shell input lines as they are read.
++.TP
++.B \-x
++Print commands and their arguments as they are executed.
++.TP
+ .B \-D
+ A list of all double-quoted strings preceded by \fB$\fP
+ is printed on the standard ouput.
diff --git a/debian/patches/pgrp-pipe.dpatch b/debian/patches/pgrp-pipe.dpatch
new file mode 100644 (file)
index 0000000..21e9f3e
--- /dev/null
@@ -0,0 +1,29 @@
+#! /bin/sh -e
+
+if [ $# -eq 3 -a "$2" = '-d' ]; then
+    pdir="-d $3"
+elif [ $# -ne 1 ]; then
+    echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+    exit 1
+fi
+case "$1" in
+    -patch) patch $pdir -f --no-backup-if-mismatch -p0 < $0;;
+    -unpatch) patch $pdir -f --no-backup-if-mismatch -R -p0 < $0;;
+    *)
+       echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+       exit 1
+esac
+exit 0
+
+# DP: Define PGRP_PIPE to avoid race condition.
+
+--- config-bot.h       2004-03-19 17:56:23.000000000 -0500
++++ config-bot.h       2005-09-16 14:32:33.000000000 -0400
+@@ -179,3 +179,6 @@
+ /* If you don't want bash to provide a default mail file to check. */
+ #undef DEFAULT_MAIL_DIRECTORY
++
++/* Bug #224543 */
++#define PGRP_PIPE 1
+
diff --git a/debian/patches/privmode.dpatch b/debian/patches/privmode.dpatch
new file mode 100644 (file)
index 0000000..eb9abf2
--- /dev/null
@@ -0,0 +1,37 @@
+#! /bin/sh -e
+
+if [ $# -eq 3 -a "$2" = '-d' ]; then
+    pdir="-d $3"
+elif [ $# -ne 1 ]; then
+    echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+    exit 1
+fi
+case "$1" in
+    -patch) patch $pdir -f --no-backup-if-mismatch -p1 < $0;;
+    -unpatch) patch $pdir -f --no-backup-if-mismatch -R -p1 < $0;;
+    *)
+       echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+       exit 1
+esac
+exit 0
+
+# DP: XXX missing description
+# DP: 
+# DP: Comment from Chet Ramey <chet@nike.ins.cwru.edu>:
+# DP: 
+# DP: Nope.  This will allow setuid scripts if not called as `sh' and not 
+# DP: called with the -p option.  I won't install this. 
+
+diff -urb bash.orig/shell.c bash/shell.c
+--- bash.orig/shell.c  2003-06-03 19:50:35.000000000 +0200
++++ bash/shell.c       2003-09-28 00:26:28.000000000 +0200
+@@ -447,7 +447,7 @@
+   if (dump_translatable_strings)
+     read_but_dont_execute = 1;
+-  if (running_setuid && privileged_mode == 0)
++  if (running_setuid && privileged_mode == 0 && act_like_sh == 0)
+     disable_priv_mode ();
+   /* Need to get the argument to a -c option processed in the
diff --git a/debian/patches/random.dpatch b/debian/patches/random.dpatch
new file mode 100644 (file)
index 0000000..6304468
--- /dev/null
@@ -0,0 +1,107 @@
+#! /bin/sh -e
+
+dir=.
+if [ $# -eq 3 -a "$2" = '-d' ]; then
+    pdir="-d $3"
+    dir=$3
+elif [ $# -ne 1 ]; then
+    echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+    exit 1
+fi
+case "$1" in
+    -patch)
+       patch $pdir -f --no-backup-if-mismatch -p1 < $0
+       echo '2.05' > $dir/_distribution
+       echo '0' > $dir/_patchlevel
+       cd $dir && autoconf
+       rm -f $dir/_distribution $dir/_patchlevel
+       ;;
+    -unpatch)
+       patch $pdir -f --no-backup-if-mismatch -R -p1 < $0
+       rm -f $dir/configure $dir/_distribution $dir/_patchlevel
+       ;;
+    *)
+       echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+       exit 1
+esac
+exit 0
+
+# DP: use the system random functions
+
+diff -urb bash.orig/config.h.in bash/config.h.in
+--- bash.orig/config.h.in      2003-09-22 14:42:35.000000000 +0200
++++ bash/config.h.in   2003-09-28 00:27:15.000000000 +0200
+@@ -606,6 +606,9 @@
+ /* Define if you have the putenv function.  */
+ #undef HAVE_PUTENV
++/* Define if you have the random function.  */
++#undef HAVE_RANDOM
++
+ /* Define if you have the readlink function. */
+ #undef HAVE_READLINK
+@@ -696,6 +699,9 @@
+ /* Define if you have the strsignal function or macro. */
+ #undef HAVE_STRSIGNAL
++/* Define if you have the srandom function.  */
++#undef HAVE_SRANDOM
++
+ /* Define if you have the sysconf function. */
+ #undef HAVE_SYSCONF
+diff -urb bash.orig/variables.c bash/variables.c
+--- bash.orig/variables.c      2003-07-31 16:28:57.000000000 +0200
++++ bash/variables.c   2003-09-28 00:27:15.000000000 +0200
+@@ -1098,16 +1098,22 @@
+ static unsigned long rseed = 1;
+ static int last_random_value;
+-/* A linear congruential random number generator based on the example
+-   one in the ANSI C standard.  This one isn't very good, but a more
+-   complicated one is overkill. */
++/* Use the random number genrator provided by the standard C library,
++   else use a linear congruential random number generator based on the
++   ANSI C standard.  This one isn't very good (the values are alternately
++   odd and even, for example), but a more complicated one is overkill. */
+ /* Returns a pseudo-random number between 0 and 32767. */
+ static int
+ brand ()
+ {
++#if defined(HAVE_RANDOM)
++  rseed = (unsigned int) (labs(random()) & 32767);
++  return rseed;
++#else
+   rseed = rseed * 1103515245 + 12345;
+   return ((unsigned int)((rseed >> 16) & 32767));     /* was % 32768 */
++#endif
+ }
+ /* Set the random number generator seed to SEED. */
+@@ -1115,8 +1121,12 @@
+ sbrand (seed)
+      unsigned long seed;
+ {
++#if defined(HAVE_SRANDOM)
++  srandom(seed);
++#else
+   rseed = seed;
+   last_random_value = 0;
++#endif
+ }
+ static SHELL_VAR *
+--- bash/configure.in~ 2004-03-02 00:04:29.000000000 +0100
++++ bash/configure.in  2004-03-02 00:05:48.000000000 +0100
+@@ -667,6 +667,9 @@
+ AC_FUNC_MKTIME
++dnl checks for random functions
++AC_CHECK_FUNCS(random srandom)
++
+ dnl
+ dnl Checks for lib/intl and related code (uses some of the output from
+ dnl AM_GNU_GETTEXT)
diff --git a/debian/patches/rbash-manpage.dpatch b/debian/patches/rbash-manpage.dpatch
new file mode 100644 (file)
index 0000000..73a9969
--- /dev/null
@@ -0,0 +1,29 @@
+#! /bin/sh -e
+
+if [ $# -eq 3 -a "$2" = '-d' ]; then
+    pdir="-d $3"
+elif [ $# -ne 1 ]; then
+    echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+    exit 1
+fi
+case "$1" in
+    -patch) patch $pdir -f --no-backup-if-mismatch -p0 < $0;;
+    -unpatch) patch $pdir -f --no-backup-if-mismatch -R -p0 < $0;;
+    *)
+       echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+       exit 1
+esac
+exit 0
+
+# DP: doc/rbash.1: fix bash(1) reference
+
+--- doc/rbash.1~       1999-11-29 22:30:03.000000000 +0100
++++ doc/rbash.1        2003-02-21 16:15:59.000000000 +0100
+@@ -3,6 +3,6 @@
+ rbash \- restricted bash, see \fBbash\fR(1)
+ .SH RESTRICTED SHELL
+ .nr zY 1
+-.so bash.1
++.so man1/bash.1
+ .SH SEE ALSO
+ bash(1)
diff --git a/debian/patches/rl-del-backspace-policy.dpatch b/debian/patches/rl-del-backspace-policy.dpatch
new file mode 100644 (file)
index 0000000..ec56b43
--- /dev/null
@@ -0,0 +1,48 @@
+#! /bin/sh -e
+
+if [ $# -eq 3 -a "$2" = '-d' ]; then
+    pdir="-d $3"
+elif [ $# -ne 1 ]; then
+    echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+    exit 1
+fi
+case "$1" in
+    -patch) patch $pdir -f --no-backup-if-mismatch -p1 < $0;;
+    -unpatch) patch $pdir -f --no-backup-if-mismatch -R -p1 < $0;;
+    *)
+       echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+       exit 1
+esac
+exit 0
+
+# DP: Handle Debian Backspace/Delete keyboard policy
+
+diff -urb bash.orig/lib/readline/terminal.c bash/lib/readline/terminal.c
+--- bash.orig/lib/readline/terminal.c  2003-09-18 17:03:42.000000000 +0200
++++ bash/lib/readline/terminal.c       2003-09-27 23:25:59.000000000 +0200
+@@ -148,6 +148,9 @@
+ /* Insert key */
+ static char *_rl_term_kI;
++/* The key sequence sent by the Delete key, if any. */
++static char *_rl_term_kD;
++
+ /* Cursor control */
+ static char *_rl_term_vs;     /* very visible */
+ static char *_rl_term_ve;     /* normal */
+@@ -314,6 +317,7 @@
+   { "ic", &_rl_term_ic },
+   { "im", &_rl_term_im },
+   { "kH", &_rl_term_kH },     /* home down ?? */
++  { "kD", &_rl_term_kD },     /* delete */
+   { "kI", &_rl_term_kI },     /* insert */
+   { "kd", &_rl_term_kd },
+   { "ke", &_rl_term_ke },     /* end keypad mode */
+@@ -492,6 +496,7 @@
+   rl_bind_keyseq_if_unbound (_rl_term_kh, rl_beg_of_line);    /* Home */
+   rl_bind_keyseq_if_unbound (_rl_term_at7, rl_end_of_line);   /* End */
++  rl_bind_keyseq_if_unbound (_rl_term_kD, rl_delete);         /* Delete */
+   _rl_keymap = xkeymap;
+ }
diff --git a/debian/patches/rl-examples-bdb.dpatch b/debian/patches/rl-examples-bdb.dpatch
new file mode 100644 (file)
index 0000000..33cca15
--- /dev/null
@@ -0,0 +1,30 @@
+#! /bin/sh -e
+
+if [ $# -eq 3 -a "$2" = '-d' ]; then
+    pdir="-d $3"
+elif [ $# -ne 1 ]; then
+    echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+    exit 1
+fi
+case "$1" in
+    -patch) patch $pdir -f --no-backup-if-mismatch -p1 < $0;;
+    -unpatch) patch $pdir -f --no-backup-if-mismatch -R -p1 < $0;;
+    *)
+       echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+       exit 1
+esac
+exit 0
+
+# DP: Modified readline examples to properly build with Debian setup.
+
+--- ./lib/readline/examples/rl.c~      Mon Nov  8 22:22:03 1999
++++ ./lib/readline/examples/rl.c       Fri Dec 31 17:34:30 1999
+@@ -11,7 +11,7 @@
+ #include <stdio.h>
+ #include <sys/types.h>
+-#include "posixstat.h"
++#include <sys/stat.h>
+ #if defined (READLINE_LIBRARY)
+ #  include "readline.h"
diff --git a/debian/patches/rl-header.dpatch b/debian/patches/rl-header.dpatch
new file mode 100644 (file)
index 0000000..d147813
--- /dev/null
@@ -0,0 +1,28 @@
+#! /bin/sh -e
+
+if [ $# -eq 3 -a "$2" = '-d' ]; then
+    pdir="-d $3"
+elif [ $# -ne 1 ]; then
+    echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+    exit 1
+fi
+case "$1" in
+    -patch) patch $pdir -f --no-backup-if-mismatch -p0 < $0;;
+    -unpatch) patch $pdir -f --no-backup-if-mismatch -R -p0 < $0;;
+    *)
+       echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+       exit 1
+esac
+exit 0
+
+# DP: include stdio.h in readline.h
+--- lib/readline/readline.h~   Thu Aug  5 14:10:59 1999
++++ lib/readline/readline.h    Mon Oct  9 20:32:56 2000
+@@ -32,6 +32,7 @@
+ #  include "keymaps.h"
+ #  include "tilde.h"
+ #else
++#  include <stdio.h>
+ #  include <readline/rlstdc.h>
+ #  include <readline/keymaps.h>
+ #  include <readline/tilde.h>
diff --git a/debian/patches/rl-setenv.dpatch b/debian/patches/rl-setenv.dpatch
new file mode 100644 (file)
index 0000000..9ae1d08
--- /dev/null
@@ -0,0 +1,30 @@
+#! /bin/sh -e
+
+if [ $# -eq 3 -a "$2" = '-d' ]; then
+    pdir="-d $3"
+elif [ $# -ne 1 ]; then
+    echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+    exit 1
+fi
+case "$1" in
+    -patch) patch $pdir -f --no-backup-if-mismatch -p0 < $0;;
+    -unpatch) patch $pdir -f --no-backup-if-mismatch -R -p0 < $0;;
+    *)
+       echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+       exit 1
+esac
+exit 0
+
+# DP: Prefer setenv over putenv
+
+--- lib/readline/shell.c~      2004-10-17 13:07:37.000000000 +0200
++++ lib/readline/shell.c       2004-10-17 13:06:48.000000000 +0200
+@@ -122,7 +122,7 @@
+ {
+   char *b;
+-#if defined (HAVE_PUTENV)
++#if 0
+   b = (char *)xmalloc (INT_STRLEN_BOUND (int) + sizeof ("LINES=") + 1);
+   sprintf (b, "LINES=%d", lines);
+   putenv (b);
diff --git a/debian/patches/template.dpatch b/debian/patches/template.dpatch
new file mode 100644 (file)
index 0000000..e583619
--- /dev/null
@@ -0,0 +1,18 @@
+#! /bin/sh -e
+
+if [ $# -eq 3 -a "$2" = '-d' ]; then
+    pdir="-d $3"
+elif [ $# -ne 1 ]; then
+    echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+    exit 1
+fi
+case "$1" in
+    -patch) patch $pdir -f --no-backup-if-mismatch -p1 < $0;;
+    -unpatch) patch $pdir -f --no-backup-if-mismatch -R -p1 < $0;;
+    *)
+       echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
+       exit 1
+esac
+exit 0
+
+# DP: <your description>
diff --git a/debian/rules b/debian/rules
new file mode 100755 (executable)
index 0000000..92d3cbf
--- /dev/null
@@ -0,0 +1,624 @@
+#! /usr/bin/make -f
+# -*- makefile -*-
+
+#export DH_VERBOSE=1
+
+distribution := SLP
+unexport LANG LC_ALL LC_CTYPE LC_COLLATE LC_TIME LC_NUMERIC LC_MESSAGES
+
+# architecture dependent variables
+DEB_BUILD_GNU_TYPE     := $(shell dpkg-architecture -qDEB_BUILD_GNU_TYPE)
+DEB_HOST_ARCH          := $(shell dpkg-architecture -qDEB_HOST_ARCH)
+DEB_HOST_ARCH_OS       := $(shell dpkg-architecture -qDEB_HOST_ARCH_OS)
+DEB_HOST_GNU_CPU       := $(shell dpkg-architecture -qDEB_HOST_GNU_CPU)
+DEB_HOST_GNU_SYSTEM    := $(shell dpkg-architecture -qDEB_HOST_GNU_SYSTEM)
+DEB_HOST_GNU_TYPE      := $(shell dpkg-architecture -qDEB_HOST_GNU_TYPE)
+
+VERSION                := 4.1
+#PKGVERSION    := $(shell dpkg-parsechangelog \
+#                      | sed -n '/Version:/s/\(.* \)\(.*\)-2\(.*\)/\2\3/p')
+#PKGVERSION    := 3.0
+#dpkg_ctrl_args := -v$(PKGVERSION) -VBinary-Version=$(PKGVERSION)
+
+
+with_gfdl      = no
+
+CC     = gcc
+CFLAGS = -g -O2 -Wall
+SHELL  = /bin/bash
+YACC   = bison -y
+
+IX     = install -o 0 -g 0
+ID     = install -o 0 -g 0 -m 644
+
+# built with installed libreadline?
+with_installed_rl = no
+
+debflags =
+
+p      = bash
+p_stat = bash-static
+p_bins = bash-builtins
+p_doc  = bash-doc
+p_bdb  = bashdb
+
+d      = debian/$(p)
+d_stat = debian/$(p_stat)
+d_bins = debian/$(p_bins)
+d_doc  = debian/$(p_doc)
+d_bdb  = debian/$(p_bdb)
+
+conf_args = \
+       --with-curses \
+       --enable-largefile \
+       --prefix=/usr \
+       --infodir=/usr/share/info \
+       --mandir=/usr/share/man
+ifeq ($(with_installed_rl),yes)
+    conf_args += --with-installed-readline
+endif
+
+ifeq ($(distribution),SLP)
+conf_args += --without-bash-malloc
+endif
+
+static_conf_args := $(conf_args) \
+       --enable-static-link \
+       --without-bash-malloc \
+       --host=$(DEB_HOST_GNU_TYPE)
+
+conf_args += --host=$(DEB_HOST_GNU_TYPE)
+
+ifeq ($(distribution),SLP)
+build: before-build bash-build
+else
+#build: bash-build static-build preinst-build all-bashdb-build check
+build: before-build bash-build static-build preinst-build check
+endif
+
+before-build:
+       : # see #327477, needed to have HAVE_DEV_STDIN defined
+       (test -d /dev/fd && test -r /dev/stdin < /dev/null) \
+         || (test -d /proc/self/fd && test -r /dev/stdin < /dev/null)
+ifneq (,$(findstring $(DEB_HOST_ARCH_OS), linux freebsd))
+       $(CC) $(CFLAGS) -o clear_console debian/clear_console.c -lncurses
+endif
+
+# ---------------------------------------------------------------------------
+# build standard bash
+
+bash-build:
+       $(MAKE) -f debian/rules do-build-bash \
+           bash_src=bash \
+           bash_patches="$(debian_patches)" \
+           build=bash \
+           configure_args="$(conf_args)"
+bash-configure:
+       $(MAKE) -f debian/rules do-configure-bash \
+           bash_src=bash \
+           bash_patches="$(debian_patches)" \
+           build=bash \
+           configure_args="$(conf_args)"
+
+# ---------------------------------------------------------------------------
+# build static bash
+
+static-build:
+       $(MAKE) -f debian/rules do-build-static \
+           bash_src=bash \
+           bash_patches="$(debian_patches)" \
+           build=static \
+           configure_args="$(static_conf_args)"
+static-configure:
+       $(MAKE) -f debian/rules do-configure-static \
+           bash_src=bash \
+           bash_patches="$(debian_patches)" \
+           build=static \
+           configure_args="$(static_conf_args)"
+
+# ---------------------------------------------------------------------------
+# build standard bash
+
+all-bashdb-build: bashdb-build #bashdb-doc-build
+
+bashdb-build:
+       DEBUGGER_START_FILE=/usr/share/bashdb/dbg-main.inc \
+       $(MAKE) -f debian/rules do-build-bashdb \
+           bash_src=bashdb \
+           bash_patches="$(bashdb_patches)" \
+           build=bashdb \
+           configure_args="$(conf_args)"
+bashdb-configure:
+       DEBUGGER_START_FILE=/usr/share/bashdb/dbg-main.inc \
+       $(MAKE) -f debian/rules do-configure-bashdb \
+           bash_src=bashdb \
+           bash_patches="$(bashdb_patches)" \
+           build=bashdb \
+           configure_args="$(conf_args)"
+
+bashdb-doc-build: stamps/stamp-build-bashdb-doc
+stamps/stamp-build-bashdb-doc:
+       cp -p build-bashdb/doc/version.texi bashdb/doc/
+       cp -p build-bashdb/debugger/doc/version.texi bashdb/debugger/doc/
+#      $(MAKE) -C build-bashdb doc
+       $(MAKE) -C build-bashdb/debugger/doc
+       touch stamps/stamp-build-bashdb-doc
+
+# ---------------------------------------------------------------------------
+
+bash-doc-build: stamps/stamp-build-bash-doc
+stamps/stamp-build-bash-doc:
+ifeq ($(with_gfdl),yes)
+       rm -f bash/doc/bashref.info
+       $(MAKE) -C build-bash/doc bashref.info bashref.pdf
+endif
+       $(MAKE) -C build-bash/doc bash.html bash.pdf
+       touch stamps/stamp-build-bash-doc
+
+# ---------------------------------------------------------------------------
+
+check: stamps/stamp-check
+stamps/stamp-check: bash-build
+       @echo BEGIN test
+ifeq ($(DEB_BUILD_GNU_TYPE),$(DEB_HOST_GNU_TYPE))
+  ifeq (,$(findstring nocheck, $(DEB_BUILD_OPTIONS)))
+       -sh debian/locale-gen
+       LOCPATH=$(CURDIR)/locales \
+               time $(MAKE) -C build-bash test 2>&1 | tee build-bash/test-protocol
+  endif
+else
+       @echo Suppress 'make' test, because this is cross build
+endif
+       @echo END test
+       touch stamps/stamp-check
+
+# ---------------------------------------------------------------------------
+
+clean:
+       dh_testdir
+       dh_testroot
+       rm -rf stamps build-* bash bashdb
+ifeq ($(distribution),SLP)
+       rm -f debian/*.o
+else
+       rm -f debian/bash.preinst debian/*.o
+endif
+       rm -f debian/README.Debian
+       rm -rf locales
+       rm -f clear_console
+       dh_clean
+
+preinst-build: debian/bash.preinst
+debian/bash.preinst: debian/bash.preinst.c debian/md5.c debian/md5.h
+       $(CC) -O2 -c -Idebian -o debian/md5.o debian/md5.c
+       $(CC) -O2 -c -Idebian -o debian/bash.preinst.o debian/bash.preinst.c
+       $(CC) -O2 -s -o debian/bash.preinst debian/md5.o debian/bash.preinst.o
+
+# ---------------------------------------------------------------------------
+
+
+install: bash-install #bashdb-install
+
+bash-install: bash-build stamps/stamp-install-bash
+stamps/stamp-install-bash: stamps/stamp-build-bash
+       dh_testdir
+       dh_testroot
+       dh_clean -k -p$(p) -p$(p_doc) -p$(p_bins)
+       dh_installdirs -p$(p) \
+               bin \
+               etc/skel \
+               usr/share/doc/$(p)
+       dh_installdirs -p$(p_doc) \
+               usr/share/doc/$(p)
+       dh_installdirs -p$(p_bins) \
+               usr/share/doc/$(p)/examples/loadables \
+               usr/include/bash/{builtins,lib/{glob,tilde}}
+
+ifeq ($(with_gfdl),yes)
+# XXXXX
+       cp -p build-bash/doc/*.info bash/doc/
+endif
+
+       : # install it
+       $(MAKE) -C build-bash install \
+               CC='$(CC)' \
+               CFLAGS='$(CFLAGS)' \
+               YACC="$(YACC)" \
+               DESTDIR=$(CURDIR)/$(d)
+       mv $(d)/usr/bin/bash $(d)/bin/.
+       chmod 755 $(d)/usr/bin/bashbug
+       $(ID) debian/bashbug.1 $(d)/usr/share/man/man1/
+ifneq ($(with_gfdl),yes)
+       mkdir -p $(d)/usr/share/man/man1
+       cp -p bash/doc/bash.1 $(d)/usr/share/man/man1/bash.1
+endif
+
+       : # extra links
+       ln -sf bash $(d)/bin/rbash
+#      : # now shipped by dash
+ifneq ($(distribution),SLP)
+       ln -sf bash $(d)/bin/sh
+       ln -sf bash.1 $(d)/usr/share/man/man1/sh.1
+endif
+
+       : # skeleton files
+       $(ID) debian/etc.bash.bashrc $(d)/etc/bash.bashrc
+       $(ID) debian/skel.bashrc $(d)/etc/skel/.bashrc
+       $(ID) debian/skel.profile $(d)/etc/skel/.profile
+       $(ID) debian/skel.bash_logout $(d)/etc/skel/.bash_logout
+
+       : # clean_console
+ifneq (,$(findstring $(DEB_HOST_ARCH_OS), linux freebsd))
+       $(IX) clear_console $(d)/usr/bin/
+       $(ID) debian/clear_console.1 $(d)/usr/share/man/man1/
+endif
+
+ifeq (0,1)
+       : # install bash-completion
+       mkdir -p $(d)/etc/bash_completion.d
+       $(ID) debian/bash_completion/bash_completion $(d)/etc/.
+       cp -a debian/bash_completion/contrib \
+               $(d)/usr/share/doc/$(p)/completion-contrib
+       chmod 755 $(d)/usr/share/doc/$(p)/completion-contrib
+       chmod 644 $(d)/usr/share/doc/$(p)/completion-contrib/*
+       $(ID) debian/bash_completion/Changelog \
+               $(d)/usr/share/doc/$(p)/changelog.bash_completion
+       $(ID) debian/README.bash_completion $(d)/usr/share/doc/$(p)/
+       cat debian/bash_completion/README \
+               >> $(d)/usr/share/doc/$(p)/README.bash_completion
+       $(ID) debian/bash_completion/BUGS \
+               $(d)/usr/share/doc/bash/BUGS.bash_completion
+endif
+
+ifeq ($(with_gfdl),yes)
+       : # files for the bash-doc package
+       mv $(d)/usr/share/info/bash.info $(d)/usr/share/info/bashref.info
+       ln -sf bashref.info $(d)/usr/share/info/bash.info
+       mv $(d)/usr/share/info $(d_doc)/usr/share/
+else
+       rmdir $(d)/usr/share/info
+endif
+
+       dh_installexamples -p$(p_doc) bash/examples/*
+       mv $(d_doc)/usr/share/doc/$(p_doc)/examples \
+               $(d_doc)/usr/share/doc/$(p)/examples
+       rm -rf $(d_doc)/usr/share/doc/$(p)/examples/loadables
+       ln -sf ../$(p)/examples $(d_doc)/usr/share/doc/$(p_doc)/examples
+
+       cd $(d_doc)/usr/share/doc/$(p)/examples && chmod 644 \
+               *bashdb/PERMISSION complete/complete.gnu-longopt
+       cd $(d_doc)/usr/share/doc/$(p)/examples && chmod 755 \
+               misc/aliasconv.*sh misc/cshtobash
+
+       cd $(d_doc)/usr/share/doc/$(p)/examples && chmod 644 \
+               scripts/shprompt scripts/precedence \
+               scripts/bcsh.sh scripts/krand.bash
+
+       : # files for the bash-builtins package
+       $(ID) bash/include/*.h bash/*.h  $(d_bins)/usr/include/bash/
+       $(ID) build-bash/*.h $(d_bins)/usr/include/bash/
+       rm -f $(d_bins)/usr/include/bash/y.tab.h
+       $(ID) bash/builtins/*.h $(d_bins)/usr/include/bash/builtins/
+       $(ID) bash/lib/glob/*.h $(d_bins)/usr/include/bash/lib/glob/
+       $(ID) bash/lib/tilde/*.h $(d_bins)/usr/include/bash/lib/tilde/
+       $(ID) bash/examples/loadables/{README,*.c} \
+               $(d_bins)/usr/share/doc/$(p)/examples/loadables
+       $(ID) build-bash/examples/loadables/Makefile \
+               $(d_bins)/usr/share/doc/$(p)/examples/loadables
+       ln -sf bash $(d_bins)/usr/share/doc/$(p_bins)
+
+       cat debian/README stamps/stamp-patch-bash > debian/README.Debian
+
+       touch stamps/stamp-install-bash
+
+bashdb-install: stamps/stamp-install-bashdb
+stamps/stamp-install-bashdb: stamps/stamp-build-bashdb
+       dh_testdir
+       dh_testroot
+       dh_clean -k -p$(p_bdb)
+       dh_installdirs -p$(p_bdb) \
+               usr/share/doc/$(p_bdb) \
+               usr/share/emacs/site-lisp/$(p_bdb)
+
+       : # install it
+       $(MAKE) -C build-bashdb install \
+               CC='$(CC)' \
+               CFLAGS='$(CFLAGS)' \
+               YACC="$(YACC)" \
+               DESTDIR=$(CURDIR)/$(d_bdb)
+       rm -f $(d_bdb)/usr/bin/bashbug
+       rm -f $(d_bdb)/usr/share/man/man1/bashbug.1
+       rm -f $(d_bdb)/usr/share/info/*
+
+       mv $(d_bdb)/usr/share/man/man1/bash.1 \
+               $(d_bdb)/usr/share/man/man1/bash+dbg.1
+
+       $(MAKE) -C build-bashdb/debugger/doc install \
+               DESTDIR=$(CURDIR)/$(d_bdb)
+       cp -p build-bashdb/debugger/doc/bashdb.html \
+               $(d_bdb)/usr/share/doc/$(p_bdb)/.
+       cp -p build-bashdb/debugger/doc/bashdb.1 \
+               $(d_bdb)/usr/share/man/man1/.
+
+       : # some corrections
+       mv $(d_bdb)/usr/bin/bash $(d_bdb)/usr/bin/bash+dbg
+       sed -e 's,/usr/bin/bash,/usr/bin/bash+dbg,g' \
+           -e 's,/lib/bashdb,/share/bashdb,g' \
+               $(d_bdb)/usr/bin/bashdb > $(d_bdb)/usr/bin/bashdb.new
+       mv -f $(d_bdb)/usr/bin/bashdb.new $(d_bdb)/usr/bin/bashdb
+       chmod 755 $(d_bdb)/usr/bin/bashdb
+       cp -p bashdb/debugger/emacs/*.el \
+               $(d_bdb)/usr/share/emacs/site-lisp/$(p_bdb)/
+
+       touch stamps/stamp-install-bashdb
+
+binary-doc: bash-install bash-doc-build
+       dh_testdir
+       dh_testroot
+       mkdir -p $(d_doc)/usr/share/doc/$(p)
+       dh_installdocs -p$(p_doc) 
+ifeq ($(with_gfdl),yes)
+       cp -p build-bash/doc/bashref.pdf $(d_doc)/usr/share/doc/$(p)/.
+       dh_link -p$(p_doc) \
+           /usr/share/doc/$(p)/bashref.pdf /usr/share/doc/$(p_doc)/bashref.pdf
+else
+       rm -f $(d_doc)/usr/share/doc-base/bashref
+endif
+       cp -p build-bash/doc/bash.html build-bash/doc/bash.pdf \
+           $(d_doc)/usr/share/doc/$(p)/
+       dh_link -p$(p_doc) \
+           /usr/share/doc/$(p)/bash.html /usr/share/doc/$(p_doc)/bash.html \
+           /usr/share/doc/$(p)/bash.pdf /usr/share/doc/$(p_doc)/bash.pdf
+       dh_installchangelogs -p$(p_doc) bash/CWRU/changelog
+       dh_compress -p$(p_doc) -Xexamples -X.pdf
+       dh_fixperms -p$(p_doc)
+       dh_installdeb -p$(p_doc)
+       dh_gencontrol -p$(p_doc)
+       dh_md5sums -p$(p_doc)
+       dh_builddeb -p$(p_doc)
+
+ifeq ($(distribution),SLP)
+binary-bash: bash-install
+else
+binary-bash: bash-install debian/bash.preinst
+endif
+       dh_testdir
+       dh_testroot
+       dh_installchangelogs -p$(p)
+       dh_installdocs -p$(p) \
+               bash/{CHANGES,NEWS,COMPAT,doc/INTRO,POSIX} \
+               debian/{README.Debian,README.abs-guide,README.commands} \
+               debian/inputrc.arrows
+ifeq ($(with_gfdl),yes)
+       cp -p bash/doc/FAQ $(d)/usr/share/doc/$(p)/.
+endif
+       cp -p debian/FAQ $(d)/usr/share/doc/$(p)/.
+       dh_installman -p$(p) bash/doc/rbash.1 debian/bash-builtins.7
+       dh_installmenu -p$(p)
+       dh_strip -p$(p)
+       dh_compress -p$(p)
+       dh_fixperms -p$(p)
+       dh_shlibdeps -p$(p) -- -dPre-Depends $(d)/bin/bash debian/bash.preinst
+       dh_installdeb -p$(p)
+       dh_gencontrol -p$(p)
+       dh_md5sums -p$(p)
+       dh_builddeb -p$(p)
+
+# Even though it contains only headers and example files,
+# bash-builtins is NOT arch-independent because the config.h* files
+# differ on different archs.
+binary-builtins: bash-install
+       dh_testdir
+       dh_testroot
+       dh_compress -p$(p_bins) -Xexamples
+       dh_fixperms -p$(p_bins)
+       dh_installdeb -p$(p_bins)
+       dh_gencontrol -p$(p_bins)
+       dh_md5sums -p$(p_bins)
+       dh_builddeb -p$(p_bins)
+
+binary-static: static-build
+       dh_testdir
+       dh_testroot
+       dh_clean -k -p$(p_stat)
+       dh_installdirs -p$(p_stat) \
+               bin \
+               usr/share/man/man1
+       cp -p build-static/bash $(d_stat)/bin/bash-static
+       cp -p bash/doc/bash.1 $(d_stat)/usr/share/man/man1/bash-static.1
+       dh_installdocs -p$(p_stat)
+       dh_installchangelogs -p$(p_stat)
+       dh_strip -p$(p_stat)
+       dh_compress -p$(p_stat)
+       dh_fixperms -p$(p_stat)
+       dh_installdeb -p$(p_stat)
+       dh_gencontrol -p$(p_stat)
+       dh_md5sums -p$(p_stat)
+       dh_builddeb -p$(p_stat)
+
+binary-bashdb: bashdb-install
+       dh_testdir
+       dh_testroot
+       dh_installdocs -p$(p_bdb) \
+               bashdb/{CHANGES,NEWS,README}
+       cp -p debian/README.bashdb $(d_bdb)/usr/share/doc/$(p_bdb)/README.Debian
+       for i in AUTHORS CHANGES NEWS README THANKS TODO; do \
+         cp -p bashdb/debugger/$$i \
+           $(d_bdb)/usr/share/doc/$(p_bdb)/$$i.bashdb; \
+       done
+       dh_installdocs -p$(p_bdb)
+       dh_installchangelogs -p$(p_bdb) bashdb/debugger/ChangeLog
+       dh_installemacsen -p$(p_bdb)
+       dh_strip -p$(p_bdb)
+       dh_compress -p$(p_bdb)
+       dh_fixperms -p$(p_bdb)
+       dh_installdeb -p$(p_bdb)
+       dh_gencontrol -p$(p_bdb)
+       dh_md5sums -p$(p_bdb)
+       dh_builddeb -p$(p_bdb)
+
+ifeq ($(distribution),SLP)
+binary-indep:
+binary-arch: binary-bash
+else
+binary-indep: binary-doc
+binary-arch: binary-bash binary-builtins binary-static #binary-bashdb
+endif
+binary:        binary-indep binary-arch
+
+# ---------------------------------------------------------------------------
+# common rules for all bash build variations
+
+do-build-$(build): stamps/stamp-build-$(build)
+stamps/stamp-build-$(build): stamps/stamp-configure-$(build)
+       dh_testdir
+ifneq (,$(profiled_build))
+       $(MAKE) -C build-$(build) \
+               CC='$(CC)' \
+               CFLAGS='$(CFLAGS) -fprofile-generate' \
+               YACC="$(YACC)" \
+               deb_builddir=build-$(build)/ \
+               $(debflags)
+       -sh debian/locale-gen
+       cp debian/run-my-gprof bash/tests/
+       LOCPATH=$(CURDIR)/locales \
+           time $(MAKE) -C build-$(build) TESTSCRIPT=run-my-gprof test 2>&1 \
+               | tee build-bash/profile-protocol
+       $(MAKE) -C build-$(build) clean
+       rm -f build-$(build)/lib/malloc/malloc*.gc??
+       $(MAKE) -C build-$(build) \
+               CC='$(CC)' \
+               CFLAGS='$(CFLAGS) -fprofile-use' \
+               YACC="$(YACC)" \
+               deb_builddir=build-$(build)/ \
+               $(debflags)
+else
+       $(MAKE) -C build-$(build) \
+               CC='$(CC)' \
+               CFLAGS='$(CFLAGS)' \
+               YACC="$(YACC)" \
+               deb_builddir=build-$(build)/ \
+               $(debflags)
+endif
+ifeq ($(with_gfdl),yes)
+       $(MAKE) -C build-$(build)/doc \
+               bash.info
+endif
+       touch stamps/stamp-build-$(build)
+
+do-configure-$(build): stamps/stamp-configure-$(build)
+stamps/stamp-configure-$(build): stamps/stamp-patch-$(bash_src)
+       dh_testdir
+       rm -rf build-$(build)
+       mkdir build-$(build)
+       cd build-$(build) && \
+           CC="$(CC)" CFLAGS="$(CFLAGS)" YACC="$(YACC)" \
+               ../$(bash_src)/configure $(configure_args)
+       if ! grep -q '#define HAVE_DEV_STDIN 1' build-$(build)/config.h; then \
+         echo "HAVE_DEV_STDIN not defined, abortig build"; \
+         exit 1; \
+       fi
+       touch stamps/stamp-configure-$(build)
+
+patchdir       = debian/patches
+debian_patches = \
+       bash41-001 \
+       bash41-002 \
+       bash41-003 \
+       bash41-004 \
+       bash41-005 \
+       bashbug-editor \
+       deb-bash-config \
+       deb-examples \
+       man-arithmetic \
+       man-fignore \
+       man-bashrc \
+       man-bashlogout \
+       man-substring-exp \
+       man-nocaseglob \
+       man-test \
+       man-test2 \
+       privmode \
+       rbash-manpage \
+       bash-default-editor \
+       bash-subst-param-length \
+       pgrp-pipe \
+       input-err \
+       exec-redirections-man \
+       bash-aliases-repeat \
+       builtins-declare-fix \
+
+ifeq ($(with_gfdl),yes)
+  debian_patches += \
+       man-substring-exp-doc \
+       man-test2-doc \
+       exec-redirections-texi \
+
+endif
+
+# all debian_patches, without bash205b-*
+# patches integrated in bashdb: builtins-shift, execute-cmd, man-arithmetic,
+#     man-builtin, man-fignore, random, rbash-manpage, report-155436,
+#     rl-8bit-init, s390-build
+# and bashdb patch
+#      rbash-manpage \
+
+bashdb_patches = \
+       bashdb \
+       rl-examples-bdb \
+       rl-inputrc \
+       bashbug-editor \
+       deb-bash-config \
+       deb-examples \
+       privmode \
+
+#      various \
+
+# these are applied in bashdb cvs as well
+#      man-arithmetic \
+#      man-fignore \
+#      random \
+#      report-155436 \
+#      s390-build \
+#      builtins-shift
+
+patch-$(bash_src): stamps/stamp-patch-$(bash_src)
+stamps/stamp-patch-$(bash_src): stamps/stamp-unpack-$(bash_src) \
+    $(foreach p,$(bash_patches),stamps/stamp-patch-$(bash_src)-$(p))
+       echo -e "\nPatches applied in this version:" > pxxx
+       for i in $(bash_patches); do \
+         echo -e "\n$$i:" >> pxxx; \
+         sed -n 's/^# *DP: */  /p' $(patchdir)/$$i.dpatch >> pxxx; \
+       done
+       mv -f pxxx $@
+
+stamps/stamp-patch-$(bash_src)-%: $(patchdir)/%.dpatch
+       if [ -f $@ ]; then \
+         echo "$* patches already applied."; exit 1; \
+       fi
+       sh -e $< -patch -d $(bash_src)
+       echo "$* patches applied." > $@
+
+unpack-$(bash_src): stamps/stamp-unpack-$(bash_src)
+stamps/stamp-unpack-$(bash_src):
+       mkdir -p stamps
+       rm -rf bash-$(VERSION) $(bash_src)
+       rm -f stamps/stamp-patch-$(bash_src){,-*}
+       tar xf bash-$(VERSION)*.tar.xz
+       mv bash-$(VERSION) $(bash_src)
+       rm -f bash/y.tab.?
+       cp -p /usr/share/misc/config.* $(bash_src)/.
+       cp -p /usr/share/misc/config.* $(bash_src)/support/.
+       touch stamps/stamp-unpack-$(bash_src)
+
+.PHONY: unpack patch binary binary-arch binary-indep clean \
+    build bash-build static-build preinst-build \
+    all-bashdb-build bashdb-build bashdb-doc-build \
+    check \
+    bash-configure static-configure bashdb-configure \
+    binary-doc binary-bash binary-builtins binary-static binary-bashdb \
+    install bash-install bashdb-install
+
+# Local Variables:
+# mode: makefile
+# end:
diff --git a/debian/run-my-gprof b/debian/run-my-gprof
new file mode 100644 (file)
index 0000000..7a495ba
--- /dev/null
@@ -0,0 +1,32 @@
+#! /bin/sh
+
+PATH=.:$PATH   # just to get recho/zecho/printenv if not run via `make tests'
+export PATH
+
+# unset BASH_ENV only if it is set
+[ "${BASH_ENV+set}" = "set" ] && unset BASH_ENV
+# ditto for SHELLOPTS
+#[ "${SHELLOPTS+set}" = "set" ] && unset SHELLOPTS
+
+: ${THIS_SH:=../bash}
+export THIS_SH
+
+${THIS_SH} ./version
+
+rm -f /tmp/xx
+
+echo Any output from any test, unless otherwise noted, indicates a possible anomaly
+
+echo Running tests as test load ...
+
+for x in run-*
+do
+       case $x in
+       $0|run-minimal|run-gprof|run-all)       ;;
+       run-jobs|run-gprof)     echo SKIP $x ;;
+       *.orig|*~) ;;
+       *)      echo $x ; sh $x ;;
+       esac
+done
+
+exit 0
diff --git a/debian/skel.bash_logout b/debian/skel.bash_logout
new file mode 100644 (file)
index 0000000..de4f5f7
--- /dev/null
@@ -0,0 +1,7 @@
+# ~/.bash_logout: executed by bash(1) when login shell exits.
+
+# when leaving the console clear the screen to increase privacy
+
+if [ "$SHLVL" = 1 ]; then
+    [ -x /usr/bin/clear_console ] && /usr/bin/clear_console -q
+fi
diff --git a/debian/skel.bashrc b/debian/skel.bashrc
new file mode 100644 (file)
index 0000000..e96b37f
--- /dev/null
@@ -0,0 +1,99 @@
+# ~/.bashrc: executed by bash(1) for non-login shells.
+# see /usr/share/doc/bash/examples/startup-files (in the package bash-doc)
+# for examples
+
+# If not running interactively, don't do anything
+[ -z "$PS1" ] && return
+
+# don't put duplicate lines in the history. See bash(1) for more options
+# don't overwrite GNU Midnight Commander's setting of `ignorespace'.
+HISTCONTROL=$HISTCONTROL${HISTCONTROL+:}ignoredups
+# ... or force ignoredups and ignorespace
+HISTCONTROL=ignoreboth
+
+# append to the history file, don't overwrite it
+shopt -s histappend
+
+# for setting history length see HISTSIZE and HISTFILESIZE in bash(1)
+
+# check the window size after each command and, if necessary,
+# update the values of LINES and COLUMNS.
+shopt -s checkwinsize
+
+# make less more friendly for non-text input files, see lesspipe(1)
+#[ -x /usr/bin/lesspipe ] && eval "$(SHELL=/bin/sh lesspipe)"
+
+# set variable identifying the chroot you work in (used in the prompt below)
+if [ -z "$debian_chroot" ] && [ -r /etc/debian_chroot ]; then
+    debian_chroot=$(cat /etc/debian_chroot)
+fi
+
+# set a fancy prompt (non-color, unless we know we "want" color)
+case "$TERM" in
+    xterm-color) color_prompt=yes;;
+esac
+
+# uncomment for a colored prompt, if the terminal has the capability; turned
+# off by default to not distract the user: the focus in a terminal window
+# should be on the output of commands, not on the prompt
+#force_color_prompt=yes
+
+if [ -n "$force_color_prompt" ]; then
+    if [ -x /usr/bin/tput ] && tput setaf 1 >&/dev/null; then
+       # We have color support; assume it's compliant with Ecma-48
+       # (ISO/IEC-6429). (Lack of such support is extremely rare, and such
+       # a case would tend to support setf rather than setaf.)
+       color_prompt=yes
+    else
+       color_prompt=
+    fi
+fi
+
+if [ "$color_prompt" = yes ]; then
+    PS1='${debian_chroot:+($debian_chroot)}\[\033[01;32m\]\u@\h\[\033[00m\]:\[\033[01;34m\]\w\[\033[00m\]\$ '
+else
+    PS1='${debian_chroot:+($debian_chroot)}\u@\h:\w\$ '
+fi
+unset color_prompt force_color_prompt
+
+# If this is an xterm set the title to user@host:dir
+case "$TERM" in
+xterm*|rxvt*)
+    PS1="\[\e]0;${debian_chroot:+($debian_chroot)}\u@\h: \w\a\]$PS1"
+    ;;
+*)
+    ;;
+esac
+
+# enable color support of ls and also add handy aliases
+if [ -x /usr/bin/dircolors ]; then
+    test -r ~/.dircolors && eval "$(dircolors -b ~/.dircolors)" || eval "$(dircolors -b)"
+    alias ls='ls --color=auto'
+    #alias dir='dir --color=auto'
+    #alias vdir='vdir --color=auto'
+
+    #alias grep='grep --color=auto'
+    #alias fgrep='fgrep --color=auto'
+    #alias egrep='egrep --color=auto'
+fi
+
+# some more ls aliases
+#alias ll='ls -l'
+#alias la='ls -A'
+#alias l='ls -CF'
+
+# Alias definitions.
+# You may want to put all your additions into a separate file like
+# ~/.bash_aliases, instead of adding them here directly.
+# See /usr/share/doc/bash-doc/examples in the bash-doc package.
+
+if [ -f ~/.bash_aliases ]; then
+    . ~/.bash_aliases
+fi
+
+# enable programmable completion features (you don't need to enable
+# this, if it's already enabled in /etc/bash.bashrc and /etc/profile
+# sources /etc/bash.bashrc).
+if [ -f /etc/bash_completion ] && ! shopt -oq posix; then
+    . /etc/bash_completion
+fi
diff --git a/debian/skel.profile b/debian/skel.profile
new file mode 100644 (file)
index 0000000..c9db459
--- /dev/null
@@ -0,0 +1,22 @@
+# ~/.profile: executed by the command interpreter for login shells.
+# This file is not read by bash(1), if ~/.bash_profile or ~/.bash_login
+# exists.
+# see /usr/share/doc/bash/examples/startup-files for examples.
+# the files are located in the bash-doc package.
+
+# the default umask is set in /etc/profile; for setting the umask
+# for ssh logins, install and configure the libpam-umask package.
+#umask 022
+
+# if running bash
+if [ -n "$BASH_VERSION" ]; then
+    # include .bashrc if it exists
+    if [ -f "$HOME/.bashrc" ]; then
+       . "$HOME/.bashrc"
+    fi
+fi
+
+# set PATH so it includes user's private bin if it exists
+if [ -d "$HOME/bin" ] ; then
+    PATH="$HOME/bin:$PATH"
+fi
diff --git a/debian/watch b/debian/watch
new file mode 100644 (file)
index 0000000..dd1998d
--- /dev/null
@@ -0,0 +1,2 @@
+version=2
+ftp://ftp.gnu.org/gnu/bash/bash-([\d\.]*).tar.gz debian uupdate
index fdb97c7..58c5d14 100644 (file)
@@ -22,10 +22,7 @@ Patch10: input-err.patch
 Patch11: bash-aliases-repeat.patch
 Patch12: builtins-declare-fix.patch
 
-Requires(post): ncurses-libs
-
 BuildRequires: bison
-#BuildRequires: ncurses-devel
 BuildRequires: autoconf
 
 %description