Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

{bio}[foss/2020b] ABRA2 v2.23, CRISPR-DAV v2.3.4, Excel-Writer-XLSX v1.09, FLASH v2.2.00, PRINSEQ v0.20.4, pysamstats v1.1.2 w/ Python 3.8.6 #13139

Merged
Merged
Show file tree
Hide file tree
Changes from 13 commits
Commits
Show all changes
26 commits
Select commit Hold shift + click to select a range
c49ebef
adding easyconfigs: naturalsort-0.1.3-foss-2020b.eb, pysamstats-1.1.2…
Jun 14, 2021
af9d999
less strict requirements of pysamstats
Jun 14, 2021
c39a53a
repaired source file name
Jun 14, 2021
a91aa34
changed http to https
Jun 14, 2021
a9662fa
changes according to review
Jun 15, 2021
69c6bdb
WIP removing hardcoded paths
Jun 15, 2021
5443b56
functional crispr-dav
Jun 23, 2021
974e09c
flash2 should be accessible via `flash` cmd
Jun 28, 2021
c06d427
review changes
Jun 29, 2021
b8bf8f4
setting crisprdav easyblock explicitely
Aug 17, 2021
d2c98b1
Delete crispr-dav-2.3.4-foss-2020b.eb
deniskristak Aug 17, 2021
0333231
removing explicit crispr-dav easyblock
Aug 17, 2021
fd5fbdc
Update CRISPR-DAV-2.3.4-foss-2020b.eb
deniskristak Aug 17, 2021
7e59428
Delete crispr-dav-2.3.4-foss2020b_remove_hardcoding.patch
deniskristak Aug 18, 2021
59b8101
Rename crispr-dav-2.3.4-foss2020b_remove_hardcoding.patch to crispr-d…
deniskristak Aug 18, 2021
37abf2d
Update CRISPR-DAV-2.3.4-foss-2020b.eb
deniskristak Aug 18, 2021
3b79f49
Create CRISPR-DAV-2.3.4-foss-2020b.eb
deniskristak Aug 18, 2021
daf8db7
Update Excel-Writer-XLSX-1.09-foss-2020b.eb
deniskristak Aug 18, 2021
852ce7a
Update FLASH-2.2.00-foss-2020b.eb
deniskristak Aug 18, 2021
37cc749
Update FLASH-2.2.00-foss-2020b.eb
deniskristak Aug 18, 2021
0464e66
Delete naturalsort-0.1.3-foss-2020b.eb
deniskristak Aug 18, 2021
1b1c3c6
Update pysamstats-1.1.2-foss-2020b.eb
deniskristak Aug 18, 2021
f231d83
Update CRISPR-DAV-2.3.4-foss-2020b.eb
deniskristak Aug 19, 2021
47df656
fix suggestions for ABRA2, CRISPR-DAV, PRINSEQ easyconfigs
boegel Aug 19, 2021
db6b328
fix long line in Excel-Writer-XLSX easyconfig
boegel Aug 19, 2021
c062a0e
stick to SAMtools 1.11 as dependency for CRISPR-DAV
boegel Aug 19, 2021
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
48 changes: 48 additions & 0 deletions easybuild/easyconfigs/a/ABRA2/ABRA2-2.23-GCC-10.2.0.eb
Original file line number Diff line number Diff line change
@@ -0,0 +1,48 @@
easyblock = 'MakeCp'

name = 'ABRA2'
version = '2.23'

homepage = 'https://github.com/mozack/abra2'
description = "Assembly Based ReAligner"

toolchain = {'name': 'GCC', 'version': '10.2.0'}

source_urls = ['https://github.com/mozack/abra2/archive/']
sources = ['v%(version)s.tar.gz']
patches = ['ABRA2-2.22_fix-Makefile.patch']
checksums = [
'3993f66a493070ee49df2865b6786a45a0cf6c379bae83e94b8339abbe673289', # v2.23.tar.gz
'05090efb306fc84d09f007a848ce0d0472f8633633b0a6eaf86ab075d092bc0d', # ABRA2-2.22_fix-Makefile.patch
]

builddependencies = [('Maven', '3.6.3', '', True)]

