Mercurial > repos > yating-l > jbrowsearchivecreator
comparison TrackHub.py @ 3:eda851e52060 draft
planemo upload for repository https://github.com/Yating-L/jbrowse-archive-creator.git commit 479fc6490e24ca0e5034ae6c3579882e97e095e6-dirty
| author | yating-l |
|---|---|
| date | Wed, 31 May 2017 15:45:47 -0400 |
| parents | 25ad6770359e |
| children | 7e471cdd9e71 |
comparison
equal
deleted
inserted
replaced
| 2:25ad6770359e | 3:eda851e52060 |
|---|---|
| 1 #!/usr/bin/env python | 1 #!/usr/bin/env python |
| 2 | 2 |
| 3 import os | 3 import os |
| 4 import subprocess | 4 import subprocess |
| 5 import shutil | 5 import shutil |
| 6 import zipfile | |
| 6 import json | 7 import json |
| 7 import utils | 8 import utils |
| 8 | 9 |
| 9 | 10 |
| 10 class TrackHub: | 11 class TrackHub: |
| 70 def indexName(self): | 71 def indexName(self): |
| 71 subprocess.call(['generate-names.pl', '-v', '--out', self.json]) | 72 subprocess.call(['generate-names.pl', '-v', '--out', self.json]) |
| 72 print "finished name index \n" | 73 print "finished name index \n" |
| 73 | 74 |
| 74 def makeArchive(self): | 75 def makeArchive(self): |
| 75 shutil.make_archive(self.out_path, 'zip', self.out_path) | |
| 76 file_dir = os.path.abspath(self.outfile) | 76 file_dir = os.path.abspath(self.outfile) |
| 77 source_dir = os.path.dirname(file_dir) | 77 source_dir = os.path.dirname(file_dir) |
| 78 folder_name = os.path.basename(self.outfolder) | 78 folder_name = os.path.basename(self.outfolder) |
| 79 source_name = os.path.basename(self.out_path) | 79 source_name = os.path.basename(self.out_path) |
| 80 source = os.path.join(source_dir, folder_name, source_name) | 80 source = os.path.join(source_dir, folder_name, source_name) |
| 86 except OSError as oserror: | 86 except OSError as oserror: |
| 87 print "Cannot create symlink to the data({0}): {1}".format(oserror.errno, oserror.strerror) | 87 print "Cannot create symlink to the data({0}): {1}".format(oserror.errno, oserror.strerror) |
| 88 os.symlink(source, slink) | 88 os.symlink(source, slink) |
| 89 return slink | 89 return slink |
| 90 | 90 |
| 91 #TODO: this will list all zip files in the filedir and sub-dirs. worked in Galaxy but all list zip files in test-data when | |
| 92 #run it locally. May need modify | |
| 93 def outHtml(self, slink): | 91 def outHtml(self, slink): |
| 94 with open(self.outfile, 'w') as htmlfile: | 92 with open(self.outfile, 'w') as htmlfile: |
| 95 htmlstr = 'The JBrowse Hub is created: <br>' | 93 htmlstr = 'The JBrowse Hub is created: <br>' |
| 96 zipfiles = '<li><a href = "%s">Download</a></li>' | |
| 97 url = self.jbrowse_host + "/JBrowse-1.12.1/index.html?data=%s" | 94 url = self.jbrowse_host + "/JBrowse-1.12.1/index.html?data=%s" |
| 98 jbrowse_hub = '<li><a href = "%s" target="_blank">View JBrowse Hub</a></li>' % url | 95 jbrowse_hub = '<li><a href = "%s" target="_blank">View JBrowse Hub</a></li>' % url |
| 99 filedir_abs = os.path.abspath(self.outfile) | |
| 100 filedir = os.path.dirname(filedir_abs) | |
| 101 filedir = os.path.join(filedir, self.outfolder) | |
| 102 for root, dirs, files in os.walk(filedir): | |
| 103 for file in files: | |
| 104 if file.endswith('.zip'): | |
| 105 relative_directory = os.path.relpath(root, filedir) | |
| 106 relative_file_path = os.path.join(relative_directory, file) | |
| 107 htmlstr += zipfiles % relative_file_path | |
| 108 link_name = os.path.basename(slink) | 96 link_name = os.path.basename(slink) |
| 109 relative_path = os.path.join('data', link_name + '/json') | 97 relative_path = os.path.join('data', link_name + '/json') |
| 110 htmlstr += jbrowse_hub % relative_path | 98 htmlstr += jbrowse_hub % relative_path |
| 111 htmlfile.write(htmlstr) | 99 htmlfile.write(htmlstr) |
| 112 | 100 |
