Mercurial > repos > dfornika > snippy
view snippy_core_wrapper.pl @ 21:0e733df972b5 draft
planemo upload commit d65fe6718a4e9a9fa6dba28e6702335222c3e221-dirty
author | dfornika |
---|---|
date | Tue, 12 Mar 2019 17:37:29 -0400 |
parents | 3bbfe41787af |
children |
line wrap: on
line source
#!/usr/bin/env perl #-------------------------------------- # # snippy_core_wrapper.pl # # This is an intermediary script between snippy-core.xml and snippy-core # It: # - Copys the supplied zipped snippy output files to the working dir # - Untars them to their datafile name # - Builds the snippy-core command # - Runs the snippy-core command # #-------------------------------------- use warnings; use strict; use File::Copy; use File::Basename; my(@Options, $indirs, $ref); setOptions(); my @list_of_dirs = split /\s+/, $indirs; #The list of final directories to be passed to snippy-core will be stored here. my @snippy_outs; foreach my $d (@list_of_dirs){ print STDERR "$d\n"; my $bn = basename($d); my ($name, $dir, $ext) = fileparse($d, '\..*'); copy($d, $bn); print STDERR "$d, $bn, $name, $dir, $ext\n"; `tar -xf $bn`; } my $test_list = `ls -d */`; $test_list =~ s/\///g; print STDERR "$test_list\n"; @snippy_outs = split /\s+/, $test_list; my $commandline = "snippy-core "; $commandline .= " --ref $ref " if $ref; $commandline .= join(" ", @snippy_outs); print STDERR "snippy-core commandline: $commandline\n"; my $ok = system($commandline); #---------------------------------------------------------------------- # Option setting routines sub setOptions { use Getopt::Long; @Options = ( {OPT=>"help", VAR=>\&usage, DESC=>"This help"}, {OPT=>"ref=s", VAR=>\$ref, DEFAULT=>"", DESC=>"Reference genome."}, {OPT=>"indirs=s", VAR=>\$indirs, DEFAULT=>"", DESC=>"A whitespace delimited list of the snippy output zipped dirs."}, ); &GetOptions(map {$_->{OPT}, $_->{VAR}} @Options) || usage(); # Now setup default values. foreach (@Options) { if (defined($_->{DEFAULT}) && !defined(${$_->{VAR}})) { ${$_->{VAR}} = $_->{DEFAULT}; } } } sub usage { print "Usage: $0 [options] -i inputfile > ... \n"; foreach (@Options) { printf " --%-13s %s%s.\n",$_->{OPT},$_->{DESC}, defined($_->{DEFAULT}) ? " (default '$_->{DEFAULT}')" : ""; } exit(1); }