dependencies = [
('Java', '11', '', True),
('BWA', '0.7.17'),
]

parallel = 1

buildopts = 'CXX="$CXX" CXXFLAGS="$CXXFLAGS"'
buildopts += '&& make standalone CXX="$CXX" CXXFLAGS="$CXXFLAGS"'

files_to_copy = [
(['abra'], 'bin'),
(['target/libAbra.%s' % SHLIB_EXT], 'lib'),
'target/abra2-%(version)s-jar-with-dependencies.jar',
]

postinstallcmds = ["cd %(installdir)s && mv abra2-%(version)s-jar-with-dependencies.jar abra2-%(version)s.jar"]

sanity_check_paths = {
'files': ['abra2-%(version)s.jar', 'bin/abra', 'lib/libAbra.%s' % SHLIB_EXT],
boegel marked this conversation as resolved.
Show resolved Hide resolved
'dirs': [],
}

modextravars = {
"LC_ALL": "en_US.UTF-8",
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@deniskristak Hmm, why is this needed? That looks a bit fishy, it doesn't belong in a module generated by EasyBuild...

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

ABRA2 needs it because of this:
mozack/abra2#25

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

OK, please add a comment with a reference to that issue then:

# required to work around localization bug, see https://github.com/mozack/abra2/issues/25
modextravars = {'LC_ALL': 'en_US.UTF-8'}

}

moduleclass = 'bio'
35 changes: 35 additions & 0 deletions easybuild/easyconfigs/c/CRISPR-DAV/CRISPR-DAV-2.3.4-foss-2020b.eb
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
name = 'CRISPR-DAV'
version = '2.3.4'

homepage = 'https://github.com/pinetree1/crispr-dav/'
description = """CRISPR-DAV is a pipeline to analyze
amplicon-based NGS data of CRISPR clones in a high throughput manner."""

toolchain = {'name': 'foss', 'version': '2020b'}

source_urls = ['https://github.com/pinetree1/crispr-dav/archive/']
sources = ['v%(version)s.tar.gz']
patches = ['crispr-dav-2.3.4-foss2020b_remove_hardcoding.patch']
deniskristak marked this conversation as resolved.
Show resolved Hide resolved
checksums = [
'49975cd48bdbf31fe5a9e2aaa3f5ed85d3cc6f65a422ee3aa8daed890159d2ae', # v2.3.4.tar.gz
# crispr-dav-2.3.4-foss2020b_remove_hardcoding.patch
'41475a09754d65cc2c88d4161be6eacdfc98242bccbe49778c4f1f74210a6cb2',
]

dependencies = [
('R', '4.0.3'),
('Perl', '5.32.0'),
('NGS', '2.10.9'),
('Pysam', '0.16.0.1'),
('Excel-Writer-XLSX', '1.09'),
('naturalsort', '0.1.3'),
deniskristak marked this conversation as resolved.
Show resolved Hide resolved
('pysamstats', '1.1.2'),
('ABRA2', '2.23'),
('PRINSEQ', '0.20.4', '-Perl-%(perlver)s'),
('SAMtools', '1.12'),
('BEDTools', '2.30.0'),
('FLASH', '2.2.00'),
('Archive-Zip', '1.68'),
]

moduleclass = 'bio'
Original file line number Diff line number Diff line change
@@ -0,0 +1,129 @@
# author: Denis Kristak (INUITS)
# changing example command to contain absolute paths + tabs escaping + changing plotting type to cairo
diff -ruN crispr-dav-2.3.4_orig/Examples/example1/run.sh crispr-dav-2.3.4/Examples/example1/run.sh
--- crispr-dav-2.3.4_orig/Examples/example1/run.sh 2019-07-26 21:15:08.000000000 +0200
+++ crispr-dav-2.3.4/Examples/example1/run.sh 2021-06-22 12:57:41.700453098 +0200
@@ -4,6 +4,7 @@

