Mercurial > repos > chemteam > gmx_restraints
view merge_top.py @ 2:005b29f764cc draft
"planemo upload for repository https://github.com/galaxycomputationalchemistry/galaxy-tools-compchem/tools/gromacs commit d75a4b4a47d2a74aacb6d3ff90755f9a5289cfb1"
author | chemteam |
---|---|
date | Wed, 18 Dec 2019 15:26:53 -0500 |
parents | 72c2b7992c26 |
children | 42e4eda6eb5d |
line wrap: on
line source
import re import sys def combine_tops(top_text, itp_texts): """ Search through parent topology top_text and replace #include lines with the relevant child topologies from the dictionary itp_texts """ for itp in itp_texts: # split on include string, then rejoin around itp file spl = re.split('#include ".*{}"\n'.format(itp), top_text) top_text = itp_texts[itp].join(spl) return top_text top = sys.argv[1] # parent topology file itps_file = sys.argv[2] # file with list of child topologies (.itp files) with open(itps_file) as f: itps = f.read().split() with open(top, 'r') as f: top_text = f.read() itp_texts = {} # create dictionary of child topologies for itp in itps: with open(itp, 'r') as f: itp_texts[itp] = f.read() for itp in itp_texts: # child tops may also refer to each other; we need to check this itp_texts[itp] = combine_tops(itp_texts[itp], itp_texts) with open('top_output.top', 'w') as f: # now combine all children into the parent f.write(combine_tops(top_text, itp_texts))