-
Notifications
You must be signed in to change notification settings - Fork 2
/
varscan_template.sh
50 lines (40 loc) · 1.64 KB
/
varscan_template.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
function parse_yaml {
local prefix=$2
local s='[[:space:]]*' w='[a-zA-Z0-9_]*' fs=$(echo @|tr @ '\034')
sed -ne "s|^\($s\):|\1|" \
-e "s|^\($s\)\($w\)$s:$s[\"']\(.*\)[\"']$s\$|\1$fs\2$fs\3|p" \
-e "s|^\($s\)\($w\)$s:$s\(.*\)$s\$|\1$fs\2$fs\3|p" $1 |
awk -F$fs '{
indent = length($1)/2;
vname[indent] = $2;
for (i in vname) {if (i > indent) {delete vname[i]}}
if (length($3) > 0) {
vn=""; for (i=0; i<indent; i++) {vn=(vn)(vname[i])("_")}
printf("%s%s%s=\"%s\"\n", "'$prefix'",vn, $2, $3);
}
}'
}
eval $(parse_yaml parameters.yaml)
printf "#Printing VarScan commands"
printf "\n"
printf "samtools mpileup"
printf " -f ${path_to_reference} "
printf "${working_directory}/${folder}/${output_bam_merged}.sorted.uniq.rg.bam"
printf " -a -o ${working_directory}/${folder}/${output_bam_merged}.sorted.uniq.rg.mpileup"
printf "\n"
printf "varscan pileup2cns "
printf "${working_directory}/${folder}/${output_bam_merged}.sorted.uniq.rg.mpileup > "
printf "${working_directory}/${folder}/VarScan.tsv"
printf "\n"
printf "python ${varscan_scripts_path}/vscan_pileup2cns2vcf.py "
printf "${working_directory}/${folder}/VarScan.tsv > ${working_directory}/${folder}/${output_bam_merged}_VarScan.vcf"
printf "\n"
printf "rm ${working_directory}/${folder}/VarScan.tsv"
printf "\n"
printf "bcftools norm ${working_directory}/${folder}/${output_bam_merged}_VarScan.vcf"
printf " --output ${working_directory}/${folder}/${output_bam_merged}_VarScan_norm.vcf"
printf " --output-type v"
printf " -m \"-\""
printf "\n"
printf "rm ${working_directory}/${folder}/${output_bam_merged}_VarScan.vcf"
printf "\n \n"