## If there is problem loading Perl modules., set PERL5LIB accordingly.
#export PERL5LIB=$HOME/perlmod/lib/perl5:$PERL5LIB
-../../crispr.pl --conf conf.txt --region amplicon.bed --crispr site.bed \
- --sitemap sample.site --fastqmap fastq.list --genome genomex
+
+$EBROOTCRISPRMINDAV/crispr.pl --conf $EBROOTCRISPRMINDAV/Examples/example1/conf.txt --region $EBROOTCRISPRMINDAV/Examples/example1/amplicon.bed --crispr $EBROOTCRISPRMINDAV/Examples/example1/site.bed \
+ --sitemap $EBROOTCRISPRMINDAV/Examples/example1/sample.site --fastqmap $EBROOTCRISPRMINDAV/Examples/example1/fastq.list --genome genomex --verbose 1

diff -ruN crispr-dav-2.3.4_orig/Modules/NGS.pm crispr-dav-2.3.4/Modules/NGS.pm
--- crispr-dav-2.3.4_orig/Modules/NGS.pm 2019-07-26 21:15:08.000000000 +0200
+++ crispr-dav-2.3.4/Modules/NGS.pm 2021-06-21 17:37:39.381993860 +0200
@@ -296,7 +296,7 @@
my $cmd = "$self->{bwa} mem";
$cmd .= " $h{param}" if $h{param};
if ( $h{id} && $h{sm} ) {
- $cmd .= " -R \'\@RG\tID:$h{id}\tSM:$h{sm}\tPL:$h{pl}\'";
+ $cmd .= " -R \'\@RG\\tID:$h{id}\\tSM:$h{sm}\\tPL:$h{pl}\'";
}
$cmd .= " $h{idxbase} $h{read1_inf}";
$cmd .= " $h{read2_inf}" if -f $h{read2_inf};
@@ -558,7 +558,7 @@
# file is already indexed.
my $cmd = "rm -rf $workdir && mkdir -p $workdir" .
" && $self->{java} -Djava.io.tmpdir=$tmpdir -jar $h{abra} --threads 2" .
- " --ref $h{ref_fasta} --targets $h{target_bed} --working $workdir" .
+ " --ref $h{ref_fasta} --targets $h{target_bed} --tmpdir $workdir" .
" --in $h{bam_inf} --out $h{bam_outf}";

if ($h{single}) {
diff -ruN crispr-dav-2.3.4_orig/Rscripts/allele.R crispr-dav-2.3.4/Rscripts/allele.R
--- crispr-dav-2.3.4_orig/Rscripts/allele.R 2019-07-26 21:15:08.000000000 +0200
+++ crispr-dav-2.3.4/Rscripts/allele.R 2021-06-22 13:13:45.868418215 +0200
@@ -114,7 +114,7 @@
} else {
h<-400
w<- ifelse(n>40, 13*n, h*1.25)
- png(filename=outfile, height=h, width=w)
+ png(filename=outfile, type='cairo', height=h, width=w)
}

on.exit(dev.off())
diff -ruN crispr-dav-2.3.4_orig/Rscripts/amplicon.R crispr-dav-2.3.4/Rscripts/amplicon.R
--- crispr-dav-2.3.4_orig/Rscripts/amplicon.R 2019-07-26 21:15:08.000000000 +0200
+++ crispr-dav-2.3.4/Rscripts/amplicon.R 2021-06-22 13:13:45.868418215 +0200
@@ -111,7 +111,7 @@
if ( high_res ) {
tiff(filename=outfile, width=5, height=4, units='in', res=1200)
} else {
- png(filename=outfile, width=500, height=400)
+ png(filename=outfile, type='cairo', width=500, height=400)
}
on.exit(dev.off())
print(p)
diff -ruN crispr-dav-2.3.4_orig/Rscripts/hdr.R crispr-dav-2.3.4/Rscripts/hdr.R
--- crispr-dav-2.3.4_orig/Rscripts/hdr.R 2019-07-26 21:15:08.000000000 +0200
+++ crispr-dav-2.3.4/Rscripts/hdr.R 2021-06-22 13:13:45.868418215 +0200
@@ -102,7 +102,7 @@
h<-400
barspace=60
w<- ifelse( n*barspace<h, h, n*barspace)
- png(filename=outfile, width=w, height=h)
+ png(filename=outfile, type='cairo', width=w, height=h)
}

