Skip to content
Snippets Groups Projects
scrape_software_versions.py 1.76 KiB
Newer Older
nservant's avatar
nservant committed
#!/usr/bin/env python
from __future__ import print_function
from collections import OrderedDict
import re

nservant's avatar
nservant committed
# Add additional regexes for new tools in process get_software_versions
nservant's avatar
nservant committed
regexes = {
    'nf-core/hic': ['v_pipeline.txt', r"(\S+)"],
    'Nextflow': ['v_nextflow.txt', r"(\S+)"],
nservant's avatar
nservant committed
    'Bowtie2': ['v_bowtie2.txt', r"Bowtie2 v(\S+)"],
    'Python': ['v_python.txt', r"Python v(\S+)"],
    'Samtools': ['v_samtools.txt', r"Samtools v(\S+)"],
nservant's avatar
nservant committed
    'MultiQC': ['v_multiqc.txt', r"multiqc, version (\S+)"],
}
results = OrderedDict()
results['nf-core/hic'] = '<span style="color:#999999;\">N/A</span>'
results['Nextflow'] = '<span style="color:#999999;\">N/A</span>'
nservant's avatar
nservant committed
results['Bowtie2'] = '<span style="color:#999999;\">N/A</span>'
results['Python'] = '<span style="color:#999999;\">N/A</span>'
results['Samtools'] = '<span style="color:#999999;\">N/A</span>'
nservant's avatar
nservant committed
results['MultiQC'] = '<span style="color:#999999;\">N/A</span>'

# Search each file using its regex
for k, v in regexes.items():
    with open(v[0]) as x:
        versions = x.read()
        match = re.search(v[1], versions)
        if match:
            results[k] = "v{}".format(match.group(1))

# Remove software set to false in results
for k in results:
    if not results[k]:
        del(results[k])

# Dump to YAML
print ('''
id: 'software_versions'
section_name: 'nf-core/hic Software Versions'
section_href: 'https://github.com/nf-core/hic'
plot_type: 'html'
description: 'are collected at run time from the software output.'
data: |
    <dl class="dl-horizontal">
''')
for k,v in results.items():
    print("        <dt>{}</dt><dd><samp>{}</samp></dd>".format(k,v))
print ("    </dl>")

# Write out regexes as csv file:
with open('software_versions.csv', 'w') as f:
    for k,v in results.items():
        f.write("{}\t{}\n".format(k,v))