-
Notifications
You must be signed in to change notification settings - Fork 39
/
Copy pathsnakeTrack.py
48 lines (43 loc) · 1.83 KB
/
snakeTrack.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
#!/usr/bin/env python3
#Copyright (C) 2013 by Ngan Nguyen
# Copyright (C) 2012-2019 by UCSC Computational Genomics Lab
#
#Released under the MIT license, see LICENSE.txt
"""Snake tracks
"""
from optparse import OptionGroup
import re
def addSnakeOptions(parser):
group = parser.add_argument_group("SNAKE TRACKS", "Snake track options")
group.add_argument('--selfAlignmentSnakes', dest="selfAlignmentTrack",
help="Produce a self-alignment snake track for every genome",
action="store_true", default=False)
group = parser.add_argument_group(group)
def writeTrackDb_snakes(f, halfile, genomes, subgenomes, currgenome, properName, snpwidth=None, doSelfAlignment=False):
for i, genome in enumerate(genomes):
if not doSelfAlignment and genome == currgenome: #current genome
continue
#SNAKE TRACKS
genomeProperName = genome
if genome in properName:
genomeProperName = properName[genome]
if genome == currgenome:
genomeProperName += " (self)"
f.write("\t\ttrack snake%s\n" %genome)
f.write("\t\tlongLabel %s\n" %genomeProperName)
f.write("\t\tshortLabel %s\n" %genomeProperName)
f.write("\t\totherSpecies %s\n" %genome)
if genome in subgenomes:
f.write("\t\tvisibility full\n")
f.write("\t\tparent hubCentralAlignments\n")
else:
f.write("\t\tvisibility hide\n")
f.write("\t\tparent hubCentralAlignments off\n")
if snpwidth:
f.write("\t\tshowSnpWidth %d\n" % snpwidth)
f.write("\t\tpriority %d\n" %(i + 2))
f.write("\t\tbigDataUrl %s\n" % halfile)
f.write("\t\ttype halSnake\n")
f.write("\t\tgroup snake\n")
f.write("\t\tsubGroups view=Snake orgs=%s\n" %genome)
f.write("\n")