3 # selector is a simple command line utility for selection of strings
4 # with a dynamic pattern-matching.
6 # Copyright (c) 2009, 2010, 2011, 2012 Francois Fleuret
7 # Written by Francois Fleuret <francois@fleuret.org>
9 # This file is part of selector.
11 # selector is free software: you can redistribute it and/or modify
12 # it under the terms of the GNU General Public License version 3 as
13 # published by the Free Software Foundation.
15 # selector is distributed in the hope that it will be useful, but
16 # WITHOUT ANY WARRANTY; without even the implied warranty of
17 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
18 # General Public License for more details.
20 # You should have received a copy of the GNU General Public License
21 # along with selector. If not, see <http://www.gnu.org/licenses/>.
23 # This script installs two key-bindings:
25 # Alt-r for selector-based command history
27 # Alt-c for selector-based directoy history
29 # Note that you have to call it with "source bash-selector.sh"
30 # otherwise the key-bindings will not be effective in your current
33 if [[ "${BASH_SOURCE[0]}" == "${0}" ]]; then
34 echo "This script must be called with 'source $(basename $0)'" >&2
38 ######################################################################
39 # Selector-based command history
40 ######################################################################
42 function selector-history () {
43 selector --bash -j -y -u -c 7,4,0,3 -q <(history)
46 ######################################################################
47 # Selector-based directory history
48 ######################################################################
50 # The file where we will keep track of the directories
52 export SELECTOR_CD_HISTORY
54 [[ "${SELECTOR_CD_HISTORY}" ]] || SELECTOR_CD_HISTORY=${HOME}/.selector-cd-history
56 # The function to use in place of the standard "cd"
58 function selector-cd () {
59 if [[ -z "$1" ]]; then
65 if [[ -f ${SELECTOR_CD_HISTORY} ]]; then
66 TMP=$(mktemp /tmp/selector-cd.XXXXXX)
67 tail -999 < ${SELECTOR_CD_HISTORY} > ${TMP}
68 cat ${TMP} > ${SELECTOR_CD_HISTORY}
72 echo $PWD | sed -e "s!^${HOME}!~!" >> ${SELECTOR_CD_HISTORY}
75 function selector-cd-search () {
76 PATH_TEMP=$(mktemp /tmp/selector-cd-path.XXXXXX)
77 selector -j -y -u -t "cd" -l 1000 -d -i -c 7,2,0,3 -o ${PATH_TEMP} -q ${SELECTOR_CD_HISTORY}
78 NEW_PATH="$(cat ${PATH_TEMP} | sed -e 's!~!'${HOME}'!')"
79 if [[ -s "${NEW_PATH}" ]]; then
80 selector-cd "$(cat ${PATH_TEMP} | sed -e 's!^~!'${HOME}'!')"
87 ######################################################################
88 # The key-bindings themselves
89 ######################################################################
91 # M-t appends the selected history line and the end of the current
92 # one bind '"\C-[t":"\C-a\C-kselector-history\C-m\C-a\C-y\C-e"'
101 # M-r puts the selected history line in place of the current one
102 bind '"\C-[r":"\C-a\C-kselector-history\C-m"'
106 # M-c provides a dynamic list of directories to cd into
107 bind '"\C-[c":"\C-a\C-kselector-cd-search\C-m"'
111 echo "Unknown argument $1" >&2
121 echo "source bash-selector.sh <--hist|--cd> [...]"
123 echo "Defines bash functions, and installs key-bindings and aliases to use selector"
124 echo "for history search with M-r and/or intelligent cd history with M-c."