| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859 | #! /bin/bashfindup (){  DIR='..'  DIRTEST=$( cd $DIR ; pwd )  while [[ "$DIRTEST" != "/" ]]; do    DIR="$DIR/.."    DIRTEST=$( cd $DIR ; pwd )    if [[ -d "$DIR/$1" ]]; then      echo "$DIR/$1"      return 0    fi  done  # Failed to find  return 1}if [ ! -f terragrunt.hcl ]; then  echo "ERROR: No terragrunt.hcl in this directory. Aborting."  exit 1fiGITSOURCE=$( cat terragrunt.hcl | egrep -v '^ *#' | egrep 'source *= *"git@' )if [ "$GITSOURCE" == "" ]; then  echo "ERROR: No source from Git detected. Aborting."  exit 2fi# Strip off source = and quotesGITSOURCE=$( echo "$GITSOURCE" | sed -E 's/.*"([^"]+)".*/\1/' )# Strip off any ?ref= if it's thereGITSOURCE=$( echo "$GITSOURCE" | sed -E 's/\?.*$//' )# Thanks to terragrunt needing that magic // constructGITSOURCE_REPO=$( echo "$GITSOURCE" | sed -E 's#//.*$##' )GITSOURCE_PATHINREPO=$( echo "$GITSOURCE" | sed -E "s#.*//##" )BARE_REPONAME=$( basename "$GITSOURCE_REPO" .git )LOCALPATH=$( findup "$BARE_REPONAME" )if [[ "$LOCALPATH" == "" ]]; then  echo "ERROR:  No $BARE_REPONAME in any parent directory"  exit 1fiNEWPATH="$LOCALPATH//$GITSOURCE_PATHINREPO"echo Substituting \'$GITSOURCE\' with \'$NEWPATH\'# Test locally# the double // is intentional! Terragrunt uses this to determine the root of the modules repository.terragrunt $* --terragrunt-source $NEWPATH
 |