Roll src/third_party/WebKit f007c95:0171005 (svn 185074:185088)
[chromium-blink-merge.git] / tools / cr / cr-bash-helpers.sh
blobe7e7593df2fb4b53496d3a774c270253257f2553
1 #!/bin/bash
3 # Copyright 2013 The Chromium Authors. All rights reserved.
4 # Use of this source code is governed by a BSD-style license that can be
5 # found in the LICENSE file.
7 # Source this file into your shell to gain the cr function and tab completion
8 # for it
10 # Make sure we're being sourced (possibly by another script). Check for bash
11 # since zsh sets $0 when sourcing.
12 if [[ -n "$BASH_VERSION" && "${BASH_SOURCE:-$0}" == "$0" ]]; then
13 echo "ERROR: cr-bash-helpers.sh must be sourced."
14 exit 1
17 READLINK_e=("readlink" "-e")
18 if [[ -x `which greadlink` ]]; then
19 READLINK_e=("greadlink" "-e")
22 cr_base_dir=$(dirname $(${READLINK_e[@]} "${BASH_SOURCE:-$0}"))
23 cr_main="${cr_base_dir}/main.py"
24 cr_exec=("PYTHONDONTWRITEBYTECODE=1" "python" "${cr_main}")
26 # The main entry point to the cr tool.
27 # Invokes the python script with pyc files turned off.
28 function cr() {
29 env ${cr_exec[@]} "$@"
32 # Attempts to cd to the root/src of the current client.
33 function crcd() {
34 cd $(cr info -s CR_SRC)
37 # Add to your PS1 to have the current selected output directory in your prompt
38 function _cr_ps1() {
39 cr info -s CR_OUT_FULL
42 # The tab completion handler, delegates into the python script.
43 function _cr_complete() {
44 COMPREPLY=()
45 local cur="${COMP_WORDS[COMP_CWORD]}"
46 local main="python -B "${cr_main}")"
47 local completions="$(env COMP_CWORD=${COMP_CWORD} \
48 COMP_WORD=${cur} \
49 ${cr_exec[@]})"
50 COMPREPLY=( $(compgen -W "${completions}" -- ${cur}) )
53 # Setup the bash auto complete
54 complete -F _cr_complete cr