annotate make_ucsc_track.sh @ 5:998c98233c36 draft

Uploaded
author nikos
date Tue, 15 Jul 2014 07:19:39 -0400
parents 5b5460b79488
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
4
5b5460b79488 Uploaded
nikos
parents:
diff changeset
1 #!/bin/bash
5b5460b79488 Uploaded
nikos
parents:
diff changeset
2
5b5460b79488 Uploaded
nikos
parents:
diff changeset
3 # This tool creates a UCSC track line given a bigWig or bedGraph input file, a track name and genome assembly.
5b5460b79488 Uploaded
nikos
parents:
diff changeset
4
5b5460b79488 Uploaded
nikos
parents:
diff changeset
5 ## Define URL prefix
5b5460b79488 Uploaded
nikos
parents:
diff changeset
6
5b5460b79488 Uploaded
nikos
parents:
diff changeset
7 URL="http://data.bric.dk/galaxy/UCSC"
5b5460b79488 Uploaded
nikos
parents:
diff changeset
8
5b5460b79488 Uploaded
nikos
parents:
diff changeset
9 #parse input
5b5460b79488 Uploaded
nikos
parents:
diff changeset
10 while getopts hi:t:n:o: myarg
5b5460b79488 Uploaded
nikos
parents:
diff changeset
11 do case "$myarg" in
5b5460b79488 Uploaded
nikos
parents:
diff changeset
12 h) echo "Usage: create UCSC track line -i <INPUT_FILE> -t <FILE_TYPE> -n <TRACK_NAME> -o <ASSEMBLY>"
5b5460b79488 Uploaded
nikos
parents:
diff changeset
13 exit ;;
5b5460b79488 Uploaded
nikos
parents:
diff changeset
14 i) input_file="$OPTARG" ;;
5b5460b79488 Uploaded
nikos
parents:
diff changeset
15 t) file_type="$OPTARG" ;;
5b5460b79488 Uploaded
nikos
parents:
diff changeset
16 n) track_name="$OPTARG" ;;
5b5460b79488 Uploaded
nikos
parents:
diff changeset
17 o) org_assembly="$OPTARG" ;;
5b5460b79488 Uploaded
nikos
parents:
diff changeset
18 [?]) echo "Usage: create UCSC track line -i <INPUT_FILE> -t <FILE_TYPE> -n <TRACK_NAME> -o <ASSEMBLY>"
5b5460b79488 Uploaded
nikos
parents:
diff changeset
19
5b5460b79488 Uploaded
nikos
parents:
diff changeset
20 exit 1 ;;
5b5460b79488 Uploaded
nikos
parents:
diff changeset
21 esac
5b5460b79488 Uploaded
nikos
parents:
diff changeset
22 done
5b5460b79488 Uploaded
nikos
parents:
diff changeset
23
5b5460b79488 Uploaded
nikos
parents:
diff changeset
24 ####################################################################
5b5460b79488 Uploaded
nikos
parents:
diff changeset
25 # Check if a link to that file exists in the UCSC webfolder
5b5460b79488 Uploaded
nikos
parents:
diff changeset
26 flag=0
5b5460b79488 Uploaded
nikos
parents:
diff changeset
27
5b5460b79488 Uploaded
nikos
parents:
diff changeset
28 for link in `ls -1 $UCSCPATH`
5b5460b79488 Uploaded
nikos
parents:
diff changeset
29 do
5b5460b79488 Uploaded
nikos
parents:
diff changeset
30 if [ `readlink -f $input_file` == `readlink -f $UCSCPATH/$link` ] ; then
5b5460b79488 Uploaded
nikos
parents:
diff changeset
31 link_path=/$link # use already existing link
5b5460b79488 Uploaded
nikos
parents:
diff changeset
32 flag=1
5b5460b79488 Uploaded
nikos
parents:
diff changeset
33 fi
5b5460b79488 Uploaded
nikos
parents:
diff changeset
34 done
5b5460b79488 Uploaded
nikos
parents:
diff changeset
35
5b5460b79488 Uploaded
nikos
parents:
diff changeset
36 # If link to input file doesn't exist, create anonymous soft-link for input file in a folder accessible from the web.
5b5460b79488 Uploaded
nikos
parents:
diff changeset
37
5b5460b79488 Uploaded
nikos
parents:
diff changeset
38 if [ $flag == 0 ]; then
5b5460b79488 Uploaded
nikos
parents:
diff changeset
39
5b5460b79488 Uploaded
nikos
parents:
diff changeset
40 link_path=`mktemp -u --tmpdir=/`
5b5460b79488 Uploaded
nikos
parents:
diff changeset
41 ln -s $input_file $UCSCPATH$link_path
5b5460b79488 Uploaded
nikos
parents:
diff changeset
42 fi
5b5460b79488 Uploaded
nikos
parents:
diff changeset
43
5b5460b79488 Uploaded
nikos
parents:
diff changeset
44 ####################################################################
5b5460b79488 Uploaded
nikos
parents:
diff changeset
45 ##Convert 4th character of file_type to uppercase (e.g. bigwig -> bigWig). UCSC browser doesn't recognize the file type otherwise.
5b5460b79488 Uploaded
nikos
parents:
diff changeset
46
5b5460b79488 Uploaded
nikos
parents:
diff changeset
47 ##Split file_type string to prefix (big) and suffix (wig, bed) and uppercase the first character of the latter.
5b5460b79488 Uploaded
nikos
parents:
diff changeset
48 prefix=`echo ${file_type:0:3}`
5b5460b79488 Uploaded
nikos
parents:
diff changeset
49 suffix=`echo ${file_type:3} | sed -e "s/\b\(.\)/\u\1/g"`
5b5460b79488 Uploaded
nikos
parents:
diff changeset
50
5b5460b79488 Uploaded
nikos
parents:
diff changeset
51 file_type=`echo ${prefix}${suffix}`
5b5460b79488 Uploaded
nikos
parents:
diff changeset
52
5b5460b79488 Uploaded
nikos
parents:
diff changeset
53 ####################################################################
5b5460b79488 Uploaded
nikos
parents:
diff changeset
54 #Contruct URL
5b5460b79488 Uploaded
nikos
parents:
diff changeset
55 bigURL=`echo ${URL}${link_path}`
5b5460b79488 Uploaded
nikos
parents:
diff changeset
56
5b5460b79488 Uploaded
nikos
parents:
diff changeset
57 ####################################################################
5b5460b79488 Uploaded
nikos
parents:
diff changeset
58 ## Print track line
5b5460b79488 Uploaded
nikos
parents:
diff changeset
59 echo "track name='$track_name' db=$org_assembly type=$file_type visibility=full alwaysZero=ON bigDataUrl=$bigURL"