comparison jbrowse2.py @ 133:cec274db51c0 draft

planemo upload for repository https://github.com/galaxyproject/tools-iuc/tree/master/tools/jbrowse2 commit 7d28252954cae9f8db5f8a85d8f29cb2865b504b-dirty
author fubar
date Fri, 18 Oct 2024 11:57:55 +0000 (3 months ago)
parents 1efcc387bef4
children ed3a21033188
comparison
equal deleted inserted replaced
132:1efcc387bef4 133:cec274db51c0
444 if logCommands: 444 if logCommands:
445 log.debug(command) 445 log.debug(command)
446 p = subprocess.Popen( 446 p = subprocess.Popen(
447 command, 447 command,
448 cwd=self.outdir, 448 cwd=self.outdir,
449 shell=True, 449 shell=False,
450 stdin=subprocess.PIPE, 450 stdin=subprocess.PIPE,
451 stdout=subprocess.PIPE, 451 stdout=subprocess.PIPE,
452 stderr=subprocess.PIPE, 452 stderr=subprocess.PIPE,
453 ) 453 )
454 output, err = p.communicate() 454 output, err = p.communicate()
552 contig = fl.decode("utf8").strip() 552 contig = fl.decode("utf8").strip()
553 # Merlin 172788 8 60 61 553 # Merlin 172788 8 60 61
554 else: 554 else:
555 faname = gname + ".fa.gz" 555 faname = gname + ".fa.gz"
556 fadest = os.path.realpath(os.path.join(self.outdir, faname)) 556 fadest = os.path.realpath(os.path.join(self.outdir, faname))
557 cmd = "bgzip -i -c %s -I %s.gzi > %s && samtools faidx %s" % ( 557 cmd = ["bgzip", "-i", "-c", fapath, "-I", fadest + ".gzi"]
558 fapath, 558 with open(fadest, "wb") as fout:
559 fadest, 559 self.subprocess_check_call(cmd, output=fout)
560 fadest, 560 cmd = ["samtools", "faidx", fadest]
561 fadest, 561 self.subprocess_check_call(cmd)
562 )
563 self.subprocess_popen(cmd)
564 contig = open(fadest + ".fai", "r").readline().strip() 562 contig = open(fadest + ".fai", "r").readline().strip()
565 adapter = { 563 adapter = {
566 "type": "BgzipFastaAdapter", 564 "type": "BgzipFastaAdapter",
567 "fastaLocation": { 565 "fastaLocation": {
568 "uri": faname, 566 "uri": faname,
955 if useuri: 953 if useuri:
956 url = data 954 url = data
957 else: 955 else:
958 url = tId 956 url = tId
959 dest = os.path.join(self.outdir, url) 957 dest = os.path.join(self.outdir, url)
960 cmd = "bgzip -c %s > %s" % (data, dest) 958 cmd = ["bgzip", "-c", data]
961 self.subprocess_popen(cmd) 959 with open(dest, "wb") as fout:
960 subprocess.run(cmd, stdout=fout)
962 cmd = ["tabix", "-f", "-p", "vcf", dest] 961 cmd = ["tabix", "-f", "-p", "vcf", dest]
963 self.subprocess_check_call(cmd) 962 self.subprocess_check_call(cmd)
964 trackDict = { 963 trackDict = {
965 "type": "VariantTrack", 964 "type": "VariantTrack",
966 "trackId": tId, 965 "trackId": tId,
999 self.trackIdlist.append(tId) 998 self.trackIdlist.append(tId)
1000 999
1001 def _sort_gff(self, data, dest): 1000 def _sort_gff(self, data, dest):
1002 # Only index if not already done 1001 # Only index if not already done
1003 if not os.path.exists(dest): 1002 if not os.path.exists(dest):
1004 cmd = "jbrowse sort-gff '%s' | bgzip -c > '%s'" % ( 1003 e = os.environ
1005 data, 1004 e['SHELL'] = '/bin/sh'
1006 dest, 1005 cmd = ['/bin/sh', '-c', "jbrowse sort-gff %s | bgzip -c > %s" % (data, dest)]
1007 ) 1006 subprocess.run(cmd, env=e)
1008 self.subprocess_popen(cmd)
1009 self.subprocess_check_call(["tabix", "-f", "-p", "gff", dest]) 1007 self.subprocess_check_call(["tabix", "-f", "-p", "gff", dest])
1010 1008
1011 def _sort_bed(self, data, dest): 1009 def _sort_bed(self, data, dest):
1012 # Only index if not already done 1010 # Only index if not already done
1013 if not os.path.exists(dest): 1011 if not os.path.exists(dest):
1014 cmd = "sort -k1,1 -k2,2n '%s' | bgzip -c > '%s'" % (data, dest) 1012 cmd = ["sort", "-k1,1", "-k2,2n", data]
1015 self.subprocess_popen(cmd) 1013 ps = subprocess.run(cmd, check=True, capture_output=True)
1014 cmd = ["bgzip", "-c"]
1015 with open(dest, "wb") as fout:
1016 subprocess.run(cmd, input=ps.stdout, stdout=fout)
1016 cmd = ["tabix", "-f", "-p", "bed", dest] 1017 cmd = ["tabix", "-f", "-p", "bed", dest]
1017 self.subprocess_check_call(cmd) 1018 self.subprocess_check_call(cmd)
1018 1019
1019 def add_gff(self, data, trackData): 1020 def add_gff(self, data, trackData):
1020 tId = trackData["label"] 1021 tId = trackData["label"]
1128 ] 1129 ]
1129 self.tracksToAdd[trackData["assemblyNames"]].append(copy.copy(trackDict)) 1130 self.tracksToAdd[trackData["assemblyNames"]].append(copy.copy(trackDict))
1130 self.trackIdlist.append(tId) 1131 self.trackIdlist.append(tId)
1131 1132
1132 def add_paf(self, data, trackData, pafOpts, **kwargs): 1133 def add_paf(self, data, trackData, pafOpts, **kwargs):
1133 canPIF = False 1134 canPIF = True
1134 tname = trackData["name"] 1135 tname = trackData["name"]
1135 tId = trackData["label"] 1136 tId = trackData["label"]
1136 url = tId 1137 url = tId
1137 usePIF = False # much faster if indexed remotely or locally but broken in biocontainer. 1138 usePIF = False # much faster if indexed remotely or locally but broken in biocontainer.
1138 useuri = data.startswith("http://") or data.startswith("https://") 1139 useuri = data.startswith("http://") or data.startswith("https://")
1139 if not useuri: 1140 if not useuri:
1140 if canPIF: 1141 if canPIF:
1141 fakeName = '%s.paf' % tId 1142 fakeName = "%s.paf" % tId
1142 url = "%s.pif.gz" % tId 1143 url = "%s.pif.gz" % tId
1143 cmd = ["cp", data, fakeName] 1144 cmd = ["cp", data, fakeName]
1144 self.subprocess_check_call(cmd) 1145 self.subprocess_check_call(cmd)
1145 cmd = ["jbrowse", "make-pif", fakeName] # jbrowse pif input.paf --out output.pif.gz # specify output file, creates output.pif.gz.tbi also 1146 cmd = [
1147 "jbrowse",
1148 "make-pif",
1149 fakeName,
1150 ] # jbrowse pif input.paf --out output.pif.gz # specify output file, creates output.pif.gz.tbi also
1146 self.subprocess_check_call(cmd) 1151 self.subprocess_check_call(cmd)
1147 usePIF = True 1152 usePIF = True
1148 else: 1153 else:
1149 dest = os.path.join(self.outdir, url) 1154 dest = os.path.join(self.outdir, url)
1150 self.symlink_or_copy(os.path.realpath(data), dest) 1155 self.symlink_or_copy(os.path.realpath(data), dest)