-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathuppmax_functions.sh
404 lines (358 loc) · 13.2 KB
/
uppmax_functions.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
# Various helper functions for UPPMAX
# unset or set to something other than "yes" to not export the install functions
# these include section mfshow mflink all_mflink fixup
_EXPORT_UPPMAX_INSTALL_FUNCTIONS=yes
# currently active clusters
_CURRENT_CLUSTERS="bianca rackham snowy miarka"
# "module avail" loading subgroupings before running
function mavail()
{
[[ $# != 0 ]] || { cat <<_usage_
USAGE: mavail module or mavail module/version
Perform 'module avail module/version' after loading bioinfo-tools and build-tools subgroupings in a subshell
_usage_
return; }
local M=${1:?module or module/version required}
( module load bioinfo-tools build-tools ; module avail "$M" )
}
# "module help" loading subgroupings before running
function mhelp()
{
[[ $# != 0 ]] || { cat <<_usage_
USAGE: mhelp module or mhelp module/version
Perform 'module help module/version' after loading bioinfo-tools and build-tools subgroupings in a subshell
_usage_
return; }
local M=${1:?module or module/version required}
( module load bioinfo-tools build-tools ; module help "$M" )
}
# "module show" loading subgroupings before running
function mshow()
{
[[ $# != 0 ]] || { cat <<_usage_
USAGE: mshow module or mshow module/version
Perform 'module show module/version' after loading bioinfo-tools and build-tools subgroupings in a subshell
_usage_
return; }
local M=${1:?module or module/version required}
( module load bioinfo-tools build-tools ; module show "$M" )
}
# "module spider" shortcut
function mspid()
{
[[ $# != 0 ]] || { cat <<_usage_
USAGE: mspid word [ word ... ]
Perform 'module spider' on the word or words provided
_usage_
return; }
local args=("$@")
module spider ${args[@]}
}
# Starting in the current directory, find symlinks owned by a specific user then
# remove and recreate them, which switches ownership to the current user
function ownlinks()
{
local U=${1:-wesleys}
local LINKS=("$(find . -type l -user $U)")
local L
for L in ${LINKS[@]} ; do
local D=$(dirname "$L")
local N=$(basename "$L")
local T=$(readlink "$L")
local CMD="( cd \"$D\" ; ls -l \"$N\" ; rm -f \"$N\" ; ln -s \"$T\" \"$N\" ; ls -l \"$N\"; )"
# echo "$CMD"
echo "$L"
eval "$CMD"
done
}
# Helpers for gathering info about SLURM jobs, no special privileges required
function jiu() {
local U=${1:-$USER}
[[ "$1" ]] && shift
jobinfo -u ${U} "$@"
}
function scs() { scontrol show jobid=${1:-1} ; }
function scsv() { scontrol show --details --details jobid=${1:-1} ; }
function scu() { scontrol update jobid=${1:-1} ${2} ; }
function sj() { squeue -a -o"%.7i %.8a %.9P %.8f %50j %.8u %.8T %.10M %.10l %.10L %.3D %.3C %.12R" -S j,-T,i -u ${1:-$USER} ; }
function userproj() {
local U=${1:-$USER}
sacctmgr -n list assoc where user=$U -P format=account | cat <(id -Gn $U | tr ' ' '\n') - | sort -Vu | grep -vP "($U|no_project)"
}
# Remove a personal module cache, can be annoying when built on rackham but sitting on another system.
# No special privileges required
function purge-cache() { rm -rf $HOME/.lmod.d ; }
#
# Appexpert functions for managing mf files. Use no arguments to get brief help.
#
# Show section of bioinfo-tools in which each module is found
function section()
{
[[ $# == 0 ]] && { echo "USAGE: section bioinfo-modulename [ bioinfo-modulename ... ]"; return; }
local args=("$@")
local M=
for M in ${args[@]} ; do
local COMMONDIR=(/sw/mf/common/bioinfo-tools/*/$M)
if [[ ! -d $COMMONDIR ]] ; then
echo "*** $COMMONDIR doesn't exist"
else
local SUBDIR=${COMMONDIR#/sw/mf/common/bioinfo-tools/}
SUBDIR=${SUBDIR%/$M}
echo -e "$M\t$SUBDIR\t$COMMONDIR"
fi
done
}
# Full listing of all mf files for a given module under /sw/mf
function mfshow()
{
local SUBDIR
local ALL
local OPTIND
while getopts ":ilacbpdA" opt "$@"; do
case $opt in
i) SUBDIR= ;;
l) SUBDIR=libraries ;;
a) SUBDIR=applications ;;
c) SUBDIR=compilers ;;
b) SUBDIR=build-tools ;;
p) SUBDIR=parallel ;;
d) SUBDIR=data ;;
A) ALL=yes ;;
*) echo "unknown option"; return ;;
esac
done
shift $((OPTIND-1))
[[ $# == 1 ]] || { cat <<_usage_
USAGE: mfshow [ -i (default) | -l | -a | -c | -b | -p | -d ] [ -A ] modulename
Full listing of all mf files for a given module under /sw/mf/...
Subtree options: -i bioinfo-tools (default)
-l libraries
-a applications
-c comp
-b build-tools
-p parallel
-d data
Other options: -A show trees for all clusters, not just {common,${_CURRENT_CLUSTERS// /,}}
_usage_
return; }
local M=$1
[[ $M ]] || return
if [[ $SUBDIR ]] ; then
if [[ ! $ALL ]] ; then
eval ls -la /sw/mf/{common,{${_CURRENT_CLUSTERS// /,}}}/$SUBDIR/$M/
else
ls -la /sw/mf/*/$SUBDIR/$M/
fi
else
local COMMONDIR=(/sw/mf/common/bioinfo-tools/*/$M)
if [[ ! -d $COMMONDIR ]] ; then
echo "*** $COMMONDIR doesn't exist"; return
else
SUBDIR=${COMMONDIR#/sw/mf/common/bioinfo-tools/}
SUBDIR=${SUBDIR%/$M}
fi
if [[ ! $ALL ]] ; then
eval ls -la /sw/mf/{common,{${_CURRENT_CLUSTERS// /,}}}/bioinfo-tools/$SUBDIR/$M/
else
ls -la /sw/mf/*/bioinfo-tools/$SUBDIR/$M/
fi
fi
}
# Create a cluster-specific symlink to /sw/mf/common/... for an mf file
function mflink()
{
local SUBDIR
local FORCE
local QUIET
local OPTIND
while getopts ":ilacbpdfq" opt "$@"; do
case $opt in
i) SUBDIR= ;;
l) SUBDIR=libraries ;;
a) SUBDIR=applications ;;
c) SUBDIR=compilers ;;
b) SUBDIR=build-tools ;;
p) SUBDIR=parallel ;;
d) SUBDIR=data ;;
f) FORCE=yes ;;
q) QUIET=yes ;;
*) echo "unknown option"; return ;;
esac
done
shift $((OPTIND-1))
[[ $# == 2 ]] || { cat <<_usage_
USAGE: mflink [ -i (default) | -l | -a | -c | -b | -p | -d ] [ -f ] modulename version
Create cluster-specific link to /sw/mf/common/... for an mf file, when positioned where
the modulename directories are (e.g., /sw/mf/rackham/bioinfo-tools/misc).
NOTE: all_mflink is better for general use, and there is no position requirement.
Subtree options: -i bioinfo-tools (default)
-l libraries
-a applications
-c comp
-b build-tools
-p parallel
-d data
Other options: -f force creating the link and intervening directories
-q work quietly
_usage_
return; }
M=$1
V=$2
if [[ $SUBDIR ]] ; then
if [[ $FORCE ]] ; then
mkdir -p $M && cd $M && ln -sf ../../../common/$SUBDIR/$M/$V . && [[ $QUIET ]] || pwd ; cd ..
else
mkdir $M && cd $M && ln -s ../../../common/$SUBDIR/$M/$V . && [[ $QUIET ]] || pwd ; cd ..
fi
else
if [[ $FORCE ]] ; then
mkdir -p $M && cd $M && ln -sf ../../../../common/bioinfo-tools/*/$M/$V . && [[ $QUIET ]] || pwd ; cd ..
else
mkdir $M && cd $M && ln -s ../../../../common/bioinfo-tools/*/$M/$V . && test -e $V && [[ $QUIET ]] || pwd ; cd ..
fi
fi
[[ $QUIET ]] || ls -la $M
test -e $M/$V
}
# Create all cluster mf symlinks for a given module. The version file in
# /sw/mf/common/... must already exist. Uses mflink function above
function all_mflink()
{
local SUBDIR
local FORCE
local OPT
local OPTIND
local CLUSTS="$_CURRENT_CLUSTERS"
while getopts ":ilacbpdfu:" opt "$@"; do
case $opt in
i) SUBDIR= ; OPT="-$opt" ;;
l) SUBDIR=libraries ; OPT="-$opt" ;;
a) SUBDIR=applications ; OPT="-$opt" ;;
c) SUBDIR=compilers ; OPT="-$opt" ;;
b) SUBDIR=build-tools ; OPT="-$opt" ;;
p) SUBDIR=parallel ; OPT="-$opt" ;;
d) SUBDIR=data ; OPT="-$opt" ;;
f) FORCE=yes ;;
u) CLUSTS="${OPTARG}" ;;
*) echo "unknown option" ; return ;;
esac
done
shift $((OPTIND-1))
[[ $# == 2 ]] || { cat <<_usage_
USAGE: all_mflink [ -i (default) | -l | -a | -c | -b | -p | -d ] [ -u "cluster1 cluster2" ] [ -f ] modulename version
Create all cluster-specific links (/sw/mf/{$CLUSTS}/...) to /sw/mf/common/... for an mf file
Subtree options: -i bioinfo-tools (default)
-l libraries
-a applications
-c comp
-b build-tools
-p parallel
-d data
Other options: -f force; basically required
-u string containing clusters to address; overrides \$_CURRENT_CLUSTERS
_usage_
return; }
local M=$1
local V=$2
local C=
if [[ $SUBDIR ]] ; then
if [[ $FORCE ]] ; then
for C in $CLUSTS ; do
( echo cluster=$C ; cd /sw/mf/$C/$SUBDIR/ && mflink $OPT -f -q $M $V ) || { echo "*** problem with $C/$SUBDIR/$M/$V"; }
done
else
for C in $CLUSTS ; do
( echo cluster=$C ;cd /sw/mf/$C/$SUBDIR/ && mflink $OPT -q $M $V ) || { echo "*** problem with $C/$SUBDIR/$M/$V"; }
done
fi
[[ $FORCE ]] && echo -e "\n*** FORCED"
echo -e "\n*** Done"
echo -e "\n*** mfshow $OPT $M\n"
mfshow $OPT $M
else
local COMMONDIR=(/sw/mf/common/bioinfo-tools/*/$M)
[[ -d $COMMONDIR ]] || { echo "*** $COMMONDIR doesn't exist and it must, before running this"; return; }
SUBDIR=${COMMONDIR#/sw/mf/common/bioinfo-tools/}
SUBDIR=${SUBDIR%/$M}
if [[ $FORCE ]] ; then
for C in $CLUSTS ; do
( echo cluster=$C ;cd /sw/mf/$C/bioinfo-tools/$SUBDIR/ && mflink -f -q $M $V ) || { echo "*** problem with $C/bioinfo-tools/$SUBDIR/$M/$V"; }
done
else
for C in $CLUSTS ; do
( echo cluster=$C ;cd /sw/mf/$C/bioinfo-tools/$SUBDIR/ && mflink -q $M $V ) || { echo "*** problem with $C/bioinfo-tools/$SUBDIR/$M/$V"; }
done
fi
[[ $FORCE ]] && echo -e "\n*** FORCED"
echo -e "\n*** Done"
echo -e "\n*** mfshow $OPT $M\n"
mfshow $OPT $M
fi
}
# Create miarka-specific mf symlinks for a given module. Does 'all_mflink -u miarka ...'
function miarka_mflink()
{
[[ $# -lt 2 ]] && { cat <<_usage_
USAGE: miarka_mflink [ -i (default) | -l | -a | -c | -b | -p | -d ] [ -f ] modulename version
Create all miarka-specific links (/sw/mf/miarka/...) to /sw/mf/common/... for an mf file
This is equivalent to
all_mflink -u miarka ...
so it accepts the same arguments as all_mflink. This does not check if you also gave the -u option, which you shouldn't, so don't
_usage_
return; }
all_mflink -u miarka "$@"
}
# Fix up the permissions and group ownership of installation directories. Sets
# group to 'sw' unless -G is given, setgid's directories unless -g is given, and
# makes all files group writable and other unwritable.
function fixup()
{
# NOTE: Gnu xargs assumed, providing --no-run-if-empty
local GROUP=sw
local PERM='u+rwX,g+rwX,o+rX-w'
local GROUPPERM='u+rwX,g+rX-w,o-rxw'
local SETGID_DIRS=yes
local SETX
local HELP
local OPTIND
while getopts "gG:pP:xh" o; do
case $o in
g) unset SETGID_DIRS ;;
G) GROUP=${OPTARG} ;;
p) PERM=${GROUPPERM} ;;
P) PERM=${OPTARG} ;;
x) SETX=yes ;;
h) HELP=yes ;;
esac
done
shift $((OPTIND-1))
#[[ $# == 0 || $HELP ]] && { echo -e "USAGE: $0 [ -g, to NOT setgid g+s on dirs ] [ -G group, default '$GROUP' ] [ -p, set group-restrictive permissions '$GROUPPERM' ] [ -x, show commands as they are executed ] [ -h, for help ] dir-or-file ..." ; return; }
[[ $# == 0 || $HELP ]] && {
echo "USAGE: fixup [ -g ] [ -G group ] [ -p ] [ -P permissions ] [ -x ] [ -h ] dir-or-file ..."
echo
echo " -g do NOT setgid g+s on dirs"
echo " -G group change to group 'group', default '$GROUP'"
echo " -p set group-restrictive permissions '$GROUPPERM'"
echo " -P perms set permissions to 'perms', default '$PERM'"
echo " -x show commands as they are executed, via shell 'set -x'"
echo " -h help"
return;
}
[[ $SETX ]] && set -x
args=("$@")
for arg in ${args[@]} ; do
echo "fixup: '$arg'"
echo " Changing permissions to $PERM ..."
chmod -R "$PERM" "$arg"
echo " Changing group to $GROUP ..."
chgrp -hR $GROUP "$arg"
if [[ $SETGID_DIRS ]] ; then
echo " Adding g+s to directory permissions ..."
find "$arg" -type d -print0 | xargs -0 --no-run-if-empty chmod g+s
fi
done
[[ $SETX ]] && set +x
}
if [[ "$_EXPORT_UPPMAX_INSTALL_FUNCTIONS" == "yes" ]] ; then
export -f section mfshow mflink all_mflink fixup
fi