]>
Commit | Line | Data |
---|---|---|
34846459 | 1 | #!/bin/bash |
3c347239 MF |
2 | |
3 | usage() { | |
4 | cat <<-EOF | |
d94e4fb7 | 5 | Usage: repo-cros [options] |
3c347239 | 6 | |
d94e4fb7 | 7 | Options: |
97d64453 | 8 | depot_tools clone depot_tools tree |
3c347239 MF |
9 | int switch to internal tree |
10 | ext switch to external tree | |
d94e4fb7 MF |
11 | -b <branch> switch branches (use "master" to get to ToT) |
12 | -r <path> patch to reference repo (e.g. ~/chromiumos/) | |
34846459 MF |
13 | -g <group> |
14 | -m <manifest> | |
3eb70c52 | 15 | -e <email> |
d94e4fb7 MF |
16 | |
17 | Operates on the repo in ${PWD} | |
3c347239 MF |
18 | EOF |
19 | exit ${1:-1} | |
20 | } | |
3c347239 | 21 | |
a72514e6 | 22 | v() { |
5f57468d | 23 | printf '%s\n%s\n' "${PWD}" "$*" |
a72514e6 | 24 | "$@" |
5f57468d | 25 | } |
3c347239 | 26 | |
d94e4fb7 MF |
27 | email="vapier@chromium.org" |
28 | REF= | |
29 | BRANCH= | |
30 | MANIFEST= | |
34846459 | 31 | MANIFEST_NAME= |
d906ad5b | 32 | RGROUPS=() |
d94e4fb7 | 33 | REPO_URL= |
3c347239 MF |
34 | while [[ $# -gt 0 ]] ; do |
35 | case $1 in | |
34846459 | 36 | depot_tools|dt) |
97d64453 MF |
37 | exec git clone https://git.chromium.org/chromium/tools/depot_tools.git |
38 | ;; | |
d94e4fb7 MF |
39 | int) |
40 | MANIFEST='ssh://gerrit-int.chromium.org:29419/chromeos/manifest-internal.git' | |
b05e460b | 41 | REPO_URL='https://git.chromium.org/git/external/repo.git' |
d94e4fb7 MF |
42 | ;; |
43 | ext) | |
b05e460b MF |
44 | MANIFEST='https://git.chromium.org/git/chromiumos/manifest.git' |
45 | REPO_URL='https://git.chromium.org/git/external/repo.git' | |
d94e4fb7 MF |
46 | ;; |
47 | -b) | |
48 | BRANCH=$2 | |
49 | shift | |
50 | ;; | |
51 | -r) | |
7dae893b | 52 | REF=$(realpath "${2:-$(echo ~/chromiumos)}") |
d94e4fb7 MF |
53 | shift |
54 | ;; | |
34846459 | 55 | -g) |
d906ad5b | 56 | RGROUPS+=( "$2" ) |
34846459 MF |
57 | shift |
58 | ;; | |
59 | -m) | |
60 | MANIFEST_NAME="${2%.xml}.xml" | |
61 | shift | |
62 | ;; | |
3eb70c52 MF |
63 | -e) |
64 | email=$2 | |
65 | shift | |
66 | ;; | |
5f57468d | 67 | *) |
d94e4fb7 | 68 | usage |
5f57468d | 69 | ;; |
3c347239 | 70 | esac |
5f57468d | 71 | shift |
3c347239 | 72 | done |
d94e4fb7 | 73 | |
b05e460b MF |
74 | if [[ ${#BRANCH} -eq 3 ]] && [[ -d ${REF} ]] ; then |
75 | BRANCH=$(git --git-dir="${REF}/.repo/manifests.git" branch -a | grep -o "release-${BRANCH}.*") | |
76 | fi | |
77 | ||
a72514e6 MF |
78 | v repo init \ |
79 | ${MANIFEST:+-u "${MANIFEST}"} \ | |
80 | ${REPO_URL:+--repo-url="${REPO_URL}"} \ | |
81 | ${REF:+--reference "${REF}"} \ | |
34846459 | 82 | ${MANIFEST_NAME:+-m "${MANIFEST_NAME}"} \ |
d906ad5b | 83 | ${RGROUPS:+-g "${RGROUPS[*]}"} \ |
a72514e6 MF |
84 | ${BRANCH:+-b "${BRANCH}"} |
85 | ||
d94e4fb7 MF |
86 | rdir=$(realpath "`pwd`") |
87 | while [[ ! -d ${rdir}/.repo ]] ; do | |
88 | rdir=${rdir%/*} | |
89 | [[ ${rdir:-/} == "/" ]] && break | |
90 | done | |
91 | rdir+="/.repo" | |
92 | if [[ -d ${rdir} ]] ; then | |
93 | gcfg() { git --git-dir="$1" config user.email "${@:2}" ; } | |
94 | if [[ $(gcfg "${rdir}/manifests.git") != "${email}" ]] ; then | |
95 | echo "${rdir}: setting e-mail to ${email}" | |
96 | find "${rdir}" -type d -name '*.git' | \ | |
97 | while read d ; do | |
98 | gcfg "${d}" ${email} | |
99 | done | |
100 | fi | |
101 | fi | |
102 | ||
a72514e6 | 103 | exit 0 |