diff jbrowse2.py @ 104:9e3f69d9fed1 draft

planemo upload for repository https://github.com/galaxyproject/tools-iuc/tree/master/tools/jbrowse2 commit a1537aea75fc902d0e38c0b7c698830a939648b1-dirty
author fubar
date Sun, 23 Jun 2024 00:13:57 +0000
parents 099370690407
children a074cd6b5905
line wrap: on
line diff
--- a/jbrowse2.py	Sat Jun 22 06:17:01 2024 +0000
+++ b/jbrowse2.py	Sun Jun 23 00:13:57 2024 +0000
@@ -2,6 +2,7 @@
 
 import argparse
 import binascii
+import copy
 import datetime
 # import hashlib
 import json
@@ -679,8 +680,8 @@
             ],
             "adapter": {"type": "HicAdapter", "hicLocation": {"uri": uri}},
         }
-        self.tracksToAdd[trackData["assemblyNames"]].append(trackDict)
-        self.trackIdlist.append(tId)
+        self.tracksToAdd[trackData["assemblyNames"]].append(copy.copy(trackDict))
+        self.trackIdlist.append(copy.copy(tId))
 
     def add_maf(self, data, trackData):
         """
@@ -753,8 +754,8 @@
         }
         style_json = self._prepare_track_style(trackDict)
         trackDict["style"] = style_json
-        self.tracksToAdd[gname].append(trackDict)
-        self.trackIdlist.append(tId)
+        self.tracksToAdd[gname].append(copy.copy(trackDict))
+        self.trackIdlist.append(copy.copy(tId))
         if self.config_json.get("plugins", None):
             self.config_json["plugins"].append(mafPlugin[0])
         else:
@@ -827,8 +828,8 @@
         }
         style_json = self._prepare_track_style(trackDict)
         trackDict["style"] = style_json
-        self.tracksToAdd[trackData["assemblyNames"]].append(trackDict)
-        self.trackIdlist.append(tId)
+        self.tracksToAdd[trackData["assemblyNames"]].append(copy.copy(trackDict))
+        self.trackIdlist.append(copy.copy(tId))
 
     def add_bam(self, data, trackData, bam_indexes=None, **kwargs):
         tId = trackData["label"]
@@ -884,8 +885,8 @@
         }
         style_json = self._prepare_track_style(trackDict)
         trackDict["style"] = style_json
-        self.tracksToAdd[trackData["assemblyNames"]].append(trackDict)
-        self.trackIdlist.append(tId)
+        self.tracksToAdd[trackData["assemblyNames"]].append(copy.copy(trackDict))
+        self.trackIdlist.append(copy.copy(tId))
 
     def add_cram(self, data, trackData, cram_indexes=None, **kwargs):
         tId = trackData["label"]
@@ -950,8 +951,8 @@
         }
         style_json = self._prepare_track_style(trackDict)
         trackDict["style"] = style_json
-        self.tracksToAdd[trackData["assemblyNames"]].append(trackDict)
-        self.trackIdlist.append(tId)
+        self.tracksToAdd[trackData["assemblyNames"]].append(copy.copy(trackDict))
+        self.trackIdlist.append(copy.copy(tId))
 
     def add_vcf(self, data, trackData):
         tId = trackData["label"]
@@ -1000,8 +1001,8 @@
         }
         style_json = self._prepare_track_style(trackDict)
         trackDict["style"] = style_json
-        self.tracksToAdd[trackData["assemblyNames"]].append(trackDict)
-        self.trackIdlist.append(tId)
+        self.tracksToAdd[trackData["assemblyNames"]].append(copy.copy(trackDict))
+        self.trackIdlist.append(copy.copy(tId))
 
     def _sort_gff(self, data, dest):
         # Only index if not already done
@@ -1063,8 +1064,8 @@
         }
         style_json = self._prepare_track_style(trackDict)
         trackDict["style"] = style_json
-        self.tracksToAdd[trackData["assemblyNames"]].append(trackDict)
-        self.trackIdlist.append(tId)
+        self.tracksToAdd[trackData["assemblyNames"]].append(copy.copy(trackDict))
+        self.trackIdlist.append(copy.copy(tId))
 
     def add_bed(self, data, ext, trackData):
         tId = trackData["label"]
@@ -1112,8 +1113,8 @@
         }
         style_json = self._prepare_track_style(trackDict)
         trackDict["style"] = style_json
-        self.tracksToAdd[trackData["assemblyNames"]].append(trackDict)
-        self.trackIdlist.append(tId)
+        self.tracksToAdd[trackData["assemblyNames"]].append(copy.copy(trackDict))
+        self.trackIdlist.append(copy.copy(tId))
 
     def add_paf(self, data, trackData, pafOpts, **kwargs):
         tname = trackData["name"]
@@ -1147,10 +1148,10 @@
             if gname not in self.genome_names:
                 # ignore if already there - eg for duplicates among pafs.
                 asstrack, first_contig = self.make_assembly(gpath, gname, useuri)
-                self.genome_names.append(gname)
+                self.genome_names.append(copy.copy(gname))
                 self.tracksToAdd[gname] = []
-                self.assemblies.append(asstrack)
-                self.ass_first_contigs.append(first_contig)
+                self.assemblies.append(copy.copy(asstrack))
+                self.ass_first_contigs.append(copy.copy(first_contig))
         trackDict = {
             "type": "SyntenyTrack",
             "trackId": tId,
@@ -1194,8 +1195,8 @@
                 "displayId": "%s-LinearBasicDisplay" % tId,
             }
         trackDict["style"] = style_json
-        self.tracksToAdd[trackData["assemblyNames"]].append(trackDict)
-        self.trackIdlist.append(tId)
+        self.tracksToAdd[trackData["assemblyNames"]].append(copy.copy(trackDict))
+        self.trackIdlist.append(copy.copy(tId))
 
     def process_annotations(self, track):
         category = track["category"].replace("__pd__date__pd__", TODAY)
@@ -1311,6 +1312,7 @@
             else:
                 logging.warning("Do not know how to handle %s", dataset_ext)
             # Return non-human label for use in other fields
+            logging.debug("### processanno ext=%s trackstoadd = %s" % (dataset_ext, self.tracksToAdd))
             yield outputTrackConfig["label"]
 
     def add_default_session(self, default_data):
@@ -1338,16 +1340,23 @@
                 tId = track_conf["trackId"]
                 if tId in default_data[gnome]["visibility"]["default_on"]:
                     track_types[tId] = track_conf["type"]
-                    style_data = default_data[gnome]["style"].get(tId, None)
+                    style_data = default_data[gnome]["style"].get(tId, {})
                     if not style_data:
                         logging.debug(
-                            "### No style data for %s in available default data %s"
+                            "No style data for %s in available default data %s"
                             % (tId, default_data)
                         )
-                        style_data = {"type": "LinearBasicDisplay"}
-                        if "displays" in track_conf:
-                            disp = track_conf["displays"][0]["type"]
-                            style_data["type"] = disp
+                    else:
+                        logging.debug(
+                            "style data for %s = %s"
+                            % (tId, style_data)
+                        )
+
+                    if style_data.get('type',None):
+                        style_data["type"] = "LinearBasicDisplay"
+                    if "displays" in track_conf:
+                        disp = track_conf["displays"][0]["type"]
+                        style_data["type"] = disp
                     if track_conf.get("style_labels", None):
                         # TODO fix this: it should probably go in a renderer block (SvgFeatureRenderer) but still does not work
                         # TODO move this to per track displays?
@@ -1551,8 +1560,9 @@
 def parse_style_conf(item):
     if item.text.lower() in ["false", "true", "yes", "no"]:
         return item.text.lower in ("yes", "true")
-    else:
-        return item.text
+    elif item.text.isdigit():
+        return int(item.text)
+    return item.text
 
 
 if __name__ == "__main__":
@@ -1632,28 +1642,27 @@
                             )
                         )
                     else:
-                        if trackfiles:
-                            metadata = metadata_from_node(x.find("metadata"))
-                            track_conf["dataset_id"] = metadata.get(
-                                "dataset_id", "None"
+                        metadata = metadata_from_node(x.find("metadata"))
+                        track_conf["dataset_id"] = metadata.get(
+                            "dataset_id", "None"
+                        )
+                        if x.attrib["useuri"].lower() == "yes":
+                            tfa = (
+                                x.attrib["path"],
+                                x.attrib["ext"],
+                                x.attrib["useuri"],
+                                track_conf["label"],
+                                metadata,
                             )
-                            if x.attrib["useuri"].lower() == "yes":
-                                tfa = (
-                                    x.attrib["path"],
-                                    x.attrib["ext"],
-                                    x.attrib["useuri"],
-                                    track_conf["label"],
-                                    metadata,
-                                )
-                            else:
-                                tfa = (
-                                    os.path.realpath(x.attrib["path"]),
-                                    x.attrib["ext"],
-                                    x.attrib["useuri"],
-                                    track_conf["label"],
-                                    metadata,
-                                )
-                            track_conf["trackfiles"].append(tfa)
+                        else:
+                            tfa = (
+                                os.path.realpath(x.attrib["path"]),
+                                x.attrib["ext"],
+                                x.attrib["useuri"],
+                                track_conf["label"],
+                                metadata,
+                            )
+                        track_conf["trackfiles"].append(tfa)
 
                 if is_multi_bigwig:
                     metadata = metadata_from_node(x.find("metadata"))
@@ -1670,7 +1679,6 @@
             track_conf["category"] = track.attrib["cat"]
             track_conf["format"] = track.attrib["format"]
             track_conf["conf"] = etree_to_dict(track.find("options"))
-            logging
             keys = jc.process_annotations(track_conf)
             if keys:
                 for key in keys:
@@ -1684,11 +1692,10 @@
                         if trak["trackId"] == key:
                             stile = trak.get("style", {})
                     if track.find("options/style"):
-                        supdate = {
-                            item.tag: parse_style_conf(item)
-                            for item in track.find("options/style")
-                        }
-                        stile.update(supdate)
+                        for item in track.find("options/style"):
+                            if item.text:
+                                stile[item.tag] = parse_style_conf(item)
+                    logging.debug("stile=%s" % stile)
                     default_session_data[primaryGenome]["style"][key] = stile
                     if track.find("options/style_labels"):
                         default_session_data[primaryGenome]["style_labels"][key] = {
@@ -1714,6 +1721,7 @@
         "font_size": root.find("metadata/general/font_size").text,
     }
     jc.add_general_configuration(general_data)
+    jc.add_default_session(default_session_data)
     trackconf = jc.config_json.get("tracks", [])
     for gnome in jc.genome_names:
         gtracks = jc.tracksToAdd[gnome]
@@ -1739,7 +1747,6 @@
         )
     )
     jc.write_config()
-    jc.add_default_session(default_session_data)
     # note that this can be left in the config.json but has NO EFFECT if add_defsess_to_index is called.
     # jc.add_defsess_to_index(default_session_data)
     # jc.text_index() not sure what broke here.