annotate weeder2_wrapper.sh @ 1:79f075dc6cfb draft default tip

Uploaded version 2.0.3.
author pjbriggs
date Wed, 26 Sep 2018 06:39:27 -0400
parents fb7e680232af
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
1 #!/bin/sh -e
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
2 #
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
3 # Wrapper script to run weeder2 as a Galaxy tool
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
4 #
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
5 # Usage: weeder_wrapper.sh FASTA_IN SPECIES_CODE FREQFILES_DIR MOTIFS_OUT MATRIX_OUT [ ARGS... ]
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
6 #
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
7 # ARGS: one or more arguments to supply directly to weeder2
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
8 #
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
9 # Process command line
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
10 FASTA_IN=$1
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
11 SPECIES_CODE=$2
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
12 FREQFILES_DIR=$3
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
13 MOTIFS_OUT=$4
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
14 MATRIX_OUT=$5
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
15 #
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
16 # Other arguments
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
17 ARGS=""
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
18 while [ ! -z "$6" ] ; do
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
19 ARGS="$ARGS $6"
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
20 shift
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
21 done
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
22 #
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
23 # Link to input file
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
24 ln -s $FASTA_IN
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
25 #
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
26 # Locate the FreqFiles directory
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
27 if [ $FREQFILES_DIR == "." ] ; then
1
79f075dc6cfb Uploaded version 2.0.3.
pjbriggs
parents: 0
diff changeset
28 # Don't explicitly set the location - Weeder2 from
79f075dc6cfb Uploaded version 2.0.3.
pjbriggs
parents: 0
diff changeset
29 # bioconda handles this automatically
79f075dc6cfb Uploaded version 2.0.3.
pjbriggs
parents: 0
diff changeset
30 freqfiles_dir=
0
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
31 else
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
32 # Alternative location
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
33 freqfiles_dir=$FREQFILES_DIR
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
34 fi
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
35 #
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
36 # Link to the FreqFiles directory as weeder2 executable
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
37 # expects it to be the same directory
1
79f075dc6cfb Uploaded version 2.0.3.
pjbriggs
parents: 0
diff changeset
38 if [ ! -z "$freqfiles_dir" ] ; then
79f075dc6cfb Uploaded version 2.0.3.
pjbriggs
parents: 0
diff changeset
39 if [ -d $freqfiles_dir ] ; then
79f075dc6cfb Uploaded version 2.0.3.
pjbriggs
parents: 0
diff changeset
40 echo "Linking to FreqFiles directory: $freqfiles_dir"
79f075dc6cfb Uploaded version 2.0.3.
pjbriggs
parents: 0
diff changeset
41 ln -s $freqfiles_dir FreqFiles
79f075dc6cfb Uploaded version 2.0.3.
pjbriggs
parents: 0
diff changeset
42 else
79f075dc6cfb Uploaded version 2.0.3.
pjbriggs
parents: 0
diff changeset
43 echo "ERROR FreqFiles directory not found" >&2
79f075dc6cfb Uploaded version 2.0.3.
pjbriggs
parents: 0
diff changeset
44 exit 1
79f075dc6cfb Uploaded version 2.0.3.
pjbriggs
parents: 0
diff changeset
45 fi
0
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
46 else
1
79f075dc6cfb Uploaded version 2.0.3.
pjbriggs
parents: 0
diff changeset
47 echo "WARNING FreqFiles directory not set" >&2
0
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
48 fi
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
49 #
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
50 # Construct names of input and output files
1
79f075dc6cfb Uploaded version 2.0.3.
pjbriggs
parents: 0
diff changeset
51 fasta=$(basename $FASTA_IN)
79f075dc6cfb Uploaded version 2.0.3.
pjbriggs
parents: 0
diff changeset
52 motifs_out=${fasta}.w2
79f075dc6cfb Uploaded version 2.0.3.
pjbriggs
parents: 0
diff changeset
53 matrix_out=${fasta}.matrix.w2
0
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
54 #
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
55 # Construct and run weeder command
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
56 # NB weeder logs output to stderr so redirect to stdout
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
57 # to prevent the Galaxy tool reporting failure
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
58 weeder_cmd="weeder2 -f $fasta -O $SPECIES_CODE $ARGS"
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
59 echo "Running $weeder_cmd"
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
60 $weeder_cmd 2>&1
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
61 status=$?
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
62 if [ $status -ne 0 ] ; then
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
63 echo weeder2 command finished with nonzero exit code $status >&2
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
64 echo Command was: $weeder_cmd
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
65 exit $status
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
66 fi
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
67 #
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
68 # Move outputs to final destinations
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
69 if [ -e $motifs_out ] ; then
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
70 /bin/mv $motifs_out $MOTIFS_OUT
1
79f075dc6cfb Uploaded version 2.0.3.
pjbriggs
parents: 0
diff changeset
71 else
79f075dc6cfb Uploaded version 2.0.3.
pjbriggs
parents: 0
diff changeset
72 echo ERROR missing output file: $motifs_out >&2
79f075dc6cfb Uploaded version 2.0.3.
pjbriggs
parents: 0
diff changeset
73 status=1
0
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
74 fi
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
75 if [ -e $matrix_out ] ; then
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
76 /bin/mv $matrix_out $MATRIX_OUT
1
79f075dc6cfb Uploaded version 2.0.3.
pjbriggs
parents: 0
diff changeset
77 else
79f075dc6cfb Uploaded version 2.0.3.
pjbriggs
parents: 0
diff changeset
78 echo ERROR missing output file: $matrix_out >&2
79f075dc6cfb Uploaded version 2.0.3.
pjbriggs
parents: 0
diff changeset
79 status=1
0
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
80 fi
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
81 #
fb7e680232af Uploaded v2.0.2
pjbriggs
parents:
diff changeset
82 # Done
1
79f075dc6cfb Uploaded version 2.0.3.
pjbriggs
parents: 0
diff changeset
83 exit $status