My dotfiles. Period.

sibling 2.3KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. #!/bin/bash
  2. #
  3. # Take first subdir (or a subdir specified in a file) and consider
  4. # it a git repo dir. Get its origin, exchange the last bit for
  5. # other project name and clone the other repo
  6. #
  7. # This is useful if you have a local dir where you store repos
  8. # for various projects from a common namespace that differ only
  9. # in last part of the remote URI. Now all you need to do to
  10. # clone new one is "git sibling aproject". The script will
  11. # do the rest for you including sniffing the URI.
  12. #
  13. # The script simply takes the first subdir. In case this is not
  14. # OK for you (e.g. the dir id likely to be empty or contain
  15. # come "non-compliant" repos, you can specify path to the
  16. # other "template" repo in .gittum-sibling file.
  17. #
  18. # Hint: regarding the "template" repo, you can easily create
  19. # a "fake" repo that would sit elsewhere, e.g.:
  20. # $ mkdir .some/hidden/dir
  21. # $ cd .some/hidden/dir
  22. # $ git init
  23. # $ git remote add origin ssh://our_server/projects/FAKE
  24. ## funz
  25. #
  26. die() {
  27. echo "$@" 1>&2
  28. exit 1
  29. }
  30. usage() {
  31. echo "usage: git $(basename $0) [-v] [-s SIBLING] [-r REMOTE] PROJECT"
  32. exit 0
  33. }
  34. rewrite_uri () {
  35. local remote=$1
  36. local to=$2
  37. # create a new remote URI based on current one
  38. git remote -v \
  39. | grep "^$remote" \
  40. | grep "(fetch)$" \
  41. | cut -f 2 \
  42. | cut -d" " -f 1 \
  43. | perl -pe "s|[^/]+$|$to|;"
  44. }
  45. think() {
  46. $verbose && echo "$@"
  47. }
  48. ## initz
  49. #
  50. origin_name="origin"
  51. sibling_conf=".gittum-sibling"
  52. verbose=false
  53. sibling=$(find -maxdepth 1 -type d -name "[^.]*" | sort | head -1)
  54. test -f $sibling_conf && sibling=$(cat $sibling_conf)
  55. remote_name="origin"
  56. while true; do case $1 in
  57. -r|--remote-name) remote_name=$2; shift 2 ;;
  58. -s|--sibling) sibling=$2; shift 2 ;;
  59. -v|--verbose) verbose=true; shift ;;
  60. -*) usage ;;
  61. "") break ;;
  62. *) project=$1; shift ;;
  63. esac done
  64. test -n "$project" || usage
  65. test -n "$sibling" || die "could not find older sibling"
  66. test -d "$sibling" || die "sibling does not exist: $sibling"
  67. ## body
  68. #
  69. pushd "$sibling" >/dev/null
  70. new_remote=$(rewrite_uri $remote_name $project)
  71. popd >/dev/null
  72. test -n "$new_remote" || die "no such remote at sibling: $new_remote at $sibling"
  73. think \'git clone $new_remote\'
  74. git clone $new_remote