annotate runMapping_cDNA_wrapper.pl @ 2:2d86d5b112e8

Uploaded
author edward-kirton
date Thu, 14 Jul 2011 22:14:07 -0400
parents
children bf1f8bc4abe6
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
2
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
1 #!/usr/bin/env/perl
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
2
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
3 use warnings;
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
4 use strict;
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
5 use File::Copy;
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
6
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
7 # EXPECT 24 FILE HANDLES, SOME OF WHICH MAY BE 'None'
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
8 die("Missing arguments; expected at least 24, got ".scalar(@ARGV)."\n") unless @ARGV >= 24;
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
9 my $outdir=shift @ARGV;
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
10 my $alignment_info=shift @ARGV;
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
11 my $all_contigs_fasta=shift @ARGV;
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
12 my $all_contigs_qual=shift @ARGV;
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
13 my $all_diffs=shift @ARGV;
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
14 my $all_struct_vars=shift @ARGV;
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
15 my $hc_diff=shift @ARGV;
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
16 my $hc_struct_vars=shift @ARGV;
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
17 my $mapping_qc=shift @ARGV;
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
18 my $newbler_metrics=shift @ARGV;
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
19 my $pair_align=shift @ARGV;
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
20 my $read_status=shift @ARGV;
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
21 my $ref_status=shift @ARGV;
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
22 my $tag_pair_align=shift @ARGV;
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
23 my $trim_status=shift @ARGV;
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
24 my $trimmed_reads_fasta=shift @ARGV;
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
25 my $trimmed_reads_qual=shift @ARGV;
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
26 my $contigs_ace=shift @ARGV;
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
27 my $gene_status=shift @ARGV;
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
28 my $isotigs_ace=shift @ARGV;
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
29 my $isotigs_fasta=shift @ARGV;
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
30 my $isotigs_qual=shift @ARGV;
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
31 my $isotigs_agp=shift @ARGV;
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
32 my $isotigs_layout=shift @ARGV;
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
33
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
34 # REMOVE PARAMETERS FOR OPTIONAL FILES WHICH WERE NOT PROVIDED
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
35
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
36 my @cmd=removeUnusedOptions(@ARGV);
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
37
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
38 # RUN COMMAND
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
39 # NOTE: FIRST ARG EXPECTED TO BE EXECUTABLE
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
40 my $stderr;
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
41 eval { $stderr=`@cmd 2>&1`; };
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
42 if ( $@ ) {
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
43 print STDERR "Newbler ERROR: $stderr\n";
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
44 `cat $outdir/assembly/454NewblerProgress.txt 1>&2`;
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
45 die($@);
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
46 }
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
47
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
48 get_outfile("$outdir/454AlignmentInfo.tsv", $alignment_info);
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
49 get_outfile("$outdir/454AllContigs.fna", $all_contigs_fasta);
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
50 get_outfile("$outdir/454AllContigs.qual", $all_contigs_qual);
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
51 get_outfile("$outdir/454AllDiffs.txt", $all_diffs);
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
52 get_outfile("$outdir/454AllStructVars.txt", $all_struct_vars);
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
53 get_outfile("$outdir/454HCDiff.txt", $hc_diff);
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
54 get_outfile("$outdir/454HCStructVars.txt", $hc_struct_vars);
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
55 get_outfile("$outdir/454MappingQC.xls", $mapping_qc);
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
56 get_outfile("$outdir/454NewblerMetrics.txt", $newbler_metrics);
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
57 get_outfile("$outdir/454PairAlign.txt", $pair_align);
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
58 get_outfile("$outdir/454ReadStatus.txt", $read_status);
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
59 get_outfile("$outdir/454RefStatus.txt", $ref_status);
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
60 get_outfile("$outdir/454TagPairAlign.txt", $tag_pair_align);
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
61 get_outfile("$outdir/454TrimStatus.txt", $trim_status);
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
62 get_outfile("$outdir/454TrimmedReads.fna", $trimmed_reads_fasta);
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
63 get_outfile("$outdir/454TrimmedReads.qual", $trimmed_reads_qual);
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
64 get_outfile("$outdir/454Contigs.ace", $contigs_ace);
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
65 get_outfile("$outdir/454GeneStatus.txt", $gene_status);
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
66 get_outfile("$outdir/454Isotigs.ace", $isotigs_ace);
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
67 get_outfile("$outdir/454Isotigs.fna", $isotigs_fasta);
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
68 get_outfile("$outdir/454Isotigs.qual", $isotigs_qual);
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
69 get_outfile("$outdir/454Isotigs.txt", $isotigs_agp);
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
70 get_outfile("$outdir/454IsotigsLayout.txt", $isotigs_layout);
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
71 exit;
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
72
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
73 # EVERY 'None' ARG AND IT'S PRECEEDING OPTION TAG ARE DISCARDED
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
74 sub removeUnusedOptions {
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
75 my @cmd=();
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
76 my $prev;
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
77 foreach (@_) {
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
78 unless ($_ eq 'None') {
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
79 push @cmd, $prev if defined($prev);
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
80 $prev=$_;
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
81 } else {
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
82 $prev=undef;
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
83 }
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
84 }
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
85 push @cmd, $prev if defined($prev);
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
86 return @cmd;
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
87 }
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
88
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
89 sub get_outfile {
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
90 my ($src, $dest)=@_;
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
91 # make sure dest defined and src exist; skip if dest is 'None'
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
92 if ( $dest and $dest ne 'None' and $src and -f $src ) {
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
93 move($src,$dest);
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
94 }
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
95 }
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
96
2d86d5b112e8 Uploaded
edward-kirton
parents:
diff changeset
97 __END__