Next changeset 1:11c462cd481c (2017-10-11) |
Commit message:
Uploaded |
added:
bin/._.DS_Store bin/._html.pm bin/Rcall.pm bin/align.pm bin/css/bootstrap-responsive.css bin/css/bootstrap-table.css bin/css/bootstrap-table.js bin/css/bootstrap.css bin/html.pm bin/js/bootstrap.min.js bin/js/jquery.galleriffic.js bin/js/jquery.js bin/js/jquery.opacityrollover.js bin/piPipe.pl bin/ppp.pm bin/resize.pm bin/subgroups.pm piPipe.xml test-data/TE-file-small.fa test-data/dmel-all-rRNA-r6.03.fasta test-data/dmel-all-sn-snoRNA-r6.03.fasta test-data/dmel-all-tRNA-r6.03.fasta test-data/genome-small.fa test-data/mirbase-21-dme-hairpins-16jul2015.fa test-data/reads-sample-small.fastq test-data/transcripts-file-small.fa tool-data/bwa_index.loc.sample tool_data_table_conf.xml.sample |
b |
diff -r 000000000000 -r 198009598544 bin/._.DS_Store |
b |
Binary file bin/._.DS_Store has changed |
b |
diff -r 000000000000 -r 198009598544 bin/._html.pm |
b |
Binary file bin/._html.pm has changed |
b |
diff -r 000000000000 -r 198009598544 bin/Rcall.pm --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/bin/Rcall.pm Wed Oct 11 09:57:58 2017 -0400 |
[ |
@@ -0,0 +1,100 @@ +package Rcall; + +use strict; +use warnings; +use Statistics::R; + +use Exporter; +our @ISA = qw(Exporter); +our @EXPORT_OK = qw( &histogram &pie_chart &bg_to_png ); + +sub histogram +{ + my ($size_hashR, $out_png, $size) = @_; + my (@abs, @ord); + my $i = 0; + foreach my $k (sort {$a <=> $b} keys %{$size_hashR}) + { + my $percentage = $size_hashR->{$k} * 100 / $size; + $abs[$i] = $k ; $ord[$i] = $percentage; $i++; + } + my $abs = join (",", @abs ); + my $ord = join (",", @ord ); + if (scalar(@abs) != 0) + { + + my $R = Statistics::R->new(); + $R->startR; + $R->send( + qq`library(ggplot2) + percentage = c($ord) + size =c($abs) + min = min(size) + max = max(size) + dat = data.frame(size,percentage) + png(filename=\"$out_png\", width = 800, height = 480) + c = ggplot(dat,aes(size,percentage)) + c + geom_bar(stat="identity") + scale_x_continuous(breaks=min:max)+theme( axis.text.x = element_text(angle=90, hjust=0.5, size=20), axis.text.y = element_text( size=20 ), axis.title.x = element_text( size=25, face="bold"), axis.title.y = element_text( size=25, face="bold") ) + dev.off()`); + $R->stopR(); + + } +} + +sub bg_to_png +{ + my ( $fai, $bgP, $bgM, $dir, $sb ) = @_; + my $R = Statistics::R->new(); + $R->startR; + $R->send( + qq`library('Sushi') + fai =read.table("$fai") + bgP = read.table("$bgP") + bgM = read.table("$bgM") + fun = function(chr,end) { + jpeg( paste0("$dir",as.character(chr),".png"), quality=100) + par(mfrow=c(2,1),mar=c(1,10,1,3)) + plotBedgraph(bgP, chrom=chr,chromstart=0,chromend=end,transparency=.50, color=SushiColors(2)(2)[1]) + axis(side=2,las=2,tcl=.2) + mtext("Scaled Read Depth",side=2,line=4,cex=1,font=2) + plotBedgraph(bgM, chrom=chr,chromstart=0,chromend=end,transparency=.50, flip=TRUE, color=SushiColors(2)(2)[2]) + labelgenome(chrom=chr,chromstart=0,chromend=end,side=3,n=3,scale="$sb", line=0, chromline = 0.5, scaleline = 0.5, scaleadjust =1.05, chromadjust = -0.4) + axis(side=2,las=2,tcl=.2,at=pretty(par("yaxp")[c(1,2)]),labels=-1*pretty(par("yaxp")[c(1,2)])) + mtext("Scaled Read Depth",side=2,line=4.5,cex=1,font=2) + dev.off() + } + mapply( fun, fai\$V1, fai\$V2)`); + $R->stopR(); +} + +sub pie_chart +{ + my $dir = shift; + my $in = $dir.'repartition.txt'; + my $out = $dir.'pie_chart.png'; + + my $R = Statistics::R->new(); + $R->startR; + $R->send( + qq` + library(plotrix) + library(RColorBrewer) + R =read.table("$in",header=T) + values = round(R\$percentage) + keys = R\$type + lab = paste(values, "%", sep="") + png("$out") + colors <- brewer.pal(7,"Paired") + pie(values, col=colors, labels=lab, clockwise=TRUE) + legend("bottom", legend = keys, fill=colors, bty="n", ncol = 3) + par(mai = c(0,0,0,0)) + layout(c(1,2),heights=c(0.3,1)) + plot.new() + legend("bottom", legend = keys, fill=colors, bty="n",ncol = 3) + pie(values, col=colors, labels=lab, clockwise=TRUE) + dev.off()` + ); + $R->stopR(); +} + +1; |
b |
diff -r 000000000000 -r 198009598544 bin/align.pm --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/bin/align.pm Wed Oct 11 09:57:58 2017 -0400 |
[ |
b'@@ -0,0 +1,445 @@\n+package align;\n+\n+use strict;\n+use warnings;\n+use File::Basename;\n+use String::Random;\n+\n+use FindBin;\n+use lib $FindBin::Bin;\n+use Rcall qw ( histogram );\n+\n+use Exporter;\n+our @ISA = qw( Exporter );\n+our @EXPORT = qw( &BWA_call &to_build &get_unique &sam_sorted_bam &get_hash_alignment &sam_to_bam_bg &sam_count &sam_count_mis &rpms_rpkm &get_fastq_seq &extract_sam );\n+\n+sub to_build\n+{\n+\tmy $toBuildHashP = shift; my $log = shift;\n+\n+\twhile ( my ( $k, $v ) = each %{ $toBuildHashP } )\n+\t{\n+\t\tbuild_index ( $k, $log ) if $v == 1;\n+\t}\n+}\n+\n+sub build_index\n+{\n+\tmy $to_index = shift;\n+\tmy $log = shift;\n+\tmy $index_log = $to_index.\'_index.err\';\n+\t`bwa index $to_index 2> $index_log`;\n+\tprint $log "Creating index for $to_index\\n";\n+}\n+\n+sub get_unique\n+{\n+\tmy ( $sam, $s_uni, $prefix, $details, $report ) = @_;\n+\n+\tmy $fout = $prefix.\'all.fastq\'; \n+\tmy $funi = $prefix.\'unique.fastq\';\n+\tmy $frej = $prefix.\'rejected.fastq\';\n+\t\n+ my $repartition = $prefix.\'distribution.txt\';\n+\tmy $png_rep = $prefix.\'distribution.png\';\n+\tmy ( %duplicates, %genome_hits) ;\n+\n+\t#alignement to the first reference\n+\tmy @return = sam_parse( $sam, $fout, $funi, $frej, $s_uni, \\%duplicates, \\%genome_hits, $report );\n+\tmy $ref_fai = $return[4];\n+\tmy $mappers = $return[5];\n+\tmy $mappers_uni = $return[6];\n+\tmy $size_mappedHashR = $return[7];\n+\n+\tif ( $details == 1 )\n+\t{\n+\t\t#print number of duplicates and hits number\n+\t\tmy ($pourcentage, $total) =(0,0);\n+\n+\t\t$total += $_ foreach values %{$size_mappedHashR};\n+\t\topen (my $rep, \'>\'.$repartition) || die "cannot create $repartition $!\\n";\n+\t\tprint $rep "size\\tnumber\\tpercentage\\n";\n+\t\tforeach my $k (sort{$a cmp $b} keys (%{$size_mappedHashR}))\n+\t\t{\n+\t\t\t$pourcentage = 0;\n+\t\t\t$pourcentage = $size_mappedHashR->{$k} / $total * 100 unless $total ==0;\n+\n+\t\t\tprint $rep "$k\\t$size_mappedHashR->{$k}\\t";\n+\t\t\tprintf $rep "%.2f\\n",$pourcentage;\n+\t\t}\n+\n+\t\thistogram($size_mappedHashR, $png_rep, $total);\n+\n+\n+\t\tmy $dup = $prefix.\'dup_mapnum.txt\';\n+\t\tmy $dup_u = $prefix .\'dup_unique.txt\';\n+\t\tmy $dup_r = $prefix .\'dup_nonmapp.txt\';\n+\t\topen(my $tab,">".$dup) || die "cannot open output txt file\\n";\n+\t\topen(my $tab_r,">".$dup_r) || die "cannot open output txt file\\n";\n+\t\topen(my $tab_u,">".$dup_u) || die "cannot open output txt file\\n";\n+\t\tprint $tab "sequence\\tcount\\tmapnum\\n";\n+\t\tprint $tab_u "sequence\\tcount\\n";\n+\t\tprint $tab_r "sequence\\tcount\\n";\n+\t\tforeach my $k (sort {$duplicates{$b} <=> $duplicates{$a}}keys %duplicates)\n+\t\t{\n+\t\t\t$duplicates{$k} = 0 unless exists($duplicates{$k});\n+\t\t\t$genome_hits{$k} = 0 unless exists($genome_hits{$k});\n+\t\t\tif ($genome_hits{$k} != 0) { print $tab $k."\\t".$duplicates{$k}."\\t".$genome_hits{$k}."\\n"; }\n+\t\t\telse {print $tab_r $k."\\t".$duplicates{$k}."\\n";}\n+\t\t\tif ($genome_hits{$k} == 1) { print $tab_u $k."\\t".$duplicates{$k}."\\n"; }\n+\t\t}\n+\tclose $dup; close $dup_r; close $dup_u;\n+\t}\n+\treturn ( $ref_fai, $mappers, $mappers_uni );\n+}\n+\n+sub sam_parse\n+{\n+\tmy ( $sam, $fastq_accepted, $fastq_accepted_unique, $fastq_rejected, $sam_unique, $duplicate_hashR, $best_hit_number_hashR, $report ) = @_ ;\n+\tmy ($reads, $mappers, $mappersUnique, @garbage, %size_num, %size_num_spe, %number, %numberSens, %numberReverse, %unique_number, %numberNM, %numberM, %size);\n+\t$mappers = $mappersUnique = $reads = 0;\n+\n+\topen my $fic, \'<\', $sam || die "cannot open $sam $!\\n";\n+\topen my $accepted, \'>\', $fastq_accepted || die "cannot create $fastq_accepted $! \\n";\n+\topen my $unique, \'>\', $fastq_accepted_unique || die "cannot create $fastq_accepted_unique $! \\n";\n+\topen my $rejected, \'>\', $fastq_rejected || die "cannot create $fastq_rejected $! \\n";\n+\topen my $sam_uni, \'>\', $sam_unique || die "cannot create $sam_unique $! \\n";\n+\tmy $sequence = \'\';\n+\twhile(<$fic>)\n+\t{\n+\t\tchomp $_;\n+\t\tif ($_ =~ /^\\@[A-Za-z][A-Za-z](\\t[A-Za-z][A-Za-z0-9]:[ -~]+)+$/ || $_ =~ /^\\@CO\\t.*/ )\n+\t\t{\n+\t\t\tif ($_ =~ /\\@SQ\\tSN:(.*)\\tLN:(\\d*)/)\n+\t\t\t{\n+\t\t\t\t$size{$1} = $2;\n+\t\t\t\t$unique_number{$1} = 0;\n+\t\t\t\t$number{$1} = 0;\n+\t\t\t\t$numberNM{$1} ='..b's $number_of_cpus /dev/stdin > $bam_sorted`;\n+}\n+\n+sub BWA_call\n+{\n+\tmy ( $index, $fastq, $sam, $mismatches, $number_of_cpus, $report ) = @_;\n+\tmy ( $aln_err, $samse_err, $seq_num ) = ( $sam.\'_aln.err\', $sam.\'_samse.err\', 0 );\n+\tprint $report "-----------------------------\\n";\n+\tprint $report "bwa aln -t $number_of_cpus -n $mismatches $index $fastq 2> $aln_err | bwa samse $index /dev/stdin $fastq 2> $samse_err > $sam\\n";\n+\t`bwa aln -t $number_of_cpus -n $mismatches $index $fastq 2> $aln_err | bwa samse $index /dev/stdin $fastq 2> $samse_err > $sam `;\n+}\n+\n+sub rpms_rpkm\n+{\n+ my ( $counthashR, $sizehashR, $mapped, $out_file, $piRNA_number, $miRNA_number, $bonafide_number ) =@_;\n+ open(my $out, ">".$out_file) || die "cannot open normalized file $! \\n";\n+ print $out "ID\\treads counts\\tRPKM";\n+ print $out "\\tper million of piRNAs" if ($piRNA_number != 0);\n+ print $out "\\tper million of miRNAs" if ($miRNA_number != 0);\n+ print $out "\\tper million of bonafide reads" if ($bonafide_number != 0);\n+ print $out "\\n";\n+ foreach my $k ( sort keys %{$counthashR} )\n+ {\n+ my ($rpkm, $pirna, $mirna, $bonafide) = (0,0,0,0);\n+ \n+ $rpkm = ( $counthashR->{$k} * 1000000000) / ( $sizehashR->{$k} * $mapped) if ( $sizehashR->{$k} * $mapped) != 0 ;\n+ print $out $k."\\t".$counthashR->{$k}."\\t"; printf $out "%.2f",$rpkm;\n+ \n+ if ($piRNA_number != 0 )\n+ {\n+ $pirna = ( $counthashR->{$k} * 1000000) / $piRNA_number;\n+ printf $out "\\t%.2f",$pirna;\n+ }\n+ if ($miRNA_number != 0 )\n+ {\n+ $mirna = ( $counthashR->{$k} * 1000000) / $miRNA_number;\n+ printf $out "\\t%.2f",$mirna;\n+ }\n+ if ($bonafide_number != 0 )\n+ {\n+ $bonafide = ( $counthashR->{$k} * 1000000) / $bonafide_number;\n+ printf $out "\\t%.2f",$bonafide;\n+ }\n+ print $out "\\n";\n+ \t}\n+ close $out;\n+}\n+\n+sub extract_sam\n+{\n+ my ( $hashRef, $sam_in, $sam_out, $sam_uni_out, $fastq_out, $fastq_uni_out ) = @_;\n+ \n+\topen my $s_in, \'<\', $sam_in || die "cannot open $sam_in file $!\\n";\n+\n+ open my $f_out, \'>\', $fastq_out || die "cannot create $fastq_out $!\\n"; \n+ open my $f_uni_out, \'>\', $fastq_uni_out || die "cannot create $fastq_uni_out $!\\n"; \n+ \n+ open my $s_out, \'>\', $sam_out || die "cannot create $sam_out file $!\\n" if defined ($hashRef);\n+ open my $s_uni_out, \'>\', $sam_uni_out || die "cannot create $sam_uni_out file $!\\n";\n+\n+ my $sequence = \'\';\n+ while(<$s_in>)\n+ {\n+ if ($_ =~ /^\\@[A-Za-z][A-Za-z](\\t[A-Za-z][A-Za-z0-9]:[ -~]+)+$/ || $_ =~ /^\\@CO\\t.*/ )\n+ {\n+ print $s_out $_ if defined ($hashRef);\n+ print $s_uni_out $_;\n+ next;\n+ }\n+ my @line = split (/\\t/,$_);\n+ $sequence = $line[0];\n+ if ( (! defined ($hashRef) )|| ( exists $hashRef->{$sequence} && $hashRef->{$sequence} == 1 ) )\n+ {\n+ my $arn = $line[9];\n+ if ($line[1] & 16)\n+ {\n+ $arn =reverse($arn);\n+ $arn =~ tr/atgcuATGCU/tacgaTACGA/;\n+ }\n+ #&& $line[11] eq "XT:A:U" )\n+ if ( ( $line[1] == 16 || $line[1] == 0 ) )\n+\t\t\t{\n+ \tprint $f_out "\\@".$line[0]."\\n".$arn."\\n+\\n".$line[10]."\\n" ;\n+ \tprint $s_out $_ if defined ($hashRef);\n+ \tif ( $line[11] eq "XT:A:U" )\n+ \t{\n+ \t\tprint $f_uni_out "\\@".$line[0]."\\n".$arn."\\n+\\n".$line[10]."\\n" ;\n+ \t\tprint $s_uni_out $_ ;\n+ \t}\n+ }\n+ } \n+ }\n+ close $s_in; close $s_out if defined ($hashRef); \n+ close $s_uni_out; close $f_out; close $f_uni_out;\n+}\n+\n+sub get_fastq_seq{\n+ my $fastq = shift;\n+ my %hash; my $cmp = 0; \n+\n+ open my $fic, \'<\', $fastq || die "cannot open input file $! \\n";\n+ while(<$fic>)\n+ {\n+ chomp $_;\n+ $cmp++;\n+ if ($cmp % 4 == 1)\n+ {\n+ die "file do not contain a @ at line $cmp\\n" unless ($_ =~ /^\\@/ );\n+ if ($_ =~ /^\\@(.*)\\s.*/) { $hash{$1} = 1;}\n+ elsif ($_ =~ /^\\@(.*)/) { $hash{$1} = 1;}\n+ }\n+ elsif ($cmp % 4 == 3 )\n+ {\n+ die "file do not contain a + at line $cmp\\n" unless $_ =~ /^\\+/;\n+ }\n+ }\n+ close $fic;\n+ return \\%hash;\n+}\n+\n+1;\n' |
b |
diff -r 000000000000 -r 198009598544 bin/css/bootstrap-responsive.css --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/bin/css/bootstrap-responsive.css Wed Oct 11 09:57:58 2017 -0400 |
[ |
b'@@ -0,0 +1,1109 @@\n+/*!\n+ * Bootstrap Responsive v2.3.2\n+ *\n+ * Copyright 2012 Twitter, Inc\n+ * Licensed under the Apache License v2.0\n+ * http://www.apache.org/licenses/LICENSE-2.0\n+ *\n+ * Designed and built with all the love in the world @twitter by @mdo and @fat.\n+ */\n+\n+.clearfix {\n+ *zoom: 1;\n+}\n+\n+.clearfix:before,\n+.clearfix:after {\n+ display: table;\n+ line-height: 0;\n+ content: "";\n+}\n+\n+.clearfix:after {\n+ clear: both;\n+}\n+\n+.hide-text {\n+ font: 0/0 a;\n+ color: transparent;\n+ text-shadow: none;\n+ background-color: transparent;\n+ border: 0;\n+}\n+\n+.input-block-level {\n+ display: block;\n+ width: 100%;\n+ min-height: 30px;\n+ -webkit-box-sizing: border-box;\n+ -moz-box-sizing: border-box;\n+ box-sizing: border-box;\n+}\n+\n+@-ms-viewport {\n+ width: device-width;\n+}\n+\n+.hidden {\n+ display: none;\n+ visibility: hidden;\n+}\n+\n+.visible-phone {\n+ display: none !important;\n+}\n+\n+.visible-tablet {\n+ display: none !important;\n+}\n+\n+.hidden-desktop {\n+ display: none !important;\n+}\n+\n+.visible-desktop {\n+ display: inherit !important;\n+}\n+\n+@media (min-width: 768px) and (max-width: 979px) {\n+ .hidden-desktop {\n+ display: inherit !important;\n+ }\n+ .visible-desktop {\n+ display: none !important ;\n+ }\n+ .visible-tablet {\n+ display: inherit !important;\n+ }\n+ .hidden-tablet {\n+ display: none !important;\n+ }\n+}\n+\n+@media (max-width: 767px) {\n+ .hidden-desktop {\n+ display: inherit !important;\n+ }\n+ .visible-desktop {\n+ display: none !important;\n+ }\n+ .visible-phone {\n+ display: inherit !important;\n+ }\n+ .hidden-phone {\n+ display: none !important;\n+ }\n+}\n+\n+.visible-print {\n+ display: none !important;\n+}\n+\n+@media print {\n+ .visible-print {\n+ display: inherit !important;\n+ }\n+ .hidden-print {\n+ display: none !important;\n+ }\n+}\n+\n+@media (min-width: 1200px) {\n+ .row {\n+ margin-left: -30px;\n+ *zoom: 1;\n+ }\n+ .row:before,\n+ .row:after {\n+ display: table;\n+ line-height: 0;\n+ content: "";\n+ }\n+ .row:after {\n+ clear: both;\n+ }\n+ [class*="span"] {\n+ float: left;\n+ min-height: 1px;\n+ margin-left: 30px;\n+ }\n+ .container,\n+ .navbar-static-top .container,\n+ .navbar-fixed-top .container,\n+ .navbar-fixed-bottom .container {\n+ width: 1170px;\n+ }\n+ .span12 {\n+ width: 1170px;\n+ }\n+ .span11 {\n+ width: 1070px;\n+ }\n+ .span10 {\n+ width: 970px;\n+ }\n+ .span9 {\n+ width: 870px;\n+ }\n+ .span8 {\n+ width: 770px;\n+ }\n+ .span7 {\n+ width: 670px;\n+ }\n+ .span6 {\n+ width: 570px;\n+ }\n+ .span5 {\n+ width: 470px;\n+ }\n+ .span4 {\n+ width: 370px;\n+ }\n+ .span3 {\n+ width: 270px;\n+ }\n+ .span2 {\n+ width: 170px;\n+ }\n+ .span1 {\n+ width: 70px;\n+ }\n+ .offset12 {\n+ margin-left: 1230px;\n+ }\n+ .offset11 {\n+ margin-left: 1130px;\n+ }\n+ .offset10 {\n+ margin-left: 1030px;\n+ }\n+ .offset9 {\n+ margin-left: 930px;\n+ }\n+ .offset8 {\n+ margin-left: 830px;\n+ }\n+ .offset7 {\n+ margin-left: 730px;\n+ }\n+ .offset6 {\n+ margin-left: 630px;\n+ }\n+ .offset5 {\n+ margin-left: 530px;\n+ }\n+ .offset4 {\n+ margin-left: 430px;\n+ }\n+ .offset3 {\n+ margin-left: 330px;\n+ }\n+ .offset2 {\n+ margin-left: 230px;\n+ }\n+ .offset1 {\n+ margin-left: 130px;\n+ }\n+ .row-fluid {\n+ width: 100%;\n+ *zoom: 1;\n+ }\n+ .row-fluid:before,\n+ .row-fluid:after {\n+ display: table;\n+ line-height: 0;\n+ content: "";\n+ }\n+ .row-fluid:after {\n+ clear: both;\n+ }\n+ .row-fluid [class*="span"] {\n+ display: block;\n+ float: left;\n+ width: 100%;\n+ min-height: 30px;\n+ margin-left: 2.564102564102564%;\n+ *margin-left: 2.5109110747408616%;\n+ -webkit-box-sizing: border-box;\n+ -moz-box-sizing: border-box;\n+ box-sizing: border-box;\n+ }\n+ .row-fluid [class*="span"]:first-child {\n+ margin-left: 0;\n+ }\n+ .row-fluid .controls-row [class*="span"] + [class*="span"] {\n+ margin-left: 2.564102564102564%;\n+ }\n+ .row-fluid .span12 {\n+ width: 100%;\n+ *width: 99.9468'..b'tic;\n+ }\n+}\n+\n+@media (max-width: 979px) {\n+ body {\n+ padding-top: 0;\n+ }\n+ .navbar-fixed-top,\n+ .navbar-fixed-bottom {\n+ position: static;\n+ }\n+ .navbar-fixed-top {\n+ margin-bottom: 20px;\n+ }\n+ .navbar-fixed-bottom {\n+ margin-top: 20px;\n+ }\n+ .navbar-fixed-top .navbar-inner,\n+ .navbar-fixed-bottom .navbar-inner {\n+ padding: 5px;\n+ }\n+ .navbar .container {\n+ width: auto;\n+ padding: 0;\n+ }\n+ .navbar .brand {\n+ padding-right: 10px;\n+ padding-left: 10px;\n+ margin: 0 0 0 -5px;\n+ }\n+ .nav-collapse {\n+ clear: both;\n+ }\n+ .nav-collapse .nav {\n+ float: none;\n+ margin: 0 0 10px;\n+ }\n+ .nav-collapse .nav > li {\n+ float: none;\n+ }\n+ .nav-collapse .nav > li > a {\n+ margin-bottom: 2px;\n+ }\n+ .nav-collapse .nav > .divider-vertical {\n+ display: none;\n+ }\n+ .nav-collapse .nav .nav-header {\n+ color: #777777;\n+ text-shadow: none;\n+ }\n+ .nav-collapse .nav > li > a,\n+ .nav-collapse .dropdown-menu a {\n+ padding: 9px 15px;\n+ font-weight: bold;\n+ color: #777777;\n+ -webkit-border-radius: 3px;\n+ -moz-border-radius: 3px;\n+ border-radius: 3px;\n+ }\n+ .nav-collapse .btn {\n+ padding: 4px 10px 4px;\n+ font-weight: normal;\n+ -webkit-border-radius: 4px;\n+ -moz-border-radius: 4px;\n+ border-radius: 4px;\n+ }\n+ .nav-collapse .dropdown-menu li + li a {\n+ margin-bottom: 2px;\n+ }\n+ .nav-collapse .nav > li > a:hover,\n+ .nav-collapse .nav > li > a:focus,\n+ .nav-collapse .dropdown-menu a:hover,\n+ .nav-collapse .dropdown-menu a:focus {\n+ background-color: #f2f2f2;\n+ }\n+ .navbar-inverse .nav-collapse .nav > li > a,\n+ .navbar-inverse .nav-collapse .dropdown-menu a {\n+ color: #999999;\n+ }\n+ .navbar-inverse .nav-collapse .nav > li > a:hover,\n+ .navbar-inverse .nav-collapse .nav > li > a:focus,\n+ .navbar-inverse .nav-collapse .dropdown-menu a:hover,\n+ .navbar-inverse .nav-collapse .dropdown-menu a:focus {\n+ background-color: #111111;\n+ }\n+ .nav-collapse.in .btn-group {\n+ padding: 0;\n+ margin-top: 5px;\n+ }\n+ .nav-collapse .dropdown-menu {\n+ position: static;\n+ top: auto;\n+ left: auto;\n+ display: none;\n+ float: none;\n+ max-width: none;\n+ padding: 0;\n+ margin: 0 15px;\n+ background-color: transparent;\n+ border: none;\n+ -webkit-border-radius: 0;\n+ -moz-border-radius: 0;\n+ border-radius: 0;\n+ -webkit-box-shadow: none;\n+ -moz-box-shadow: none;\n+ box-shadow: none;\n+ }\n+ .nav-collapse .open > .dropdown-menu {\n+ display: block;\n+ }\n+ .nav-collapse .dropdown-menu:before,\n+ .nav-collapse .dropdown-menu:after {\n+ display: none;\n+ }\n+ .nav-collapse .dropdown-menu .divider {\n+ display: none;\n+ }\n+ .nav-collapse .nav > li > .dropdown-menu:before,\n+ .nav-collapse .nav > li > .dropdown-menu:after {\n+ display: none;\n+ }\n+ .nav-collapse .navbar-form,\n+ .nav-collapse .navbar-search {\n+ float: none;\n+ padding: 10px 15px;\n+ margin: 10px 0;\n+ border-top: 1px solid #f2f2f2;\n+ border-bottom: 1px solid #f2f2f2;\n+ -webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.1), 0 1px 0 rgba(255, 255, 255, 0.1);\n+ -moz-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.1), 0 1px 0 rgba(255, 255, 255, 0.1);\n+ box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.1), 0 1px 0 rgba(255, 255, 255, 0.1);\n+ }\n+ .navbar-inverse .nav-collapse .navbar-form,\n+ .navbar-inverse .nav-collapse .navbar-search {\n+ border-top-color: #111111;\n+ border-bottom-color: #111111;\n+ }\n+ .navbar .nav-collapse .nav.pull-right {\n+ float: none;\n+ margin-left: 0;\n+ }\n+ .nav-collapse,\n+ .nav-collapse.collapse {\n+ height: 0;\n+ overflow: hidden;\n+ }\n+ .navbar .btn-navbar {\n+ display: block;\n+ }\n+ .navbar-static .navbar-inner {\n+ padding-right: 10px;\n+ padding-left: 10px;\n+ }\n+}\n+\n+@media (min-width: 980px) {\n+ .nav-collapse.collapse {\n+ height: auto !important;\n+ overflow: visible !important;\n+ }\n+}\n' |
b |
diff -r 000000000000 -r 198009598544 bin/css/bootstrap-table.css --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/bin/css/bootstrap-table.css Wed Oct 11 09:57:58 2017 -0400 |
[ |
@@ -0,0 +1,313 @@ +/** + * @author zhixin wen <wenzhixin2010@gmail.com> + * version: 1.11.1 + * https://github.com/wenzhixin/bootstrap-table/ + */ + +.bootstrap-table .table { + margin-bottom: 0 !important; + border-bottom: 1px solid #dddddd; + border-collapse: collapse !important; + border-radius: 1px; +} + +.bootstrap-table .table:not(.table-condensed), +.bootstrap-table .table:not(.table-condensed) > tbody > tr > th, +.bootstrap-table .table:not(.table-condensed) > tfoot > tr > th, +.bootstrap-table .table:not(.table-condensed) > thead > tr > td, +.bootstrap-table .table:not(.table-condensed) > tbody > tr > td, +.bootstrap-table .table:not(.table-condensed) > tfoot > tr > td { + padding: 8px; +} + +.bootstrap-table .table.table-no-bordered > thead > tr > th, +.bootstrap-table .table.table-no-bordered > tbody > tr > td { + border-right: 2px solid transparent; +} + +.bootstrap-table .table.table-no-bordered > tbody > tr > td:last-child { + border-right: none; +} + +.fixed-table-container { + position: relative; + clear: both; + border: 1px solid #dddddd; + border-radius: 4px; + -webkit-border-radius: 4px; + -moz-border-radius: 4px; +} + +.fixed-table-container.table-no-bordered { + border: 1px solid transparent; +} + +.fixed-table-footer, +.fixed-table-header { + overflow: hidden; +} + +.fixed-table-footer { + border-top: 1px solid #dddddd; +} + +.fixed-table-body { + overflow-x: auto; + overflow-y: auto; + height: 100%; +} + +.fixed-table-container table { + width: 100%; +} + +.fixed-table-container thead th { + height: 0; + padding: 0; + margin: 0; + border-left: 1px solid #dddddd; +} + +.fixed-table-container thead th:focus { + outline: 0 solid transparent; +} + +.fixed-table-container thead th:first-child { + border-left: none; + border-top-left-radius: 4px; + -webkit-border-top-left-radius: 4px; + -moz-border-radius-topleft: 4px; +} + +.fixed-table-container thead th .th-inner, +.fixed-table-container tbody td .th-inner { + padding: 8px; + line-height: 24px; + vertical-align: top; + overflow: hidden; + text-overflow: ellipsis; + white-space: nowrap; +} + +.fixed-table-container thead th .sortable { + cursor: pointer; + background-position: right; + background-repeat: no-repeat; + padding-right: 30px; +} + +.fixed-table-container thead th .both { + background-image: url(' QMQ5AQBCF4dWQSJxC5wwax1Cq1e7BAdxD5SL+Tq/QCM1oNiJidwox0355mXnG/DrEtIQ6azioNZQxI0ykPhTQIwhCR+BmBYtlK7kLJYwWCcJA9M4qdrZrd8pPjZWPtOqdRQy320YSV17OatFC4euts6z39GYMKRPCTKY9UnPQ6P+GtMRfGtPnBCiqhAeJPmkqAAAAAElFTkSuQmCC'); +} + +.fixed-table-container thead th .asc { + background-image: url(''); +} + +.fixed-table-container thead th .desc { + background-image: url(' '); +} + +.fixed-table-container th.detail { + width: 30px; +} + +.fixed-table-container tbody td { + border-left: 1px solid #dddddd; +} + +.fixed-table-container tbody tr:first-child td { + border-top: none; +} + +.fixed-table-container tbody td:first-child { + border-left: none; +} + +/* the same color with .active */ +.fixed-table-container tbody .selected td { + background-color: #f5f5f5; +} + +.fixed-table-container .bs-checkbox { + text-align: center; +} + +.fixed-table-container .bs-checkbox .th-inner { + padding: 8px 0; +} + +.fixed-table-container input[type="radio"], +.fixed-table-container input[type="checkbox"] { + margin: 0 auto !important; +} + +.fixed-table-container .no-records-found { + text-align: center; +} + +.fixed-table-pagination div.pagination, +.fixed-table-pagination .pagination-detail { + margin-top: 10px; + margin-bottom: 10px; +} + +.fixed-table-pagination div.pagination .pagination { + margin: 0; +} + +.fixed-table-pagination .pagination a { + padding: 6px 12px; + line-height: 1.428571429; +} + +.fixed-table-pagination .pagination-info { + line-height: 34px; + margin-right: 5px; +} + +.fixed-table-pagination .btn-group { + position: relative; + display: inline-block; + vertical-align: middle; +} + +.fixed-table-pagination .dropup .dropdown-menu { + margin-bottom: 0; +} + +.fixed-table-pagination .page-list { + display: inline-block; +} + +.fixed-table-toolbar .columns-left { + margin-right: 5px; +} + +.fixed-table-toolbar .columns-right { + margin-left: 5px; +} + +.fixed-table-toolbar .columns label { + display: block; + padding: 3px 20px; + clear: both; + font-weight: normal; + line-height: 1.428571429; +} + +.fixed-table-toolbar .bs-bars, +.fixed-table-toolbar .search, +.fixed-table-toolbar .columns { + position: relative; + margin-top: 10px; + margin-bottom: 10px; + line-height: 34px; +} + +.fixed-table-pagination li.disabled a { + pointer-events: none; + cursor: default; +} + +.fixed-table-loading { + display: none; + position: absolute; + top: 42px; + right: 0; + bottom: 0; + left: 0; + z-index: 99; + background-color: #fff; + text-align: center; +} + +.fixed-table-body .card-view .title { + font-weight: bold; + display: inline-block; + min-width: 30%; + text-align: left !important; +} + +/* support bootstrap 2 */ +.fixed-table-body thead th .th-inner { + box-sizing: border-box; +} + +.table th, .table td { + vertical-align: middle; + box-sizing: border-box; +} + +.fixed-table-toolbar .dropdown-menu { + text-align: left; + max-height: 300px; + overflow: auto; +} + +.fixed-table-toolbar .btn-group > .btn-group { + display: inline-block; + margin-left: -1px !important; +} + +.fixed-table-toolbar .btn-group > .btn-group > .btn { + border-radius: 0; +} + +.fixed-table-toolbar .btn-group > .btn-group:first-child > .btn { + border-top-left-radius: 4px; + border-bottom-left-radius: 4px; +} + +.fixed-table-toolbar .btn-group > .btn-group:last-child > .btn { + border-top-right-radius: 4px; + border-bottom-right-radius: 4px; +} + +.bootstrap-table .table > thead > tr > th { + vertical-align: bottom; + border-bottom: 1px solid #ddd; +} + +/* support bootstrap 3 */ +.bootstrap-table .table thead > tr > th { + padding: 0; + margin: 0; +} + +.bootstrap-table .fixed-table-footer tbody > tr > td { + padding: 0 !important; +} + +.bootstrap-table .fixed-table-footer .table { + border-bottom: none; + border-radius: 0; + padding: 0 !important; +} + +.bootstrap-table .pull-right .dropdown-menu { + right: 0; + left: auto; +} + +/* calculate scrollbar width */ +p.fixed-table-scroll-inner { + width: 100%; + height: 200px; +} + +div.fixed-table-scroll-outer { + top: 0; + left: 0; + visibility: hidden; + width: 200px; + height: 150px; + overflow: hidden; +} + +/* for get correct heights */ +.fixed-table-toolbar:after, .fixed-table-pagination:after { + content: ""; + display: block; + clear: both; +} |
b |
diff -r 000000000000 -r 198009598544 bin/css/bootstrap-table.js --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/bin/css/bootstrap-table.js Wed Oct 11 09:57:58 2017 -0400 |
[ |
b"@@ -0,0 +1,3094 @@\n+/**\n+ * @author zhixin wen <wenzhixin2010@gmail.com>\n+ * version: 1.11.1\n+ * https://github.com/wenzhixin/bootstrap-table/\n+ */\n+\n+(function ($) {\n+ 'use strict';\n+\n+ // TOOLS DEFINITION\n+ // ======================\n+\n+ var cachedWidth = null;\n+\n+ // it only does '%s', and return '' when arguments are undefined\n+ var sprintf = function (str) {\n+ var args = arguments,\n+ flag = true,\n+ i = 1;\n+\n+ str = str.replace(/%s/g, function () {\n+ var arg = args[i++];\n+\n+ if (typeof arg === 'undefined') {\n+ flag = false;\n+ return '';\n+ }\n+ return arg;\n+ });\n+ return flag ? str : '';\n+ };\n+\n+ var getPropertyFromOther = function (list, from, to, value) {\n+ var result = '';\n+ $.each(list, function (i, item) {\n+ if (item[from] === value) {\n+ result = item[to];\n+ return false;\n+ }\n+ return true;\n+ });\n+ return result;\n+ };\n+\n+ var getFieldIndex = function (columns, field) {\n+ var index = -1;\n+\n+ $.each(columns, function (i, column) {\n+ if (column.field === field) {\n+ index = i;\n+ return false;\n+ }\n+ return true;\n+ });\n+ return index;\n+ };\n+\n+ // http://jsfiddle.net/wenyi/47nz7ez9/3/\n+ var setFieldIndex = function (columns) {\n+ var i, j, k,\n+ totalCol = 0,\n+ flag = [];\n+\n+ for (i = 0; i < columns[0].length; i++) {\n+ totalCol += columns[0][i].colspan || 1;\n+ }\n+\n+ for (i = 0; i < columns.length; i++) {\n+ flag[i] = [];\n+ for (j = 0; j < totalCol; j++) {\n+ flag[i][j] = false;\n+ }\n+ }\n+\n+ for (i = 0; i < columns.length; i++) {\n+ for (j = 0; j < columns[i].length; j++) {\n+ var r = columns[i][j],\n+ rowspan = r.rowspan || 1,\n+ colspan = r.colspan || 1,\n+ index = $.inArray(false, flag[i]);\n+\n+ if (colspan === 1) {\n+ r.fieldIndex = index;\n+ // when field is undefined, use index instead\n+ if (typeof r.field === 'undefined') {\n+ r.field = index;\n+ }\n+ }\n+\n+ for (k = 0; k < rowspan; k++) {\n+ flag[i + k][index] = true;\n+ }\n+ for (k = 0; k < colspan; k++) {\n+ flag[i][index + k] = true;\n+ }\n+ }\n+ }\n+ };\n+\n+ var getScrollBarWidth = function () {\n+ if (cachedWidth === null) {\n+ var inner = $('<p/>').addClass('fixed-table-scroll-inner'),\n+ outer = $('<div/>').addClass('fixed-table-scroll-outer'),\n+ w1, w2;\n+\n+ outer.append(inner);\n+ $('body').append(outer);\n+\n+ w1 = inner[0].offsetWidth;\n+ outer.css('overflow', 'scroll');\n+ w2 = inner[0].offsetWidth;\n+\n+ if (w1 === w2) {\n+ w2 = outer[0].clientWidth;\n+ }\n+\n+ outer.remove();\n+ cachedWidth = w1 - w2;\n+ }\n+ return cachedWidth;\n+ };\n+\n+ var calculateObjectValue = function (self, name, args, defaultValue) {\n+ var func = name;\n+\n+ if (typeof name === 'string') {\n+ // support obj.func1.func2\n+ var names = name.split('.');\n+\n+ if (names.length > 1) {\n+ func = window;\n+ $.each(names, function (i, f) {\n+ func = func[f];\n+ });\n+ } else {\n+ func = window[name];\n+ }\n+ }\n+ if (typeof func === 'object') {\n+ return func;\n+ }\n+ if (typeof func === 'function') {\n+"..b' i < trs.length; i++) {\n+ this.expandRow_(true, $(trs[i]).data("index"));\n+ }\n+ }\n+ };\n+\n+ BootstrapTable.prototype.collapseAllRows = function (isSubTable) {\n+ if (isSubTable) {\n+ this.expandRow_(false, 0);\n+ } else {\n+ var trs = this.$body.children();\n+ for (var i = 0; i < trs.length; i++) {\n+ this.expandRow_(false, $(trs[i]).data("index"));\n+ }\n+ }\n+ };\n+\n+ BootstrapTable.prototype.updateFormatText = function (name, text) {\n+ if (this.options[sprintf(\'format%s\', name)]) {\n+ if (typeof text === \'string\') {\n+ this.options[sprintf(\'format%s\', name)] = function () {\n+ return text;\n+ };\n+ } else if (typeof text === \'function\') {\n+ this.options[sprintf(\'format%s\', name)] = text;\n+ }\n+ }\n+ this.initToolbar();\n+ this.initPagination();\n+ this.initBody();\n+ };\n+\n+ // BOOTSTRAP TABLE PLUGIN DEFINITION\n+ // =======================\n+\n+ var allowedMethods = [\n+ \'getOptions\',\n+ \'getSelections\', \'getAllSelections\', \'getData\',\n+ \'load\', \'append\', \'prepend\', \'remove\', \'removeAll\',\n+ \'insertRow\', \'updateRow\', \'updateCell\', \'updateByUniqueId\', \'removeByUniqueId\',\n+ \'getRowByUniqueId\', \'showRow\', \'hideRow\', \'getHiddenRows\',\n+ \'mergeCells\',\n+ \'checkAll\', \'uncheckAll\', \'checkInvert\',\n+ \'check\', \'uncheck\',\n+ \'checkBy\', \'uncheckBy\',\n+ \'refresh\',\n+ \'resetView\',\n+ \'resetWidth\',\n+ \'destroy\',\n+ \'showLoading\', \'hideLoading\',\n+ \'showColumn\', \'hideColumn\', \'getHiddenColumns\', \'getVisibleColumns\',\n+ \'showAllColumns\', \'hideAllColumns\',\n+ \'filterBy\',\n+ \'scrollTo\',\n+ \'getScrollPosition\',\n+ \'selectPage\', \'prevPage\', \'nextPage\',\n+ \'togglePagination\',\n+ \'toggleView\',\n+ \'refreshOptions\',\n+ \'resetSearch\',\n+ \'expandRow\', \'collapseRow\', \'expandAllRows\', \'collapseAllRows\',\n+ \'updateFormatText\'\n+ ];\n+\n+ $.fn.bootstrapTable = function (option) {\n+ var value,\n+ args = Array.prototype.slice.call(arguments, 1);\n+\n+ this.each(function () {\n+ var $this = $(this),\n+ data = $this.data(\'bootstrap.table\'),\n+ options = $.extend({}, BootstrapTable.DEFAULTS, $this.data(),\n+ typeof option === \'object\' && option);\n+\n+ if (typeof option === \'string\') {\n+ if ($.inArray(option, allowedMethods) < 0) {\n+ throw new Error("Unknown method: " + option);\n+ }\n+\n+ if (!data) {\n+ return;\n+ }\n+\n+ value = data[option].apply(data, args);\n+\n+ if (option === \'destroy\') {\n+ $this.removeData(\'bootstrap.table\');\n+ }\n+ }\n+\n+ if (!data) {\n+ $this.data(\'bootstrap.table\', (data = new BootstrapTable(this, options)));\n+ }\n+ });\n+\n+ return typeof value === \'undefined\' ? this : value;\n+ };\n+\n+ $.fn.bootstrapTable.Constructor = BootstrapTable;\n+ $.fn.bootstrapTable.defaults = BootstrapTable.DEFAULTS;\n+ $.fn.bootstrapTable.columnDefaults = BootstrapTable.COLUMN_DEFAULTS;\n+ $.fn.bootstrapTable.locales = BootstrapTable.LOCALES;\n+ $.fn.bootstrapTable.methods = allowedMethods;\n+ $.fn.bootstrapTable.utils = {\n+ sprintf: sprintf,\n+ getFieldIndex: getFieldIndex,\n+ compareObjects: compareObjects,\n+ calculateObjectValue: calculateObjectValue,\n+ getItemField: getItemField,\n+ objectKeys: objectKeys,\n+ isIEBrowser: isIEBrowser\n+ };\n+\n+ // BOOTSTRAP TABLE INIT\n+ // =======================\n+\n+ $(function () {\n+ $(\'[data-toggle="table"]\').bootstrapTable();\n+ });\n+})(jQuery);\n' |
b |
diff -r 000000000000 -r 198009598544 bin/css/bootstrap.css --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/bin/css/bootstrap.css Wed Oct 11 09:57:58 2017 -0400 |
[ |
b'@@ -0,0 +1,6167 @@\n+/*!\n+ * Bootstrap v2.3.2\n+ *\n+ * Copyright 2012 Twitter, Inc\n+ * Licensed under the Apache License v2.0\n+ * http://www.apache.org/licenses/LICENSE-2.0\n+ *\n+ * Designed and built with all the love in the world @twitter by @mdo and @fat.\n+ */\n+\n+.clearfix {\n+ *zoom: 1;\n+}\n+\n+.clearfix:before,\n+.clearfix:after {\n+ display: table;\n+ line-height: 0;\n+ content: "";\n+}\n+\n+.clearfix:after {\n+ clear: both;\n+}\n+\n+.hide-text {\n+ font: 0/0 a;\n+ color: transparent;\n+ text-shadow: none;\n+ background-color: transparent;\n+ border: 0;\n+}\n+\n+.input-block-level {\n+ display: block;\n+ width: 100%;\n+ min-height: 30px;\n+ -webkit-box-sizing: border-box;\n+ -moz-box-sizing: border-box;\n+ box-sizing: border-box;\n+}\n+\n+article,\n+aside,\n+details,\n+figcaption,\n+figure,\n+footer,\n+header,\n+hgroup,\n+nav,\n+section {\n+ display: block;\n+}\n+\n+audio,\n+canvas,\n+video {\n+ display: inline-block;\n+ *display: inline;\n+ *zoom: 1;\n+}\n+\n+audio:not([controls]) {\n+ display: none;\n+}\n+\n+html {\n+ font-size: 100%;\n+ -webkit-text-size-adjust: 100%;\n+ -ms-text-size-adjust: 100%;\n+}\n+\n+a:focus {\n+ outline: thin dotted #333;\n+ outline: 5px auto -webkit-focus-ring-color;\n+ outline-offset: -2px;\n+}\n+\n+a:hover,\n+a:active {\n+ outline: 0;\n+}\n+\n+sub,\n+sup {\n+ position: relative;\n+ font-size: 75%;\n+ line-height: 0;\n+ vertical-align: baseline;\n+}\n+\n+sup {\n+ top: -0.5em;\n+}\n+\n+sub {\n+ bottom: -0.25em;\n+}\n+\n+img {\n+ width: auto\\9;\n+ height: auto;\n+ max-width: 100%;\n+ vertical-align: middle;\n+ border: 0;\n+ -ms-interpolation-mode: bicubic;\n+}\n+\n+#map_canvas img,\n+.google-maps img {\n+ max-width: none;\n+}\n+\n+button,\n+input,\n+select,\n+textarea {\n+ margin: 0;\n+ font-size: 100%;\n+ vertical-align: middle;\n+}\n+\n+button,\n+input {\n+ *overflow: visible;\n+ line-height: normal;\n+}\n+\n+button::-moz-focus-inner,\n+input::-moz-focus-inner {\n+ padding: 0;\n+ border: 0;\n+}\n+\n+button,\n+html input[type="button"],\n+input[type="reset"],\n+input[type="submit"] {\n+ cursor: pointer;\n+ -webkit-appearance: button;\n+}\n+\n+label,\n+select,\n+button,\n+input[type="button"],\n+input[type="reset"],\n+input[type="submit"],\n+input[type="radio"],\n+input[type="checkbox"] {\n+ cursor: pointer;\n+}\n+\n+input[type="search"] {\n+ -webkit-box-sizing: content-box;\n+ -moz-box-sizing: content-box;\n+ box-sizing: content-box;\n+ -webkit-appearance: textfield;\n+}\n+\n+input[type="search"]::-webkit-search-decoration,\n+input[type="search"]::-webkit-search-cancel-button {\n+ -webkit-appearance: none;\n+}\n+\n+textarea {\n+ overflow: auto;\n+ vertical-align: top;\n+}\n+\n+@media print {\n+ * {\n+ color: #000 !important;\n+ text-shadow: none !important;\n+ background: transparent !important;\n+ box-shadow: none !important;\n+ }\n+ a,\n+ a:visited {\n+ text-decoration: underline;\n+ }\n+ a[href]:after {\n+ content: " (" attr(href) ")";\n+ }\n+ abbr[title]:after {\n+ content: " (" attr(title) ")";\n+ }\n+ .ir a:after,\n+ a[href^="javascript:"]:after,\n+ a[href^="#"]:after {\n+ content: "";\n+ }\n+ pre,\n+ blockquote {\n+ border: 1px solid #999;\n+ page-break-inside: avoid;\n+ }\n+ thead {\n+ display: table-header-group;\n+ }\n+ tr,\n+ img {\n+ page-break-inside: avoid;\n+ }\n+ img {\n+ max-width: 100% !important;\n+ }\n+ @page {\n+ margin: 0.5cm;\n+ }\n+ p,\n+ h2,\n+ h3 {\n+ orphans: 3;\n+ widows: 3;\n+ }\n+ h2,\n+ h3 {\n+ page-break-after: avoid;\n+ }\n+}\n+\n+body {\n+ margin: 0;\n+ font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;\n+ font-size: 14px;\n+ line-height: 20px;\n+ color: #333333;\n+ background-color: #ffffff;\n+}\n+\n+a {\n+ color: #0088cc;\n+ text-decoration: none;\n+}\n+\n+a:hover,\n+a:focus {\n+ color: #005580;\n+ text-decoration: underline;\n+}\n+\n+.img-rounded {\n+ -webkit-border-radius: 6px;\n+ -moz-border-radius: 6px;\n+ border-radius: 6px;\n+}\n+\n+.img-polaroid {\n+ padding: 4px;\n+ background-color: #fff;\n+ border: 1px solid #ccc;\n+ border: 1px solid rgba(0, 0, 0, 0.2);\n+ -webkit-box-shadow: 0 1px 3'..b', 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);\n+ background-image: linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);\n+}\n+\n+.accordion {\n+ margin-bottom: 20px;\n+}\n+\n+.accordion-group {\n+ margin-bottom: 2px;\n+ border: 1px solid #e5e5e5;\n+ -webkit-border-radius: 4px;\n+ -moz-border-radius: 4px;\n+ border-radius: 4px;\n+}\n+\n+.accordion-heading {\n+ border-bottom: 0;\n+}\n+\n+.accordion-heading .accordion-toggle {\n+ display: block;\n+ padding: 8px 15px;\n+}\n+\n+.accordion-toggle {\n+ cursor: pointer;\n+}\n+\n+.accordion-inner {\n+ padding: 9px 15px;\n+ border-top: 1px solid #e5e5e5;\n+}\n+\n+.carousel {\n+ position: relative;\n+ margin-bottom: 20px;\n+ line-height: 1;\n+}\n+\n+.carousel-inner {\n+ position: relative;\n+ width: 100%;\n+ overflow: hidden;\n+}\n+\n+.carousel-inner > .item {\n+ position: relative;\n+ display: none;\n+ -webkit-transition: 0.6s ease-in-out left;\n+ -moz-transition: 0.6s ease-in-out left;\n+ -o-transition: 0.6s ease-in-out left;\n+ transition: 0.6s ease-in-out left;\n+}\n+\n+.carousel-inner > .item > img,\n+.carousel-inner > .item > a > img {\n+ display: block;\n+ line-height: 1;\n+}\n+\n+.carousel-inner > .active,\n+.carousel-inner > .next,\n+.carousel-inner > .prev {\n+ display: block;\n+}\n+\n+.carousel-inner > .active {\n+ left: 0;\n+}\n+\n+.carousel-inner > .next,\n+.carousel-inner > .prev {\n+ position: absolute;\n+ top: 0;\n+ width: 100%;\n+}\n+\n+.carousel-inner > .next {\n+ left: 100%;\n+}\n+\n+.carousel-inner > .prev {\n+ left: -100%;\n+}\n+\n+.carousel-inner > .next.left,\n+.carousel-inner > .prev.right {\n+ left: 0;\n+}\n+\n+.carousel-inner > .active.left {\n+ left: -100%;\n+}\n+\n+.carousel-inner > .active.right {\n+ left: 100%;\n+}\n+\n+.carousel-control {\n+ position: absolute;\n+ top: 40%;\n+ left: 15px;\n+ width: 40px;\n+ height: 40px;\n+ margin-top: -20px;\n+ font-size: 60px;\n+ font-weight: 100;\n+ line-height: 30px;\n+ color: #ffffff;\n+ text-align: center;\n+ background: #222222;\n+ border: 3px solid #ffffff;\n+ -webkit-border-radius: 23px;\n+ -moz-border-radius: 23px;\n+ border-radius: 23px;\n+ opacity: 0.5;\n+ filter: alpha(opacity=50);\n+}\n+\n+.carousel-control.right {\n+ right: 15px;\n+ left: auto;\n+}\n+\n+.carousel-control:hover,\n+.carousel-control:focus {\n+ color: #ffffff;\n+ text-decoration: none;\n+ opacity: 0.9;\n+ filter: alpha(opacity=90);\n+}\n+\n+.carousel-indicators {\n+ position: absolute;\n+ top: 15px;\n+ right: 15px;\n+ z-index: 5;\n+ margin: 0;\n+ list-style: none;\n+}\n+\n+.carousel-indicators li {\n+ display: block;\n+ float: left;\n+ width: 10px;\n+ height: 10px;\n+ margin-left: 5px;\n+ text-indent: -999px;\n+ background-color: #ccc;\n+ background-color: rgba(255, 255, 255, 0.25);\n+ border-radius: 5px;\n+}\n+\n+.carousel-indicators .active {\n+ background-color: #fff;\n+}\n+\n+.carousel-caption {\n+ position: absolute;\n+ right: 0;\n+ bottom: 0;\n+ left: 0;\n+ padding: 15px;\n+ background: #333333;\n+ background: rgba(0, 0, 0, 0.75);\n+}\n+\n+.carousel-caption h4,\n+.carousel-caption p {\n+ line-height: 20px;\n+ color: #ffffff;\n+}\n+\n+.carousel-caption h4 {\n+ margin: 0 0 5px;\n+}\n+\n+.carousel-caption p {\n+ margin-bottom: 0;\n+}\n+\n+.hero-unit {\n+ padding: 60px;\n+ margin-bottom: 30px;\n+ font-size: 18px;\n+ font-weight: 200;\n+ line-height: 30px;\n+ color: inherit;\n+ background-color: #eeeeee;\n+ -webkit-border-radius: 6px;\n+ -moz-border-radius: 6px;\n+ border-radius: 6px;\n+}\n+\n+.hero-unit h1 {\n+ margin-bottom: 0;\n+ font-size: 60px;\n+ line-height: 1;\n+ letter-spacing: -1px;\n+ color: inherit;\n+}\n+\n+.hero-unit li {\n+ line-height: 30px;\n+}\n+\n+.pull-right {\n+ float: right;\n+}\n+\n+.pull-left {\n+ float: left;\n+}\n+\n+.hide {\n+ display: none;\n+}\n+\n+.show {\n+ display: block;\n+}\n+\n+.invisible {\n+ visibility: hidden;\n+}\n+\n+.affix {\n+ position: fixed;\n+}\n' |
b |
diff -r 000000000000 -r 198009598544 bin/html.pm --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/bin/html.pm Wed Oct 11 09:57:58 2017 -0400 |
[ |
b'@@ -0,0 +1,901 @@\n+package html;\n+\n+use strict;\n+use warnings;\n+use File::Basename;\n+\n+use Exporter;\n+our @ISA = qw( Exporter );\n+our @EXPORT_OK = qw( &main_page &details_pages &menu_page &ppp_page );\n+\n+sub main_page\n+{\n+\tmy ( $dir, $file, $list_mainTabP, $current, $ma, $ma_uni, $dir_root ) = @_;\n+\tmy ( $futHashP, $uniqueTabP, $randTabP, $pngTabP ) = get_genome ( $dir, $dir_root );\n+\n+\topen my $h, \'>\', $file || die "cannot create $file $!\\n";\n+\theader ( $h );\n+\tnavbar ( $h, $list_mainTabP, $current );\n+\tprint $h "<div class=\\"container\\"><p><a class=\\"btn\\" href=\\"$current-sub.html\\">View details »</a></p></div>\\n";\n+\tfuturette( $h, $current, $pngTabP, $futHashP );\n+\tprint $h "<div class=\\"container\\"><h2>mappers #: $ma</h2><h2>unique mappers #: $ma_uni</h2> </div>\\n";\n+\tcarousel2( $h, $uniqueTabP, $randTabP, $dir_root );\n+\tfooter($h);\n+\tclose $h;\n+}\n+\n+sub menu_page\n+{\n+\tmy ( $dir, $file, $list_mainTabP, $current, $min, $max, $simin, $simax, $pimin, $pimax, $dir_root ) = @_;\n+ my $html_ref = $1 if $dir =~ /$dir_root(.*)/;\n+\topen my $h, \'>\', $file || die "cannot create $file $!\\n";\n+ header($h);\n+ navbar ( $h, $list_mainTabP, $current );\n+ span( $h, $current, $min, $max, $simin, $simax, $pimin, $pimax );\n+ print $h " <div class=\\"container\\"> <div class=\\"row text-center\\"> <img src=\\"$html_ref/pie_chart.png\\"/><br />\\n";\n+ print $h " <A HREF=\\"$html_ref/repartition.txt\\">text file</A><br/>\\n </div></div>";\n+ footer($h);\n+ close $h;\n+}\n+\n+sub details_pages\n+{\n+\tmy ( $dir_details, $prefix, $list_mainTabP, $current, $misTE, $dir_root ) = @_;\n+ my ($Hex, $HTE, $HG, $NonUniTE, $NonUniG, $UniG ) = get_subgroups( $dir_details, $current, $misTE, $dir_root );\n+\n+ my $html_ref = $1.\'-PPP.html\' if $prefix =~ /$dir_root(.*)/;\n+ open my $h, \'>\', $prefix.\'-TEs.html\' || die "cannot create $prefix-TEs.html $!\\n";\n+ header($h);\n+ navbar ( $h, $list_mainTabP, $current );\n+ if ( $prefix =~ /bonafide_reads$/ )\n+ {\n+ \tprint $h " <div class=\\"container\\">";\n+ \tprint $h " <p><a class=\\"btn\\" href=\\"$html_ref\\">Ping Pong Partners</a></p>\\n";\n+ \tprint $h "</div>";\n+ }\n+ fut($h,\'Transposable elements\',$HTE);\n+ carousel($h,$NonUniTE,$dir_root);\n+ footer($h);\n+ close $h;\n+\n+ open $h, \'>\', $prefix.\'-genome.html\' || die "cannot create $prefix-genome.html $!\\n";\n+ header($h);\n+ navbar ( $h, $list_mainTabP, $current );\n+ fut($h,\'Genome\',$HG);\n+ carousel2($h,$UniG, $NonUniG,$dir_root);\n+ footer($h);\n+ close $h;\n+\n+ open $h, \'>\', $prefix.\'-exons.html\' || die "cannot create $prefix-exons.html $!\\n";\n+ header($h);\n+ navbar ( $h, $list_mainTabP, $current );\n+ fut($h,\'Exons\',$Hex);\n+ footer($h);\n+ close $h;\n+}\n+\n+sub ppp_page\n+{\n+\tmy ( $dir, $file, $list_mainTabP, $current, $ppp, $dir_root ) = @_;\n+\n+\tmy $ppp_file = $ppp.\'ppp.txt\';\n+\topen my $h, \'>\', $file || die "cannot create $file $!\\n";\n+\theader($h);\n+ \tnavbar ( $h, $list_mainTabP, $current );\n+ \tprint $h \'<div class="container"> <table class="wb-tables table table-striped table-hover">\'."\\n";\n+ \tprint $h \'<thead>\n+ <tr>\n+ <th data-sortable="true">ID</th>\n+ <th data-sortable="true">overlap sum</th>\n+ <th data-sortable="true">ten overlap sum</th>\n+ <th data-sortable="true">mean</th>\n+ <th data-sortable="true">standard deviation</th>\n+ \t<th data-sortable="true">z-score</th>\n+ \t<th data-sortable="true">p-value</th>\n+\t</tr>\n+ </thead>\n+ <tbody>\';\n+\n+ \topen my $f, \'<\', $ppp_file || die "cannot open $ppp_file $!\\n";\n+ \twhile ( <$f> )\n+ \t{\n+ \t\tchomp;\n+ \t\tprint $h \'<tr>\';\n+ \t\tmy ( $id, $sum, $ten, $mean, $sd, $zscore, $prob) = split /\\t/, $_;\n+ \t\tif( -d "$ppp/$id" ) \n+ \t\t{\n+ \t\t\tmy $sub_html = $ppp.$id.\'.html\';\n+ my $sub_html_ref = $1.$id if $ppp =~ /$dir_root(.*)/;\n+ \t\t\tprint $h "<td> <a href=\\"$sub_html_ref.html\\">$id</a> </td>";\n+\n+ \t\t\topen my $sub, \'>\', $sub_html || die "cannot create $sub_html\\n";\n+ \t\t\t{\n+ \t\t\t\theader($sub);\n+ \t\t\t\tprint $sub "\n+\t\t\t\t\t<div align=\\"center\\">\n+\t\t\t\t\t<h2>$id</h2>\n+\t\t\t\t\t<p> <img src=\\"$id/histogram.png\\" wi'..b'stri_TE\n+{\n+ my ($dir, $name) = @_;\n+ my (@out,@group);\n+ my $group = $dir.\'/\'.$name.\'-subgroups-bonafide_reads-TE-*distribution-*.png\';\n+ @group = glob $group;\n+ foreach (my $g =0; $g <= $#group; $g++)\n+ {\n+ if ($group[$g] =~ /.*($name-subgroups-bonafide_reads-TE-.*distribution-.*\\.png)/ )\n+ {\n+ my $tmp = $1;\n+ push @out, $1;\n+ }\n+ }\n+ return (\\@out);\n+}\n+\n+sub get_PPP\n+{\n+ my ($dir,$name) = @_;\n+ my (%distri,@group);\n+ my $group = $dir.\'/\'.$name.\'-subgroups-bonafide_reads-TE-PPPartners-*\';\n+ @group = glob $group;\n+ \n+ foreach (my $g =0; $g <= $#group; $g++)\n+ {\n+ if ($group[$g] =~ /.*($name-subgroups-bonafide_reads-TE-PPPartners-.*)/ )\n+ {\n+ my $tmp = $1;\n+ if ($tmp =~ /PPPartners-(.*?)-sens\\.txt$/)\n+ {\n+ $distri{$1} = [\'\',\'\',\'\',\'\',\'\',\'\'] unless exists $distri{$1};\n+ $distri{$1}->[0] = $tmp;\n+ }\n+ elsif ($tmp =~ /PPPartners-(.*?)-antisens\\.txt$/)\n+ {\n+ $distri{$1} = [\'\',\'\',\'\',\'\',\'\',\'\'] unless exists $distri{$1};\n+ $distri{$1}->[1] = $tmp;\n+ }\n+ elsif ($tmp =~ /PPPartners-(.*?)-sensPPP\\.txt$/)\n+ {\n+ $distri{$1} = [\'\',\'\',\'\',\'\',\'\',\'\'] unless exists $distri{$1};\n+ $distri{$1}->[2] = $tmp;\n+ }\n+ elsif ($tmp =~ /PPPartners-(.*?)-antisensPPP\\.txt$/)\n+ {\n+ $distri{$1} = [\'\',\'\',\'\',\'\',\'\',\'\'] unless exists $distri{$1};\n+ $distri{$1}->[3] = $tmp;\n+ }\n+ elsif ($tmp =~ /PPPartners-(.*?)-overlap_size\\.txt$/)\n+ {\n+ $distri{$1} = [\'\',\'\',\'\',\'\',\'\',\'\'] unless exists $distri{$1};\n+ $distri{$1}->[4] = $tmp;\n+ }\n+ elsif ($tmp =~ /PPPartners-(.*?)-histogram\\.png$/)\n+ {\n+ $distri{$1} = [\'\',\'\',\'\',\'\',\'\',\'\'] unless exists $distri{$1};\n+ $distri{$1}->[5] = $tmp;\n+ }\n+ }\n+ }\n+ return \\%distri;\n+}\n+\n+sub PPPrint\n+{\n+ my ($h, $hash) = @_;\n+ my $cmp = 0;\n+ \n+ print $h "<div class=\\"container\\">\\n";\n+ print $h "<div class=\\"row text-center\\">";\n+ while ( my ($k,$v) = each %{$hash} )\n+ {\n+ print $h "</div><div class=\\"row text-center\\">" if $cmp != 0 && $cmp % 2 == 0;\n+ print $h "\n+ \n+ <div class=\\"span6\\">\n+ <h2>$k</h2>\n+ <p class=\\"featurette-p\\"> <img src=\\"$v->[5]\\"/></p>\n+ <p class=\\"featurette-p\\"><a href=\\"$v->[4]\\">ping pong signature</a></p>\n+ <p class=\\"featurette-p\\"><a href=\\"$v->[2]\\">sens reads with PPP</a></p>\n+ <p class=\\"featurette-p\\"><a href=\\"$v->[3]\\">reverse reads with PPP</a></p>\n+ <p class=\\"featurette-p\\"><a href=\\"$v->[0]\\">sens reads without PPP</a></p>\n+ <p class=\\"featurette-p\\"><a href=\\"$v->[1]\\">reverse reads without PPP</a></p>\n+ </div>\n+ ";\n+ $cmp++;\n+ }\n+ \n+ print $h "</div></div>";\n+}\n+\n+sub printDistri\n+{\n+ my ($h, $tab) = @_;\n+ my ($txt, $name);\n+ my $cmp = 0;\n+ print $h "<div class=\\"container\\">\\n";\n+ print $h "<div class=\\"row text-center\\">";\n+ foreach my $k (@{$tab})\n+ {\n+ if ($k =~ /(.*)-(.*)\\.png$/)\n+ {\n+ $txt = $1.\'-\'.$2.\'.txt\';\n+ $name = $2;\n+ }\n+ print $h "</div><div class=\\"row text-center\\">" if $cmp != 0 && $cmp % 2 == 0;\n+ print $h "\n+ \n+ <div class=\\"span6\\">\n+ <h2>$name</h2>\n+ <p> <img src=\\"$k\\"/></p>\n+ <p class=\\"featurette-p\\"><a href=\\"$txt\\">text file</a></p>\n+ </div>\n+ ";\n+ $cmp++;\n+ }\n+ \n+ print $h "</div></div>";\n+}\n+\n+sub mapnum\n+{\n+ my $dupmapnum = shift;\n+ my $dupnum_genome = shift;\n+ open (my $dupTE, $dupmapnum) || die "cannot open ".$dupmapnum."\\n";\n+ my %dupnum_TE = ();\n+ my $header = <$dupTE>;\n+ while (<$dupTE>)\n+ {\n+ chomp $_;\n+ my @dupline = split /\\t/, $_;\n+ $dupnum_TE{$dupline[0]} = $dupline[2];\n+ }\n+ close $dupTE;\n+ open (my $du_TE, \'>\'.$dupmapnum) || die "cannot open to write ".$dupmapnum."\\n";\n+ print $du_TE "sequence\\tduplicate\\tgenome map num\\tmap num\\n";\n+ while (my ($k, $v) = each %dupnum_TE )\n+ {\n+ my $hashRef = ${$dupnum_genome}{$k};\n+ print $du_TE "$k\\t$hashRef->[0]\\t$hashRef->[1]\\t$v\\n";\n+ }\n+ close $du_TE;\n+}\n+\n+1;\n' |
b |
diff -r 000000000000 -r 198009598544 bin/js/bootstrap.min.js --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/bin/js/bootstrap.min.js Wed Oct 11 09:57:58 2017 -0400 |
[ |
b'@@ -0,0 +1,6 @@\n+/**\n+* Bootstrap.js v2.3.2 by @fat & @mdo\n+* Copyright 2013 Twitter, Inc.\n+* http://www.apache.org/licenses/LICENSE-2.0.txt\n+*/\n+!function(e){"use strict";e(function(){e.support.transition=function(){var e=function(){var e=document.createElement("bootstrap"),t={WebkitTransition:"webkitTransitionEnd",MozTransition:"transitionend",OTransition:"oTransitionEnd otransitionend",transition:"transitionend"},n;for(n in t)if(e.style[n]!==undefined)return t[n]}();return e&&{end:e}}()})}(window.jQuery),!function(e){"use strict";var t=\'[data-dismiss="alert"]\',n=function(n){e(n).on("click",t,this.close)};n.prototype.close=function(t){function s(){i.trigger("closed").remove()}var n=e(this),r=n.attr("data-target"),i;r||(r=n.attr("href"),r=r&&r.replace(/.*(?=#[^\\s]*$)/,"")),i=e(r),t&&t.preventDefault(),i.length||(i=n.hasClass("alert")?n:n.parent()),i.trigger(t=e.Event("close"));if(t.isDefaultPrevented())return;i.removeClass("in"),e.support.transition&&i.hasClass("fade")?i.on(e.support.transition.end,s):s()};var r=e.fn.alert;e.fn.alert=function(t){return this.each(function(){var r=e(this),i=r.data("alert");i||r.data("alert",i=new n(this)),typeof t=="string"&&i[t].call(r)})},e.fn.alert.Constructor=n,e.fn.alert.noConflict=function(){return e.fn.alert=r,this},e(document).on("click.alert.data-api",t,n.prototype.close)}(window.jQuery),!function(e){"use strict";var t=function(t,n){this.$element=e(t),this.options=e.extend({},e.fn.button.defaults,n)};t.prototype.setState=function(e){var t="disabled",n=this.$element,r=n.data(),i=n.is("input")?"val":"html";e+="Text",r.resetText||n.data("resetText",n[i]()),n[i](r[e]||this.options[e]),setTimeout(function(){e=="loadingText"?n.addClass(t).attr(t,t):n.removeClass(t).removeAttr(t)},0)},t.prototype.toggle=function(){var e=this.$element.closest(\'[data-toggle="buttons-radio"]\');e&&e.find(".active").removeClass("active"),this.$element.toggleClass("active")};var n=e.fn.button;e.fn.button=function(n){return this.each(function(){var r=e(this),i=r.data("button"),s=typeof n=="object"&&n;i||r.data("button",i=new t(this,s)),n=="toggle"?i.toggle():n&&i.setState(n)})},e.fn.button.defaults={loadingText:"loading..."},e.fn.button.Constructor=t,e.fn.button.noConflict=function(){return e.fn.button=n,this},e(document).on("click.button.data-api","[data-toggle^=button]",function(t){var n=e(t.target);n.hasClass("btn")||(n=n.closest(".btn")),n.button("toggle")})}(window.jQuery),!function(e){"use strict";var t=function(t,n){this.$element=e(t),this.$indicators=this.$element.find(".carousel-indicators"),this.options=n,this.options.pause=="hover"&&this.$element.on("mouseenter",e.proxy(this.pause,this)).on("mouseleave",e.proxy(this.cycle,this))};t.prototype={cycle:function(t){return t||(this.paused=!1),this.interval&&clearInterval(this.interval),this.options.interval&&!this.paused&&(this.interval=setInterval(e.proxy(this.next,this),this.options.interval)),this},getActiveIndex:function(){return this.$active=this.$element.find(".item.active"),this.$items=this.$active.parent().children(),this.$items.index(this.$active)},to:function(t){var n=this.getActiveIndex(),r=this;if(t>this.$items.length-1||t<0)return;return this.sliding?this.$element.one("slid",function(){r.to(t)}):n==t?this.pause().cycle():this.slide(t>n?"next":"prev",e(this.$items[t]))},pause:function(t){return t||(this.paused=!0),this.$element.find(".next, .prev").length&&e.support.transition.end&&(this.$element.trigger(e.support.transition.end),this.cycle(!0)),clearInterval(this.interval),this.interval=null,this},next:function(){if(this.sliding)return;return this.slide("next")},prev:function(){if(this.sliding)return;return this.slide("prev")},slide:function(t,n){var r=this.$element.find(".item.active"),i=n||r[t](),s=this.interval,o=t=="next"?"left":"right",u=t=="next"?"first":"last",a=this,f;this.sliding=!0,s&&this.pause(),i=i.length?i:this.$element.find(".item")[u](),f=e.Event("slide",{relatedTarget:i[0],direction:o});if(i.hasClass("active"))return;this.$indicat'..b',next:function(t){var n=this.$menu.find(".active").removeClass("active"),r=n.next();r.length||(r=e(this.$menu.find("li")[0])),r.addClass("active")},prev:function(e){var t=this.$menu.find(".active").removeClass("active"),n=t.prev();n.length||(n=this.$menu.find("li").last()),n.addClass("active")},listen:function(){this.$element.on("focus",e.proxy(this.focus,this)).on("blur",e.proxy(this.blur,this)).on("keypress",e.proxy(this.keypress,this)).on("keyup",e.proxy(this.keyup,this)),this.eventSupported("keydown")&&this.$element.on("keydown",e.proxy(this.keydown,this)),this.$menu.on("click",e.proxy(this.click,this)).on("mouseenter","li",e.proxy(this.mouseenter,this)).on("mouseleave","li",e.proxy(this.mouseleave,this))},eventSupported:function(e){var t=e in this.$element;return t||(this.$element.setAttribute(e,"return;"),t=typeof this.$element[e]=="function"),t},move:function(e){if(!this.shown)return;switch(e.keyCode){case 9:case 13:case 27:e.preventDefault();break;case 38:e.preventDefault(),this.prev();break;case 40:e.preventDefault(),this.next()}e.stopPropagation()},keydown:function(t){this.suppressKeyPressRepeat=~e.inArray(t.keyCode,[40,38,9,13,27]),this.move(t)},keypress:function(e){if(this.suppressKeyPressRepeat)return;this.move(e)},keyup:function(e){switch(e.keyCode){case 40:case 38:case 16:case 17:case 18:break;case 9:case 13:if(!this.shown)return;this.select();break;case 27:if(!this.shown)return;this.hide();break;default:this.lookup()}e.stopPropagation(),e.preventDefault()},focus:function(e){this.focused=!0},blur:function(e){this.focused=!1,!this.mousedover&&this.shown&&this.hide()},click:function(e){e.stopPropagation(),e.preventDefault(),this.select(),this.$element.focus()},mouseenter:function(t){this.mousedover=!0,this.$menu.find(".active").removeClass("active"),e(t.currentTarget).addClass("active")},mouseleave:function(e){this.mousedover=!1,!this.focused&&this.shown&&this.hide()}};var n=e.fn.typeahead;e.fn.typeahead=function(n){return this.each(function(){var r=e(this),i=r.data("typeahead"),s=typeof n=="object"&&n;i||r.data("typeahead",i=new t(this,s)),typeof n=="string"&&i[n]()})},e.fn.typeahead.defaults={source:[],items:8,menu:\'<ul class="typeahead dropdown-menu"></ul>\',item:\'<li><a href="#"></a></li>\',minLength:1},e.fn.typeahead.Constructor=t,e.fn.typeahead.noConflict=function(){return e.fn.typeahead=n,this},e(document).on("focus.typeahead.data-api",\'[data-provide="typeahead"]\',function(t){var n=e(this);if(n.data("typeahead"))return;n.typeahead(n.data())})}(window.jQuery),!function(e){"use strict";var t=function(t,n){this.options=e.extend({},e.fn.affix.defaults,n),this.$window=e(window).on("scroll.affix.data-api",e.proxy(this.checkPosition,this)).on("click.affix.data-api",e.proxy(function(){setTimeout(e.proxy(this.checkPosition,this),1)},this)),this.$element=e(t),this.checkPosition()};t.prototype.checkPosition=function(){if(!this.$element.is(":visible"))return;var t=e(document).height(),n=this.$window.scrollTop(),r=this.$element.offset(),i=this.options.offset,s=i.bottom,o=i.top,u="affix affix-top affix-bottom",a;typeof i!="object"&&(s=o=i),typeof o=="function"&&(o=i.top()),typeof s=="function"&&(s=i.bottom()),a=this.unpin!=null&&n+this.unpin<=r.top?!1:s!=null&&r.top+this.$element.height()>=t-s?"bottom":o!=null&&n<=o?"top":!1;if(this.affixed===a)return;this.affixed=a,this.unpin=a=="bottom"?r.top-n:null,this.$element.removeClass(u).addClass("affix"+(a?"-"+a:""))};var n=e.fn.affix;e.fn.affix=function(n){return this.each(function(){var r=e(this),i=r.data("affix"),s=typeof n=="object"&&n;i||r.data("affix",i=new t(this,s)),typeof n=="string"&&i[n]()})},e.fn.affix.Constructor=t,e.fn.affix.defaults={offset:0},e.fn.affix.noConflict=function(){return e.fn.affix=n,this},e(window).on("load",function(){e(\'[data-spy="affix"]\').each(function(){var t=e(this),n=t.data();n.offset=n.offset||{},n.offsetBottom&&(n.offset.bottom=n.offsetBottom),n.offsetTop&&(n.offset.top=n.offsetTop),t.affix(n)})})}(window.jQuery);\n\\ No newline at end of file\n' |
b |
diff -r 000000000000 -r 198009598544 bin/js/jquery.galleriffic.js --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/bin/js/jquery.galleriffic.js Wed Oct 11 09:57:58 2017 -0400 |
[ |
b"@@ -0,0 +1,979 @@\n+/**\r\n+ * jQuery Galleriffic plugin\r\n+ *\r\n+ * Copyright (c) 2008 Trent Foley (http://trentacular.com)\r\n+ * Licensed under the MIT License:\r\n+ * http://www.opensource.org/licenses/mit-license.php\r\n+ *\r\n+ * Much thanks to primary contributer Ponticlaro (http://www.ponticlaro.com)\r\n+ */\r\n+;(function($) {\r\n+\t// Globally keep track of all images by their unique hash. Each item is an image data object.\r\n+\tvar allImages = {};\r\n+\tvar imageCounter = 0;\r\n+\n+\t// Galleriffic static class\r\n+\t$.galleriffic = {\n+\t\tversion: '2.0.1',\n+\n+\t\t// Strips invalid characters and any leading # characters\n+\t\tnormalizeHash: function(hash) {\r\n+\t\t\treturn hash.replace(/^.*#/, '').replace(/\\?.*$/, '');\n+\t\t},\n+\n+\t\tgetImage: function(hash) {\n+\t\t\tif (!hash)\n+\t\t\t\treturn undefined;\n+\n+\t\t\thash = $.galleriffic.normalizeHash(hash);\r\n+\t\t\treturn allImages[hash];\n+\t\t},\n+\r\n+\t\t// Global function that looks up an image by its hash and displays the image.\n+\t\t// Returns false when an image is not found for the specified hash.\n+\t\t// @param {String} hash This is the unique hash value assigned to an image.\n+\t\tgotoImage: function(hash) {\r\n+\t\t\tvar imageData = $.galleriffic.getImage(hash);\r\n+\t\t\tif (!imageData)\n+\t\t\t\treturn false;\r\n+\n+\t\t\tvar gallery = imageData.gallery;\n+\t\t\tgallery.gotoImage(imageData);\n+\t\t\t\n+\t\t\treturn true;\r\n+\t\t},\n+\n+\t\t// Removes an image from its respective gallery by its hash.\n+\t\t// Returns false when an image is not found for the specified hash or the\n+\t\t// specified owner gallery does match the located images gallery.\n+\t\t// @param {String} hash This is the unique hash value assigned to an image.\n+\t\t// @param {Object} ownerGallery (Optional) When supplied, the located images\n+\t\t// gallery is verified to be the same as the specified owning gallery before\n+\t\t// performing the remove operation.\n+\t\tremoveImageByHash: function(hash, ownerGallery) {\n+\t\t\tvar imageData = $.galleriffic.getImage(hash);\n+\t\t\tif (!imageData)\n+\t\t\t\treturn false;\n+\n+\t\t\tvar gallery = imageData.gallery;\n+\t\t\tif (ownerGallery && ownerGallery != gallery)\n+\t\t\t\treturn false;\n+\n+\t\t\treturn gallery.removeImageByIndex(imageData.index);\n+\t\t}\r\n+\t};\n+\r\n+\tvar defaults = {\r\n+\t\tdelay: 3000,\r\n+\t\tnumThumbs: 20,\r\n+\t\tpreloadAhead: 40, // Set to -1 to preload all images\r\n+\t\tenableTopPager: false,\r\n+\t\tenableBottomPager: true,\r\n+\t\tmaxPagesToShow: 7,\r\n+\t\timageContainerSel: '',\r\n+\t\tcaptionContainerSel: '',\r\n+\t\tcontrolsContainerSel: '',\r\n+\t\tloadingContainerSel: '',\r\n+\t\trenderSSControls: true,\r\n+\t\trenderNavControls: true,\r\n+\t\tplayLinkText: 'Play',\r\n+\t\tpauseLinkText: 'Pause',\r\n+\t\tprevLinkText: 'Previous',\r\n+\t\tnextLinkText: 'Next',\r\n+\t\tnextPageLinkText: 'Next ›',\r\n+\t\tprevPageLinkText: '‹ Prev',\r\n+\t\tenableHistory: false,\n+\t\tenableKeyboardNavigation: true,\r\n+\t\tautoStart: false,\r\n+\t\tsyncTransitions: false,\r\n+\t\tdefaultTransitionDuration: 1000,\r\n+\t\tonSlideChange: undefined, // accepts a delegate like such: function(prevIndex, nextIndex) { ... }\r\n+\t\tonTransitionOut: undefined, // accepts a delegate like such: function(slide, caption, isSync, callback) { ... }\r\n+\t\tonTransitionIn: undefined, // accepts a delegate like such: function(slide, caption, isSync) { ... }\r\n+\t\tonPageTransitionOut: undefined, // accepts a delegate like such: function(callback) { ... }\r\n+\t\tonPageTransitionIn: undefined, // accepts a delegate like such: function() { ... }\n+\t\tonImageAdded: undefined, // accepts a delegate like such: function(imageData, $li) { ... }\n+\t\tonImageRemoved: undefined // accepts a delegate like such: function(imageData, $li) { ... }\r\n+\t};\r\n+\n+\t// Primary Galleriffic initialization function that should be called on the thumbnail container.\r\n+\t$.fn.galleriffic = function(settings) {\r\n+\t\t// Extend Gallery O"..b'display all thumbnails.\r\n+\t\t\tbuildPageLink: function(pager, pageNum, numPages) {\r\n+\t\t\t\tvar pageLabel = pageNum + 1;\r\n+\t\t\t\tvar currentPage = this.getCurrentPage();\r\n+\t\t\t\tif (pageNum == currentPage)\r\n+\t\t\t\t\tpager.append(\'<span class="current">\'+pageLabel+\'</span>\');\r\n+\t\t\t\telse if (pageNum < numPages) {\r\n+\t\t\t\t\tvar imageIndex = pageNum*this.numThumbs;\r\n+\t\t\t\t\tpager.append(\'<a rel="history" href="#\'+this.data[imageIndex].hash+\'" title="\'+pageLabel+\'">\'+pageLabel+\'</a>\');\r\n+\t\t\t\t}\n+\t\t\t\t\n+\t\t\t\treturn this;\r\n+\t\t\t}\r\n+\t\t});\r\n+\r\n+\t\t// Now initialize the gallery\r\n+\t\t$.extend(this, defaults, settings);\r\n+\t\t\r\n+\t\t// Verify the history plugin is available\r\n+\t\tif (this.enableHistory && !$.historyInit)\r\n+\t\t\tthis.enableHistory = false;\r\n+\t\t\r\n+\t\t// Select containers\r\n+\t\tif (this.imageContainerSel) this.$imageContainer = $(this.imageContainerSel);\r\n+\t\tif (this.captionContainerSel) this.$captionContainer = $(this.captionContainerSel);\r\n+\t\tif (this.loadingContainerSel) this.$loadingContainer = $(this.loadingContainerSel);\r\n+\n+\t\t// Initialize the thumbails\r\n+\t\tthis.initializeThumbs();\r\n+\t\t\r\n+\t\tif (this.maxPagesToShow < 3)\r\n+\t\t\tthis.maxPagesToShow = 3;\r\n+\r\n+\t\tthis.displayedPage = -1;\n+\t\tthis.currentImage = this.data[0];\r\n+\t\tvar gallery = this;\r\n+\r\n+\t\t// Hide the loadingContainer\r\n+\t\tif (this.$loadingContainer)\r\n+\t\t\tthis.$loadingContainer.hide();\r\n+\r\n+\t\t// Setup controls\r\n+\t\tif (this.controlsContainerSel) {\r\n+\t\t\tthis.$controlsContainer = $(this.controlsContainerSel).empty();\r\n+\t\t\t\r\n+\t\t\tif (this.renderSSControls) {\r\n+\t\t\t\tif (this.autoStart) {\r\n+\t\t\t\t\tthis.$controlsContainer\r\n+\t\t\t\t\t\t.append(\'<div class="ss-controls"><a href="#pause" class="pause" title="\'+this.pauseLinkText+\'">\'+this.pauseLinkText+\'</a></div>\');\r\n+\t\t\t\t} else {\r\n+\t\t\t\t\tthis.$controlsContainer\r\n+\t\t\t\t\t\t.append(\'<div class="ss-controls"><a href="#play" class="play" title="\'+this.playLinkText+\'">\'+this.playLinkText+\'</a></div>\');\r\n+\t\t\t\t}\r\n+\r\n+\t\t\t\tthis.$controlsContainer.find(\'div.ss-controls a\')\r\n+\t\t\t\t\t.click(function(e) {\r\n+\t\t\t\t\t\tgallery.toggleSlideshow();\r\n+\t\t\t\t\t\te.preventDefault();\r\n+\t\t\t\t\t\treturn false;\r\n+\t\t\t\t\t});\r\n+\t\t\t}\r\n+\t\t\r\n+\t\t\tif (this.renderNavControls) {\r\n+\t\t\t\tthis.$controlsContainer\r\n+\t\t\t\t\t.append(\'<div class="nav-controls"><a class="prev" rel="history" title="\'+this.prevLinkText+\'">\'+this.prevLinkText+\'</a><a class="next" rel="history" title="\'+this.nextLinkText+\'">\'+this.nextLinkText+\'</a></div>\')\r\n+\t\t\t\t\t.find(\'div.nav-controls a\')\r\n+\t\t\t\t\t.click(function(e) {\r\n+\t\t\t\t\t\tgallery.clickHandler(e, this);\r\n+\t\t\t\t\t});\r\n+\t\t\t}\r\n+\t\t}\r\n+\n+\t\tvar initFirstImage = !this.enableHistory || !location.hash;\n+\t\tif (this.enableHistory && location.hash) {\n+\t\t\tvar hash = $.galleriffic.normalizeHash(location.hash);\n+\t\t\tvar imageData = allImages[hash];\r\n+\t\t\tif (!imageData)\n+\t\t\t\tinitFirstImage = true;\n+\t\t}\n+\r\n+\t\t// Setup gallery to show the first image\n+\t\tif (initFirstImage)\r\n+\t\t\tthis.gotoIndex(0, false, true);\r\n+\n+\t\t// Setup Keyboard Navigation\n+\t\tif (this.enableKeyboardNavigation) {\n+\t\t\t$(document).keydown(function(e) {\n+\t\t\t\tvar key = e.charCode ? e.charCode : e.keyCode ? e.keyCode : 0;\n+\t\t\t\tswitch(key) {\n+\t\t\t\t\tcase 32: // space\n+\t\t\t\t\t\tgallery.next();\n+\t\t\t\t\t\te.preventDefault();\n+\t\t\t\t\t\tbreak;\n+\t\t\t\t\tcase 33: // Page Up\n+\t\t\t\t\t\tgallery.previousPage();\n+\t\t\t\t\t\te.preventDefault();\n+\t\t\t\t\t\tbreak;\n+\t\t\t\t\tcase 34: // Page Down\n+\t\t\t\t\t\tgallery.nextPage();\n+\t\t\t\t\t\te.preventDefault();\n+\t\t\t\t\t\tbreak;\n+\t\t\t\t\tcase 35: // End\n+\t\t\t\t\t\tgallery.gotoIndex(gallery.data.length-1);\n+\t\t\t\t\t\te.preventDefault();\n+\t\t\t\t\t\tbreak;\n+\t\t\t\t\tcase 36: // Home\n+\t\t\t\t\t\tgallery.gotoIndex(0);\n+\t\t\t\t\t\te.preventDefault();\n+\t\t\t\t\t\tbreak;\n+\t\t\t\t\tcase 37: // left arrow\n+\t\t\t\t\t\tgallery.previous();\n+\t\t\t\t\t\te.preventDefault();\n+\t\t\t\t\t\tbreak;\n+\t\t\t\t\tcase 39: // right arrow\n+\t\t\t\t\t\tgallery.next();\n+\t\t\t\t\t\te.preventDefault();\n+\t\t\t\t\t\tbreak;\n+\t\t\t\t}\n+\t\t\t});\n+\t\t}\n+\n+\t\t// Auto start the slideshow\r\n+\t\tif (this.autoStart)\r\n+\t\t\tthis.play();\r\n+\r\n+\t\t// Kickoff Image Preloader after 1 second\r\n+\t\tsetTimeout(function() { gallery.preloadInit(); }, 1000);\r\n+\r\n+\t\treturn this;\r\n+\t};\r\n+})(jQuery);\r\n' |
b |
diff -r 000000000000 -r 198009598544 bin/js/jquery.js --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/bin/js/jquery.js Wed Oct 11 09:57:58 2017 -0400 |
[ |
b'@@ -0,0 +1,5 @@\n+/*! jQuery v1.9.1 | (c) 2005, 2012 jQuery Foundation, Inc. | jquery.org/license\n+//@ sourceMappingURL=jquery.min.map\n+*/(function(e,t){var n,r,i=typeof t,o=e.document,a=e.location,s=e.jQuery,u=e.$,l={},c=[],p="1.9.1",f=c.concat,d=c.push,h=c.slice,g=c.indexOf,m=l.toString,y=l.hasOwnProperty,v=p.trim,b=function(e,t){return new b.fn.init(e,t,r)},x=/[+-]?(?:\\d*\\.|)\\d+(?:[eE][+-]?\\d+|)/.source,w=/\\S+/g,T=/^[\\s\\uFEFF\\xA0]+|[\\s\\uFEFF\\xA0]+$/g,N=/^(?:(<[\\w\\W]+>)[^>]*|#([\\w-]*))$/,C=/^<(\\w+)\\s*\\/?>(?:<\\/\\1>|)$/,k=/^[\\],:{}\\s]*$/,E=/(?:^|:|,)(?:\\s*\\[)+/g,S=/\\\\(?:["\\\\\\/bfnrt]|u[\\da-fA-F]{4})/g,A=/"[^"\\\\\\r\\n]*"|true|false|null|-?(?:\\d+\\.|)\\d+(?:[eE][+-]?\\d+|)/g,j=/^-ms-/,D=/-([\\da-z])/gi,L=function(e,t){return t.toUpperCase()},H=function(e){(o.addEventListener||"load"===e.type||"complete"===o.readyState)&&(q(),b.ready())},q=function(){o.addEventListener?(o.removeEventListener("DOMContentLoaded",H,!1),e.removeEventListener("load",H,!1)):(o.detachEvent("onreadystatechange",H),e.detachEvent("onload",H))};b.fn=b.prototype={jquery:p,constructor:b,init:function(e,n,r){var i,a;if(!e)return this;if("string"==typeof e){if(i="<"===e.charAt(0)&&">"===e.charAt(e.length-1)&&e.length>=3?[null,e,null]:N.exec(e),!i||!i[1]&&n)return!n||n.jquery?(n||r).find(e):this.constructor(n).find(e);if(i[1]){if(n=n instanceof b?n[0]:n,b.merge(this,b.parseHTML(i[1],n&&n.nodeType?n.ownerDocument||n:o,!0)),C.test(i[1])&&b.isPlainObject(n))for(i in n)b.isFunction(this[i])?this[i](n[i]):this.attr(i,n[i]);return this}if(a=o.getElementById(i[2]),a&&a.parentNode){if(a.id!==i[2])return r.find(e);this.length=1,this[0]=a}return this.context=o,this.selector=e,this}return e.nodeType?(this.context=this[0]=e,this.length=1,this):b.isFunction(e)?r.ready(e):(e.selector!==t&&(this.selector=e.selector,this.context=e.context),b.makeArray(e,this))},selector:"",length:0,size:function(){return this.length},toArray:function(){return h.call(this)},get:function(e){return null==e?this.toArray():0>e?this[this.length+e]:this[e]},pushStack:function(e){var t=b.merge(this.constructor(),e);return t.prevObject=this,t.context=this.context,t},each:function(e,t){return b.each(this,e,t)},ready:function(e){return b.ready.promise().done(e),this},slice:function(){return this.pushStack(h.apply(this,arguments))},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},eq:function(e){var t=this.length,n=+e+(0>e?t:0);return this.pushStack(n>=0&&t>n?[this[n]]:[])},map:function(e){return this.pushStack(b.map(this,function(t,n){return e.call(t,n,t)}))},end:function(){return this.prevObject||this.constructor(null)},push:d,sort:[].sort,splice:[].splice},b.fn.init.prototype=b.fn,b.extend=b.fn.extend=function(){var e,n,r,i,o,a,s=arguments[0]||{},u=1,l=arguments.length,c=!1;for("boolean"==typeof s&&(c=s,s=arguments[1]||{},u=2),"object"==typeof s||b.isFunction(s)||(s={}),l===u&&(s=this,--u);l>u;u++)if(null!=(o=arguments[u]))for(i in o)e=s[i],r=o[i],s!==r&&(c&&r&&(b.isPlainObject(r)||(n=b.isArray(r)))?(n?(n=!1,a=e&&b.isArray(e)?e:[]):a=e&&b.isPlainObject(e)?e:{},s[i]=b.extend(c,a,r)):r!==t&&(s[i]=r));return s},b.extend({noConflict:function(t){return e.$===b&&(e.$=u),t&&e.jQuery===b&&(e.jQuery=s),b},isReady:!1,readyWait:1,holdReady:function(e){e?b.readyWait++:b.ready(!0)},ready:function(e){if(e===!0?!--b.readyWait:!b.isReady){if(!o.body)return setTimeout(b.ready);b.isReady=!0,e!==!0&&--b.readyWait>0||(n.resolveWith(o,[b]),b.fn.trigger&&b(o).trigger("ready").off("ready"))}},isFunction:function(e){return"function"===b.type(e)},isArray:Array.isArray||function(e){return"array"===b.type(e)},isWindow:function(e){return null!=e&&e==e.window},isNumeric:function(e){return!isNaN(parseFloat(e))&&isFinite(e)},type:function(e){return null==e?e+"":"object"==typeof e||"function"==typeof e?l[m.call(e)]||"object":typeof e},isPlainObject:function(e){if(!e||"object"!==b.type(e)||e.nodeType||b.isWindow(e))return!1;try{if(e.constructor&&!y.call(e,"constructor")&&!y.call(e.constructor.prototype,"isPrototypeOf"))r'..b' ir(e,t){var n,r={height:e},i=0;for(t=t?1:0;4>i;i+=2-t)n=Zt[i],r["margin"+n]=r["padding"+n]=e;return t&&(r.opacity=r.width=e),r}b.each({slideDown:ir("show"),slideUp:ir("hide"),slideToggle:ir("toggle"),fadeIn:{opacity:"show"},fadeOut:{opacity:"hide"},fadeToggle:{opacity:"toggle"}},function(e,t){b.fn[e]=function(e,n,r){return this.animate(t,e,n,r)}}),b.speed=function(e,t,n){var r=e&&"object"==typeof e?b.extend({},e):{complete:n||!n&&t||b.isFunction(e)&&e,duration:e,easing:n&&t||t&&!b.isFunction(t)&&t};return r.duration=b.fx.off?0:"number"==typeof r.duration?r.duration:r.duration in b.fx.speeds?b.fx.speeds[r.duration]:b.fx.speeds._default,(null==r.queue||r.queue===!0)&&(r.queue="fx"),r.old=r.complete,r.complete=function(){b.isFunction(r.old)&&r.old.call(this),r.queue&&b.dequeue(this,r.queue)},r},b.easing={linear:function(e){return e},swing:function(e){return.5-Math.cos(e*Math.PI)/2}},b.timers=[],b.fx=rr.prototype.init,b.fx.tick=function(){var e,n=b.timers,r=0;for(Xn=b.now();n.length>r;r++)e=n[r],e()||n[r]!==e||n.splice(r--,1);n.length||b.fx.stop(),Xn=t},b.fx.timer=function(e){e()&&b.timers.push(e)&&b.fx.start()},b.fx.interval=13,b.fx.start=function(){Un||(Un=setInterval(b.fx.tick,b.fx.interval))},b.fx.stop=function(){clearInterval(Un),Un=null},b.fx.speeds={slow:600,fast:200,_default:400},b.fx.step={},b.expr&&b.expr.filters&&(b.expr.filters.animated=function(e){return b.grep(b.timers,function(t){return e===t.elem}).length}),b.fn.offset=function(e){if(arguments.length)return e===t?this:this.each(function(t){b.offset.setOffset(this,e,t)});var n,r,o={top:0,left:0},a=this[0],s=a&&a.ownerDocument;if(s)return n=s.documentElement,b.contains(n,a)?(typeof a.getBoundingClientRect!==i&&(o=a.getBoundingClientRect()),r=or(s),{top:o.top+(r.pageYOffset||n.scrollTop)-(n.clientTop||0),left:o.left+(r.pageXOffset||n.scrollLeft)-(n.clientLeft||0)}):o},b.offset={setOffset:function(e,t,n){var r=b.css(e,"position");"static"===r&&(e.style.position="relative");var i=b(e),o=i.offset(),a=b.css(e,"top"),s=b.css(e,"left"),u=("absolute"===r||"fixed"===r)&&b.inArray("auto",[a,s])>-1,l={},c={},p,f;u?(c=i.position(),p=c.top,f=c.left):(p=parseFloat(a)||0,f=parseFloat(s)||0),b.isFunction(t)&&(t=t.call(e,n,o)),null!=t.top&&(l.top=t.top-o.top+p),null!=t.left&&(l.left=t.left-o.left+f),"using"in t?t.using.call(e,l):i.css(l)}},b.fn.extend({position:function(){if(this[0]){var e,t,n={top:0,left:0},r=this[0];return"fixed"===b.css(r,"position")?t=r.getBoundingClientRect():(e=this.offsetParent(),t=this.offset(),b.nodeName(e[0],"html")||(n=e.offset()),n.top+=b.css(e[0],"borderTopWidth",!0),n.left+=b.css(e[0],"borderLeftWidth",!0)),{top:t.top-n.top-b.css(r,"marginTop",!0),left:t.left-n.left-b.css(r,"marginLeft",!0)}}},offsetParent:function(){return this.map(function(){var e=this.offsetParent||o.documentElement;while(e&&!b.nodeName(e,"html")&&"static"===b.css(e,"position"))e=e.offsetParent;return e||o.documentElement})}}),b.each({scrollLeft:"pageXOffset",scrollTop:"pageYOffset"},function(e,n){var r=/Y/.test(n);b.fn[e]=function(i){return b.access(this,function(e,i,o){var a=or(e);return o===t?a?n in a?a[n]:a.document.documentElement[i]:e[i]:(a?a.scrollTo(r?b(a).scrollLeft():o,r?o:b(a).scrollTop()):e[i]=o,t)},e,i,arguments.length,null)}});function or(e){return b.isWindow(e)?e:9===e.nodeType?e.defaultView||e.parentWindow:!1}b.each({Height:"height",Width:"width"},function(e,n){b.each({padding:"inner"+e,content:n,"":"outer"+e},function(r,i){b.fn[i]=function(i,o){var a=arguments.length&&(r||"boolean"!=typeof i),s=r||(i===!0||o===!0?"margin":"border");return b.access(this,function(n,r,i){var o;return b.isWindow(n)?n.document.documentElement["client"+e]:9===n.nodeType?(o=n.documentElement,Math.max(n.body["scroll"+e],o["scroll"+e],n.body["offset"+e],o["offset"+e],o["client"+e])):i===t?b.css(n,r,s):b.style(n,r,i,s)},n,a?i:t,a,null)}})}),e.jQuery=e.$=b,"function"==typeof define&&define.amd&&define.amd.jQuery&&define("jquery",[],function(){return b})})(window);\n\\ No newline at end of file\n' |
b |
diff -r 000000000000 -r 198009598544 bin/js/jquery.opacityrollover.js --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/bin/js/jquery.opacityrollover.js Wed Oct 11 09:57:58 2017 -0400 |
b |
@@ -0,0 +1,42 @@ +/** + * jQuery Opacity Rollover plugin + * + * Copyright (c) 2009 Trent Foley (http://trentacular.com) + * Licensed under the MIT License: + * http://www.opensource.org/licenses/mit-license.php + */ +;(function($) { + var defaults = { + mouseOutOpacity: 0.67, + mouseOverOpacity: 1.0, + fadeSpeed: 'fast', + exemptionSelector: '.selected' + }; + + $.fn.opacityrollover = function(settings) { + // Initialize the effect + $.extend(this, defaults, settings); + + var config = this; + + function fadeTo(element, opacity) { + var $target = $(element); + + if (config.exemptionSelector) + $target = $target.not(config.exemptionSelector); + + $target.fadeTo(config.fadeSpeed, opacity); + } + + this.css('opacity', this.mouseOutOpacity) + .hover( + function () { + fadeTo(this, config.mouseOverOpacity); + }, + function () { + fadeTo(this, config.mouseOutOpacity); + }); + + return this; + }; +})(jQuery); |
b |
diff -r 000000000000 -r 198009598544 bin/piPipe.pl --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/bin/piPipe.pl Wed Oct 11 09:57:58 2017 -0400 |
[ |
b'@@ -0,0 +1,269 @@\n+#!/usr/bin/perl\n+use strict;\n+use warnings;\n+use Getopt::Long;\n+use Parallel::ForkManager;\n+use File::Basename;\n+use File::Copy::Recursive qw( dircopy );\n+use POSIX;\n+use FindBin;\n+use lib $FindBin::Bin;\n+use resize qw ( size_distribution );\n+use subgroups qw (subgroups );\n+use ppp qw ( ping_pong_partners );\n+use Rcall qw (pie_chart bg_to_png );\n+use align qw ( to_build get_unique sam_count sam_count_mis sam_sorted_bam rpms_rpkm BWA_call get_fastq_seq extract_sam sam_to_bam_bg );\n+use html qw ( main_page details_pages menu_page ppp_page );\n+use File::Copy;\n+\n+my ( @fastq, @fastq_n, $dir, $min, $max, $mis, $misTE, $help, $Pcheck, $Dcheck, $mapnumf, $html_out);\n+my ( $ref, $tRNAs, $rRNAs, $snRNAs, $miRNAs, $exons, $TE );\n+my ( $si_min, $si_max, $pi_min, $pi_max );\n+my ( $build_index, $build_tRNAs, $build_rRNAs, $build_snRNAs, $build_miRNAs, $build_exons, $build_TE );\n+my $max_procs = 4;\n+\n+( $build_index, $build_tRNAs, $build_rRNAs, $build_snRNAs, $build_miRNAs, $build_exons, $build_TE ) = (0,0,0,0,0,0,0);\n+( $min, $max, $mis, $misTE, $si_min, $si_max, $pi_min, $pi_max, $dir ) = ( 18, 29, 0, 3, 21, 21, 23, 29 );\n+$Pcheck =\'true\';\n+\n+GetOptions (\n+\t"fastq=s" => \\@fastq,\n+\t"fastq_n=s" => \\@fastq_n,\n+\t"dir=s" => \\$dir,\n+\t"min:i" => \\$min,\n+\t"max:i" => \\$max,\n+\t"si_min:i" => \\$si_min,\n+\t"si_max:i" => \\$si_max,\n+\t"pi_min:i" => \\$pi_min,\n+\t"pi_max:i" => \\$pi_max,\n+\t"mis:i" => \\$mis,\n+\t"misTE:i" => \\$misTE,\n+\t"html:s" => \\$html_out,\n+\t"PPPon:s" => \\$Pcheck,\n+\t"Dison:s" => \\$Dcheck,\n+\t"help" => \\$help,\n+\t"ref:s" => \\$ref,\n+\t"tRNAs:s" => \\$tRNAs,\n+\t"rRNAs:s" => \\$rRNAs,\n+\t"snRNAs:s" => \\$snRNAs,\n+\t"miRNAs:s" => \\$miRNAs,\n+\t"exons:s" => \\$exons,\n+\t"TE:s" => \\$TE,\n+\t"build_index" => \\$build_index,\n+\t"build_tRNAs" => \\$build_tRNAs,\n+\t"build_snRNAs" => \\$build_snRNAs,\n+\t"build_miRNAs" => \\$build_miRNAs,\n+\t"build_exons" => \\$build_exons,\n+\t"build_rRNAs" => \\$build_rRNAs,\n+\t"build_TE" => \\$build_TE\n+);\n+\n+my $fq_collection = \'fastq_dir/\';\n+mkdir $dir; mkdir $fq_collection;\n+$dir = $dir.\'/\' unless $dir =~ /\\/$/;\n+mkdir $dir.\'/css\';mkdir $dir.\'/js\';\n+dircopy( $FindBin::Bin.\'/css\', $dir.\'/css\' );\n+dircopy( $FindBin::Bin.\'/js\', $dir.\'/js\' );\n+\n+my $file = $dir.\'report.txt\';\n+open my $report, \'>\', $file or die "Cannot open $file $!\\n";\n+\n+my %toBuild;\n+@toBuild{ ( $ref, $tRNAs, $rRNAs, $snRNAs, $miRNAs, $exons, $TE ) } = ( $build_index, $build_tRNAs, $build_rRNAs, $build_snRNAs, $build_miRNAs, $build_exons, $build_TE ) ;\n+to_build ( \\%toBuild, $report );\n+\n+my $proc_child = ceil($max_procs / scalar(@fastq));\n+my $proc_grand_child = ceil($proc_child/5);\n+my $pm = Parallel::ForkManager->new($max_procs);\n+my $pm3 = Parallel::ForkManager->new($proc_grand_child);\n+\n+$pm->run_on_finish( sub {\n+\tmy ($pid, $exit_code, $ident) = @_;\n+\tprint $report "Fastq fork $ident just finished ".\n+\t"with PID $pid and exit code: $exit_code\\n";\n+\tdie "Something went wrong!\\n" if $exit_code != 0;\n+\t});\n+$pm->run_on_start( sub {\n+\tmy ($pid,$ident)=@_;\n+\tprint $report "Fastq fork : $ident started, pid: $pid\\n";\n+\t});\n+$pm3->run_on_finish( sub {\n+\tmy ($pid, $exit_code, $ident) = @_;\n+\tprint $report "** Subgroup fork $ident just finished ".\n+\t"with PID $pid and exit code: $exit_code\\n";\n+\tdie "Something went wrong!\\n" if $exit_code != 0;\n+\t});\n+$pm3->run_on_start( sub {\n+\tmy ($pid,$ident)=@_;\n+\tprint $report "** Subgroup fork $ident started, pid: $pid\\n";\n+\t});\n+\n+\n+foreach my $child ( 0 .. $#fastq )\n+{\n+\tmy @suffix = (\'.fastq\', \'.fastq.gz,\', \'.fq\', \'.fq.gz\', \'ref\', \'.dat\', \'.fa\',\'.fas\',\'.fasta\', \'.txt\');\n+\tmy ( $name, $path, $suffix ) = fileparse( $fastq[$child], @suffix );\n+\tmy ( $ref_name, $ref_path, $ref_suffix ) = fileparse( $ref, @suffix );\n+\tmy ( $TE_name, $TE_path, $TE_suffix ) = fileparse( $TE, @suffix );\n+\tmy ( $ex_name, $ex_path, $ex_suffix ) = fileparse( $exons,@suffix );\n+\n+\t$pm->start($fastq[$child]) and next;\n+\n+\tmy $dir_fq = $dir.$name.\'/\';\n+\tmkdir $dir_fq;\n+\n+\tmy $gen_dir = $dir_fq.\'genome/\';\n+\tmkdir $gen_dir;\n+\n+\tmy $size_dir = $dir_fq'..b'all ( $ref, $types[$grand_child], $type_sam_genome, $mis, $proc_child, $report );\n+\t\t\textract_sam ( undef, $type_sam_TEs, $type_sam_TEs, $type_sam_uni_TEs, $type_uni_TEs_fastq, $type_uni_TEs_fastq );\n+\t\t\textract_sam ( undef, $type_sam_exons, $type_sam_exons, $type_sam_uni_exons, $type_exons_fastq, $type_uni_exons_fastq );\n+\t\t\textract_sam ( undef, $type_sam_genome, $type_sam_genome, $type_sam_uni_genome, $type_genome_fastq, $type_uni_genome_fastq );\n+\t\t}\n+\t\telse\n+\t\t{\n+\t\t\textract_sam ( $type_sequence_hashP, $sam_TEs, $type_sam_TEs, $type_sam_uni_TEs, $type_TEs_fastq, $type_uni_TEs_fastq );\n+\t\t\textract_sam ( $type_sequence_hashP, $sam_exons, $type_sam_exons, $type_sam_uni_exons, $type_exons_fastq, $type_uni_exons_fastq );\n+\t\t\textract_sam ( $type_sequence_hashP, $sam_genome, $type_sam_genome, $type_sam_uni_genome, $type_genome_fastq, $type_uni_genome_fastq );\n+\t\t}\n+\n+\t\tmy $ex_count_file = $type_dir.\'exons_reads_counts.txt\';\n+\t\tmy ( $ex_count, $ex_ref_size ) = sam_count ( $type_sam_exons );\n+\t\trpms_rpkm( $ex_count, $ex_ref_size, $ma, $ex_count_file, $pi, $mi, $bo );\n+\n+\t\tmy ( $TEs_count, $TEs_ref_size, $TEs_count_NoM, $TEs_count_M ) = sam_count_mis ( $type_sam_TEs );\n+\t\tmy $TEs_count_file = $type_dir.$type_prefix.\'TEs_reads_counts.txt\';\n+\t\tmy $TEs_count_file_M = $type_dir.$type_prefix.\'TEs_reads_counts_mismatches.txt\';\n+\t\tmy $TEs_count_file_noM = $type_dir.$type_prefix.\'TEs_reads_counts_nomismatches.txt\';\n+\t\trpms_rpkm( $TEs_count, $TEs_ref_size, $ma, $TEs_count_file, $pi, $mi, $bo );\n+\t\trpms_rpkm( $TEs_count_NoM, $TEs_ref_size, $ma, $TEs_count_file_M, $pi, $mi, $bo );\n+\t\trpms_rpkm( $TEs_count_M, $TEs_ref_size, $ma, $TEs_count_file_noM, $pi, $mi, $bo );\n+\n+\t\tsam_to_bam_bg ( $type_sam_TEs, $scale, $grand_child );\n+\t\tsam_sorted_bam ( $type_sam_exons, $grand_child ); sam_sorted_bam ( $type_sam_uni_exons, $grand_child ); \n+\t\tsam_sorted_bam ( $type_sam_uni_TEs, $grand_child ); \n+\n+\t\tmy $Gviz_TEs = $type_dir.\'Gviz_TEs/\';\n+\t\tmkdir $Gviz_TEs;\n+\t\tbg_to_png ( $group_dir.\'TEs.fai\', $type_dir.$type_prefix.\'TEs_plus.bedgraph\', $type_dir.$type_prefix.\'TEs_minus.bedgraph\', $Gviz_TEs, \'Kb\' );\n+\n+\t\tmy $Gviz_genome= $type_dir.\'Gviz_genome/\';\n+\t\tmy $Gviz_genome_rand = $Gviz_genome.\'rand/\';\n+\t\tmy $Gviz_genome_uni = $Gviz_genome.\'unique/\';\n+\t\tmkdir $Gviz_genome; mkdir $Gviz_genome_uni; mkdir $Gviz_genome_rand;\n+\n+\t\tsam_to_bam_bg ( $type_sam_genome, $scale, $grand_child );\n+\t\tsam_to_bam_bg ( $type_sam_uni_genome, $scale, $grand_child );\n+\n+\t\tbg_to_png ( $fai_file, $type_dir.$type_prefix.\'genome_unique_plus.bedgraph\', $type_dir.$type_prefix.\'genome_unique_minus.bedgraph\', $Gviz_genome_uni, \'Mb\' );\n+\t\tbg_to_png ( $fai_file, $type_dir.$type_prefix.\'genome_plus.bedgraph\', $type_dir.$type_prefix.\'genome_minus.bedgraph\', $Gviz_genome_rand, \'Mb\' );\n+\n+\t\t#HTML Details\n+\t\tmy $prefix_details_pages = $dir.$fastq_n[$child].\'-\'.$types_names[$grand_child];\n+\t\tdetails_pages ( $type_dir, $prefix_details_pages, \\@fastq_n, $fastq_n[$child], $misTE, $dir );\n+\n+\t\t$pm3->finish($grand_child);\n+\t}\n+\t$pm3->wait_all_children;\n+\n+\tif ( $Pcheck eq \'true\' )\n+\t{\n+\t\tmy $ppp = $group_dir.\'PPPartners/\'; mkdir $ppp;\n+\t\tprint $report "ping_pong_partners $group_dir/bonafide_reads/TEs.sam $ppp\\n";\n+\t\tping_pong_partners ( $group_dir.\'TEs.fai\', $group_dir.\'bonafide_reads/bonafide_reads-TEs_sorted.bam\', $ppp, $min );\n+\t\tmy $ppp_page = $dir.$fastq_n[$child].\'-bonafide_reads-PPP.html\';\n+\t\tppp_page ( $group_dir, $ppp_page, \\@fastq_n, $fastq_n[$child], $ppp, $dir );\n+\t}\n+\n+\t#HTML Main Webpage\n+\tmy $index_page = $dir.$fastq_n[$child].\'.html\';\n+ main_page ( $gen_dir, $index_page, \\@fastq_n, $fastq_n[$child], $ma, $ma_uni, $dir );\n+ copy ($index_page, $html_out) if $child == 0;\n+\t#HTML Menu\n+\tmy $menu_page = $dir.$fastq_n[$child].\'-sub.html\';\n+\tmenu_page ( $group_dir, $menu_page, \\@fastq_n, $fastq_n[$child], $min, $max, $si_min, $si_max, $pi_min, $pi_max, $dir );\n+\n+\t$pm->finish($child); # pass an exit code to finish\n+}\n+$pm->wait_all_children;\n+\n+print $report "Job done!\\n";\n+close $report;\n' |
b |
diff -r 000000000000 -r 198009598544 bin/ppp.pm --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/bin/ppp.pm Wed Oct 11 09:57:58 2017 -0400 |
[ |
@@ -0,0 +1,199 @@ +package ppp; + +use strict; +use warnings; +use FindBin; +use lib $FindBin::Bin; +use Rcall qw ( histogram ); +use Math::CDF; + +use Exporter; +our @ISA = qw( Exporter ); +our @EXPORT_OK = qw( &ping_pong_partners ); + +sub ping_pong_partners +{ + my ( $TE_fai, $sam, $dir, $max ) = @_; + my ( $hashRef, $dupRef ) = count_mapped ( $TE_fai, $sam ); + my ( %num_per_overlap_size, $overlap_number, $reverseR, $begRev, $endRev, $sensR, $begSens, $endSens, $snum, $rnum, $overlap ); + my ( $SP, $AP, $SN, $AN, $txt); + my $flag = 0; + my @distri_overlap = (); my @overlaps_names = (); + + open my $ppp_f, '>', $dir."ppp.txt" || die "cannot create ppp.txt $!\n"; + foreach my $k ( sort keys %{$hashRef} ) + { + my $v = $hashRef->{$k}; + my $TE_dir = $dir.$k.'/'; + + %num_per_overlap_size = (); $overlap_number = 0; + $flag = 0; + for ( my $i = 0; $i <= $#{$v->[1]} ; $i++ ) + { + $reverseR = ${$v->[1]}[$i] ; + $begRev = $reverseR->[0]; + $endRev = $begRev + length($reverseR->[1]) - 1; + + my $revR = reverse($reverseR->[1]); + $revR =~ tr/atgcuATGCU/tacgaTACGA/; + + for ( my $j = 0; $j <= $#{$v->[0]}; $j++ ) + { + $sensR = ${$v->[0]}[$j]; + $begSens = $sensR->[0]; + + $endSens = $begSens + length($sensR->[1]) - 1; + + if ( $begSens <= $endRev && $endSens > $endRev ) + { + $flag = 1; + + mkdir $TE_dir; + open $SP, '>>', $TE_dir."sensPPP.txt" || die "cannot create sensPPP\n"; + open $AP, '>>', $TE_dir."antisensPPP.txt" || die "cannot create antisensPPP\n"; + open $SN, '>>', $TE_dir."sens.txt" || die "cannot create sens\n"; + open $AN, '>>', $TE_dir."antisens.txt" || die "cannot create antisens\n"; + open $txt, '>', $TE_dir.'overlap_size.txt' || die "cannot open repartition\n"; + + $overlap = $endRev - $begSens + 1; + $snum = $dupRef->{$sensR->[0].$sensR->[1].$sensR->[2].$sensR->[3]}; + $rnum = $dupRef->{$reverseR->[0].$reverseR->[1].$reverseR->[2].$reverseR->[3]}; + + if ( $overlap == 10 ) + { + print $SP ">$sensR->[0]|$sensR->[2]|$sensR->[3]|$snum\n$sensR->[1]\n"; + print $AP ">$reverseR->[0]|$reverseR->[2]|$reverseR->[3]|$rnum\n$revR\n"; + } + else + { + print $SN ">$sensR->[0]|$sensR->[2]|$sensR->[3]|$snum\n$sensR->[1]\n"; + print $AN ">$reverseR->[0]|$reverseR->[2]|$reverseR->[3]|$rnum\n$revR\n"; + } + next if $overlap > $max; + if ( $snum < $rnum ) + { + $num_per_overlap_size{$overlap} += $snum; + $overlap_number += $snum; + } + else + { + $num_per_overlap_size{$overlap} += $rnum ; + $overlap_number += $rnum ; + } + } + } + } + + if ( $max != 0 ) + { + my @overlaps = (); + push @overlaps_names, $k; + for my $i (1..$max) + { + $num_per_overlap_size{$i} = 0 unless exists( $num_per_overlap_size{$i} ); + push @overlaps, $num_per_overlap_size{$i}; + } + push @distri_overlap, \@overlaps; + } + + if ( $flag == 1 ) + { + my $histo_png = $TE_dir.'histogram.png'; + histogram( \%num_per_overlap_size, $histo_png, $overlap_number ); + print $txt "size\tnumber\tpercentage of the total overlap number\n"; + foreach my $k ( sort {$a <=> $b} keys %num_per_overlap_size ) + { + my $percentage = 0; + $percentage = $num_per_overlap_size{$k} * 100 / $overlap_number unless $overlap_number == 0; + print $txt "$k\t$num_per_overlap_size{$k}\t"; printf $txt "%.2f\n",$percentage; + + } + close $txt; + } + + } + + foreach my $tabP ( @distri_overlap ) + { + my $sum = sum($tabP); + my $ten = $tabP->[9]; + my $mean = mean($tabP); + my $std = standard_deviation($tabP, $mean); + my $zsc = z_significance($ten, $mean, $std); + my $name = shift @overlaps_names; + my $prob = 'NA'; + $prob = 1 - &Math::CDF::pnorm( $zsc ) if $zsc ne 'NA'; + print $ppp_f (join ("\t", $name, $sum, $ten, $mean, $std, $zsc, $prob ),"\n" ); + } + close $ppp_f; +} + +sub count_mapped +{ + my ( $fai, $in_file ) = @_; + my ( %mapped, %dup ); + + open my $f, '<', $fai || die "cannot open $fai $! \n"; + while(<$f>) + { + if ($_ =~ /(.*)\t(\d+)\n/) + { + $mapped{$1} = []; + $mapped{$1}->[0] = []; $mapped{$1}->[1] = []; + } + } + close $f; + + open my $infile, "samtools view $in_file |"|| die "cannot open input file $! \n"; + while(<$infile>) + { + unless ($_ =~ /^\@[A-Za-z][A-Za-z](\t[A-Za-z][A-Za-z0-9]:[ -~]+)+$/ || $_ =~ /^\@CO\t.*/ ) + { + my @line = split (/\t/,$_); + if ($line[1] == 0) + { + push @{$mapped{$line[2]}->[0]} , [$line[3], $line[9], $line[1], $line[2]] unless exists ($dup{$line[3].$line[9].$line[1].$line[2]}); + $dup{$line[3].$line[9].$line[1].$line[2]}+=1; + } + elsif ($line[1] == 16) + { + push @{$mapped{$line[2]}->[1]} , [$line[3], $line[9], $line[1], $line[2]] unless exists ($dup{$line[3].$line[9].$line[1].$line[2]}); + $dup{$line[3].$line[9].$line[1].$line[2]}+=1; + } + } + } + close $infile; + return (\%mapped, \%dup ); +} + +sub sum +{ + my $arrayref = shift; + my $result = 0; + foreach (@$arrayref) {$result += $_} + return $result; +} + +sub mean +{ + my $arrayref = shift; + my $result; + foreach (@$arrayref) {$result += $_} + return $result / scalar(@$arrayref); +} + +sub standard_deviation +{ + my ($arrayref, $mean) = @_; + return sqrt ( mean ( [map $_**2 , @$arrayref ]) - ($mean**2)); +} + +sub z_significance +{ + my ($ten, $mean, $std) = @_; + my $z = 'NA'; + $z = (($ten - $mean) / $std) if $std != 0; + return $z; +} + +1; |
b |
diff -r 000000000000 -r 198009598544 bin/resize.pm --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/bin/resize.pm Wed Oct 11 09:57:58 2017 -0400 |
[ |
@@ -0,0 +1,101 @@ +package resize; + +use strict; +use warnings; + +use FindBin; +use lib $FindBin::Bin; +use Rcall qw ( histogram ); + +use Exporter; +our @ISA = qw( Exporter ); +our @EXPORT_OK = qw( &size_distribution ); + +sub size_distribution +{ + my ( $fastq, $fastq_out, $dir, $min, $max ) = @_; + + my ( %fragments_size, %duplicates ) ; + my $num = size($min, $max, $fastq, $fastq_out, \%fragments_size, \%duplicates); + + my $png = $dir.'histogram.png'; + histogram(\%fragments_size, $png, $num); + + my $size = $dir.'reads_size.txt'; + + + my $pourcentage; + open my $o, '>', $size || die "cannot open $size $!\n"; + print $o "size\tnumber\tpercentage\n"; + foreach my $k (sort { $a <=> $b } keys %fragments_size ) + { + $pourcentage = $fragments_size{$k} / $num * 100; + + print $o "$k\t$fragments_size{$k}\t"; + printf $o "%.2f\n",$pourcentage; + } + close $o; + + my $dup = $dir.'duplicates.txt' ; + open $o, '>', $dup || die "cannot open $size $!\n"; + print $o "size\tnumber\n"; + foreach my $k (sort { $duplicates{$b} <=> $duplicates{$a} } keys %duplicates ) + { + print $o "$k\t$duplicates{$k}\n"; + } + close $o; +} + +sub size +{ + my ($min, $max, $in_file, $out_file, $sizeHashR, $duplicateHashR) = @_; + my ($numreads, $size, $cmp, $ok, $line) = (0, 0, 0, 0); + my @fastq; + open (my $in, $in_file) || die "cannot open $in_file $!\n"; + open (my $out, ">".$out_file) || die "cannot create $out_file $!\n"; + while(<$in>) + { + chomp $_; + $cmp++; $line++; + if ($cmp == 1) + { + die "file do not contain a @ at line $line\n" unless ($_ =~ /^\@/ ); + $ok = 0; @fastq = (); + push(@fastq,$_); + } + elsif ($cmp == 2) + { + #die "unrecognized symbol at line $line\n" unless ($_ =~ /[atcgATCGnN]+/ || $_ =~ /^$/ ); + push(@fastq,$_); + $size = length($_); + if ($size >= $min && $size <= $max) + { + $numreads++; + ${$sizeHashR}{$size}+=1; + ${$duplicateHashR}{$_}+=1 if (defined($duplicateHashR)); + $ok = 1; + } + } + elsif ($cmp == 3 ) + { + die "file do not contain a + at line $line\n" unless $_ =~ /^\+/; + push(@fastq,$_); + } + elsif ($cmp == 4 ) + { + push(@fastq,$_); + $cmp = 0; + if ($ok == 1) + { + foreach my $t (@fastq) + { + print $out $t."\n"; + } + } + } + } + close $in; close $out; + return $numreads; +} + +1; |
b |
diff -r 000000000000 -r 198009598544 bin/subgroups.pm --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/bin/subgroups.pm Wed Oct 11 09:57:58 2017 -0400 |
[ |
@@ -0,0 +1,148 @@ +package subgroups; + +use strict; +use warnings; +use Exporter; +our @ISA = qw( Exporter ); +our @EXPORT_OK = qw( &subgroups ); + +use POSIX; +use FindBin; +use lib $FindBin::Bin; +use align qw ( get_hash_alignment ); + +sub subgroups +{ + my ($fin, $dir, $mis, $mis_TE, $proc, $tRNAs, $rRNAs, $snRNAs, $miRNAs, $exons, $TE, $min_si, $max_si, $min_pi, $max_pi, $report ) = @_; + my (@files, $sum, $pie, $repar, %ismapped, %isjunk, %repartition, @junk_ref, @all_ref ); + + print $report "----------------------------\n"; + print $report "Create subgroups:\nfastq_in: $fin\ndirectory_out: $dir\nmismatches: $mis\nmismatches TE: $mis_TE\n"; + + mkdir $dir; + $dir = $dir.'/' unless $dir =~ /(.*)\/$/; + + my $accept_miRNas = $dir.'miRNAs.fastq'; + my $reject_miRNAs = $dir.'miRNAs_rejected.fastq'; + my $sam_miRNAs = $dir.'miRNAs.sam'; + my @tmp = get_hash_alignment($miRNAs, $mis, 1, 1, $accept_miRNas, $reject_miRNAs, $fin, $proc, 'miRNAs',$sam_miRNAs, $report); + my $mi = $tmp[0]; + $repartition{'miRNAs'} = $mi; + + my $sam = new String::Random; + $sam = $sam->randpattern("CCcccccc"); + my $reject_rRNAs = $dir.'rRNAs_rejected.fastq'; + @tmp = get_hash_alignment($rRNAs, $mis, 0, 1, 'NA', $reject_rRNAs, $reject_miRNAs, $proc, 'rRNAs', $sam, $report); + $repartition{'rRNAs'} = $tmp[0]; + unlink $sam, $sam.'_aln.err', $sam.'_samse.err'; + + $sam = new String::Random; + $sam = $sam->randpattern("CCcccccc"); + my $reject_tRNAs = $dir.'tRNAs_rejected.fastq'; + @tmp = get_hash_alignment($tRNAs, $mis, 0, 1, 'NA', $reject_tRNAs, $reject_rRNAs, $proc, 'tRNAs', $sam, $report); + $repartition{'tRNAs'} = $tmp[0]; + unlink $sam, $sam.'_aln.err', $sam.'_samse.err'; + + $sam = new String::Random; + $sam = $sam->randpattern("CCcccccc"); + my $bonafide = $dir.'bonafide_reads.fastq'; + @tmp = get_hash_alignment($snRNAs, $mis, 0, 1, 'NA', $bonafide, $reject_tRNAs, $proc, 'snRNAs', $sam, $report); + $repartition{'snRNAs'} = $tmp[0]; + my $bo = $tmp[1]; + unlink $sam, $sam.'_aln.err', $sam.'_samse.err'; + + my $sam_exons = $dir.'exons.sam'; + my $reject_exons = $dir.'rejected_exons.fastq'; + @tmp = get_hash_alignment($exons, $mis, 0, 1, 'NA', $reject_exons, $bonafide, $proc, 'exons', $sam_exons, $report, $dir.'exons.fai'); + $repartition{'exons'} = $tmp[0]; + + + my $sam_TEs = $dir.'TEs.sam'; + my $reject_TEs = $dir.'rejected.fastq'; + @tmp = get_hash_alignment($TE, $mis_TE, 0, 1, 'NA', $reject_TEs, $reject_exons, $proc, 'TEs', $sam_TEs, $report, $dir.'TEs.fai' ); + $repartition{'TEs'} = $tmp[0] ; $repartition{'others'} = $tmp[1]; + unlink $sam, $sam.'_aln.err', $sam.'_samse.err'; + unlink $reject_exons; + unlink $reject_rRNAs; + unlink $reject_miRNAs; + unlink $reject_tRNAs; + + #create repartition + my $pi = fastqSubgroups($bonafide, $dir, $min_si, $max_si, $min_pi, $max_pi ); + + open (my $re, '>'.$dir.'repartition.txt') || die "cannot open $dir repartition.txt $!\n"; + print $re "type\tnumber\tpercentage\n"; + $sum += $_ foreach values %repartition; + foreach my $k ( sort keys %repartition ) + { + my $prct = 0; + $prct = $repartition{$k} / $sum * 100 if $sum != 0; + print $re "$k\t$repartition{$k}\t"; printf $re "%.2f\n",$prct; + } + return ( $bo, $mi, $pi); +} + +sub fastqSubgroups +{ + my ( $fastq, $output_directory, $min_si, $max_si, $min_pi, $max_pi ) = @_; + my $fastq_siRNA = $output_directory."siRNAs.fastq"; + my $fastq_piRNA = $output_directory."piRNAs.fastq"; + + open my $fic, '<', $fastq || die "cannot open input file $! \n"; + open my $si, '>', $fastq_siRNA || die "cannot open siRNA.fastq $! \n"; + open my $pi, '>', $fastq_piRNA || die "cannot open piRNA.fastq $! \n"; + + my ($length, $cmp, $type, $siRNA_number, $miRNA_h_number, $piRNA_number, $not_pi_number) = (0,0,0,0,0,0,0); + my (@fastq) =(); my $seq_name; + my $out; + while(<$fic>) + { + chomp $_; + $cmp++; + if ($cmp == 1) + { + die "file do not contain a @ at line $cmp\n" unless ($_ =~ /^\@/ ); + $type = 0; @fastq = (); + if ($_ =~ /^\@(.*)\s.*/) { $seq_name = $1;} + elsif ($_ =~ /^\@(.*)/) {$seq_name = $1;} + push(@fastq,$_); + } + elsif ($cmp == 2) + { + #die "unrecognized symbol at line $cmp\n" unless $_ =~ /[atcgATCGnN]+/; + push(@fastq,$_); + $length = length($_); + $type = 0; + if ( $length >= $min_si && $length <= $max_si ) + { + $type = 2; + $siRNA_number++; + } + if ($length >= $min_pi && $length <= $max_pi ) + { + $type += 4; + $piRNA_number++; + } + } + elsif ($cmp == 3 ) + { + die "file do not contain a + at line $cmp\n" unless $_ =~ /^\+/; + push(@fastq,$_); + } + elsif ($cmp == 4 ) + { + push(@fastq,$_); + $cmp = 0; + if ($type != 0) + { + if ($type & 4 ) { foreach my $t (@fastq) { print $pi $t."\n";} } + if ($type & 2 ) { foreach my $t (@fastq) { print $si $t."\n";} } + } + } + } + close $fic; + close $si; close $pi; + return ($piRNA_number); +} + +1; |
b |
diff -r 000000000000 -r 198009598544 piPipe.xml --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/piPipe.xml Wed Oct 11 09:57:58 2017 -0400 |
b |
b'@@ -0,0 +1,227 @@\n+<tool id="piPipe" name="piPipe" version="0.0.1">\n+ <description>Full studies of sRNA</description>\n+ <command interpreter="perl">\n+\n+ ./bin/piPipe.pl\n+\n+ --fastq ${first_input}\n+ --fastq_n ${first_input.name}\n+ #for $input_file in $input_files:\n+ --fastq ${input_file.additional_input}\n+ --fastq_n ${input_file.additional_input.name}\n+ #end for\n+\n+ #if $Genome.refGenomeSource == "history":\n+ --ref "${Genome.ownFile}"\n+ --build_index\n+ #else:\n+ --ref "${Genome.indices.fields.path}"\n+ #end if\n+\n+ #if $tRNAs.refGenomeSource == "history":\n+ --tRNAs "${tRNAs.ownFile}"\n+ --build_tRNAs\n+ #else:\n+ --tRNAs "${tRNAs.indices.fields.path}"\n+ #end if\n+\n+ #if $snRNAs.refGenomeSource == "history":\n+ --snRNAs "${snRNAs.ownFile}"\n+ --build_snRNAs\n+ #else:\n+ --snRNAs "${snRNAs.indices.fields.path}"\n+ #end if\n+\n+ #if $miRNAs.refGenomeSource == "history":\n+ --miRNAs "${miRNAs.ownFile}"\n+ --build_miRNAs\n+ #else:\n+ --miRNAs "${miRNAs.indices.fields.path}"\n+ #end if\n+\n+ #if $exons.refGenomeSource == "history":\n+ --exons "${exons.ownFile}"\n+ --build_exons\n+ #else:\n+ --exons "${exons.indices.fields.path}"\n+ #end if\n+\n+ #if $TE.refGenomeSource == "history":\n+ --TE "${TE.ownFile}"\n+ --build_TE\n+ #else:\n+ --TE "${TE.indices.fields.path}"\n+ #end if\n+\n+ #if $rRNAs.refGenomeSource == "history":\n+ --rRNAs "${rRNAs.ownFile}"\n+ --build_rRNAs\n+ #else:\n+ --rRNAs "${rRNAs.indices.fields.path}"\n+ #end if\n+\n+ --si_min $si_min\n+ --si_max $si_max\n+ --pi_min $pi_min\n+ --pi_max $pi_max\n+ --min $min\n+ --max $max\n+\n+ --mis $mis\n+ --misTE $misTE\n+ --dir $html_out.files_path\n+ --html $html_out\n+ --PPPon $PPPon\n+ </command>\n+\n+ <requirements>\n+ <requirement type="package" version="3.4.0">R</requirement>\n+ <requirement type="package" version="0.7.15-r1140">bwa</requirement>\n+ <requirement type="package" version="2.26.0">bedTools</requirement>\n+ <requirement type="package" version="1.5">samtools</requirement>\n+ </requirements>\n+\n+ <inputs>\n+ <param format="fastqsanger" name="first_input" type="data" label="fastq produced by fasteris" help=""/>\n+ <repeat name="input_files" title="Additional Fastq Files">\n+ <param format="fastqsanger" name="additional_input" type="data" label="fastq produced by fasteris" help=""/>\n+ </repeat>\n+ <conditional name="Genome">\n+ <param name="refGenomeSource" type="select" label="Will you select a reference genome from your history or use a built-in index?">\n+ <option value="indexed">Use a built-in index</option>\n+ <option value="history">Use one from the history</option>\n+ </param>\n+ <when value="indexed">\n+ <param name="indices" type="select" label="Select a reference genome">\n+ <options from_data_table="bwa_indexes">\n+ <filter type="sort_by" column="2" />\n+ <validator type="no_options" message="No indexes are available" />\n+ </options>\n+ </param>\n+ </when>\n+ <when value="history">\n+ <param name="ownFile" type="data" format="fasta" metadata_name="dbkey" label="Select a reference from history" />\n+ </when>\n+ </conditional>\n+ <conditional name="TE">\n+ <param name="refGenomeSource" type="select" label="Will you select TE database from your history or use a built-in index?">\n+ <option value="indexed">Use a built-in index</option>\n+ <option value="history">Use one from the history</option>\n+ </param>\n+ <when value="indexed">\n+ <param name="indices" type="select" label="Select a TE reference">\n+ <options from_data_table="bwa_indexes">\n+ <filter type="sort_by" column="2" />\n+ <validator type="no_options" message="No indexes are available" />\n+ </options>\n+ </param>\n+ </when>\n+ <when value="history">\n+ <param name="ownF'..b'ndexes">\n+ <filter type="sort_by" column="2" />\n+ <validator type="no_options" message="No indexes are available" />\n+ </options>\n+ </param>\n+ </when>\n+ <when value="history">\n+ <param name="ownFile" type="data" format="fasta" metadata_name="dbkey" label="Select a reference from history" />\n+ </when>\n+ </conditional>\n+ <conditional name="rRNAs">\n+ <param name="refGenomeSource" type="select" label="Will you select rRNAs database from your history or use a built-in index?">\n+ <option value="indexed">Use a built-in index</option>\n+ <option value="history">Use one from the history</option>\n+ </param>\n+ <when value="indexed">\n+ <param name="indices" type="select" label="Select a rRNAs reference">\n+ <options from_data_table="bwa_indexes">\n+ <filter type="sort_by" column="2" />\n+ <validator type="no_options" message="No indexes are available" />\n+ </options>\n+ </param>\n+ </when>\n+ <when value="history">\n+ <param name="ownFile" type="data" format="fasta" metadata_name="dbkey" label="Select a reference from history" />\n+ </when>\n+ </conditional>\n+ <conditional name="tRNAs">\n+ <param name="refGenomeSource" type="select" label="Will you select tRNA database from your history or use a built-in index?">\n+ <option value="indexed">Use a built-in index</option>\n+ <option value="history">Use one from the history</option>\n+ </param>\n+ <when value="indexed">\n+ <param name="indices" type="select" label="Select a tRNA reference">\n+ <options from_data_table="bwa_indexes">\n+ <filter type="sort_by" column="2" />\n+ <validator type="no_options" message="No indexes are available" />\n+ </options>\n+ </param>\n+ </when>\n+ <when value="history">\n+ <param name="ownFile" type="data" format="fasta" metadata_name="dbkey" label="Select a reference from history" />\n+ </when>\n+ </conditional>\n+ <conditional name="exons">\n+ <param name="refGenomeSource" type="select" label="Will you select exons database from your history or use a built-in index?">\n+ <option value="indexed">Use a built-in index</option>\n+ <option value="history">Use one from the history</option>\n+ </param>\n+ <when value="indexed">\n+ <param name="indices" type="select" label="Select a exons reference">\n+ <options from_data_table="bwa_indexes">\n+ <filter type="sort_by" column="2" />\n+ <validator type="no_options" message="No indexes are available" />\n+ </options>\n+ </param>\n+ </when>\n+ <when value="history">\n+ <param name="ownFile" type="data" format="fasta" metadata_name="dbkey" label="Select a reference from history" />\n+ </when>\n+ </conditional>\n+ <param name="min" type="integer" value="18" label="minimum read size"/>\n+ <param name="max" type="integer" value="29" label="maximum read size"/>\n+ <param name="si_min" type="integer" value="21" label="lower bound of siRNA range"/> \n+ <param name="si_max" type="integer" value="21" label="higher bound of siRNA range"/>\n+ <param name="pi_min" type="integer" value="23" label="lower bound of piRNA range"/>\n+ <param name="pi_max" type="integer" value="29" label="higher bound of piRNA range"/>\n+\n+ <param name="mis" type="integer" value="0" label="genome mismatches"/>\n+ <param name="misTE" type="integer" value="3" label="TE mismatches"/>\n+ <param name="PPPon" type="boolean" checked="true" label="PPPartners"/>\n+ </inputs>\n+ <outputs>\n+ <data format="html" name="html_out" label="${tool.name}_${first_input.name}_${on_string}"/>\n+\n+ <collection type="list" label="${tool.name}_fastq_outputs" name="output1">\n+ <discover_datasets pattern="(?P<name>.*)" directory="fastq_dir" />\n+ </collection>\n+\n+ </outputs>\n+</tool>\n' |
b |
diff -r 000000000000 -r 198009598544 test-data/TE-file-small.fa --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/test-data/TE-file-small.fa Wed Oct 11 09:57:58 2017 -0400 |
b |
b'@@ -0,0 +1,34 @@\n+>BATUMI_I\tBEL\tDrosophila melanogaster\n+ttttggtccttcgagccggatcacctggattttcaagtttgtccaccagcgaacaaattataagataagtacgaaatttccattccttttaattgccggtctgcagcaaaaggttcgaaaatccaatttcgttcaatttgctgtaagatttattgtcaaatctaacggatttctccgacaaaaggcaattaaagaaaagtacttatccaatctcacgggcgccgcatattactcgccgttctccgttctcctttcaccctcattcgtgaaaatttctaaagtccaaatgggcgaatatatttaaatattaatccagtgcgataatgcaaaattccaaatgtgaaaaagtgaataatttgtgccaagttcagtgaaactttctaagtccaaagctctgccaaaattggcaaaaattctgttctcgtttcactgtgtcaaagcgaagccaaacttcttttcgcaacacatttttgctttaactccgcagtccacttaataccatttgctttgctatcgaagaataccacaacgaaacaaacaacaccataccctctggccattcaaataacatattaattaacatttccgcagttccatatctcttacatcaacatatacctactccatactcttgcatatattcacatcttacacaatatatcctcaccatatattacatatattacatcaacatataatatccacatatattaccgacatacattgcgcatattatcagcattcctttaacgtataccaaagtttaaattcgatcccgtcggcaaatccaaccacaaataaaatttattccaagtgccgacgcggaaaggcgttttcttttccatcaattttttccgtaaatttccaaattaatttccgagcaataaattaaaagcggttttttctttttttttaacaaataacttattgttgaaaacatttattaaattattaaaaattatataaataatacgaccgccaaatacaagtcgttcacccgacaaatattttttcctgtattgcttggatattaatttgtgtttgttttagaagtacttacaacgcggagaaaagactccaaatccaccattccattttctccgtttccagttataaacaaaaaaataaataaaattttcttccttctaataaacattttattttaccgtgttcacattccaagtgttccaaccgtaaataaggtggacctaattaccataaatcacaggtcatttatacaattcgctgttcactccgagtcacctgtccaattagtctaaactacggcgtttccacttcgcaaattcaacaccactttctcacccattacatcctatacggtccttttccgctgctttataccgttcacggcaggaagcttaaatttattaagtggaatctgtctactttttcaaaagtgtgaccgggctccaaaaacgcttcccttccatttcgtatttcttcgattatgcccatcggggacgataagaagaaattgtccgctgacaaacccaggtctattttttcaccacaagggcccaagagtccaagaatcccaagcatttcggtgaaaacgcctgcgcagatttccgacgactgtgccactccatccaaagccacagtacagcgcacagctaaaaatatggctgcttccgatctagcgctagccaaattcatttcggtttctgacgctcaagcgaatttgaggctcagatcaacactccggaatccgcagctccaaccgtcacgatgcttagcgtccgtcgcgaccaagtccgaagcctatgggacaaggttgaaaagaattcgacctctgctcagagtgccttgtgtcagcaggcgagcggcagcaagcggcatgcctattctcagggctagttacagttattgctattcagtctatgaaaggtgtgttgcccagctcgttgataaaatcgagcaggggcacttctcagtccatcccaagcgaacgctgcggcccaggcctacatttcctctggctgtcggttgcctccatgcgatacaggagttttcgcaggtgactatcttcgctggccgctttccggatcttttacacgccatttatattaataatccacggctgactccgttcgaaaagttattccacttaaatgccaaaacaagtggcgacgcgcatgccatagtttcgatttcgcctctcaccaaacgagggttttcctctgcgtgggaaaacctaatagagcgtttcgaaaataaacgattgttggtaaacagtcaattgaaaatactgtttaatgtgcagtcgataccacaggaatctggggcggccttgaaggtaatgcaaagtactgttcaaggttgcttgactgccttagaactgtcaggcatcaacactgagaactgggactgcctgctggaatatctgtgttcatccaagctcccgaagataactctctccttatgggagcagtctctacataagaaagccgacatcccgacatggggagaactgaacaccttcctcacagaacgtcatcgaaccctagaggccatcgatgatgtgagaccgtccgtaccaagtcagtcgcactccaaagcgatgaactcaagtgggccctctagagatggcaagctggcgtccgacttgtgcaacaaggaaaaccatcctgtccgtgtatgtcgcgttttctccaaatggtcggttgacgaccggtcagcctacattaaacggaagcagttatgcttaaactactttgcaaagggacatcagcttcgtgagtgcaaagatcgacaaagttttacttggtggccggcatcacacgttgttgcaccgaaacaacctcttttccagcaattcaagcccttcaaatcctgcaagcccaatttccgctactcaggccaatttcgttccaaacgagcaagccggtgttcaaaattattttgccacggctcaagagctatccttcttggcagtgccataatcaatagttcccatcttggcactaactttaaggcacgcgccctgatcgactccggatcagaggcgacattcataaccgagccactgttcaatctaattagattgccattccaggtggttcaagcccaagtctcgggcttaaaccaaacagtagctgctcagttcaagaacgctgcagtttcaccatccgatctccgactaggccgcgttgcagttggagacgacggcctatgtcctccctcaactagccggaaatctgccttcctacccaattccgcaaaatttcttcgggatcttcccgattttccactggcggatccaaaattctatgagagcgccccaatagatgtacttatccggagcccacatcctgcttcggtgcttctgagtggagcaaaaaccaacatctgtggctctctcttggggcaagagaccattttccgctgggtactaactgggccagtgtcagcctcagcccaaagcaggattcctctttttcgacacagatctcccacgcgtacgataattcactggacaaactcctcacaaaatttggggaggtggaggatataccaacaaagttgcaaaagaatccgattccatgtgcgagaacgggttggtaaatgcttacgacgacaccagtgcggcaaatatgtcgttactctgccttttcgcgacccagaacatatcggttgcgggctagggcattctaggtcttgggcgttggctcagttcttgaagaatgagcagcgtctaaaaaaagatgaggccttgaaagcgagatacgattcggtgatccaggaatatctcgacttaaagcacatgcgacaagttctgcctacccatgattgcaacgcctattatatgccacatcacgccgtcttaaaaccggagagtgtaactactaaactccgtgtagtattcaatgcctccagcccttcatcgaatggtaccagtttaaatgatatccttcatgctgg'..b'ggaagtttataagagactttgcacgaataacgaagcccatgactaaacaattgaaagggaaaagacaagttactacagacaaagactttgtagacgcattcgaacagtgcaaaactcttctgtccaatgacccaatactcatacacccagacttcgaaaaaccattcattcttactacggatgctagtaacttcgcgttaggagccgtactatctcaaggctccttacaaaacgatagacctgtatgttttgccagcaggaccctctccgacaccgaagtcaactattcaaccatagaaaaagaaatgttggcaataatatgggcagtaaaatacttcagaccatatatttatggcgtaaaatttactattgttacagatcacaagccactaatatggcttatgaatttcaaagaacccaactcaaaaataattcgttggagactccaactcatggaatacaattttgaaataattcacaagaaaggttcacaaaatgtaattgcagacgccttaagtagagcggacccaaatttaaactacaacgaaacactgactgttaagccttgccccacatccgaaaaacctattaacgaatttaacacgcaactcatactagaaatagatacaaatacgtcttaccaaactacaacaccatttaaacaaaagattaggaaaaaatattcacagccttgcttcgatttcgataatattgttaaaatcttgaaaggaaccctaaaacctaacaggatttgcgcattcttggcggacgataataattccgcattaatcgaaaaagcattctcaacgtattttgcacataaaaaacactttaaaattatcagatgcaaatcacttctccacgaaatcgtaggaaaccccgaacaaaacaaattcattcaggaatatcacactaacagcaaccacagaggcatagacgaaacattccttcacctcaaacgagaaacctacttccccaatatgaaaaacaaaatctctgaattaattaggaattgcgaaacctgtctaaaactcaaatacgacaggcaaccacaaaatatagtatttgaaaccccagaaaccccatcgaaacccctcgacataatacacatagacatctatactattaacaataattttaacctgacaatcatagacaaattctcaaaattcgcagctgtctaccccatcccaaatagaaacggcatcaattgcatcaaagcaatcaaaaattttttcagtcaattcggactacccaaaaaactaatacacgaccaaggagtagaattttgcaacgacatatttcgaaagttttgctctcaatataatatacttctccatgtcacatccttccagcaatcttcaagtaattctccagtagaacgtttacactcctctttgacagagatttacagaataatactagacacacggaaaaaacacaaattacctacagaccacgaagaaataatgtcagaaactgtaataacatataacaacgcaatccactccaccaccaaacacaccccttttgaactttttaatggtaggacccatttattcgagaaaacaataatacccaataatgagcatgactatttaaataaactaaatacgttccaagacaaactatactccgaaataaaagaaaaattgtccacaaacacccaacaaaggatagaaaagctaaacacaagcagagtagaaccaacaacagtacaacctaacagcacaattttcagaaaagaaaacaggagaaataaattaacaccacggttttccttacacagaacagcaaaagacaaaggaaaaactctagtaaccacaagaaatcaaaaaatccacaaatcaaaaattaggaaaatatccaaacctccaaatgacttaagcctttccacctgcattccagatcttgccatggggcataccaatctatcttcatccacaacttcaatagcaccaacctcctagcaaaagtgccggtagggaaaacactcgtgataggaaactataaaaaaattagccacataatcgatctgtccgaatacaccaactgtattgaaaaattataccacaccatcgataccctaagacaagatgaaacactcaccgattctatatcaatactaaatgctaaactggcccaaactcaaagtaaaatagacgcactaacacccttttcacgccacaaaagaggtcttattaacgggttaggtagtttagtcaaagtcgtcaccggcaacatggacgccaatgatgcaaagaatatagaaacagaaattaaccacttaaaaagccagtccaccactatctcagataacttcgaaatacagaactcgttcaatgatgaagttcaactacggttcaaaaacttaacaagacacattaacaatgaacagaatttgattaaaaacttcttcgaaaacactcaaaatacaatttacacaaaaatatacaacaacgaagaagaaataaagaaactacaatatataaataggcttaactacaatatagatttattagttagccacctaagcgacattatagaaagtacactgcttgccaaaattaatgttatcccaaaactcatcttagacaagacagaaataaccaaaatcaaacaaatttttaaaacacaaaactacacaataaaatccgagcaacacatttataacctcttaaaaatgaacgcactcaattaccaaaacaaaataatttttagtatcaaaattcctatttttttaagttgtaactacgaaatggcaagattaattccacttccaataaattccacacaatttgtaatagcacctaagtacttaatatataataacaaaagtaacagcatgttttcaactatgtataaatgtcctgtaatagaagaacaattcgtctgcgaaatcgactccatcaataatcttaaaaataatacttgcctgggacaccttatccaaaataagaccagctactgcgacataaaggaaacgggactcacgactgatgtgttcgaaccggaaaaaggcttcatacttgtatttaacgggaacaacctcccaatcatctcctccaaccagaccataactagtatcaatggatcagctataataaagtataacaattgcacattaaaaatcaatgaaataaactacgacaacagggcggtatcaacagaagagcaccccgacttcttcctaccaccaatgcggaaactaataaaaaatgccactatcaacatactcaccttggaaagacttcacctggatacactcacaacatccaataagctactggtcgtcgccgcaggaaactctcgacactcgacaaccttgtatatcctcttcaccgtatccctagtcgccgtaatactcacctggacacttcgaagggacacccacatcttccataccgggcccgaccacattcttccaatcgtcgctccaccaattcctccgtctatggccttcgctccaaactggggggggagg\n+>ZAM_LTR\tGypsy\tDrosophila melanogaster\n+agttaccgacccatcggtaccatacaccacccctccctctaagccaccacgcctacacaagtagaagacatcgaaccgggaagctttgcgatacaaagttgcagcataaacatcaacaacgggtcagacgccgacatccgcccaaaatgctgacaccacatccttttcgctcagacagaacaacgcatacaattccatatacatacgtataaacatactcatactttctgctgtgtcagatactttatttctaagaactttaacattgtaatacatacacacatattcactgttagcccatttaagacgaagaataaagacgaccacagtcgagtgcaagcagcaaacacttgtagacgtacataatctccgatcaaaattctcccaagacgaccgtggctacgttctggacccgcataactcctctatctttctgagtgataatacctccgcaagactccccggaggtaac\n' |
b |
diff -r 000000000000 -r 198009598544 test-data/dmel-all-rRNA-r6.03.fasta --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/test-data/dmel-all-rRNA-r6.03.fasta Wed Oct 11 09:57:58 2017 -0400 |
b |
b'@@ -0,0 +1,294 @@\n+>FBtr0086345 type=rRNA; loc=2R:complement(19766144..19766278); ID=FBtr0086345; name=5SrRNA:CR33353-RA; dbxref=FlyBase:FBtr0086345,FlyBase_Annotation_IDs:CR33353-RA,REFSEQ:NR_001892; score=0; score_text=Weakly Supported; MD5=9162f14f3b33b2210e2100cada0b7f92; length=135; parent=FBgn0053353; release=r6.03; species=Dmel; \n+GCCAACGACCATACCACGCTGAATACATCGGTTCTCGTCCGATCACCGAAATTAAGCAGCGTCGGGCGCGGTTAGTACTTAGATGAGGGACCGCTTGGGAACACCGCGTGTTGTTGGCCTCGTCCACAACTTTTT\n+>FBtr0086346 type=rRNA; loc=2R:complement(19765775..19765909); ID=FBtr0086346; name=5SrRNA:CR33354-RA; dbxref=FlyBase:FBtr0086346,FlyBase_Annotation_IDs:CR33354-RA,REFSEQ:NR_001891; score=0; score_text=Weakly Supported; MD5=9162f14f3b33b2210e2100cada0b7f92; length=135; parent=FBgn0053354; release=r6.03; species=Dmel; \n+GCCAACGACCATACCACGCTGAATACATCGGTTCTCGTCCGATCACCGAAATTAAGCAGCGTCGGGCGCGGTTAGTACTTAGATGAGGGACCGCTTGGGAACACCGCGTGTTGTTGGCCTCGTCCACAACTTTTT\n+>FBtr0086347 type=rRNA; loc=2R:complement(19765409..19765543); ID=FBtr0086347; name=5SrRNA:CR33355-RA; dbxref=FlyBase:FBtr0086347,FlyBase_Annotation_IDs:CR33355-RA,REFSEQ:NR_001890; score=0; score_text=Weakly Supported; MD5=9162f14f3b33b2210e2100cada0b7f92; length=135; parent=FBgn0053355; release=r6.03; species=Dmel; \n+GCCAACGACCATACCACGCTGAATACATCGGTTCTCGTCCGATCACCGAAATTAAGCAGCGTCGGGCGCGGTTAGTACTTAGATGAGGGACCGCTTGGGAACACCGCGTGTTGTTGGCCTCGTCCACAACTTTTT\n+>FBtr0086349 type=rRNA; loc=2R:complement(19764648..19764782); ID=FBtr0086349; name=5SrRNA:CR33357-RA; dbxref=FlyBase:FBtr0086349,FlyBase_Annotation_IDs:CR33357-RA,REFSEQ:NR_001888; score=0; score_text=Weakly Supported; MD5=dacf3866c94cfe27156e359c01e8f212; length=135; parent=FBgn0053357; release=r6.03; species=Dmel; \n+GCCAACGACCATACCACGCTGAATACATCGGTTCTCGTCCGATCACCGAAATTAAGCAGCGTCGGGCGCGGTTAGTACTTAGATGGGGGACCGCTTGGGAACACCGCGTGTTGTTGGCCTCGTCCACAACTTTTT\n+>FBtr0086350 type=rRNA; loc=2R:complement(19764289..19764423); ID=FBtr0086350; name=5SrRNA:CR33358-RA; dbxref=FlyBase:FBtr0086350,FlyBase_Annotation_IDs:CR33358-RA,REFSEQ:NR_001887; score=0; score_text=Weakly Supported; MD5=dacf3866c94cfe27156e359c01e8f212; length=135; parent=FBgn0053358; release=r6.03; species=Dmel; \n+GCCAACGACCATACCACGCTGAATACATCGGTTCTCGTCCGATCACCGAAATTAAGCAGCGTCGGGCGCGGTTAGTACTTAGATGGGGGACCGCTTGGGAACACCGCGTGTTGTTGGCCTCGTCCACAACTTTTT\n+>FBtr0086351 type=rRNA; loc=2R:complement(19763913..19764047); ID=FBtr0086351; name=5SrRNA:CR33359-RA; dbxref=FlyBase:FBtr0086351,FlyBase_Annotation_IDs:CR33359-RA,REFSEQ:NR_001886; score=0; score_text=Weakly Supported; MD5=dacf3866c94cfe27156e359c01e8f212; length=135; parent=FBgn0053359; release=r6.03; species=Dmel; \n+GCCAACGACCATACCACGCTGAATACATCGGTTCTCGTCCGATCACCGAAATTAAGCAGCGTCGGGCGCGGTTAGTACTTAGATGGGGGACCGCTTGGGAACACCGCGTGTTGTTGGCCTCGTCCACAACTTTTT\n+>FBtr0086352 type=rRNA; loc=2R:complement(19763544..19763678); ID=FBtr0086352; name=5SrRNA:CR33360-RA; dbxref=FlyBase:FBtr0086352,FlyBase_Annotation_IDs:CR33360-RA,REFSEQ:NR_001885; score=0; score_text=Weakly Supported; MD5=dacf3866c94cfe27156e359c01e8f212; length=135; parent=FBgn0053360; release=r6.03; species=Dmel; \n+GCCAACGACCATACCACGCTGAATACATCGGTTCTCGTCCGATCACCGAAATTAAGCAGCGTCGGGCGCGGTTAGTACTTAGATGGGGGACCGCTTGGGAACACCGCGTGTTGTTGGCCTCGTCCACAACTTTTT\n+>FBtr0086353 type=rRNA; loc=2R:complement(19763175..19763309); ID=FBtr0086353; name=5SrRNA:CR33361-RA; dbxref=FlyBase:FBtr0086353,FlyBase_Annotation_IDs:CR33361-RA,REFSEQ:NR_001884; score=0; score_text=Weakly Supported; MD5=9162f14f3b33b2210e2100cada0b7f92; length=135; parent=FBgn0053361; release=r6.03; species=Dmel; \n+GCCAACGACCATACCACGCTGAATACATCGGTTCTCGTCCGATCACCGAAATTAAGCAGCGTCGGGCGCGGTTAGTACTTAGATGAGGGACCGCTTGGGAACACCGCGTGTTGTTGGCCTCGTCCACAACTTTTT\n+>FBtr0086354 type=rRNA; loc=2R:complement(19762802..19762936); ID=FBtr0086354; name=5SrRNA:CR33362-RA; dbxref=FlyBase:FBtr0086354,FlyBase_Annotation_IDs:CR33362-RA,REFSEQ:NR_001883; score=0; score_text=Weakly Supported; MD5=dacf3866c94cfe27156e359c01e8f212; length=135; parent=FBgn0053362; release=r6.03; species=Dme'..b'AATTATCATTGATTTTTGTGTTTATTATATGCACTTGTATGATTAACAATGCGAAAGATTCAGGATACCTTCGGGACCCGTCTTGAAACACGGACCAAGGAGTCTAACATATGTGCAAGTTATTGGGATATAAACCTAATAGCGTAATTAACTTGACTAATAATGGGATTAGTTTTTTAGCTATTTATAGCTAATTAACACAATCCCGGGGCGTTCTATATAGTTATGTATAATGTATATTTATATTATTTATGCCTCTAACTGGAACGTACCTTGAGCATATATGCTGTGACCCGAAAGATGGTGAACTATACTTGATCAGGTTGAAGTCAGGGGAAACCCTGATGGAAGACCGAAACAGTTCTGACGTGCAAATCGATTGTCAGAATTGAGTATAGGGGCGAAAGACCAATCGAACCATCTAGTAGCTGGTTCCTTCCGAAGTTTCCCTCAGGATAGCTGGTGCATTTTAATATTATATAAAATAATCTTATCTGGTAAAGCGAATGATTAGAGGCCTTAGGGTCGAAACGATCTTAACCTATTCTCAAACTTTAAATGGGTAAGAACCTTAACTTTCTTGATATGAAGTTCAAGGTTATGATATAATGTGCCCAGTGGGCCACTTTTGGTAAGCAGAACTGGCGCTGTGGGATGAACCAAACGTAATGTTACGGTGCCCAAATTAACAACTCATGCAGATACCATGAAAGGCGTTGGTTGCTTAAAACAGCAGGACGGTGATCATGGAAGTCGAAATCCGCTAAGGAGTGTGTAACAACTCACCTGCCGAAGCAACTAGCCCTTAAAATGGATGGCGCTTAAGTTGTATACCTATACATTACCGCTAAAGTAGATGATTTATATTACTTGTGATATAAATTTTGAAACTTTAGTGAGTAGGAAGGTACAATGGTATGCGTAGAAGTGTTTGGCGTAAGCCTGCATGGAGCTGCCATTGGTACAGATCTTGGTGGTAGTAGCAAATAATCGAATGAGACCTTGGAGGACTGAAGTGGAGAAGGGTTTCGTGTGAACAGTGGTTGATCACGAGTTAGTCGGTCCTAAGTTCAAGGCGAAAGCCGAAAATTTTCAAGTAAAACAAAAATGCCTAACTATATAAACAAAGCGAATTATAATACACTTGAATAATTTTGAACGAAAGGGAATACGGTTCCAATTCCGTAACCTGTTGAGTATCCGTTTGTTATTAAATATGGGCCTCGTGCTCATCCTGGCAACAGGAACGACCATAAAGAAGCCGTCGAGAGATATCGGAAGAGTTTTCTTTTCTGTTTTATAGCCGTACTACCATGGAAGTCTTTCGCAGAGAGATATGGTAGATGGGCTAGAAGAGCATGACATATACTGTTGTGTCGATATTTTCTCCTCGGACCTTGAAAATTTATGGTGGGGACACGCAAACTTCTCAACAGGCCGTACCAATATCCGCAGCTGGTCTCCAAGGTGAAGAGTCTCTAGTCGATAGAATAATGTAGGTAAGGGAAGTCGGCAAATTAGATCCGTAACTTCGGGATAAGGATTGGCTCTGAAGATTGAGATAGTCGGGCTTGATTGGGAAACAATAACATGGTTTATGTGCTCGTTCTGGGTAAATAGAGTTTCTAGCATTTATGTTAGTTACTTGTTCCCCGGATAGTTTAGTTACGTAGCCAATTGTGGAACTTTCTTGCTAAAATTTTTAAGAATACTATTTGGGTTAAACCAATTAGTTCTTATTAATTATAACGATTATCAATTAACAATCAATTCAGAACTGGCACGGACTTGGGGAATCCGACTGTCTAATTAAAACAAAGCATTGTGATGGCCCTAGCGGGTGTTGACACAATGTGATTTCTGCCCAGTGCTCTGAATGTCAAAGTGAAGAAATTCAAGTAAGCGCGGGTCAACGGCGGGAGTAACTATGACTCTCTTAAGGTAGCCAAATGCCTCGTCATCTAATTAGTGACGCGCATGAATGGATTAACGAGATTCCTACTTGTCCCTATCTACTATCTAGCGAAACCACAGCCAAGGGAACGGGCTTGGAATAATTAGCGGGGAAAGAAGACCCTTTTGAGCTTGACTCTAATCTGGCAGTGTAAGGAGACATAAGAGGTGTAGAATAAGTGGGAGATATTAGACCTCGGTTTGGTATCGTCAATGAAATACCACTACTCTTATTGTTTCCTTACTTACTTGATTAAATGGAACGTGTATCATTTCCTAGCCATTATACGGATATATTTATTATATCTTATGGTATTGGGTTTTGATGCAAGCTTCTTGATCAAAGTATCACGAGTTTGTTATATAATCGCAAACAAATTCTTTAATAAAACGATGCATTTATGTATTTTTGATTTGAAAATTTGGTATAACTCCAATTACTCAGGTATGATCCAATTCAAGGACATTGCCAGGTAGGGAGTTTGACTGGGGCGGTACATCTCTCAAATAATAACGGAGGTGTCCCAAGGCCAGCTCAGTGCGGACAGAAACCACACATAGAGCAAAAGGGCAAATGCTGACTTGATCTCGGTGTTCAGTACACACAGGGACAGCAAAAGCTCGGCCTATCGATCCTTTTGGTTTAAAGAGTTTTTAACAAGAGGTGTCAGAAAAGTTACCATAGGGATAACTGGCTTGTGGCGGCCAAGCGTTCATAGCGACGTCGCTTTTTGATCCTTCGATGTCGGCTCTTCCTATCATTGTGAAGCAAAATTCACCAAGCGTTGGATTGTTCACCCATGCAAGGGAACGTGAGCTGGGTTTAGACCGTCGTGAGACAGGTTAGTTTTACCCTACTAATGACAAAACGTTGTTGCGACAGCATTCCTGCGTAGTACGAGAGGAACCGCAGGTACGGACCAATGGCACAATACTTGTTCGAGCGAACAGTGGTATGACGCTACGTCCGTTGGATTATGCCTGAACGCCTCTAAGGTCGTATCCGTGCTGGACTGCAATGATAAATAAGGGGCAATTTGCATTGTATGGCTTCTAAACCATTTAAAGTTTATAATTTACTTTATAAACGACAATGGATGTGATGCCAATGTAATTTGTAACATAGTAAATTGGGAGGATCTTCGATCACCTGATGCCGCGCTAGTTACATATAAAAGCATTATTTAATACAATGACAAAGCCTAGAATCAATTGTAAACGACTTTTGTAACAGGCAAGGTGTTGTAAGTGGTTGAGCAGCTGCCATACTGCGATCCACTGAAGCTTATCCTTTGCTTGATGATTCGA\n+>FBtr0346887 type=rRNA; loc=rDNA:46205..46327; ID=FBtr0346887; name=5.8SrRNA:CR45852-RA; dbxref=FlyBase:FBtr0346887,FlyBase_Annotation_IDs:CR45852-RA; score=1; score_text=Weakly Supported; MD5=7f8e1dfdda0f9ae351c9e28c52e54e21; length=123; parent=FBgn0267512; release=r6.03; species=Dmel; \n+AACTCTAAGCGGTGGATCACTCGGCTCATGGGTCGATGAAGAACGCAGCAAACTGTGCGTCATCGTGTGAACTGCAGGACACATGAACATCGACATTTTGAACGCATATCGCAGTCCATGCTG\n+>FBtr0346898 type=rRNA; loc=X:23291700..23291729; ID=FBtr0346898; name=2SrRNA:CR45864-RA; dbxref=FlyBase:FBtr0346898,FlyBase_Annotation_IDs:CR45864-RA; score=1; score_text=Weakly Supported; MD5=79181b9131521cbf99fa2d8f99e7b410; length=30; parent=FBgn0267524; release=r6.03; species=Dmel; \n+TGCTTGGACTACATATGGTTGAGGGTTGTA\n' |
b |
diff -r 000000000000 -r 198009598544 test-data/dmel-all-sn-snoRNA-r6.03.fasta --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/test-data/dmel-all-sn-snoRNA-r6.03.fasta Wed Oct 11 09:57:58 2017 -0400 |
b |
b'@@ -0,0 +1,638 @@\n+>FBtr0081560 type=snoRNA; loc=3R:complement(7472907..7473222); ID=FBtr0081560; name=scaRNA:MeU5-C46-RA; dbxref=FlyBase:FBtr0081560,FlyBase_Annotation_IDs:CR32863-RA,REFSEQ:NR_001999; score=0; score_text=Weakly Supported; MD5=001dca55ff90bbedfc8b9a3593a2c84c; length=316; parent=FBgn0043853; release=r6.03; species=Dmel; \n+TGCCCATGATGAAATATTCGACATCGGAGTTTGCGCATTGGCGACAAGACCTAAGGCTCAGACTCTAGCAAATCTAGTTTCATCCGTTGTAATCTTTGCTGCTGCACTCCAGAATTTGCAGTGGCCGTAAGGCCAGCGGGACACCAACAGCCAGGGATCAAGACTATTATCTGTCATTGAGTCCTAGACAGATAGTTTAGTCTCTGGTTTACAGAACACCCAAATGGAAATGAAACACGCGCTTTTGTCGACCCAGGAGCCAGTTAGGTCTAAGCTGTTTGTCATGGTGACGACGTCTTTAGTAATCTGAGCGCAA\n+>FBtr0070292 type=snoRNA; loc=X:complement(1482492..1482590); ID=FBtr0070292; name=snoRNA:M-RA; dbxref=FlyBase:FBtr0070292,FlyBase_Annotation_IDs:CR32807-RA,REFSEQ:NR_002093; score=0; score_text=Weakly Supported; MD5=81314d41b5db15222ab4c0daca9e3a65; length=99; parent=FBgn0044508; release=r6.03; species=Dmel; \n+AATTCAATGATTTCAACTTCACTGCTGACCAGCCACGCCTCAACGCCTCGGAGTGTTTGCCCCCAGTCTCTGATAGATACACCATATTCTAATACACAC\n+>FBtr0076635 type=snoRNA; loc=3L:8601948..8602031; ID=FBtr0076635; name=snoRNA:U49:66Db-RA; dbxref=FlyBase:FBtr0076635,FlyBase_Annotation_IDs:CR32910-RA,REFSEQ:NR_001955; score=0; score_text=Weakly Supported; MD5=b2175b964d1d7e4cbe00bd8e55b73ca8; length=84; parent=FBgn0060291; release=r6.03; species=Dmel; \n+CTGCACATGATGATAATTGAAAGTTCTTGATAGGAATTGCCGGCTGACACATATATGAAGCTAATTCTAGTTTATCTGATTACA\n+>FBtr0076634 type=snoRNA; loc=3L:8601473..8601552; ID=FBtr0076634; name=snoRNA:U49:66Da-RA; dbxref=FlyBase:FBtr0076634,FlyBase_Annotation_IDs:CR32911-RA,REFSEQ:NR_001954; score=0; score_text=Weakly Supported; MD5=9f94db9a46640f6af279661b83c98768; length=80; parent=FBgn0060292; release=r6.03; species=Dmel; \n+TGCACATGATGATAATTTGTCTTCTTGATAGGAAGTGCCAACTGACACATAAATGAAGCTAGTTTAACCCTCTGAAAGCA\n+>FBtr0086857 type=snoRNA; loc=2R:17702873..17702949; ID=FBtr0086857; name=snoRNA:snR38:54Ec-RA; dbxref=FlyBase:FBtr0086857,FlyBase_Annotation_IDs:CR32901-RA,REFSEQ:NR_001769; score=1; score_text=Weakly Supported; MD5=b4b17beebede66cbd74a108e03863fa7; length=77; parent=FBgn0063373; release=r6.03; species=Dmel; \n+ATGATGTGATGAACACCTTATTTAAGCCAAACAGTTATCCCTGTCATAAGAATAATTGATGATATATTCAGCTGACA\n+>FBtr0086852 type=snoRNA; loc=2R:17701689..17701764; ID=FBtr0086852; name=snoRNA:snR38:54Eb-RA; dbxref=FlyBase:FBtr0086852,FlyBase_Annotation_IDs:CR32896-RA,REFSEQ:NR_001764; score=0; score_text=Weakly Supported; MD5=8d40774ceb21d85153c649f6fc4db139; length=76; parent=FBgn0063374; release=r6.03; species=Dmel; \n+CCTTTGTGATGAGCATCCTTTTAAAGCCAAACAGTTATCCCTGTCATAAGAATAATTGATGATACAATAATCTGAC\n+>FBtr0086851 type=snoRNA; loc=2R:17701447..17701523; ID=FBtr0086851; name=snoRNA:Me28S-G3277a-RA; dbxref=FlyBase:FBtr0086851,FlyBase_Annotation_IDs:CR32893-RA,REFSEQ:NR_001763; score=0; score_text=Weakly Supported; MD5=600b5d664ea787a79c37dee706e5f5c3; length=77; parent=FBgn0063375; release=r6.03; species=Dmel; \n+GGGCAATGATGAACACTTTATTTAAGCCAAACAGTTATCCCTGTCATAAGAATAATTGATGATAAAAGTTGCTGATT\n+>FBtr0086848 type=snoRNA; loc=2R:17700741..17700813; ID=FBtr0086848; name=snoRNA:U76:54Eb-RA; dbxref=FlyBase:FBtr0086848,FlyBase_Annotation_IDs:CR32891-RA,REFSEQ:NR_001760; score=0; score_text=Weakly Supported; MD5=f3741fc5731e0cc5330b00315b4c69eb; length=73; parent=FBgn0063376; release=r6.03; species=Dmel; \n+TGAAAATGATGATTAATTATTATTTGCTACTCTTGAAGAGCTTTGATGAATACTTACACCTTAGAAACTGAGT\n+>FBtr0086845 type=snoRNA; loc=2R:17699932..17700004; ID=FBtr0086845; name=snoRNA:Me28S-A1666a-RA; dbxref=FlyBase:FBtr0086845,FlyBase_Annotation_IDs:CR32889-RA,REFSEQ:NR_001757; score=1; score_text=Weakly Supported; MD5=31c77ac9f94d8024de98d0866f13ded1; length=73; parent=FBgn0063377; release=r6.03; species=Dmel; \n+TGTAAATGATGATTTATTATTATTTGCTACTCTTGAAGGTCATTGATGAATACTTTCACCTTAAAACCTGATG\n+>FBtr0086855 type=snoRNA; loc=2R:17702411..17702477; ID=FBtr0086855; name=snoRNA:U31:54Ed-RA; dbxref=FlyBase:FBtr0086855,FlyBase_Annotation_IDs:CR32899-RA,REFSEQ:NR_001767; score=1; score'..b'1f5; length=192; parent=FBgn0041720; release=r6.03; species=Dmel; \n+ATCGCTTCTCGGCCTTATGGCTAAGATCAAAGTGTAGTATCTGTTCTTATCAGCTTAACATCTGATAGTTCCTCCATTGGAGGACAACAAATGTTAAACTGATTTTTGGAATCAGACGGAGTGCTAGGAGCTTGCTCCACCTCTGTCGCGGGTTGGCCCGGTATTGCAGTACCGCCGGGATTTCGGCCCAAC\n+>FBtr0075315 type=snRNA; loc=3L:16653769..16654006; ID=FBtr0075315; name=snRNA:U12:73B-RA; dbxref=FlyBase:FBtr0075315,FlyBase_Annotation_IDs:CR32162-RA,REFSEQ:NR_001972; score=0; score_text=Weakly Supported; MD5=d1d774f1395d1eac2663f02d5417bf80; length=238; parent=FBgn0041721; release=r6.03; species=Dmel; \n+GTGCCTCAAACTAATGAGTAAGGAAAACCAATCAGCCTTGCTAATCGCTTGGCAGTATTGGCTTCTAGGCAGGGGGGCGTGTCCCGCGCCCCTTGAAGCTCAAATTTTTGCAAGGGCACAGGTCGTCCCCTCCTCCTCCGCGTGGGTGGCGTTCGGCCGAGCGAACCGGCGCCTACTTTGCGTCCGGCTAGCGAGGATCTCTGGGTGCCATCCCACGGCTGGGTGTTGCGATCTGCCC\n+>FBtr0081294 type=snRNA; loc=2L:19816414..19816540; ID=FBtr0081294; name=snRNA:U5:38ABb-RA; dbxref=FlyBase:FBtr0081294,FlyBase_Annotation_IDs:CR32880-RA,REFSEQ:NR_001674; score=0; score_text=Weakly Supported; MD5=a01600165b1bf498f3106a7b1d3e6994; length=127; parent=FBgn0043021; release=r6.03; species=Dmel; \n+ACTCTGGTTTCTCTTCAATTGTCGAATAAATCTTTCGCCTTTTACTAAAGATTTCCGTGGAGAGGAACACTCTAATGAGTCTAAACACAATTTTTATTGAGGCCTGATAACTTATGCTATCGGGCCA\n+>FBtr0081315 type=snRNA; loc=2L:complement(19811948..19812074); ID=FBtr0081315; name=snRNA:U5:38ABa-RA; dbxref=FlyBase:FBtr0081315,FlyBase_Annotation_IDs:CR32881-RA,REFSEQ:NR_001671; score=0; score_text=Weakly Supported; MD5=668f472d3ac9ab7cff94b99e52c1cd78; length=127; parent=FBgn0043022; release=r6.03; species=Dmel; \n+TACTCTGGTTTCTCTTCAATTGTCGAATAAATCTTTCGCCTTTTACTAAAGATTTCCGTGGAGAGGAACACTCTAATGAGTCTAAACTCAATTTTTGTATGACCTGGCTAAATATTTAGTTGGGCCA\n+>FBtr0100848 type=snRNA; loc=3L:3593823..3593893; ID=FBtr0100848; name=snRNA:U7-RA; dbxref=FlyBase_Annotation_IDs:CR33504-RA,FlyBase:FBtr0100848,REFSEQ:NR_002270; score=0; score_text=Weakly Supported; MD5=deb394a435f81cd75ed6b95c5a32647e; length=71; parent=FBgn0053504; release=r6.03; species=Dmel; \n+ATTGAAAATTTTTATTCTCTTTGAAATTTGTCTTGGTGGGACCCTTTGTCTAGGCATTGAGTGTTCCCGTT\n+>FBtr0091929 type=snRNA; loc=3R:complement(7474553..7474996); ID=FBtr0091929; name=snRNA:7SK-RA; dbxref=FlyBase:FBtr0091929,FlyBase_Annotation_IDs:CR33925-RA,REFSEQ:NR_002493,REFSEQ:NR_002493,REFSEQ:NR_002493; score=0; score_text=Weakly Supported; MD5=7cfa92ec944a572fe4ebf5510d257106; length=444; parent=FBgn0065099; release=r6.03; species=Dmel; \n+GGAAGTGTATTCTGTGATTGTTCTGTACATTGATCGATATTCAGGTAACTGCATCTGCTTATCAGATCTGTTCAGAGCCGACCCTCCGTCACACCTTTGTGTTTCCCAGTAATTCTGCCTGGCGTTGCCGTGGCTCCTCGTTCGGATCGGCTTTCCGCTGCCTTCCACTGGATGACGACGGGTTATCCGGCGGTCGACGCACGGTCATGCACCCCCGATCCGTCGCCCCCACCACCCCGCGGATTCTGGTCTCGACCGGAAGCCGTATTGGGCGGGGACGGGCGGCGGTCCGGTGCTGAAGCCGGCGACAGTTGCCCGAGTCAGCCACTTTCAAAATTTGTTGGTTAAGTAACTTAGTAGCTTAGCTTCGGATTTTCGTAACAAATTTGCTGTTCAGAACACTTCCATGTACGCGGCATTGCCGAGCAATTTGCCCATTCTTTT\n+>FBtr0111039 type=snRNA; loc=3L:complement(3893056..3893330); ID=FBtr0111039; name=snRNA:U11-RA; dbxref=FlyBase:FBtr0091696,FlyBase:FBtr0111039,FlyBase_Annotation_IDs:CR34151-RA,FlyBase_Annotation_IDs:CR33708-RA,REFSEQ:NR_003121; score=1; score_text=Weakly Supported; MD5=614c010295f08932d4b6d778d2e59eab; length=275; parent=FBgn0083987; release=r6.03; species=Dmel; \n+AAAAAGGGTGCTCGTCCTGGCACGTTTCCGATCACGAAACTCAAGTGCGGACGCATTGCGCCGCAGGAGCGTCTCCTTCGCTCCGCCCCTGGACTTCTCCGGGGATAGGCGGGGGCGAGCGTTCCATTGCCGCCTTCGACGCCTCCTTGCGCGCCCAGTGGGGTATGGCTTTGCATATCCAGTGCGTAATTTTTGTATTTGGGGCCGCGGCTGCACATTGTGGATTGCTCGGGGATTCCCGGATCTCCCTGCGTGCCAGTGCGCTGCGCCCCGCC\n+>FBtr0306791 type=snRNA; loc=3R:complement(5195004..5195163); ID=FBtr0306791; name=snRNA:U4atac:82E-RA; dbxref=REFSEQ:NR_048324,FlyBase:FBtr0306791,FlyBase_Annotation_IDs:CR43269-RA; score=0; score_text=Weakly Supported; MD5=e1ae4c911a264f805369d33185bc3304; length=160; parent=FBgn0263018; release=r6.03; species=Dmel; \n+ACCTTCCTTGTCTTGGGGAGCAGAAATGTTCAATGAACGTCTAGTGAGGACATTGCTGCTGACACCAATGATGACACCCCCGCTCGCCGATCGTTCGCGATTGGAGTTCGGAATTTTTGGACCAGGCTCCTTTACTTTACAGGGAGCCGCCTCTTGAATG\n' |
b |
diff -r 000000000000 -r 198009598544 test-data/dmel-all-tRNA-r6.03.fasta --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/test-data/dmel-all-tRNA-r6.03.fasta Wed Oct 11 09:57:58 2017 -0400 |
b |
b'@@ -0,0 +1,671 @@\n+>FBtr0086234 type=tRNA; loc=2R:20657891..20657962; ID=FBtr0086234; name=tRNA:CR30155-RA; dbxref=FlyBase:FBtr0086234,FlyBase_Annotation_IDs:CR30155-RA; score=0; score_text=Weakly Supported; MD5=243cf738b4d1a6d2ea2ee34d091c0d0a; length=72; parent=FBgn0050155; release=r6.03; species=Dmel; \n+GACTCCGTGGCGCAACGGTAGCGCGTCTGACTCCAGATCAGAAGGTTGCGTGTTCAAATCACGTCGGGGTCA\n+>FBtr0072445 type=tRNA; loc=2R:25076005..25076076; ID=FBtr0072445; name=tRNA:CR30198-RA; dbxref=FlyBase:FBtr0072445,FlyBase_Annotation_IDs:CR30198-RA; score=0; score_text=Weakly Supported; MD5=0402c54abcbe0755c6f346504ea6eadc; length=72; parent=FBgn0050198; release=r6.03; species=Dmel; \n+GGGGACGTAGCTCAGTGGTAGAGCGCTCGCTTCGCATGTGAGAAGTCCCGGGTTCAAACCCCGGCGTCTCCA\n+>FBtr0072446 type=tRNA; loc=2R:25076765..25076836; ID=FBtr0072446; name=tRNA:CR30199-RA; dbxref=FlyBase:FBtr0072446,FlyBase_Annotation_IDs:CR30199-RA; score=0; score_text=Weakly Supported; MD5=0402c54abcbe0755c6f346504ea6eadc; length=72; parent=FBgn0050199; release=r6.03; species=Dmel; \n+GGGGACGTAGCTCAGTGGTAGAGCGCTCGCTTCGCATGTGAGAAGTCCCGGGTTCAAACCCCGGCGTCTCCA\n+>FBtr0072447 type=tRNA; loc=2R:25077048..25077119; ID=FBtr0072447; name=tRNA:CR30200-RA; dbxref=FlyBase:FBtr0072447,FlyBase_Annotation_IDs:CR30200-RA; score=0; score_text=Weakly Supported; MD5=0402c54abcbe0755c6f346504ea6eadc; length=72; parent=FBgn0050200; release=r6.03; species=Dmel; \n+GGGGACGTAGCTCAGTGGTAGAGCGCTCGCTTCGCATGTGAGAAGTCCCGGGTTCAAACCCCGGCGTCTCCA\n+>FBtr0071983 type=tRNA; loc=2R:complement(23072019..23072100); ID=FBtr0071983; name=tRNA:CR30201-RA; dbxref=FlyBase:FBtr0071983,FlyBase_Annotation_IDs:CR30201-RA; score=0; score_text=Weakly Supported; MD5=b1d29cdc3617f5d88834dfcf6cb94669; length=82; parent=FBgn0050201; release=r6.03; species=Dmel; \n+GCTGCGGTGTCCGAGTGGTTAAGGAGATGGACTTGAAATCCATTGGGTTCTACCCGCACAGGTTCAAGTCCTGTCCGCA\n+GCG\n+>FBtr0071962 type=tRNA; loc=2R:23072581..23072662; ID=FBtr0071962; name=tRNA:CR30202-RA; dbxref=FlyBase:FBtr0071962,FlyBase_Annotation_IDs:CR30202-RA; score=0; score_text=Weakly Supported; MD5=79b58dd799cb26435c738e215a4d9d46; length=82; parent=FBgn0050202; release=r6.03; species=Dmel; \n+GTTGCGGTGTCCGAGTGGTTAAGGAGATGGACTTGAAATCCATTGGGTTCTACCCGCGCAGGTTCGAATCCTGTCCGCA\n+GCG\n+>FBtr0071631 type=tRNA; loc=2R:complement(21161063..21161134); ID=FBtr0071631; name=tRNA:CR30206-RA; dbxref=FlyBase:FBtr0071631,FlyBase_Annotation_IDs:CR30206-RA; score=0; score_text=Weakly Supported; MD5=9ff9c8260337fb111671830edb8e3824; length=72; parent=FBgn0050206; release=r6.03; species=Dmel; \n+GACTCCGTGGCGCAACGGTAGCGCGTCCGACTCCAGATCGGAAGGTTGCGTGTTCAAATCACGTCGGGGTCA\n+>FBtr0071574 type=tRNA; loc=2R:21161526..21161597; ID=FBtr0071574; name=tRNA:CR30208-RA; dbxref=FlyBase:FBtr0071574,FlyBase_Annotation_IDs:CR30208-RA; score=0; score_text=Weakly Supported; MD5=9ff9c8260337fb111671830edb8e3824; length=72; parent=FBgn0050208; release=r6.03; species=Dmel; \n+GACTCCGTGGCGCAACGGTAGCGCGTCCGACTCCAGATCGGAAGGTTGCGTGTTCAAATCACGTCGGGGTCA\n+>FBtr0071626 type=tRNA; loc=2R:complement(21182678..21182749); ID=FBtr0071626; name=tRNA:CR30209-RA; dbxref=FlyBase:FBtr0071626,FlyBase_Annotation_IDs:CR30209-RA; score=0; score_text=Weakly Supported; MD5=9ff9c8260337fb111671830edb8e3824; length=72; parent=FBgn0050209; release=r6.03; species=Dmel; \n+GACTCCGTGGCGCAACGGTAGCGCGTCCGACTCCAGATCGGAAGGTTGCGTGTTCAAATCACGTCGGGGTCA\n+>FBtr0086247 type=tRNA; loc=2R:complement(20658104..20658175); ID=FBtr0086247; name=tRNA:CR30211-RA; dbxref=FlyBase:FBtr0086247,FlyBase_Annotation_IDs:CR30211-RA; score=0; score_text=Weakly Supported; MD5=243cf738b4d1a6d2ea2ee34d091c0d0a; length=72; parent=FBgn0050211; release=r6.03; species=Dmel; \n+GACTCCGTGGCGCAACGGTAGCGCGTCTGACTCCAGATCAGAAGGTTGCGTGTTCAAATCACGTCGGGGTCA\n+>FBtr0086326 type=tRNA; loc=2R:complement(20000296..20000368); ID=FBtr0086326; name=tRNA:CR30212-RA; dbxref=FlyBase:FBtr0086326,FlyBase_Annotation_IDs:CR30212-RA; score=0; score_text=Weakly Supported; MD5=0567b432dd5034bd45ae2ceabd04c98a; length=73; parent=FBgn0050212; release='..b'Btr0070604; name=tRNA:P:3E-RA; dbxref=FlyBase:FBtr0070604,FlyBase_Annotation_IDs:CR32784-RA; score=0; score_text=Weakly Supported; MD5=6422ca8821a00d410403891c4f001230; length=72; parent=FBgn0025118; release=r6.03; species=Dmel; \n+GGCTCGTTGGTCTAGGGGTATGATTTTCGCTTCGGGTGCGAGAGGTCCCGGGTTCAATTCCCGGACGAGCCC\n+>FBtr0081622 type=tRNA; loc=3R:6819894..6819966; ID=FBtr0081622; name=tRNA:K5:84ABd-RA; dbxref=FlyBase:FBtr0081622,FlyBase_Annotation_IDs:CR31490-RA; score=0; score_text=Weakly Supported; MD5=4195a41533aa06bd1237285868c628ad; length=73; parent=FBgn0026162; release=r6.03; species=Dmel; \n+GCCCGGATAGCTCAGTCGGTAGAGCATTGGACTTTTAATCCAAGGGTCCAGGGTTCAAGTCCCTGTTCGGGCG\n+>FBtr0081661 type=tRNA; loc=3R:complement(6821068..6821140); ID=FBtr0081661; name=tRNA:K5:84ABc-RA; dbxref=FlyBase:FBtr0081661,FlyBase_Annotation_IDs:CR31487-RA; score=0; score_text=Weakly Supported; MD5=4195a41533aa06bd1237285868c628ad; length=73; parent=FBgn0026163; release=r6.03; species=Dmel; \n+GCCCGGATAGCTCAGTCGGTAGAGCATTGGACTTTTAATCCAAGGGTCCAGGGTTCAAGTCCCTGTTCGGGCG\n+>FBtr0081623 type=tRNA; loc=3R:6821789..6821861; ID=FBtr0081623; name=tRNA:K5:84ABb-RA; dbxref=FlyBase:FBtr0081623,FlyBase_Annotation_IDs:CR31489-RA; score=0; score_text=Weakly Supported; MD5=4195a41533aa06bd1237285868c628ad; length=73; parent=FBgn0026164; release=r6.03; species=Dmel; \n+GCCCGGATAGCTCAGTCGGTAGAGCATTGGACTTTTAATCCAAGGGTCCAGGGTTCAAGTCCCTGTTCGGGCG\n+>FBtr0080644 type=tRNA; loc=2L:14495878..14495949; ID=FBtr0080644; name=tRNA:P:35Bd-RA; dbxref=FlyBase:FBtr0080644,FlyBase_Annotation_IDs:CR31985-RA; score=0; score_text=Weakly Supported; MD5=c3cf92f97e1293f17ef34dd4a33c2dd2; length=72; parent=FBgn0028882; release=r6.03; species=Dmel; \n+GGCTCGTTGGTCTAGGGGTATGATTTCCGCTTAGGGTGCGGGAGGTCCCGGGTTCAAATCCCGGACGAGCCC\n+>FBtr0080717 type=tRNA; loc=2L:complement(15132306..15132389); ID=FBtr0080717; name=tRNA:L:35C-RA; dbxref=FlyBase:FBtr0080717,FlyBase_Annotation_IDs:CR31831-RA; score=1; score_text=Weakly Supported; MD5=250f163ecd83070ef11ff4724f417121; length=84; parent=FBgn0028889; release=r6.03; species=Dmel; \n+GCCAGGTTGGCCGAGCGGTCTAAGGCGCCAGATTTAAGCTCTGGTTCTCGAGAGAGAGCGTGGGTTCGAGTCCCACACC\n+TGGCA\n+>FBtr0080609 type=tRNA; loc=2L:complement(14010565..14010636); ID=FBtr0080609; name=tRNA:Q:34E-RA; dbxref=FlyBase:FBtr0080609,FlyBase_Annotation_IDs:CR31838-RA; score=0; score_text=Weakly Supported; MD5=ed31990a1414708ea663c4eb1a47f303; length=72; parent=FBgn0028909; release=r6.03; species=Dmel; \n+GGTTCTATGGTGTAATGGTTAGCACTTTGGACTCTGAATCCAGCGATCCGAGTTCAAATCTCGGTAGAACCT\n+>FBtr0080647 type=tRNA; loc=2L:14599674..14599745; ID=FBtr0080647; name=tRNA:P:35Bc-RA; dbxref=FlyBase:FBtr0080647,FlyBase_Annotation_IDs:CR31984-RA; score=0; score_text=Weakly Supported; MD5=c3cf92f97e1293f17ef34dd4a33c2dd2; length=72; parent=FBgn0028910; release=r6.03; species=Dmel; \n+GGCTCGTTGGTCTAGGGGTATGATTTCCGCTTAGGGTGCGGGAGGTCCCGGGTTCAAATCCCGGACGAGCCC\n+>FBtr0080660 type=tRNA; loc=2L:complement(14599396..14599467); ID=FBtr0080660; name=tRNA:P:35Bb-RA; dbxref=FlyBase:FBtr0080660,FlyBase_Annotation_IDs:CR31979-RA; score=0; score_text=Weakly Supported; MD5=c3cf92f97e1293f17ef34dd4a33c2dd2; length=72; parent=FBgn0028911; release=r6.03; species=Dmel; \n+GGCTCGTTGGTCTAGGGGTATGATTTCCGCTTAGGGTGCGGGAGGTCCCGGGTTCAAATCCCGGACGAGCCC\n+>FBtr0080646 type=tRNA; loc=2L:14598859..14598930; ID=FBtr0080646; name=tRNA:P:35Ba-RA; dbxref=FlyBase:FBtr0080646,FlyBase_Annotation_IDs:CR31983-RA; score=0; score_text=Weakly Supported; MD5=c3cf92f97e1293f17ef34dd4a33c2dd2; length=72; parent=FBgn0028912; release=r6.03; species=Dmel; \n+GGCTCGTTGGTCTAGGGGTATGATTTCCGCTTAGGGTGCGGGAGGTCCCGGGTTCAAATCCCGGACGAGCCC\n+>FBtr0086526 type=tRNA; loc=2R:19414598..19414679; ID=FBtr0086526; name=tRNA:S4:56D-RA; dbxref=FlyBase:FBtr0086526,FlyBase_Annotation_IDs:CR30224-RA; score=0; score_text=Weakly Supported; MD5=bda31e491947aa0e742dec30594b08f0; length=82; parent=FBgn0028981; release=r6.03; species=Dmel; \n+GCAGTCGTGGCCGAGTGGTTAAGGCGTCTGACTCGAAATCAGATTCCCTCTGGGAGCGTAGGTTCGAATCCTACCGGCT\n+GCG\n' |
b |
diff -r 000000000000 -r 198009598544 test-data/genome-small.fa --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/test-data/genome-small.fa Wed Oct 11 09:57:58 2017 -0400 |
b |
b'@@ -0,0 +1,13 @@\n+>chrom_1 2R_6242001-6272000_and_2R_6490001-6550000\n+TCAGTTTGGTCAGTCAAGTGCGTTTTGCTAGGCGTGGAGTAAGATGAACGCGAACAGAAACTTTTGAATTTTGAAGTAAAATTTAAATTTAAGTGAAAGGTTCGAAGTAATTGTTAATTGAAAAATAAATCAAATGCAGTTTAGCCTGATCTGAGGAAAGAAAGAACGAGTGCTAAGCTCAATGAACTTTCACTCTCCGCTCTCTCCCTATACATCGCGCTTCCAGCGAGAAATCTCTGCTGATCGTTCTCATTTCCACGTTCGCTTGGCGTTTTGATCAGTTTCGAATTTGACTTATAGCGACGCTGGTCGGAGCTCTCTCGGCAAACAAAAACCGTGACAAGCAAAGATTTGAGCAAAGATTTGCCCAGAAGGGGTCTTGCTCGACACCAATAATAAAAATGCCGCGATAGAAGTGTGTGTGCCATTGACCAACATTTTAATATTTTTAAATTGTTTCTTGTGTGCTCACGAAACGTGTTCATGTGGCGCCTCAATTGATTTGATCTTATTTCACCAATTATCAAAGTGTTAAGTCTGCCATACGAAAGCATTTAAATGAAGTAATACATATGTATAAATGTACATATATACACTTAACCCACTGCTGAGGTCTCCAGCTTTCAGTGCCAGTTTGGAGTCCACGACGGAGAAGTTAAGCCACAACTTCTGGCATCAGATTAAGAGCTAAACCTATTTCAGCAGTAGCCGCAAGCATGTGAGTGCTTTAAATTCATAAAAACACATTAAAGTGCGTATTTTTAACTTTATTTAAATTGATAAATTTTATACCATTGATTGATTTATTTTATACCAATATTTATAAAATAGTTGGCCTGCTTTGGAAAAAAGAAGATGGATAAAAGTTGCACAAATAAAATGTGTGAAACGTGGTAAAAACTTGTGAATTTTGTGTCCAAAAATGGTTTAACATATATTATTACAATATCATTTAAACAAATTGTGGGTTCAGGCAGTTTAAAATTTCAATATATGGCAAAAGGCAAGTTAAAATTTTTCCCCAAATCATCAGACACAAGGACACTAAAATAAGTTTTTACTTTAGAAGTCACCCAGAACCATGTGCTGGAAAATGTTCTCCAACGAAGCTTCGGATTTTAATAATCATTAGGTACCAGTTGCTAATCAATTTTAGATTAAATATGCTTTTAGATAAGGATGTTGTCAGGTGATATTATGGATACGTATGAACATATGTTGCTACTTATTCTTGTTTAGTCCCACATCCCTAGATCAGTTAAAGGGTATACTAGATTCTTTTAAAAGTATCCAACATGTAAAACAAAGTCTTTTCGACCAAGGAAAGTATATAAATTCTTGATCAAGATTATTAATTGAGTCGATTATGTCCGTTCGTATATCCATTTGAACTTCGGGATCTCTGTACCTATAAAGGATTCAGCATACAGATCCTAAAGACTTTCCACACGTATGCTTATTTCCAAACGTAGCCACACCCAATGTAACGTCGACACACTGCAAACCATTTTTGGCCCTGATTTTAATTTCTTGGAATATGAACCTCTAAACCAATACTCTGTCTTTAATGACAGGAGCGGATTATAGAAGCACATTTCTTATCTTATCACTATTTATGTATATTTCACAAGTGTGACCAAGCTAATAGTGATATTAGTAAAATCTAATAGGCAACGCATAGACCTAAAGAATTAGAATGTGGTTTCCCACAACGATCAAAAAAAAAAATATTAAAACATTTTCAAAAGGTGTGTCAGTTTTGGGCGGTTGTGGGCGTGCCTCTAGAATCGTTTTATCTAATCTCAACTCTCTAGCTATAATGGTTCCTGAGATGGTGGTGTTCATACGGACAGACTGACATGGCCAGATCAACTCGGCTATTGGTTCTGATCAAGAATATATATACTTTATAATAATAAATAAATAATATACTTTATATGGTCGAAAACGTTTTGTCTGTTACATACTTTTTAACGAATCTAGTATACCCTTTTACTCTACGAGTAACGGGTACAACAAAAATGCTATATTCGACTTATGTTCTGACAGTCAGATACCCGTTACTCAGTTAGTGGAAATGGTGAATTGATTGAGAAAATATTTAAACAAATTTGAAAGTATGGGCGTGGCAAAAAGTTTTTTGGTAAATCGATAAAAATTTACAAGTGTAATAAAAATATAAAAAAAAATTTGAAAACATTTTTTAAAAGTGCAAGGATGTGCAAGTTTTAGGCGGCTATAGGCATTAGGGGGGCTTGGCAACTTTCTATCTGTTATATTTTGGAAGTGACAAACAGGTTCTTTTTTCGTCTTGGGCAACTATTATAATATATTATATTATATACTAAATAACAAGTTTACAAAGAATTCACTACACTAGTAATAAAAGCTATCACTACTTCAAAGTTAGCAGACCCAATACGAAATTCAATGACCAAATAGAAGTCAGCACCAAAACTTAATTACTTAAAAATTTCTTTGAGTGACAGAAGGAAAACTTATATTAGGACAGTATATTTCTTAGATTAGATTTATGGAAGATAACAATGTACTAATTTCTGAATTGTTTAAATAATATCGAACGAGTCAACTACCTTATCCAAACCGCTACCGGAGCACTATCCCTTCGAAAGCTTAGTCTCATTTCTCAACAGCTAACTATAATTTGAAAATATTTAGAATAAAGTTATTGTTCGATAGGCTCATGTTTTTTTTGGGATGAAAGGGGATTTTTATTAAATGTCCGAAAATAATTTTTCGTCACTAAAGTTTGGTATGGTATTTGGCATGATGCGATCGTCAAATGTTTTTACCGAGTCACTAACTTGGACATAGTCTCTAAAACATACTTTTGATTTTATTTTTACTTAGTTCCGAACTAGGGGTCAATAATTTAAGTTATTGAAATTCAGTTGCCCCGCGTGGGACAATCTAATCGAATGCTAATTGTAATTCGGTTATTTATCCTGCGCACTTCATTGGGGTCGTACAAATAATGAGTTCTGATTACAGCGATTGTGCCCAAGTCTAGTGTTGCCGATAAGATAGCCGCAATAGATACTAAGCAGAGCTACATGCACACCCAAAGTGCCGTTGTGACTCATCGACTCCTCGACCATTGTTGCGGGTCCGACAATAGGCCTGTACTCGATCAGCGATTTTTAAAAGGTGTGTGAACCGCGCAGAAAGCTTTGGAAAGCTTGTAGAGTTTGTGCCAATGCCTCGGCAGAGAACTTGTTCTTATGGATTGTGGCTGACCTTGCCGTAGAAGCCCATTATGTTTTTATTTGCATAATACCTTAGAACAGTCGAAGGGTTTTCGGGCTATCGCATTTCAATATCTTGGAGATTATGAAAAGCTTTGCCAGCTGTTTTGAAGTTCGCAGCTGTGCTCTGGAAAACTCCCTCTCCATTACCAACTTGCGGCATTGACGCTCTCGCCGTAACCGTTACCCGTTAACCGTTTTGAGCTCGGCGACCTAAGCTTTTGGCTGCGTCGCGAGGTTTAGTTAATATTATTAACCGGAGTGACGGCCAAGTTGTCGCAACGTTTCTCGTGGATCGCAGATCGTGGCGGTAAGGCGAGCTTTTTGCCGGGGGCTCAAAGTGTGAGTGTGAGGTGTCTTCAGTTTGGTTTTTTTCACATAGCGTGGCATTACTCTCTTTGACGAATTCAATGCGACGTCGCGCTTTTTTCGGTTCTGCAACTTCCGTTAGTCGGTGGCTCGAAAAGTAAACAAAGTGCTGCATATCGCATGCAAACGTGACAATCTTTCAGACGCACTCCAACTTGATAACTTGATAAGCATCTGTGAGATGCAAAGATACAAGTTATAAAGCACCATCTCGCGAAGCCATGTAGCCGAGTGAAAAAAGTAAAATATGCGAAAGCAGAAAAACAAAAAATTTGTGCGTGTGTTAGTTGGCCA'..b'ATTACCTTATACGTATAAATTTTATCATTCAATTCCGAAAGCATTTTGGGCGAAAATAAAGTACTTACTTTTAGGGCGAAAAATAAGTAAGTTGCCATTAAATGGAATATTTTTTTGTTACGATGATTAGTCATTTATAATAAAAATTTAAAATATGGGCAATTTGGTCCCCTAATCAACATGCACATATGTACATACATATATTTACATTTTCCCAAATGTGTCTGTAATTTTTTTTTTAGTATGGAAACGCAGACAGTAGGAAAAACGTAGCCAACAAAAAAGGCAAAAAATGCGTTTGCCGCAGACACAAATTATCGATCCGAACATTACACAAACACGCACACGGACAGAATTAAGCAGCACCGCAAAGTAAAACACTTGGGTAAACCCCCAAAAATGGTTGGAGCTGAGTGGGGGTGGCAAGGGCACTTTTTTTTGTTGCGGCAACTTCTTTAAGTTGTTCTTGATAAAAAAGTCATGACCTAACACAATATGTCCGTAAATAAGCCTGTGTAACAAAATAAGGCCATTGGCCCTGAAATGTACCTGATATATTGTTTTTTGTTAGTATTTAGAGGTGTTAGAAAAGATGAAGGTATTTGCTTAAAAATTGTGATTAATCTCAATCCCTTACATTTTTTAAAATAATAATCACAAAGCTTCGTTTCGCGTTGAAACTGAATTTTTTGCAATTCAACCCTTCCCACTTATTATAGTTTTCGTTCTGTTCTCACTAGCAAATGTTCTCACTCCAGTTTCTCTCGCCTCTCCCTCTTTATATTTGTTGTTACGGCCTGGTAAACCAACTGACCGTGTGGCCTAATGGATAAGGCGTCGGACTTCGGATCCGAAGATTGCAGGTTCGAGTCCTGTCACGGTCGACCGTTCTATGCTTTTTTTTAATATTCATATTTTTCCTTGAGCTATGAATATTACAGCTTTCATTAATTGGCCAAGTCAATTGCTGAAAAAAATATTTATTAGTTCTTTAAGGAACTAGAAGCTTAAATAGTGTATTGGGCTTGCGTAAGGACAAGTAGCAGTCGTGGCCGAGTGGTTAAGGCGTCTGACTCGAAATCAGATTCCCTCTGGGAGCGTAGGTTCGAATCCTACCGGCTGCGAATGAGAATGTATATTTTATTTCATATGTTTTTATTTTCTGAAATTAAATAAAAACGTTCTGCATAGCAAAACAAATGAGTGCTAGGTGTTTAAAAATACATTATTTTATTGCCATACGGAATTATCCTATTTAACGATCAATTTATATTTATAAGGTAGAGAATTAACCTTTTTTTTAATTGTCTTATAGAATTATCCTATTTAACGATCAAACTATATTTAAAAGTATAAAAAATAGTAGGAAACGTAGGAAATTAACCTTTGGCCCTGTAATATGCATAAACTCCGGAAGATTGTTGGGATTTGATCAAAAATAAGCAGTCGTGGCCGAGTGGTTAAGGCGTCTGACTCGAAATCAGATTCCCTCTGGGAGCGTAGGTTCGAATCCTACCGGCTGCGGAAGGGTAGTCCTATATTTTTTATGTTTTAATTTTTAAAAGGAGCATTCTTTCAGTTTTGAATATGTTTATTATATTACACACTGTGCCTTTGTTTGGCAATTACTTTCTGTCTAATGAATTTCTTAATTCAATTATAATCCGCATTTTGATCATATTTCGTATTCAAGGAACCACATCTCTAATTTTTTTACCTTGCCTATTTGTCTCGCATTGTGTAGCCCAAACACAACAACACCACCCACCAGACACGCACAAAATTATTTACATTTGCTGCTGACGAGTTCGTTGAACCTTTGATAACCTTTTTGGTCTGCTCCTCGGCAATTTTATTTCTCTATATACTAAATTTTTCGGCTGTCTTTCCTTTACTTTCGTTTTGCTCTTCCGTCTGTGGGCGTATATCGCCGTCCACAAAAAGCCTCAAAATGTCTTTGGTCCTTTTGCACCATTGACGTTGTTGTTTCCGCAGGTCCGAGCCCGCAGGAATCTTTGATAAAGATCTTTATATTATCAATGTCTAAGTATAGATAAAATGAATAAATAATTATGAAATAAGAATGTAAATACAATTTTCAATCAATCGTTTTAAGCAAGGTTCATTTGCAATATTATAAACTATGATAGACCGTTTTGTATCATTGATCTTGGGAATTTGGGACGCCGGTTGCGTAACTGACCGTGTGGCCCAATGGATAAGGCGTCGGACTTCGGATCCGAAGATTGCAGGTTCGAGTCCTGTCACGGTCGAAGCTCAGGCTATATTTTTTTAAATTATATTTTGTTCGTCCTAGAATATATTAATATGGGAGATTCCCTAGCCCAACCCAAACACACCAACACCACCCACCAGACACGTACAAAATTATTTACATTTGCTGCTGACGAGTTCGTTGAACCTTTGATAACCTTTTTGGTCTGCTCCTCGGCAATTTTATTTCTCTATATACTAAATTTTTCGTCTTTCTTTCCTTTACTTTCGTTTTGCTCTTTCGTCTGTGGGCGTATATCGCCGTCCACAAAAAGCCTCAAAATGTCTTTGGTCCTTTTGCACCATTGACGTTGTTGTTTCCGCAGGTCAGAGCCCGCAGGAATCTTTGATAATGATCTTTCTATTATTAATGTCTAAGTATAGATAAAATGAATAAATAATTATGAAAAAAGAATGTAAATACAATTTTCAATCAATCGTTTTAAGCAAGGTTCATTTGCAATATTATAAACTATAATAGACCGTTTTGTATCATTGATCTTGGGAATTTGGGACGCCGGTTGCGTAACTGACCGTGTGGCCCAATGGATAAGGCGTCGGACTTCGGATCCGAAGATTGCAGGTTCGAGTCCTGTCACGGTCGAAGCTCAGGCTACATTTTTTTTAAATTATATTTTGTTCGTCCTAGAATATATTAATATGGGAGATTCCCTAGCCCAACCCATTTGTGTAACCTGAGAAATTGGGAATTTGGGACGGCGGTTGCGTAACTGACCGTGTGGCCCAATGGATAAGGCGTCGGACTTCGGATCCGAAGATTGCAGGTTCGAGTCCTGTCACGGTCGAAGCTCAGGCTATATTTTTTTTAAATTATATTTTGTTCGTCCTAGAATATATTTATATGGGAGATTCCCTAGCCCAACCCATTTGTGTAACCTGAGAAATTGGGAATTTGGGACGGGGGTTACGTAACCGACCGTGTGGCCCAATGGATAAGGCGTCGGACTTCGGATCCGAAGATTGCAGGTTCGAGTCCTGTCACGGTCGTACCTCAGTATTTAATTTTTTTTGAACTTATTTTTCGTTCGTCCTATAATATATTAATATGGGAGATTCCCTAGCCCCACTCATTTGTGTAACCTGAGTGCGGTAAGCAGCAATCGTAACCAATTGGCATACCGAATTGAAAGATTTATTGGACTTTTACATGGGTCGTCCATGGACGAATCAACATGTGGCTGCCACCGCAAGAAGCCCAACTTTGTTCGTTGGCTCTTGCTGCCTGGGCTTGCACTGAAACAAATCTCTTTAACGTCAGCAAAAAATAAAAAGATATTTTTTCTAAAGTATGTATTGTCGTACATTTGGTTTATAATTTTAATATTTAGCGTATCAATTAAATCAATGTGTCTATGTGTCCGATACTTTCGTGTATTTTGTTATGTTTCTGTGTATCTGCTGGTGTCGTTGCTGCAATTGTTGCTAGCTTGAATAGCTATATATTTTTTATTCTCTTTTGTCAGCAAGCAGACTGAGGAGCAAGTTTTAAGCAACAAGAACGACACGCGGAGGAACAAGCTGGTCTACAAAGTGGAGGACGAGGCTGCAATTTATGTGGAGGTCCGGCTGTCCACAGTCCGCGGTCCAAAAGAGATCCGAGGGCCCACAGAGTCGGCTTAGCATAATAAACGTCAGAATTAATTGGATTTTAATTGTCTGTTAAGCGCTGAAATTAAGTGCAGCAAAACTAGATTGTCGGCCAG\n' |
b |
diff -r 000000000000 -r 198009598544 test-data/mirbase-21-dme-hairpins-16jul2015.fa --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/test-data/mirbase-21-dme-hairpins-16jul2015.fa Wed Oct 11 09:57:58 2017 -0400 |
b |
b'@@ -0,0 +1,512 @@\n+>dme-mir-1_MI0000116 Drosophila melanogaster miR-1 stem-loop\n+TTCAGCCTTTGAGAGTTCCATGCTTCCTTGCATTCAATAGTTATATTCAAGCATATGGAATGTAAAGAAGTATGGAGCGAAATCTGGCGAG\n+>dme-mir-2a-1_MI0000117 Drosophila melanogaster miR-2a-1 stem-loop\n+GCTGGGCTCTCAAAGTGGTTGTGAAATGCATTTCCGCTTTGCGCGGCATATCACAGCCAGCTTTGATGAGCTTAGC\n+>dme-mir-2a-2_MI0000118 Drosophila melanogaster miR-2a-2 stem-loop\n+ATCTAAGCCTCATCAAGTGGTTGTGATATGGATACCCAACGCATATCACAGCCAGCTTTGATGAGCTAGGAT\n+>dme-mir-2b-1_MI0000119 Drosophila melanogaster miR-2b-1 stem-loop\n+CTTCAACTGTCTTCAAAGTGGCAGTGACATGTTGTCAACAATATTCATATCACAGCCAGCTTTGAGGAGCGTTGCGG\n+>dme-mir-2b-2_MI0000120 Drosophila melanogaster miR-2b-2 stem-loop\n+TTGTGTCATTCTTCAAAGTGGTTGTGAAATGTTTGCCTTTTTATGCCTATTCATATCACAGCCAGCTTTGAGGAGCGACGCGA\n+>dme-mir-3_MI0000121 Drosophila melanogaster miR-3 stem-loop\n+GATCCTGGGATGCATCTTGTGCAGTTATGTTTCAATCTCACATCACTGGGCAAAGTGTGTCTCAAGATC\n+>dme-mir-4_MI0000122 Drosophila melanogaster miR-4 stem-loop\n+TTGCAATTAGTTTCTTTGGTCGTCCAGCCTTAGGTGATTTTTCCGGTCATAAAGCTAGACAACCATTGAAGTTCGTTGTGG\n+>dme-mir-5_MI0000123 Drosophila melanogaster miR-5 stem-loop\n+GCTAAAAGGAACGATCGTTGTGATATGAGTTGTTTCCTAACATATCACAGTGATTTTCCTTTATAACGC\n+>dme-mir-6-1_MI0000124 Drosophila melanogaster miR-6-1 stem-loop\n+TTTAATGTAGAGGGAATAGTTGCTGTGCTGTAAGTTAATATACCATATCTATATCACAGTGGCTGTTCTTTTTGTACCTAAA\n+>dme-mir-6-2_MI0000125 Drosophila melanogaster miR-6-2 stem-loop\n+TAACCCAAGGGAACTTCTGCTGCTGATATATTATTGAAAAACTACTATATCACAGTGGCTGTTCTTTTTGGTTG\n+>dme-mir-6-3_MI0000126 Drosophila melanogaster miR-6-3 stem-loop\n+CAAAAAGAAGGGAACGGTTGCTGATGATGTAGTTTGAAACTCTCACAATTTATATCACAGTGGCTGTTCTTTTTTGTTTG\n+>dme-mir-7_MI0000127 Drosophila melanogaster miR-7 stem-loop\n+GAGTGCATTCCGTATGGAAGACTAGTGATTTTGTTGTTTGGTCTTTGGTAATAACAATAAATCCCTTGTCTTCTTACGGCGTGCATTT\n+>dme-mir-8_MI0000128 Drosophila melanogaster miR-8 stem-loop\n+AAGGACATCTGTTCACATCTTACCGGGCAGCATTAGATCCTTTTTATAACTCTAATACTGTCAGGTAAAGATGTCGTCCGTGTCCTT\n+>dme-mir-9a_MI0000129 Drosophila melanogaster miR-9a stem-loop\n+GCTATGTTGTCTTTGGTTATCTAGCTGTATGAGTGATAAATAACGTCATAAAGCTAGCTTACCGAAGTTAATATTAGC\n+>dme-mir-10_MI0000130 Drosophila melanogaster miR-10 stem-loop\n+CCACGTCTACCCTGTAGATCCGAATTTGTTTTATACTAGCTTTAAGGACAAATTCGGTTCTAGAGAGGTTTGTGTGG\n+>dme-mir-11_MI0000131 Drosophila melanogaster miR-11 stem-loop\n+GCACTTGTCAAGAACTTTCTCTGTGACCCGCGTGTACTTAAAAGCCGCATCACAGTCTGAGTTCTTGCTGAGTGC\n+>dme-mir-12_MI0000132 Drosophila melanogaster miR-12 stem-loop\n+TACGGTTGAGTATTACATCAGGTACTGGTGTGCCTTAAATCCAACAACCAGTACTTATGTCATACTACGCCGTG\n+>dme-mir-13a_MI0000133 Drosophila melanogaster miR-13a stem-loop\n+TACGTAACTCCTCAAAGGGTTGTGAAATGTCGACTATTATCTACTCATATCACAGCCATTTTGATGAGTTTCGTG\n+>dme-mir-13b-1_MI0000134 Drosophila melanogaster miR-13b-1 stem-loop\n+CCATGTCGTTAAAATGTTTGTGAACTTATGTATTCACAATCATATCACAGCCATTTTGACGAGTTTGG\n+>dme-mir-13b-2_MI0000135 Drosophila melanogaster miR-13b-2 stem-loop\n+TATTAACGCGTCAAAATGACTGTGAGCTATGTGGATTTGACTTCATATCACAGCCATTTTGACGAGTTTG\n+>dme-mir-14_MI0000136 Drosophila melanogaster miR-14 stem-loop\n+TGTGGGAGCGAGACGGGGACTCACTGTGCTTATTAAATAGTCAGTCTTTTTCTCTCTCCTATA\n+>dme-mir-263a_MI0000343 Drosophila melanogaster miR-263a stem-loop\n+TAGATCTCGGCACAGTTAATGGCACTGGAAGAATTCACGGGGTAATTTTTATACAACCCGTGATCTCTTAGTGGCATCTATGGTGCGAGAATAA\n+>dme-mir-184_MI0000354 Drosophila melanogaster miR-184 stem-loop\n+GGTTGGCCGGTGCATTCGTACCCTTATCATTCTCTCGCCCCGTGTGCACTTAAAGACAACTGGACGGAGAACTGATAAGGGCTCGTATCACCAATTCATC\n+>dme-mir-274_MI0000355 Drosophila melanogaster miR-274 stem-loop\n+TCCTGTGTTGCAGTTTCGTTTTGTGACCGACACTAACGGGTAATTGTTTGGCCGCCAGGATTACTCGTTTTTGCGATCACAAATTATGAAATTGCAGCAA\n+>dme-mir-275_MI0000356 Drosophila melanogaster miR-275 stem-loop\n+TGTAAAGTCTCCTACCTTGCGCGCTAATCAGTGACCGGGGCTGGTTTTTTATATACAGTCAGGTACCTGAAGTAGCGCGCGTGGTGGCAGACATATAT\n+>dme-mir-92a_MI0000357 Drosophila melanogaster miR-92a stem-loop\n+AATATGAATTTCCCGTAGGACGGGAAGGTGTCAACGTTTTGCATTTCGAATAAACATTGCACTTGTCCCGGCCTATGGGCGGTTTGTAATAAACA\n+>dme-mir-219_MI0000358 Drosophila melanogaster miR-219 stem-loop\n+TAATTCGATTTTTAGCTATGATTGTCCAAACGCAATTCTTGTTGATATTCAATATTCAAGGGTTGC'..b'TATATCTAGGCCAAATATATATACTTGTTCTATGTATTAGTTATTTGCAAAGGAATACATGTGCCTGTATATATATTCGGTAAAATCACATCTTTGAATT\n+>dme-mir-4980_MI0017766 Drosophila melanogaster miR-4980 stem-loop\n+GAAGAGGCTGAGAGCGGGAAAGTGAGAAGTAGAGAGCGCAGATAGGGAGTGGGAGCTTATACCGTTATAAAGCCAACTTCCGTTCTGCGTTTCGTTCCAACCCCCCACCTCTCTTTCCCTCT\n+>dme-mir-4981_MI0017767 Drosophila melanogaster miR-4981 stem-loop\n+TGGCCACGTGCCCGCAAGACGCCTTCGGCCGGCGCAAAGTTTCAATTTGATATTCCTTGGCCGGTCGAGCAGCGTCTTGGGGTTGTTCGTGGATT\n+>dme-mir-4982_MI0017768 Drosophila melanogaster miR-4982 stem-loop\n+CCAACTTTGCTGGCATTCGGTGGCCAATAATGCAATTGCATGTCCTTGTTGCTGTTGCAATGTTGCAGCTGGAATTGCAATTGCATTTCTAGTTGCCGCTGCTGCTGCTCGAGTGGCAA\n+>dme-mir-4983_MI0017769 Drosophila melanogaster miR-4983 stem-loop\n+GGCTGGCTGTCTTGACCCACTTGCTCGTTTGCATTTCTGAAAAATGTATACGCAAAAACCAAAATCAGAAATTCTTTTGAGCAAGTGTGTCATGAAATTGCCATTCGT\n+>dme-mir-4984_MI0017770 Drosophila melanogaster miR-4984 stem-loop\n+CTTCGCTCGAGGTGTGAAAACCTTTTGGCCAGCGAATACGCCTCGGATCCAATCACGTTTCAAGATCGAGGTGAATTCTTTGACGTATTCGCTGGCCAAATGACACGTTCGCCATGTTTTGCG\n+>dme-mir-4985_MI0017771 Drosophila melanogaster miR-4985 stem-loop\n+TTGGGGGCGCTGCACTGGCATTGAAAAGTGAATTACATTGATCGTGACATGGGAATGGAAAATGTCGCCGAGCCATGTAAATCGTTTGGCCTACCCGTCTA\n+>dme-mir-4986_MI0017772 Drosophila melanogaster miR-4986 stem-loop\n+TTCTGCCGCTTTTGCTGTGGCTTCTCTGCATGGGATTCCCCATTCTGCATGGCGCCGATCTCTGCCAGCCCATCGGATGGCGGAACTTCCAGTGCAGCGAGGTCGCTTCTCTGCAGGATCTG\n+>dme-mir-4987_MI0017773 Drosophila melanogaster miR-4987 stem-loop\n+GCGGTGCCGTTGATGATGACACAGCGCGCTTGCAACAGCGTGCGGCACGATTCTCACAGCAGGGCTCCAGCTCGGCCAAAAAATCGGTCGTCGCCATTGCAAGCTCACCGTTTGGTCTCACCACGGCCAAGA\n+>dme-mir-9369_MI0028918 Drosophila melanogaster miR-9369 stem-loop\n+AGCGAGAGGGTATTATGTATTCATATTTGTAATATCATGATACATATTCTCCTTTCGCTCTA\n+>dme-mir-9370_MI0028919 Drosophila melanogaster miR-9370 stem-loop\n+TTTGGGTTGCCGGTACCGGGTGGTTTCCCCGATATCCACGACCCATACCA\n+>dme-mir-9371_MI0028920 Drosophila melanogaster miR-9371 stem-loop\n+AAATCACTTTGCTTGGAATTCACATTGATGTACGTAAGAATTCATCACGAAGTGGTTTCTG\n+>dme-mir-9372_MI0028921 Drosophila melanogaster miR-9372 stem-loop\n+TAAAAGCACATTTCGCCAGCACGTGTACTTTCCACCTCGTCTGTGATTTTGGTTTTTAACG\n+>dme-mir-9373_MI0028922 Drosophila melanogaster miR-9373 stem-loop\n+AGTTTGTGAGGAGCGTTCGGCGGATACACATCGCACCCATCGCTCTTGGCCAGCTCGTC\n+>dme-mir-9374_MI0028923 Drosophila melanogaster miR-9374 stem-loop\n+CGTGCAATAATTTCCTCGATTGGCATCAAGTGGCTTCCAGTCGGGTACATATTGCACAAGA\n+>dme-mir-9375_MI0028924 Drosophila melanogaster miR-9375 stem-loop\n+CCGAGTATATGGAATTTCTGTTTTGCCTAGTATGAACCGAAACTCGATATAATTCAGAA\n+>dme-mir-9376_MI0028925 Drosophila melanogaster miR-9376 stem-loop\n+ATAGCCAGCATGGCCAAAGCGCTGTGCTTAAGTGGTCCAAGCGACCGAAAGCACTTTGACCATGCGGTGGTGGCCA\n+>dme-mir-9377_MI0028926 Drosophila melanogaster miR-9377 stem-loop\n+CGCTCTTTCTCTCTATCTGGCCTGGCCTGGCTTGATGGGGAGAAGGAGAGGG\n+>dme-mir-9378_MI0028927 Drosophila melanogaster miR-9378 stem-loop\n+AGTGGAGTGAGACCTCGAGTTCGGGCAAATCTGATAGCCGAACGGGAGTTTCCTCCATTGGG\n+>dme-mir-9379_MI0028928 Drosophila melanogaster miR-9379 stem-loop\n+CGCATGTCAGGTGGTAATCCATTAGTATAAACATGGTATGGCCACTTGACAGTCGGC\n+>dme-mir-9380_MI0028929 Drosophila melanogaster miR-9380 stem-loop\n+GCTCCTGCTGCATCTGTTGGCGATAGCGCTCGTCACTCTTGGCCGTGTACTCCGCCTCCAACAGATCCAGCAGCAGA\n+>dme-mir-9381_MI0028930 Drosophila melanogaster miR-9381 stem-loop\n+GCCAGGGAAGGGTCGAGTGCGGATCCCTTGCCCCAGCGGCTATTCGCCTGCGCACTCGGTCCATCCCTGGCTCA\n+>dme-mir-9382_MI0028931 Drosophila melanogaster miR-9382 stem-loop\n+ATCACAGTGTGGCTGAGGGATTCCACTTTCCTTATAACTTTTGCCGATCCCCGGCGCCACTGTGATCGT\n+>dme-mir-9383_MI0028932 Drosophila melanogaster miR-9383 stem-loop\n+GGGTGCAGATCAAGTGCGAGCTGCGCATTCTCTCGCAGTTCGCCTTCAATCTGAACCCCGA\n+>dme-mir-9384_MI0028933 Drosophila melanogaster miR-9384 stem-loop\n+AGGCATAATTCAACTCACACGTCTACAGGTACATATGTGTGTGTTCGGTTATGTACTTTG\n+>dme-mir-9385_MI0028934 Drosophila melanogaster miR-9385 stem-loop\n+ACAGTGTATGCAAATGATGAATGTGCCATATCAGAAACTATTCCTCATTGCTATACCTGTGGT\n+>dme-mir-9388_MI0028938 Drosophila melanogaster miR-9388 stem-loop\n+CAAGTATTTTGGTACGTATGTATGTATGTACATACATGTGTATATGGTACATTCATGTAGTACATACATACATATGTATGCAAGTACGTACG\n' |
b |
diff -r 000000000000 -r 198009598544 test-data/reads-sample-small.fastq --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/test-data/reads-sample-small.fastq Wed Oct 11 09:57:58 2017 -0400 |
b |
b'@@ -0,0 +1,182280 @@\n+@HWI-ST132:678:C1LFKACXX:6:1103:5043:24327\n+TCTGTCGTGCATTGTCGG\n++\n+IHFC<HHHHHDFFFFCCB\n+@HWI-ST132:678:C1LFKACXX:6:1101:19372:1918\n+AGAATTGTGACCTGAATC\n++\n+BCCFFFFDFFHHHFHIJJ\n+@HWI-ST132:678:C1LFKACXX:6:1101:18439:2762\n+CGCGCGCTACACTGACGG\n++\n+@@@D?DD@FFFDDEEFGI\n+@HWI-ST132:678:C1LFKACXX:6:1101:10715:4477\n+TAACTGAGTACCTGGCTC\n++\n+:??DDD2222ADDE<CGG\n+@HWI-ST132:678:C1LFKACXX:6:1101:20172:4409\n+TTCTACAGTCCGACGATC\n++\n+=@BF:====DFFHBGGIJ\n+@HWI-ST132:678:C1LFKACXX:6:1101:11143:4891\n+TTCGAGACAGTAACCACA\n++\n+=@@D;D?D>C<DFIIHGG\n+@HWI-ST132:678:C1LFKACXX:6:1101:9335:5110\n+AAGTAACGAAAGGATTAC\n++\n+:?@B4=2=CFHHHJIJJJ\n+@HWI-ST132:678:C1LFKACXX:6:1101:16012:5749\n+AGATTTACAATTTTGGGC\n++\n+BC@DFFFFHDFFHJIJJJ\n+@HWI-ST132:678:C1LFKACXX:6:1101:4811:6756\n+TGTACTACTCTACTTGTT\n++\n+CCCFFFADHHHHHJJCGI\n+@HWI-ST132:678:C1LFKACXX:6:1101:7299:9245\n+CATTGGAACTAAATGACC\n++\n+=BBDA4=BFHHHHJIIHJ\n+@HWI-ST132:678:C1LFKACXX:6:1101:13600:10898\n+ATCCCGGACGAGCCCCCA\n++\n+@CCFFFFFHHH@FHIJJI\n+@HWI-ST132:678:C1LFKACXX:6:1101:9047:12024\n+ACGACAACCGTCATCCCG\n++\n+@CCFFFFFHHHHFJJIJI\n+@HWI-ST132:678:C1LFKACXX:6:1101:7548:13223\n+ATAGACCTGACAGCGTGC\n++\n+?@@FDDFFH:ADAFHCGI\n+@HWI-ST132:678:C1LFKACXX:6:1101:7552:14739\n+GGAGGAAGTAGCTTTTTT\n++\n+BBBDDDFFH2AADFHIJI\n+@HWI-ST132:678:C1LFKACXX:6:1101:19574:14871\n+TTCCCCGTCGGGGAGCCA\n++\n+BBBFFFFDF?FHF:??FH\n+@HWI-ST132:678:C1LFKACXX:6:1101:9689:16020\n+TGCTGGTCGACTATACTC\n++\n+B?@DAAADFFHHHJJ@FG\n+@HWI-ST132:678:C1LFKACXX:6:1101:10332:16559\n+GCCCGGCTAGCTCAACCC\n++\n+=B@FA=@DHFHHHIJIIJ\n+@HWI-ST132:678:C1LFKACXX:6:1101:16598:17271\n+TCCACCACGTTCCCGTGG\n++\n+BBBFFF:AA<CFHIHCGH\n+@HWI-ST132:678:C1LFKACXX:6:1101:16473:17908\n+TTCTACAGTCCGACGATC\n++\n+BBBFFF>AADHFHGHHHI\n+@HWI-ST132:678:C1LFKACXX:6:1101:17076:19365\n+TCCCCGGCATCTCCACCA\n++\n+CC@FFFFFHHHHHJIJJJ\n+@HWI-ST132:678:C1LFKACXX:6:1101:2970:20077\n+TCCCGGATGGAACCACCA\n++\n+B@BFDBAD@DFHHHHIJI\n+@HWI-ST132:678:C1LFKACXX:6:1101:19292:22029\n+TACAGAGGGCTGCGAGAC\n++\n+CCCFFFFFHHHHG@FDHH\n+@HWI-ST132:678:C1LFKACXX:6:1101:7403:22551\n+GCAGTCGTGGCCGCGCGG\n++\n+@@@DDDDDHDHHF12?FH\n+@HWI-ST132:678:C1LFKACXX:6:1101:6550:24420\n+TCTTTGGTATTCTCGCTG\n++\n+@@@DDDDAFHHHF<+AEG\n+@HWI-ST132:678:C1LFKACXX:6:1101:15312:25043\n+ATGACACCGTTGGAAGAA\n++\n+@BCFFFFFHHHHFGHEEF\n+@HWI-ST132:678:C1LFKACXX:6:1101:10841:25468\n+TCTTTGGTATTCTCGCTG\n++\n+BCCFFFFBFHHHHEIJJJ\n+@HWI-ST132:678:C1LFKACXX:6:1101:6460:26533\n+TCCCGGGTTTCGGCACCA\n++\n+CCCFFFFDHHH<DGHIJJ\n+@HWI-ST132:678:C1LFKACXX:6:1101:8169:26973\n+ATCCTGGTCACGGCACCA\n++\n+@CCFFFFEHBH@FHIJJJ\n+@HWI-ST132:678:C1LFKACXX:6:1101:17561:28189\n+TCCCGGATGGAACCACCA\n++\n+BBCFFFDD?FDFHJIJJJ\n+@HWI-ST132:678:C1LFKACXX:6:1101:11670:30039\n+TTCTACAGTCCGACGATC\n++\n+CCCFFFFFHHHHGJJIIJ\n+@HWI-ST132:678:C1LFKACXX:6:1101:5395:30961\n+TACGGACCAATGGCAAAA\n++\n+@B@FDDDDH=FHDHIGIG\n+@HWI-ST132:678:C1LFKACXX:6:1101:8747:33935\n+CGCATGAATGGATTAAAA\n++\n+@@@DDF<DHH>FHGGBHG\n+@HWI-ST132:678:C1LFKACXX:6:1101:9941:34387\n+ATCCCATCCTCGTCGCCA\n++\n+BCBDFFFFHHHHHH@FHI\n+@HWI-ST132:678:C1LFKACXX:6:1101:14543:34442\n+TCCACCACGTTCCCGTGG\n++\n+@C@FFFADFFHGHJJEHI\n+@HWI-ST132:678:C1LFKACXX:6:1101:5887:34986\n+AAACTTTCAACAACGGAT\n++\n+@@@DFFFFH<FHHIICGI\n+@HWI-ST132:678:C1LFKACXX:6:1101:9891:35111\n+AAGAGTCTTGTCTGGTAC\n++\n+BCCFFBDFHHHHHJFHHI\n+@HWI-ST132:678:C1LFKACXX:6:1101:10051:35463\n+TCTTGATCGAAGCCCCGG\n++\n+B@BFFFFFHFFHGJJJJJ\n+@HWI-ST132:678:C1LFKACXX:6:1101:4680:35647\n+CGGGATGTAGCGCAGCTT\n++\n+BB@FADFDFHGFHEIIJJ\n+@HWI-ST132:678:C1LFKACXX:6:1101:14569:35583\n+AAGATAGAGTAGTTTTTT\n++\n+BBCDFFFFHCHHHHIJJJ\n+@HWI-ST132:678:C1LFKACXX:6:1101:13960:37817\n+AAAGTTCGGAAAACTGGC\n++\n+@CCFDFDFHHHHHBGFGI\n+@HWI-ST132:678:C1LFKACXX:6:1101:16007:38099\n+GATGACTGGGGTGAAGTC\n++\n+B@BDDFFFHG?CFBGIEG\n+@HWI-ST132:678:C1LFKACXX:6:1101:8213:39438\n+TAATGATTCCTGTACTGA\n++\n+BBBFFFFFHHHHFHIJIJ\n+@HWI-ST132:678:C1LFKACXX:6:1101:15318:43042\n+CCGCTGCTGATCACACTG\n++\n+CCCFFFFFHDHHHJJJJJ\n+@HWI-ST132:678:C1LFKACXX:6:1101:16708:44453\n+TGCTAGAGGGTCTCGGTA\n++\n+?BBF;A=DFH<DHIE<<C\n+@HWI-ST132:678:C1LFKACXX:6:1101:8544:45645\n+TGCGGCTGGATCACCTCC\n++\n+@CCFFFFF:FHHHIJJJI\n+@HWI-ST132:678:C1LFKACXX:6:1101:16382:46217\n+AT'..b'276\n+GATCCCAGATCCGCTGTGTTT\n++\n+CCCFFFFFHHHHHIJFGHHIJ\n+@HWI-ST132:678:C1LFKACXX:6:1213:14045:90482\n+ATACTAGATTCGTTGAAAAGT\n++\n+@@@F7DDDFA<CC?;FAEBH?\n+@HWI-ST132:678:C1LFKACXX:6:1302:4633:32096\n+TGTTGCGGCAACTTCTTTAAGTTG\n++\n+CCCFFFFFHHHHHJJJJJJJJHIJ\n+@HWI-ST132:678:C1LFKACXX:6:2107:6041:64276\n+TGGCCTAATGGATAAGGCGTCGGACT\n++\n+@CCFFFDFHHHHHIJJJJ<FHIJJJJ\n+@HWI-ST132:678:C1LFKACXX:6:1112:9014:81599\n+TTCGGATCCGAAGATTGCAGG\n++\n+@CCFFDFFHGGGGDCEGIJJJ\n+@HWI-ST132:678:C1LFKACXX:6:2105:11875:25254\n+CGAAGATTGCAGGTTCGAGTC\n++\n+CC@FFFFFHHHFCAFHIJ+AH\n+@HWI-ST132:678:C1LFKACXX:6:2101:16974:2305\n+ACCGTTCTATGCTTTTTTTT\n++\n+:BBDDDDFHH<2<CFHIIJJ\n+@HWI-ST132:678:C1LFKACXX:6:1313:11404:80054\n+ACCGTTCTATGCTTTTTTTTA\n++\n+@@CFBDFF?FHHGIIIIGIIC\n+@HWI-ST132:678:C1LFKACXX:6:1116:12125:58757\n+AAGTAGCAGTCGTGGCCGAGTG\n++\n+??+4=B?DDHHF<EGHGGGIDG\n+@HWI-ST132:678:C1LFKACXX:6:1205:9493:45438\n+GCAGTCGTGGCCGAGTGG\n++\n+BCCFDFFFHHHHHIDCFH\n+@HWI-ST132:678:C1LFKACXX:6:1207:2720:86231\n+GCAGTCGTGGCCGAGTGG\n++\n+@@@FFFFDHHHGFIG2AF\n+@HWI-ST132:678:C1LFKACXX:6:1214:18091:41339\n+GCAGTCGTGGCCGAGTGGTTAAGG\n++\n+?@:4ABDDHHFHFDGCGDFHFGIG\n+@HWI-ST132:678:C1LFKACXX:6:1309:18921:24185\n+GCAGTCGTGGCCGAGTGGTTAAGG\n++\n+@CCFDFFFHHHHHI@ACGFHIIIJ\n+@HWI-ST132:678:C1LFKACXX:6:1106:1391:88663\n+GCAGTCGTGGCCGAGTGGTTAAGGC\n++\n+@@@FDEDDAFHHHJH+AFFHIJEHG\n+@HWI-ST132:678:C1LFKACXX:6:1310:15410:68712\n+GCAGTCGTGGCCGAGTGGTTAAGGC\n++\n+@@@DDFFFHHHHH?EEGHIJHIEEH\n+@HWI-ST132:678:C1LFKACXX:6:1202:15769:84946\n+AGCGTAGGTTCGAATCCT\n++\n+?@@D=ADDHHFDHFGGIG\n+@HWI-ST132:678:C1LFKACXX:6:2105:13686:25294\n+AGCGTAGGTTCGAATCCT\n++\n+BCCFFFFFFHHDDHHIJJ\n+@HWI-ST132:678:C1LFKACXX:6:1106:17247:63193\n+AATCCTACCGGCTGCGAATGA\n++\n+@BBFFDEFHFHHHFFFFHGHJ\n+@HWI-ST132:678:C1LFKACXX:6:1107:17291:97995\n+ATCCTACCGGCTGCGAATGA\n++\n+@CCFFFFFDFFHHJGEHGBG\n+@HWI-ST132:678:C1LFKACXX:6:2105:5531:13237\n+ACCGGCTGCGAATGAGAA\n++\n+B@BFFFFFGHDFCFHEGI\n+@HWI-ST132:678:C1LFKACXX:6:1111:11783:45506\n+ACCGGCTGCGAATGAGAATGT\n++\n+???DFFFFFHF:CCCGHHBG<\n+@HWI-ST132:678:C1LFKACXX:6:2105:11033:71535\n+CGGCTGCGAATGAGAATGTATATTT\n++\n+?BBDFFFF@<@ACAAEHHHGGIJJI\n+@HWI-ST132:678:C1LFKACXX:6:2103:20548:80488\n+AATGAGAATGTATATTTT\n++\n+BCBDDFFFHHFHHJJJJJ\n+@HWI-ST132:678:C1LFKACXX:6:1213:10954:88904\n+GCAGTCGTGGCCGAGTGG\n++\n+B@CFFFFFFHGFHGIFHI\n+@HWI-ST132:678:C1LFKACXX:6:1301:8478:85932\n+GCAGTCGTGGCCGAGTGG\n++\n+@CCFDFFDFHHHHGHAFG\n+@HWI-ST132:678:C1LFKACXX:6:2101:5467:98324\n+GCAGTCGTGGCCGAGTGG\n++\n+@@CFFDFFHHGHH>GAGH\n+@HWI-ST132:678:C1LFKACXX:6:2107:20194:63182\n+GCAGTCGTGGCCGAGTGG\n++\n+BCCFFFFFHGHHHBH<EH\n+@HWI-ST132:678:C1LFKACXX:6:1116:13015:74545\n+GCAGTCGTGGCCGAGTGGTTAAGGC\n++\n+B@:BDDFDFHFFFBG2CDHGGGFHI\n+@HWI-ST132:678:C1LFKACXX:6:1209:1463:48119\n+GCAGTCGTGGCCGAGTGGTTAAGGC\n++\n+BCCFDFDDHHHHHJJFHIIJJJIJJ\n+@HWI-ST132:678:C1LFKACXX:6:1313:4928:7411\n+GCAGTCGTGGCCGAGTGGTTAAGGC\n++\n+@C@FFDFFHHFHHJJAEGGHGIIJI\n+@HWI-ST132:678:C1LFKACXX:6:1113:20573:45425\n+AGTCGTGGCCGAGTGGTTAAGGC\n++\n+CCCFFFFFFHHHH?EHHHIIJJJ\n+@HWI-ST132:678:C1LFKACXX:6:2109:6492:70002\n+GTCGTGGCCGAGTGGTTAAGGC\n++\n+CCCFFFFFGHG@2<EAFHGGJI\n+@HWI-ST132:678:C1LFKACXX:6:1104:13333:89311\n+TTAAGGCGTCTGACTCGAAATCAGA\n++\n+CCCFFFFFHHHHHIIJJGGIJJJJJ\n+@HWI-ST132:678:C1LFKACXX:6:1306:7606:88539\n+TGACTCGAAATCAGATTCCCTCTG\n++\n+CCCFFFFFHHHHHJJJIJGIJJJJ\n+@HWI-ST132:678:C1LFKACXX:6:2108:19159:27727\n+ATATAGCCTGAGCTTCGACC\n++\n+JJJJJIHF?HHHFDFFFCCC\n+@HWI-ST132:678:C1LFKACXX:6:1211:6213:41030\n+TCGGATCCGAAGATTGCAGG\n++\n+@@CFFFFFDHHGHEHEFFHI\n+@HWI-ST132:678:C1LFKACXX:6:1203:8956:45599\n+AGATTGCAGGTTCGAGTCCT\n++\n+@@@DFFFFHHFHH<A<AEHH\n+@HWI-ST132:678:C1LFKACXX:6:1303:5477:98042\n+GTAACTGACCGTGTGGCCCAATGGA\n++\n+??@DFFFFGHDHGG?GGIEH3<FGH\n+@HWI-ST132:678:C1LFKACXX:6:1315:9507:45115\n+AAGATTGCAGGTTCGAGTC\n++\n+@@@:BDDDAFHHFIIGHFA\n+@HWI-ST132:678:C1LFKACXX:6:1306:9972:7484\n+AAGATTGCAGGTTCGAGTCCT\n++\n+@@CFFFFAFFHHHG@GEBGHH\n+@HWI-ST132:678:C1LFKACXX:6:1303:16006:44426\n+AGATTGCAGGTTCGAGTCCT\n++\n+@@@FFFFFDHDFHCE<AEHI\n+@HWI-ST132:678:C1LFKACXX:6:1214:13442:64117\n+AATGGATAAGGCGTCGGA\n++\n+818A:3ADHHFBFC1@FB\n+@HWI-ST132:678:C1LFKACXX:6:1214:1663:16969\n+ATTGCAGGTTCGAGTCCTG\n++\n+@@@FDFFFCFFHHIGHIIJ\n' |
b |
diff -r 000000000000 -r 198009598544 test-data/transcripts-file-small.fa --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/test-data/transcripts-file-small.fa Wed Oct 11 09:57:58 2017 -0400 |
b |
b'@@ -0,0 +1,26 @@\n+>FBtr0078666 type=mRNA; loc=3R:complement(join(5822026..5824307,5824361..5824504)); ID=FBtr0078666; name=CG2023-RA; dbxref=FlyBase:FBtr0078666,FlyBase_Annotation_IDs:CG2023-RA,REFSEQ:NM_141338,REFSEQ:NM_141338,REFSEQ:NM_141338; score=11; score_text=Strongly Supported; MD5=d3ca07b9149e74faf0d15d708cb012db; length=2426; parent=FBgn0037383; release=r6.16; species=Dmel; \n+GTTAAATGCACGTCACCAAAGCAGAATAATAGAATATTTTCGAAACAAAACAAAGTTGGAGACATGGACAAGGATGCGTTTACATTACAGGCCATACGGCAGGACCTTATCGATAACAATCTGCAGGCTAAGGCAATAATACACGACATCCTGAACAGCCGCACCTCCATCGCCGAACTCGAGGAGCTGAACGAAGCGGGCCGCTCCAAACTGTCTGCTATCCGCAAAAGCATCGAGCGGCTGGACGACTGGGCGCGGGACACGGCAGACTCTGCGCTGGCCAATGAAGTGGACGACCACCGTGATCAGTTCTCCAAAACGCTGCAGGCGTTCCGAAAAGCAAACGTGTCCACGATGCTGGAGATCGAGAAGGCCAATCGGGAGGAGTTAATGGCCATTACCGGCGAGAGTGAGCTACGCCAACGAACCACAACACGGGCGCGGCACAACCAGGGCAGTCTGGTTTCGCAGGAGAACGACGTGACCGAGAAGATGCTGGCTATATCGCGGCACCTCTCGGAGACCACCCAGAAGAGCGCCATCACCCTGGAAACGCTCGTGGCCTCGTCGCAAAATGTGGAGGCCACCAGCGACGAACTGCACCACACGGCCGGCAGCATTAGCATGTCCGGCAAGCTGCTCAAAAAGTACGGACGACGCGAGTGCACTGACAAAATGCTGCTCTTCTTCGCCTTCTCCTTGTTCCTCGCCTGTGTCTTTTACATCGTCCAAAAGCGACTCTTCTAAGACTCCACAAATGGACAAAACCCGTTCCCAAAATAGCTTAAGGTTGTCGCTTCTGTTGTCTAGGTATAGCTAGATTAAGCTTAGCACATGACCATACCTTGTAAGCACAGCTCCTATATTTATATTATTTAGTGATTTGCCTAAGTTGTAAACGTGGTACAGCCAAAGACCCTAGAATAACAAGATGCGTAACGCCATACGATTTTTTGGCACACGATTTTTTGGCCGTGGCTCTAGAGGTGGCTCCAGGCTCTCTCGAATTTTTGTTAGAGAGCGAGAGAGCGAAGAGCGCTACAGCGAACAGCTCTTTTCAACGCACAAAGTGATAGCAGACATCTGTATGTGTGCACACGTATTCACATGCATTGTAAATTTGACAAAATATGCCCTTCACCTTAGAAGTTCTTTGGCTTTAAATCTATATTATTTTTTATCAATTGGCACCATGCGAAAAATTCTTGTTTTGCATTGCCTTAACGTTATTATTATTTGAAAATAGATTAGAAATAGTCAAATCTATGTACATATTATCACAAAAATAAATTTCAAAAATGAATTTATATAAGAATATTTGTCATTAGAGTATTCATCTTGCGGCGTGTGAAAAATTAATAAGGCAATGATTGTTGAGTGCTTGTGTCCGCACTTCGTGCCTCAAGATATGAACAAAGCAAAGACACTAGAATAATTCTATTGTCTTTGATATTACTTTTGCAATTTAATTTAATTGCATATTTAATTATTTAGTATATTTATTAAATCATTTGACTTAATATGATGTAACATTAACATTAAAAGTGTTTCAAAAAAAATATTTCGGTTTTAAAAAATTGTCAGATGAGAGACAAATTAGAATTAAACATAAATACAAATGTGTAAACGGTAGCTAATTCGAGCGGCGATTTTAACAAAGAAATTTAAAAAAGCTTTAAAATTATAATAGCCAGGGCGCGAATTTTTAAAAATTTTTTATTTTATCATATTGCTAGGAAATTGGCAAAAACTACCCTAATATGTACCATGTAAATTCGTTTCTTCGATCAGAATTGATTTCGGCCCGAAAATCGTCTTCTAGCACAACACGCACACTTATACGCGTTCTCGTCTCTTGTTTTTACTCACACAAGCAAGCAAATTATATTTTTAGATTTCTTACGCTCTAAGCGGGAGTGAGCGGAAAGAGAGTAATTTTGGCCGTCACCAAAAAAGTGGCTGCATAGTGCCAAACCAATGTATGGCCGTTACGCATCTTGTTATTCTAGTGTCTTTGGTACAGCCTAGTATAGTATGGTAAATGCAATTTATTTTTATTTAGAATATATGAGTGTTGTATATGTAGATAAAAATGTTAAGCAAGTTAGTAAGGGCACCTAGGCACTCCTCCGGGGTTTGTGAATCCGTTGGTGTTGACCAACCTGCAGATGTCCTTGTATGACCGCGCCGATTTTGCAGGCCTTTCTGGCTGTGGCTGGGAATAACCTCTGTTGTAATAGTCAGGATAGAACTGGAACCAAGAAGGCCTGTGGTAGTTGTAGTCGGGAAAAAATTCTTTAAGCACAGAGCTGCTGCAGAATCTGCTTAGCCCCAGAATCCACAGCAGAATGTATATAATCGACTTGCGCATGGCCACTTCGCCTGAGCTTAAGATTTGGAATAAAGCCGTACCCGATTCTCATTGT\n+>FBtr0345575 type=mRNA; loc=2R:complement(join(8564187..8564768,8564826..8567202)); ID=FBtr0345575; name=Cyp6a14-RE; dbxref=FlyBase:FBtr0345575,FlyBase_Annotation_IDs:CG8687-RE,REFSEQ:NM_001299270; score=11; score_text=Strongly Supported; MD5=8174de0eb4bb4210648ec87219a6a80c; length=2959; parent=FBgn0033302; release=r6.16; species=Dmel; \n+AGTTGTCCCTAAACGCTGATTCAGTGAAGTCGTTTACGCGATAAGTTTACTGTGTGAAAAAGAAATAAAAGTTTCGTCAGCCTTTAGGTGGAATTCCCTCTATTGGTTGTCCGAAATCGGCAACATACATTTGTTTAACACCAACATTTGTCTTTGCTTTACCAAATAAATGATGTTTGAGGTGCCGTTACTCATTGACAGCAATATAGAACTTGGTACTACCAAAGACACTAGAATAACAAGATGCGTAACGGCCATACATTGGTTTGGCACTATGCAGCCACTTTTTTGGTGACGGCCAAAATTGCTCTCTTTCCGCTCGCTCACGCGCCCTTCTTATTATAATTTTAAAGCTGTTTAAATTTGTTTGTTAAAATCGCCGCTCGAATTATCTACCGTTTACACATTTATATTTATGTTTAATTCTAATTTGTCTCTCATCTGACAATTTTTTAAAAGCGAAATAATTTTTTTGAAACACTTTTAATGTTAATGTTACATCATATTAGGTCAAATGATTTAATAAATATACTAAATAATTAAATATGATAACTGTTTATTGCAAAAGTAATATCAAAGACACTAGAATTATTCTAGTGTCTTTGCTTTGTTCATATCTTGAGGCACGAAATGCGGACACAAGCACTCAACAATCATTGCCTTATTAATTTTTCACACGCCGCAAGATGAATACTCTAATGACAAATATTCTTATATAAAGTCATTTTTGAAATTGATTTTTGTGATAATATGTACATAGATTTGGCTTTTTCTAATCTATTTTCAAATAATAATAACGTTAAGGCAATGTAAAACAAGAATTTTTCGCATGGTGCCAATT'..b'CACCAAATGATATGTAATTAAAATTAAATAAATATCTAAACACATATTGTGAATGACGACTAATCTTGCAAACGACATTACATACTTTATGTAGGGCGAATTCTGGTTGATTTTTACAATCGACCACTTGACGAGCAGTTAAGCCAGTTCTTTTTTTTTTGTTTAAAACAATACGTATTTTATTTTTACAAGACATTCCCTAACTAGGTTAGGGTTCCCATTTAAAGGTATTTCCTTACTCGCTTACAATTGAATCCCGAAATGGATTCAATGTACTATTTATCTAATATCACCTCATGGCATCTAAGGAATTTAAGGGATCTTTGAACTAACACCTACATATTTGTGTATTGTATTCAAATATATTGTGTATCTGTCTGGTAAAGTGTTAACTTAACTTTGTAAATACTATGCGGTTTACTTTAAAGACAAATCAAAGGCGATAGTGTGCGAAAGCAAAAGGAAACAATTAAATACGAGTATAATAAATATTTTTTTCAAAT\n+>FBtr0310270 type=mRNA; loc=X:join(15024436..15024954,15030586..15030847,15030911..15031068,15031178..15031467,15031543..15032573,15033606..15034414); ID=FBtr0310270; name=be-RF; dbxref=FlyBase:FBtr0310270,FlyBase_Annotation_IDs:CG32594-RF,REFSEQ:NM_001258745,REFSEQ:NM_001258745; score=15; score_text=Strongly Supported; MD5=5539c8fae56fdff6eb554e4ed9309709; length=3069; parent=FBgn0052594; release=r6.16; species=Dmel; \n+TTAGAGCTAAACGAACTGCCATCCGGTAAACACGTCTCACAACGTTATTTGTGTTGAATATATATATATTTTTTTGTTGTGGCTCTTTTTTTTTAATTTCTGCGGCCCCTAAAGTTCGACGATCGTGAGAAGGGAAAAAGAGTGTGAAGTGACCTAAGCGGTTTTGAAATATCTATCTTGGCAAAACGAAAACAAATTTGTTAAAGCACATATAAACAAAAACAAAATAACAAAAATAAAAGTGAAGCAAAGGTGAAGAAGACCAGAATGAATTCGCGACGGATTGCTCTGGTCCTCCTAATCGGCATAATCGTTTCGTTTTCTGGCCATGATGCACTAACCTATCCGGAGCGCTTCGATCGCCTGCCCACTTGGGGTGGTCATTCCCAAATTGGTGGGCCGCTGCTGGATACCGCCCACCGGGAGAATCGTGAGAAAAGGGAGAATAGGGTGGACCTGTGCCGGCACTGTTTCTGCATTCATCTCAAGGCAATCTGTGATTACAAGCTTAACAAAACGCTCCCGAACGAATTTAACGATAAACTATTGGTGCCGCTGAACATCAAATATATTGAGGTGCGACTGACTGTTGGCACCCAGTTCGTGATGTACGAGAACTTCTTCCAGGACAACCAGGTGAACTACTTTGGTGTAATCGGAGTGGGGAAAGATGACCAGGTGGAAATAACCAGCAATGCATTTAGCCACAACAAAGGCGGTTTTCCCAACATCGAAATACGAAATGTATTGCGAGTTTTTCTGCGTGAGAAATTCCTGACCGGTGCGGACTACAAGCTGCTGGTGGAGGATGTTACTCAGCTGTCCGTATTCTCCAATGCCCTTCAGATGACTAATCTAGACTGTTCTCTCAAGCGGATCAAGGAGCTGAATCTGATGAAGAACGCTTTCAATCCTGGGGTTGCCAAATATGGAATAAATCTCCGCATCGAGGATTCGAACATCAATCAGCTGGGTATATTCGGCGTGTCCATGGGCAAGGTGAGCCTGTTGCGCTGCCACATCGACATGATCATGAGCAACGCCTTTGACGTTACCAGCATCAAGGAGCTGATTATCGAGGGCTGCAATATCGAGGTGATCGAGAGCCAGGCGCTAACCAACAAATTGCATAGCGATAAGGTGGCCATCGTGGATACGGTGATCGGTACGATTGAGGGTCAGGCGATCAGTCAGAGCGGTATAACTACCATGATTATGTTTGGAAATACAATTACAAAAATACGTTCGAATGCCATTCAAATTGTTGCCGTTAGTCTGTTCATACGCAACAATTCAATGAGCCATGTGGAGCCCAATTGGTTGAGTGTCAGCCAGGCCGATCAAGTGGAGATTGCGAATAATCGCTTCGAGGACTACGGACGCTGTGAACTGAACATTGGCTCCTCGAACTGCAGTTTTCGCAACAATATACTGCAGAATCCGCAATCGGGTAGCCTCAATTTTACATGTCGCGTCCACCAGGTGCGCGTGGGCACCGAGTGCTCGTGCAACAAGTCCTGGCTATCGGAGCTAACCGATCATGATCTGGAATCGGAAATCATGTGTCAGGTGGCAAAGCGTGATGCCAACTGCTTTAATGCCACCAATACGGATGTCCGCCGGTATGTCAACGAGGCATGTGGCAGCAATGTGACCCGCTACTGTATGGGTGGCCAGTGGGTGACCAAGGCGGTCAGTGATCATTCTAGCGACTCCAGCAAATTGACCATCGGAATGATAGCCCTTGAGATTGTGATTTTAACACTCTTGCTTGTTGCGATTGTCTGTGTGTTGGCCAAAAACTGTGGCAGTGGAAGCTGCGCTCCTGCCGGTGGCCAGTCCACTGATAATTGCCTAATCGAGGAGGACATTCGCAACTCACTGCGCCAGCTCGCACTGCACAGCGAGAGCAATAAGACACGCAAGGCTATACTGAAGCTGATCAATGGTCATTTGAGCAAGGGGGAGTGCAACGATCGGATACTCTTTATAGTGGACAACATGCCGCAAAATCAGGCGATCGAAAGCCTGCTGTTTAGGCACATATCGCAGAGTCACATGGAGCCCAGTGATAGTGAGGCATATGCCAGCACCGCCTTAACAGCCAATGCAACAGCACCACCACTGCCGCCCAGTACCGATTCCAGTGAGCCCATCTACCAAGAGCTCGACCAGCAACGACTGATCATCGACGACAAGTACTCATTGCCGCTGAATTCCGACGAGGATCCGCCGTACTCGGAGCCGTCCAATATGATGAATACGAACGACATGCCACCGGCATATCAATATGCCACACCGATGCGCATCCTGCCATGCCACCAGATGCAGCATCAGCAGCCGTCGACGACGGCCAATTATGCCATCCCCGTTTGGAGGTCCACTCCAAGTGCCACGCCCACTAGCCGCCCACCCTCGGGCTCACAGGAGGGGTCGGCCACCGCCACAGCGCCCAGAGCTGTCAAGGATTTGCGGCAGGCTCTGCAGAACTCCCCACAGTTCCATCCCAACCAGCTGACCTCAACGCGCAACCAAAGACAAATCCTGCAGATTCTGCCGCCGCTTCAGCCGCCGCCGTACACTCAGAGGTCACAGGTCAGGGGTCAGCGGAGGCGCAGCTTCGAGTGCCTCGATGGCGCCGCCAGCTTGGCGGCCATGGAGCACATGGACTCCGGCTCGGATCACTCTGGCGGCAGTGATGTGACCGTCCAAATTGCTGATGTGATCGACTACGCGGATGCCTAAAAGTATGCAGAGCACTCAAATATATACTATACTATATATATATAGTACAGGTATATAGTAACATAATATGCTTCTCATATTACGTTTACATACTTACACTAATTGTACATACAATCTTGCACATGCATAAACACATGAAACCAGTTTACATTTTTACTTACACTTAAGCGCATAATTTGTTGTGCATCCATACCGTTATTTTTCCGTTTTTTTTTGTACACATATACTGATTAGACATTCCCGTTTCTCGCGACTCACTTCGAGCCGATCAAAAACTCTGTACAGTCAGTCTTAAGCCGACAACGAAGAAATAAAGATCTAAAC\n' |
b |
diff -r 000000000000 -r 198009598544 tool-data/bwa_index.loc.sample --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/tool-data/bwa_index.loc.sample Wed Oct 11 09:57:58 2017 -0400 |
b |
b'@@ -0,0 +1,931 @@\n+\n+\n+\n+\n+\n+\n+<!DOCTYPE html>\n+<html lang="en">\n+ <head>\n+ <meta charset="utf-8">\n+ <link rel="dns-prefetch" href="https://assets-cdn.github.com">\n+ <link rel="dns-prefetch" href="https://avatars0.githubusercontent.com">\n+ <link rel="dns-prefetch" href="https://avatars1.githubusercontent.com">\n+ <link rel="dns-prefetch" href="https://avatars2.githubusercontent.com">\n+ <link rel="dns-prefetch" href="https://avatars3.githubusercontent.com">\n+ <link rel="dns-prefetch" href="https://github-cloud.s3.amazonaws.com">\n+ <link rel="dns-prefetch" href="https://user-images.githubusercontent.com/">\n+\n+\n+\n+ <link crossorigin="anonymous" href="https://assets-cdn.github.com/assets/frameworks-bedfc518345498ab3204d330c1727cde7e733526a09cd7df6867f6a231565091.css" media="all" rel="stylesheet" />\n+ <link crossorigin="anonymous" href="https://assets-cdn.github.com/assets/github-36dc4044670fb93253d932fbc3a10282233e86290bfaf8285c479925456b3d47.css" media="all" rel="stylesheet" />\n+ \n+ \n+ \n+ \n+\n+ <meta name="viewport" content="width=device-width">\n+ \n+ <title>ucd-biocore-galaxy/bwa_index.loc at master \xc2\xb7 najoshi/ucd-biocore-galaxy</title>\n+ <link rel="search" type="application/opensearchdescription+xml" href="/opensearch.xml" title="GitHub">\n+ <link rel="fluid-icon" href="https://github.com/fluidicon.png" title="GitHub">\n+ <meta property="fb:app_id" content="1401488693436528">\n+\n+ \n+ <meta content="https://avatars2.githubusercontent.com/u/607905?v=4&s=400" property="og:image" /><meta content="GitHub" property="og:site_name" /><meta content="object" property="og:type" /><meta content="najoshi/ucd-biocore-galaxy" property="og:title" /><meta content="https://github.com/najoshi/ucd-biocore-galaxy" property="og:url" /><meta content="Contribute to ucd-biocore-galaxy development by creating an account on GitHub." property="og:description" />\n+\n+ <link rel="assets" href="https://assets-cdn.github.com/">\n+ <link rel="web-socket" href="wss://live.github.com/_sockets/VjI6MjEwNDI1ODEzOmRlNDljMGYyZDllODM5ZDNlZjIxZjE5NTg0OTc5ZDgyYjM4YTE0Nzk3ZmY1OTkwZDMyMzQ0ODI0OGJlMjE3N2Q=--f8baca754bfadb9aadd516112fca27dd1f441d24">\n+ <meta name="pjax-timeout" content="1000">\n+ <link rel="sudo-modal" href="/sessions/sudo_modal">\n+ <meta name="request-id" content="65EB:385B:547C2B7:9CAB0F2:59D3704F" data-pjax-transient>\n+ \n+\n+ <meta name="selected-link" value="repo_source" data-pjax-transient>\n+\n+ <meta name="google-site-verification" content="KT5gs8h0wvaagLKAVWq8bbeNwnZZK1r1XQysX3xurLU">\n+<meta name="google-site-verification" content="ZzhVyEFwb7w3e0-uOTltm8Jsck2F5StVihD0exw2fsA">\n+ <meta name="google-analytics" content="UA-3769691-2">\n+\n+<meta content="collector.githubapp.com" name="octolytics-host" /><meta content="github" name="octolytics-app-id" /><meta content="https://collector.githubapp.com/github-external/browser_event" name="octolytics-event-url" /><meta content="65EB:385B:547C2B7:9CAB0F2:59D3704F" name="octolytics-dimension-request_id" /><meta content="iad" name="octolytics-dimension-region_edge" /><meta content="iad" name="octolytics-dimension-region_render" /><meta content="29629007" name="octolytics-actor-id" /><meta content="rom1po" name="octolytics-actor-login" /><meta content="1c29c85d1e7154d6d4a96f789ac78391bf768e2457e1928abb1e027acfd4ddd5" name="octolytics-actor-hash" />\n+<meta content="/<user-name>/<repo-name>/blob/show" data-pjax-transient="true" name="analytics-location" />\n+\n+\n+\n+\n+ <meta class="js-ga-set" name="dimension1" content="Logged In">\n+\n+\n+ \n+\n+ <meta name="hostname" content="github.com">\n+ <meta name="user-login" content="rom1po">\n+\n+ <meta name="expected-hostname" content="github.com">\n+ <meta name="js-proxy-site-detection-payload" content="ZTkzZTAyZWZlZDEwMjRhMWI4YjM2ZTZjNTVjMDRhNjEwNGM1YjA2N2Y4M2U1NjQyZjFmY2YwNDRhOGRlZjJhOHx7InJlbW90ZV9hZGRyZXNzIjoiMTkzLjQ5LjE2Ni40NCIsInJlcXVlc3RfaWQiOiI2NUVCOjM4NUI6NTQ3QzJCNzo5Q0FCMEYyOjU5RDM3MDRGIiwidGltZXN0YW1wIjoxNTA3MDI'..b' 3.54 2.29 6.53 5.47 7.59.4.07.55-.17.55-.38 0-.19-.01-.82-.01-1.49-2.01.37-2.53-.49-2.69-.94-.09-.23-.48-.94-.82-1.13-.28-.15-.68-.52-.01-.53.63-.01 1.08.58 1.23.82.72 1.21 1.87.87 2.33.66.07-.52.28-.87.51-1.07-1.78-.2-3.64-.89-3.64-3.95 0-.87.31-1.59.82-2.15-.08-.2-.36-1.02.08-2.12 0 0 .67-.21 2.2.82.64-.18 1.32-.27 2-.27.68 0 1.36.09 2 .27 1.53-1.04 2.2-.82 2.2-.82.44 1.1.16 1.92.08 2.12.51.56.82 1.27.82 2.15 0 3.07-1.87 3.75-3.65 3.95.29.25.54.73.54 1.48 0 1.07-.01 1.93-.01 2.2 0 .21.15.46.55.38A8.013 8.013 0 0 0 16 8c0-4.42-3.58-8-8-8z"/></svg>\n+</a>\n+ <ul class="list-style-none d-flex flex-wrap ">\n+ <li class="mr-3"><a href="https://github.com/contact" data-ga-click="Footer, go to contact, text:contact">Contact GitHub</a></li>\n+ <li class="mr-3"><a href="https://developer.github.com" data-ga-click="Footer, go to api, text:api">API</a></li>\n+ <li class="mr-3"><a href="https://training.github.com" data-ga-click="Footer, go to training, text:training">Training</a></li>\n+ <li class="mr-3"><a href="https://shop.github.com" data-ga-click="Footer, go to shop, text:shop">Shop</a></li>\n+ <li class="mr-3"><a href="https://github.com/blog" data-ga-click="Footer, go to blog, text:blog">Blog</a></li>\n+ <li><a href="https://github.com/about" data-ga-click="Footer, go to about, text:about">About</a></li>\n+\n+ </ul>\n+ </div>\n+</div>\n+\n+\n+\n+ <div id="ajax-error-message" class="ajax-error-message flash flash-error">\n+ <svg aria-hidden="true" class="octicon octicon-alert" height="16" version="1.1" viewBox="0 0 16 16" width="16"><path fill-rule="evenodd" d="M8.865 1.52c-.18-.31-.51-.5-.87-.5s-.69.19-.87.5L.275 13.5c-.18.31-.18.69 0 1 .19.31.52.5.87.5h13.7c.36 0 .69-.19.86-.5.17-.31.18-.69.01-1L8.865 1.52zM8.995 13h-2v-2h2v2zm0-3h-2V6h2v4z"/></svg>\n+ <button type="button" class="flash-close js-flash-close js-ajax-error-dismiss" aria-label="Dismiss error">\n+ <svg aria-hidden="true" class="octicon octicon-x" height="16" version="1.1" viewBox="0 0 12 16" width="12"><path fill-rule="evenodd" d="M7.48 8l3.75 3.75-1.48 1.48L6 9.48l-3.75 3.75-1.48-1.48L4.52 8 .77 4.25l1.48-1.48L6 6.52l3.75-3.75 1.48 1.48z"/></svg>\n+ </button>\n+ You can\'t perform that action at this time.\n+ </div>\n+\n+\n+ \n+ <script crossorigin="anonymous" src="https://assets-cdn.github.com/assets/frameworks-db06d5e5cc508b59a3d6d16c22bb523005ca9fc0c513cbb039b32a25204b6be7.js"></script>\n+ \n+ <script async="async" crossorigin="anonymous" src="https://assets-cdn.github.com/assets/github-da65661edce7dd1ef92a685ec40dae4e270e94dc323d9b2c7762d98dcff91964.js"></script>\n+ \n+ \n+ \n+ \n+ <div class="js-stale-session-flash stale-session-flash flash flash-warn flash-banner d-none">\n+ <svg aria-hidden="true" class="octicon octicon-alert" height="16" version="1.1" viewBox="0 0 16 16" width="16"><path fill-rule="evenodd" d="M8.865 1.52c-.18-.31-.51-.5-.87-.5s-.69.19-.87.5L.275 13.5c-.18.31-.18.69 0 1 .19.31.52.5.87.5h13.7c.36 0 .69-.19.86-.5.17-.31.18-.69.01-1L8.865 1.52zM8.995 13h-2v-2h2v2zm0-3h-2V6h2v4z"/></svg>\n+ <span class="signed-in-tab-flash">You signed in with another tab or window. <a href="">Reload</a> to refresh your session.</span>\n+ <span class="signed-out-tab-flash">You signed out in another tab or window. <a href="">Reload</a> to refresh your session.</span>\n+ </div>\n+ <div class="facebox" id="facebox" style="display:none;">\n+ <div class="facebox-popup">\n+ <div class="facebox-content" role="dialog" aria-labelledby="facebox-header" aria-describedby="facebox-description">\n+ </div>\n+ <button type="button" class="facebox-close js-facebox-close" aria-label="Close modal">\n+ <svg aria-hidden="true" class="octicon octicon-x" height="16" version="1.1" viewBox="0 0 12 16" width="12"><path fill-rule="evenodd" d="M7.48 8l3.75 3.75-1.48 1.48L6 9.48l-3.75 3.75-1.48-1.48L4.52 8 .77 4.25l1.48-1.48L6 6.52l3.75-3.75 1.48 1.48z"/></svg>\n+ </button>\n+ </div>\n+</div>\n+\n+\n+ </body>\n+</html>\n+\n' |
b |
diff -r 000000000000 -r 198009598544 tool_data_table_conf.xml.sample --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/tool_data_table_conf.xml.sample Wed Oct 11 09:57:58 2017 -0400 |
b |
@@ -0,0 +1,7 @@ +<tables> + <!-- Locations of configurations --> + <table name="bwa_indexes" comment_char="#"> + <columns>value, dbkey, name, path</columns> + <file path="tool-data/bwa_index.loc" /> + </table> +</tables> \ No newline at end of file |