print(p)
diff -ruN crispr-dav-2.3.4_orig/Rscripts/indel.R crispr-dav-2.3.4/Rscripts/indel.R
--- crispr-dav-2.3.4_orig/Rscripts/indel.R 2019-07-26 21:15:08.000000000 +0200
+++ crispr-dav-2.3.4/Rscripts/indel.R 2021-06-22 13:27:15.254201732 +0200
@@ -81,7 +81,7 @@
} else {
h<-450
w<- ifelse(n>10, 50*n, h)
- png(filename=imgfile, height=h, width=w)
+ png(filename=imgfile, type='cairo', height=h, width=w)
}

on.exit(dev.off())
diff -ruN crispr-dav-2.3.4_orig/Rscripts/read_chr.R crispr-dav-2.3.4/Rscripts/read_chr.R
--- crispr-dav-2.3.4_orig/Rscripts/read_chr.R 2019-07-26 21:15:08.000000000 +0200
+++ crispr-dav-2.3.4/Rscripts/read_chr.R 2021-06-22 13:13:45.868418215 +0200
@@ -72,7 +72,7 @@
w<-ifelse(n>5, 100*n, 550)
max_w=1000
w <- ifelse(w>max_w, max_w, w)
- png(filename=outfile, height=h, width=w)
+ png(filename=outfile, type='cairo', height=h, width=w)
}

print(p)
diff -ruN crispr-dav-2.3.4_orig/Rscripts/read_stats.R crispr-dav-2.3.4/Rscripts/read_stats.R
--- crispr-dav-2.3.4_orig/Rscripts/read_stats.R 2019-07-26 21:15:08.000000000 +0200
+++ crispr-dav-2.3.4/Rscripts/read_stats.R 2021-06-22 13:13:45.868418215 +0200
@@ -69,7 +69,7 @@
} else {
h<-400
w<- ifelse(n>10, 50*n, h)
- png(filename=outfile, height=h, width=w)
+ png(filename=outfile, type='cairo', height=h, width=w)
}

p <- ggplot(dat.m, aes(x=Sample, y=value, fill=variable)) +
diff -ruN crispr-dav-2.3.4_orig/Rscripts/snp.R crispr-dav-2.3.4/Rscripts/snp.R
--- crispr-dav-2.3.4_orig/Rscripts/snp.R 2019-07-26 21:15:08.000000000 +0200
+++ crispr-dav-2.3.4/Rscripts/snp.R 2021-06-22 13:13:45.868418215 +0200
@@ -76,7 +76,7 @@
if ( high_res ) {
tiff(filename=outfile, width=5, height=4, units='in', res=1200)
} else {
- png(filename=outfile, width=500, height=400)
+ png(filename=outfile, type='cairo', width=500, height=400)
}
print(p)
invisible(dev.off())
@@ -182,7 +182,7 @@
wt <- 600
}
ht <- 400
- png(filename=outfile, width=wt, height=ht)
+ png(filename=outfile, type='cairo', width=wt, height=ht)
}

print(p)
Original file line number Diff line number Diff line change
@@ -0,0 +1,128 @@
# changing example command to contain absolute paths + tabs escaping + changing plotting type to cairo
deniskristak marked this conversation as resolved.
Show resolved Hide resolved
diff -ruN crispr-dav-2.3.4_orig/Examples/example1/run.sh crispr-dav-2.3.4/Examples/example1/run.sh
--- crispr-dav-2.3.4_orig/Examples/example1/run.sh 2019-07-26 21:15:08.000000000 +0200
+++ crispr-dav-2.3.4/Examples/example1/run.sh 2021-06-22 12:57:41.700453098 +0200
@@ -4,6 +4,7 @@

## If there is problem loading Perl modules., set PERL5LIB accordingly.
#export PERL5LIB=$HOME/perlmod/lib/perl5:$PERL5LIB
-../../crispr.pl --conf conf.txt --region amplicon.bed --crispr site.bed \
- --sitemap sample.site --fastqmap fastq.list --genome genomex
+
+$EBROOTCRISPRMINDAV/crispr.pl --conf $EBROOTCRISPRMINDAV/Examples/example1/conf.txt --region $EBROOTCRISPRMINDAV/Examples/example1/amplicon.bed --crispr $EBROOTCRISPRMINDAV/Examples/example1/site.bed \
+ --sitemap $EBROOTCRISPRMINDAV/Examples/example1/sample.site --fastqmap $EBROOTCRISPRMINDAV/Examples/example1/fastq.list --genome genomex --verbose 1

