 40839ea8d4
			
		
	
	40839ea8d4
	
	
	
		
			
			We often use gitiles links to point to some source code which is
relevant for a discussion or code review. It often requires 10-15
mouse clicks in order to navigate to a path in gitiles and generate a
link. This is cumbersome and may discourage providing links to gitiles.
This script intends to provide a fast way to generate and open gitiles
links. It requires a one time setup of gitiles.url in .git/config file:
  [gitiles]
    url = https://gerrit.googlesource.com/gerrit
Once gitiles.url is setup we can generate gitiles URLs easily.
Examples
========
* print gitiles URL for the current HEAD and current directory:
  $ gitiles
  https://gerrit.googlesource.com/gerrit/+/d685ac1193e086b896cfc019ef4504d1b7ce455b/
* print gitiles URL for current HEAD and Documentation directory:
  $ gitiles Documentation
* print gitiles URL for branch stable-2.15 and current directory:
  $ gitiles -b stable-2.15
* print gitiles URL for current HEAD and a path relative to the current directory:
  $ pwd
  gerrit-server
  $ gitiles ./src/main/resources
The script also supports "open" command which open gitiles URL using
OS's native way of opening URLs:
  $ gitiles open
  $ gitiles open -b stable-2.15 Documentation
Change-Id: Icd31723711535e886313d3d17afb57caa4a710b1
		
	
		
			
				
	
	
		
			85 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			85 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
| #!/bin/bash
 | |
| #
 | |
| # Copyright (C) 2018 The Android Open Source Project
 | |
| #
 | |
| # Licensed under the Apache License, Version 2.0 (the "License");
 | |
| # you may not use this file except in compliance with the License.
 | |
| # You may obtain a copy of the License at
 | |
| #
 | |
| # http://www.apache.org/licenses/LICENSE-2.0
 | |
| #
 | |
| # Unless required by applicable law or agreed to in writing, software
 | |
| # distributed under the License is distributed on an "AS IS" BASIS,
 | |
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | |
| # See the License for the specific language governing permissions and
 | |
| # limitations under the License.
 | |
| 
 | |
| usage() {
 | |
|   me=`basename "$0"`
 | |
|   echo >&2 "Usage: $me [open] [-b branch] [path]"
 | |
|   exit 1
 | |
| }
 | |
| 
 | |
| cmd_open() {
 | |
|   case "$(uname)" in
 | |
|     Darwin)
 | |
|       echo "open"
 | |
|       ;;
 | |
|     Linux)
 | |
|       echo "xdg-open"
 | |
|       ;;
 | |
| 
 | |
|     *)
 | |
|       echo >&2 "Don't know how to open URLs on $(uname)"
 | |
|       exit 1
 | |
|   esac
 | |
| }
 | |
| 
 | |
| URL=$(git config --get gitiles.url)
 | |
| 
 | |
| if test -z "$URL" ; then
 | |
|   echo >&2 "gitiles.url must be set in .git/config"
 | |
|   exit 1
 | |
| fi
 | |
| 
 | |
| while test $# -gt 0 ; do
 | |
|   case "$1" in
 | |
|   open)
 | |
|     CMD=$(cmd_open)
 | |
|     shift
 | |
|     ;;
 | |
|   -b|--branch)
 | |
|     shift
 | |
|     B=$1
 | |
|     shift
 | |
|     ;;
 | |
|   -h|--help)
 | |
|     usage
 | |
|     ;;
 | |
| 
 | |
|   *)
 | |
|     P=$1
 | |
|     shift
 | |
|   esac
 | |
| done
 | |
| 
 | |
| if test -z "$CMD" ; then
 | |
|   CMD=echo
 | |
| fi
 | |
| 
 | |
| if test -z "$B" ; then
 | |
|   B=$(git rev-parse HEAD)
 | |
| fi
 | |
| 
 | |
| URL="$URL/+/$B"
 | |
| 
 | |
| if test -z "$P" ; then
 | |
|   P=$(git rev-parse --show-prefix)
 | |
| elif test ${P:0:2} = "./" ; then
 | |
|   P=$(git rev-parse --show-prefix)${P:2}
 | |
| fi
 | |
| 
 | |
| URL="$URL/$P"
 | |
| 
 | |
| $CMD $URL
 |