[11705] | 1 | #!/bin/sh |
---|
[10286] | 2 | |
---|
[10334] | 3 | ## Create minimal developement environment for NEMO |
---|
| 4 | ################################################### |
---|
[10286] | 5 | |
---|
[11705] | 6 | ## Optional arguments (developer ID, 'repo' to replicate the layout of the whole repository) |
---|
[10334] | 7 | |
---|
[11705] | 8 | dir='NEMO_dev'; repo='0'; root='/NEMO' |
---|
| 9 | ver='4.0.1' |
---|
[10334] | 10 | |
---|
[11705] | 11 | year=$( date +%Y ) |
---|
[10655] | 12 | |
---|
[11705] | 13 | while (( $# )); do |
---|
| 14 | [ "$1" == 'repo' ] && { dir='NEMO_repo' && repo='1' && root='/'; shift; } |
---|
| 15 | id=$1 |
---|
| 16 | shift |
---|
| 17 | done |
---|
| 18 | |
---|
| 19 | [ -d $dir ] && { echo $dir 'already exists => QUIT'; exit 2; } |
---|
| 20 | |
---|
[10334] | 21 | ## Copy of the repository with empty root directories |
---|
[11705] | 22 | echo 'Download a void working copy of' $root 'from the repository ("svn co --depth empty")' |
---|
[10655] | 23 | svn co --depth empty http://forge.ipsl.jussieu.fr/nemo/svn/$root $dir |
---|
| 24 | echo |
---|
[10334] | 25 | |
---|
[11705] | 26 | |
---|
[10334] | 27 | ## Switch to developer role if ID is provided |
---|
[11705] | 28 | if [ -n "$id" ]; then |
---|
| 29 | echo 'Switch to developer role by relocating the URL scheme from HTTP to SVN+SSH' |
---|
| 30 | echo '("svn sw --relocate http://... svn+ssh://...")' |
---|
| 31 | ssh-copy-id -i ~/.ssh/id_rsa.pub $id@forge.ipsl.jussieu.fr 2> /dev/null |
---|
| 32 | svn sw --relocate http://forge.ipsl.jussieu.fr \ |
---|
| 33 | svn+ssh://$id@forge.ipsl.jussieu.fr/ipsl/forge/projets \ |
---|
| 34 | $dir |
---|
[10655] | 35 | echo |
---|
[10286] | 36 | fi |
---|
| 37 | |
---|
[11705] | 38 | ## If requested by 'repo', |
---|
| 39 | if [ "$repo" == '1' ]; then |
---|
[10655] | 40 | echo "With 'repo' arg, create a lightweight copy of the repository" |
---|
[11705] | 41 | echo 'for the developement of the sources defined as "externals"' |
---|
[10655] | 42 | |
---|
| 43 | for item in utils/build/{arch,makenemo,mk} utils/tools \ |
---|
[11705] | 44 | vendors/{AGRIF/dev,AGRIF/release-$ver,FCM,IOIPSL} ; do |
---|
| 45 | echo '¤' $item |
---|
| 46 | svn up -q --parents $dir/$item |
---|
[10655] | 47 | done |
---|
[11705] | 48 | |
---|
| 49 | dir+=/'NEMO' |
---|
[10655] | 50 | echo |
---|
[10334] | 51 | fi |
---|
[10286] | 52 | |
---|
[11705] | 53 | |
---|
[10286] | 54 | ## Get the 1st level tree under 'branches' and 'releases' |
---|
[11705] | 55 | echo "Get empty folders under '/NEMO/branches' (\"svn up --depth empty --parents\"):" \ |
---|
| 56 | {UKMO,$((year - 1)),$year} |
---|
| 57 | svn up -q --set-depth empty --parents $dir/branches/{UKMO,$((year - 1)),$year} |
---|
[10655] | 58 | echo |
---|
[10286] | 59 | |
---|
[11705] | 60 | |
---|
[10334] | 61 | ## Download trunk and last release |
---|
[11705] | 62 | echo 'Full download of 2 main branches ("svn up"): trunk and last stable' |
---|
[10655] | 63 | echo "¤ '/NEMO/trunk'" |
---|
| 64 | svn up -q $dir/trunk |
---|
[10286] | 65 | |
---|
[11705] | 66 | echo "¤ '/NEMO/releases/release-$ver'" |
---|
| 67 | svn up -q --parents $dir/releases/release-$ver |
---|
[10655] | 68 | |
---|
[10286] | 69 | exit 0 |
---|