diff -ruN crispr-dav-2.3.4_orig/Modules/NGS.pm crispr-dav-2.3.4/Modules/NGS.pm
--- crispr-dav-2.3.4_orig/Modules/NGS.pm 2019-07-26 21:15:08.000000000 +0200
+++ crispr-dav-2.3.4/Modules/NGS.pm 2021-06-21 17:37:39.381993860 +0200
@@ -296,7 +296,7 @@
my $cmd = "$self->{bwa} mem";
$cmd .= " $h{param}" if $h{param};
if ( $h{id} && $h{sm} ) {
- $cmd .= " -R \'\@RG\tID:$h{id}\tSM:$h{sm}\tPL:$h{pl}\'";
+ $cmd .= " -R \'\@RG\\tID:$h{id}\\tSM:$h{sm}\\tPL:$h{pl}\'";
}
$cmd .= " $h{idxbase} $h{read1_inf}";
$cmd .= " $h{read2_inf}" if -f $h{read2_inf};
@@ -558,7 +558,7 @@
# file is already indexed.
my $cmd = "rm -rf $workdir && mkdir -p $workdir" .
" && $self->{java} -Djava.io.tmpdir=$tmpdir -jar $h{abra} --threads 2" .
- " --ref $h{ref_fasta} --targets $h{target_bed} --working $workdir" .
+ " --ref $h{ref_fasta} --targets $h{target_bed} --tmpdir $workdir" .
" --in $h{bam_inf} --out $h{bam_outf}";

if ($h{single}) {
diff -ruN crispr-dav-2.3.4_orig/Rscripts/allele.R crispr-dav-2.3.4/Rscripts/allele.R
--- crispr-dav-2.3.4_orig/Rscripts/allele.R 2019-07-26 21:15:08.000000000 +0200
+++ crispr-dav-2.3.4/Rscripts/allele.R 2021-06-22 13:13:45.868418215 +0200
@@ -114,7 +114,7 @@
} else {
h<-400
w<- ifelse(n>40, 13*n, h*1.25)
- png(filename=outfile, height=h, width=w)
+ png(filename=outfile, type='cairo', height=h, width=w)
}

on.exit(dev.off())
diff -ruN crispr-dav-2.3.4_orig/Rscripts/amplicon.R crispr-dav-2.3.4/Rscripts/amplicon.R
--- crispr-dav-2.3.4_orig/Rscripts/amplicon.R 2019-07-26 21:15:08.000000000 +0200
+++ crispr-dav-2.3.4/Rscripts/amplicon.R 2021-06-22 13:13:45.868418215 +0200
@@ -111,7 +111,7 @@
if ( high_res ) {
tiff(filename=outfile, width=5, height=4, units='in', res=1200)
} else {
- png(filename=outfile, width=500, height=400)
+ png(filename=outfile, type='cairo', width=500, height=400)
}
on.exit(dev.off())
print(p)
diff -ruN crispr-dav-2.3.4_orig/Rscripts/hdr.R crispr-dav-2.3.4/Rscripts/hdr.R
--- crispr-dav-2.3.4_orig/Rscripts/hdr.R 2019-07-26 21:15:08.000000000 +0200
+++ crispr-dav-2.3.4/Rscripts/hdr.R 2021-06-22 13:13:45.868418215 +0200
@@ -102,7 +102,7 @@
h<-400
barspace=60
w<- ifelse( n*barspace<h, h, n*barspace)
- png(filename=outfile, width=w, height=h)
+ png(filename=outfile, type='cairo', width=w, height=h)
}

print(p)
diff -ruN crispr-dav-2.3.4_orig/Rscripts/indel.R crispr-dav-2.3.4/Rscripts/indel.R
--- crispr-dav-2.3.4_orig/Rscripts/indel.R 2019-07-26 21:15:08.000000000 +0200
+++ crispr-dav-2.3.4/Rscripts/indel.R 2021-06-22 13:27:15.254201732 +0200
@@ -81,7 +81,7 @@
} else {
h<-450
w<- ifelse(n>10, 50*n, h)
- png(filename=imgfile, height=h, width=w)
+ png(filename=imgfile, type='cairo', height=h, width=w)
}

on.exit(dev.off())
diff -ruN crispr-dav-2.3.4_orig/Rscripts/read_chr.R crispr-dav-2.3.4/Rscripts/read_chr.R
--- crispr-dav-2.3.4_orig/Rscripts/read_chr.R 2019-07-26 21:15:08.000000000 +0200
+++ crispr-dav-2.3.4/Rscripts/read_chr.R 2021-06-22 13:13:45.868418215 +0200
@@ -72,7 +72,7 @@
w<-ifelse(n>5, 100*n, 550)
max_w=1000
w <- ifelse(w>max_w, max_w, w)
- png(filename=outfile, height=h, width=w)
+ png(filename=outfile, type='cairo', height=h, width=w)
}

print(p)
diff -ruN crispr-dav-2.3.4_orig/Rscripts/read_stats.R crispr-dav-2.3.4/Rscripts/read_stats.R
--- crispr-dav-2.3.4_orig/Rscripts/read_stats.R 2019-07-26 21:15:08.000000000 +0200
+++ crispr-dav-2.3.4/Rscripts/read_stats.R 2021-06-22 13:13:45.868418215 +0200
@@ -69,7 +69,7 @@
} else {
h<-400
w<- ifelse(n>10, 50*n, h)
- png(filename=outfile, height=h, width=w)
+ png(filename=outfile, type='cairo', height=h, width=w)
}

p <- ggplot(dat.m, aes(x=Sample, y=value, fill=variable)) +
diff -ruN crispr-dav-2.3.4_orig/Rscripts/snp.R crispr-dav-2.3.4/Rscripts/snp.R
--- crispr-dav-2.3.4_orig/Rscripts/snp.R 2019-07-26 21:15:08.000000000 +0200
+++ crispr-dav-2.3.4/Rscripts/snp.R 2021-06-22 13:13:45.868418215 +0200
@@ -76,7 +76,7 @@
if ( high_res ) {
tiff(filename=outfile, width=5, height=4, units='in', res=1200)
} else {
- png(filename=outfile, width=500, height=400)
+ png(filename=outfile, type='cairo', width=500, height=400)
}
print(p)
invisible(dev.off())
@@ -182,7 +182,7 @@
wt <- 600
}
ht <- 400
- png(filename=outfile, width=wt, height=ht)
+ png(filename=outfile, type='cairo', width=wt, height=ht)
}

print(p)
Original file line number Diff line number Diff line change
@@ -0,0 +1,32 @@
easyblock = 'PerlModule'

name = 'Excel-Writer-XLSX'
version = '1.09'

homepage = 'https://metacpan.org/pod/Excel::Writer::XLSX'
description = """The Excel::Writer::XLSX module can be used to create an Excel file in the 2007+ XLSX format.
Multiple worksheets can be added to a workbook and formatting can be applied to cells. Text, numbers, and formulas
can be written to the cells."""

toolchain = {'name': 'foss', 'version': '2020b'}

source_urls = ['https://cpan.metacpan.org/authors/id/J/JM/JMCNAMARA/']
sources = ['%(name)s-%(version)s.tar.gz']
checksums = ['d679c6ac19e93c32ab77594c793e41b948c7bb3873b600e70ad637d093dca187']

dependencies = [
('Perl', '5.32.0'),
('Archive-Zip', '1.68'),
]

options = {'modulename': 'Excel::Writer::XLSX'}

sanity_check_paths = {
'files': ['bin/extract_vba'],
deniskristak marked this conversation as resolved.
Show resolved Hide resolved
'dirs': ['lib', 'bin'],
deniskristak marked this conversation as resolved.
Show resolved Hide resolved
}

sanity_check_commands = ['extract_vba --help 2>&1 | grep "This utility is used to extract the VBA project binary from an Excel"']


moduleclass = 'tools'
Loading