Mercurial > repos > peterjc > mira4_assembler
annotate tools/mira4/mira4.py @ 15:b0ffe0e7282b draft
Uploaded v0.0.2 preview 7, fixed bash syntax error
author | peterjc |
---|---|
date | Thu, 20 Feb 2014 05:07:19 -0500 |
parents | 7fcabeeca5df |
children | 381aa262c8cb |
rev | line source |
---|---|
0
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
1 #!/usr/bin/env python |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
2 """A simple wrapper script to call MIRA and collect its output. |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
3 """ |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
4 import os |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
5 import sys |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
6 import subprocess |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
7 import shutil |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
8 import time |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
9 |
9 | 10 #Do we need any PYTHONPATH magic? |
11 from mira4_make_bam import make_bam | |
12 | |
0
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
13 WRAPPER_VER = "0.0.1" #Keep in sync with the XML file |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
14 |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
15 def stop_err(msg, err=1): |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
16 sys.stderr.write(msg+"\n") |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
17 sys.exit(err) |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
18 |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
19 |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
20 def get_version(mira_binary): |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
21 """Run MIRA to find its version number""" |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
22 # At the commend line I would use: mira -v | head -n 1 |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
23 # however there is some pipe error when doing that here. |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
24 cmd = [mira_binary, "-v"] |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
25 try: |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
26 child = subprocess.Popen(cmd, |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
27 stdout=subprocess.PIPE, |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
28 stderr=subprocess.STDOUT) |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
29 except Exception, err: |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
30 sys.stderr.write("Error invoking command:\n%s\n\n%s\n" % (" ".join(cmd), err)) |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
31 sys.exit(1) |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
32 ver, tmp = child.communicate() |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
33 del child |
9 | 34 return ver.split("\n", 1)[0].strip() |
0
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
35 |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
36 |
7 | 37 try: |
38 mira_path = os.environ["MIRA4"] | |
12
a6a56440567c
Uploaded v0.0.2 preview 4, now using MIRA 4.0 (not RC), and sets MIRA4 environment variable during install.
peterjc
parents:
11
diff
changeset
|
39 except KeyError: |
7 | 40 stop_err("Environment variable $MIRA4 not set") |
41 mira_binary = os.path.join(mira_path, "mira") | |
42 if not os.path.isfile(mira_binary): | |
13
7fcabeeca5df
Uploaded v0.0.2 preview 5, fixes for MIRA 4.0 (final), more verbose error if $MIRA4 path wrong
peterjc
parents:
12
diff
changeset
|
43 stop_err("Missing mira under $MIRA4, %r\nFolder contained: %s" |
7fcabeeca5df
Uploaded v0.0.2 preview 5, fixes for MIRA 4.0 (final), more verbose error if $MIRA4 path wrong
peterjc
parents:
12
diff
changeset
|
44 % (mira_binary, ", ".join(os.listdir(mira_path)))) |
9 | 45 mira_convert = os.path.join(mira_path, "miraconvert") |
46 if not os.path.isfile(mira_convert): | |
13
7fcabeeca5df
Uploaded v0.0.2 preview 5, fixes for MIRA 4.0 (final), more verbose error if $MIRA4 path wrong
peterjc
parents:
12
diff
changeset
|
47 stop_err("Missing miraconvert under $MIRA4, %r\nFolder contained: %s" |
7fcabeeca5df
Uploaded v0.0.2 preview 5, fixes for MIRA 4.0 (final), more verbose error if $MIRA4 path wrong
peterjc
parents:
12
diff
changeset
|
48 % (mira_convert, ", ".join(os.listdir(mira_path)))) |
7 | 49 |
0
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
50 mira_ver = get_version(mira_binary) |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
51 if not mira_ver.strip().startswith("4.0"): |
9 | 52 stop_err("This wrapper is for MIRA V4.0, not:\n%s\n%s" % (mira_ver, mira_binary)) |
53 mira_convert_ver = get_version(mira_convert) | |
54 if not mira_convert_ver.strip().startswith("4.0"): | |
55 stop_err("This wrapper is for MIRA V4.0, not:\n%s\n%s" % (mira_ver, mira_convert)) | |
5
ffefb87bd414
Uploaded v0.0.1 preview 5, using MIRA 4.0 RC4, supports segment_placement (pairing type)
peterjc
parents:
4
diff
changeset
|
56 if "-v" in sys.argv or "--version" in sys.argv: |
ffefb87bd414
Uploaded v0.0.1 preview 5, using MIRA 4.0 RC4, supports segment_placement (pairing type)
peterjc
parents:
4
diff
changeset
|
57 print "%s, MIRA wrapper version %s" % (mira_ver, WRAPPER_VER) |
9 | 58 if mira_ver != mira_convert_ver: |
59 print "WARNING: miraconvert %s" % mira_convert_ver | |
0
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
60 sys.exit(0) |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
61 |
7 | 62 |
11
02350bef2e99
Uploaded v0.0.2 preview 3, correction regression in URL
peterjc
parents:
9
diff
changeset
|
63 try: |
02350bef2e99
Uploaded v0.0.2 preview 3, correction regression in URL
peterjc
parents:
9
diff
changeset
|
64 threads = int(os.environ.get("GALAXY_SLOTS", "1")) |
02350bef2e99
Uploaded v0.0.2 preview 3, correction regression in URL
peterjc
parents:
9
diff
changeset
|
65 except ValueError: |
02350bef2e99
Uploaded v0.0.2 preview 3, correction regression in URL
peterjc
parents:
9
diff
changeset
|
66 threads = 1 |
02350bef2e99
Uploaded v0.0.2 preview 3, correction regression in URL
peterjc
parents:
9
diff
changeset
|
67 assert 1 <= threads, threads |
7 | 68 |
0
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
69 |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
70 def log_manifest(manifest): |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
71 """Write the manifest file to stderr.""" |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
72 sys.stderr.write("\n%s\nManifest file\n%s\n" % ("="*60, "="*60)) |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
73 with open(manifest) as h: |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
74 for line in h: |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
75 sys.stderr.write(line) |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
76 sys.stderr.write("\n%s\nEnd of manifest\n%s\n" % ("="*60, "="*60)) |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
77 |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
78 |
4 | 79 def collect_output(temp, name, handle): |
9 | 80 """Moves files to the output filenames (global variables).""" |
0
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
81 n3 = (temp, name, name, name) |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
82 f = "%s/%s_assembly/%s_d_results" % (temp, name, name) |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
83 if not os.path.isdir(f): |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
84 log_manifest(manifest) |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
85 stop_err("Missing output folder") |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
86 if not os.listdir(f): |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
87 log_manifest(manifest) |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
88 stop_err("Empty output folder") |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
89 missing = [] |
4 | 90 |
91 old_maf = "%s/%s_out.maf" % (f, name) | |
92 if not os.path.isfile(old_maf): | |
93 #Triggered extractLargeContigs.sh? | |
94 old_maf = "%s/%s_LargeContigs_out.maf" % (f, name) | |
95 | |
96 #De novo or single strain mapping, | |
97 old_fasta = "%s/%s_out.unpadded.fasta" % (f, name) | |
9 | 98 ref_fasta = "%s/%s_out.padded.fasta" % (f, name) |
4 | 99 if not os.path.isfile(old_fasta): |
9 | 100 #Mapping (StrainX versus reference) or de novo |
4 | 101 old_fasta = "%s/%s_out_StrainX.unpadded.fasta" % (f, name) |
9 | 102 ref_fasta = "%s/%s_out_StrainX.padded.fasta" % (f, name) |
4 | 103 if not os.path.isfile(old_fasta): |
9 | 104 old_fasta = "%s/%s_out_ReferenceStrain.unpadded.fasta" % (f, name) |
105 ref_fasta = "%s/%s_out_ReferenceStrain.padded.fasta" % (f, name) | |
106 | |
4 | 107 |
108 missing = False | |
109 for old, new in [(old_maf, out_maf), | |
110 (old_fasta, out_fasta)]: | |
0
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
111 if not os.path.isfile(old): |
4 | 112 missing = True |
0
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
113 else: |
4 | 114 handle.write("Capturing %s\n" % old) |
0
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
115 shutil.move(old, new) |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
116 if missing: |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
117 log_manifest(manifest) |
4 | 118 sys.stderr.write("Contents of %r:\n" % f) |
119 for filename in sorted(os.listdir(f)): | |
120 sys.stderr.write("%s\n" % filename) | |
0
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
121 |
9 | 122 #For mapping mode, probably most people would expect a BAM file |
123 #using the reference FASTA file... | |
124 msg = make_bam(mira_convert, out_maf, ref_fasta, out_bam, handle) | |
125 if msg: | |
126 stop_err(msg) | |
127 | |
0
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
128 def clean_up(temp, name): |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
129 folder = "%s/%s_assembly" % (temp, name) |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
130 if os.path.isdir(folder): |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
131 shutil.rmtree(folder) |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
132 |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
133 #TODO - Run MIRA in /tmp or a configurable directory? |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
134 #Currently Galaxy puts us somewhere safe like: |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
135 #/opt/galaxy-dist/database/job_working_directory/846/ |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
136 temp = "." |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
137 #name, out_fasta, out_qual, out_ace, out_caf, out_wig, out_log = sys.argv[1:8] |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
138 name = "MIRA" |
9 | 139 manifest, out_maf, out_bam, out_fasta, out_log = sys.argv[1:] |
0
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
140 |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
141 start_time = time.time() |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
142 #cmd_list =sys.argv[8:] |
11
02350bef2e99
Uploaded v0.0.2 preview 3, correction regression in URL
peterjc
parents:
9
diff
changeset
|
143 cmd_list = [mira_binary, "-t", str(threads), manifest] |
0
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
144 cmd = " ".join(cmd_list) |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
145 |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
146 assert os.path.isdir(temp) |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
147 d = "%s_assembly" % name |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
148 assert not os.path.isdir(d), "Path %s already exists" % d |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
149 try: |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
150 #Check path access |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
151 os.mkdir(d) |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
152 except Exception, err: |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
153 log_manifest(manifest) |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
154 sys.stderr.write("Error making directory %s\n%s" % (d, err)) |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
155 sys.exit(1) |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
156 |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
157 #print os.path.abspath(".") |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
158 #print cmd |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
159 |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
160 handle = open(out_log, "w") |
4 | 161 handle.write("======================== MIRA manifest (instructions) ========================\n") |
162 m = open(manifest, "rU") | |
163 for line in m: | |
164 handle.write(line) | |
165 m.close() | |
166 del m | |
167 handle.write("\n") | |
168 handle.write("============================ Starting MIRA now ===============================\n") | |
169 handle.flush() | |
0
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
170 try: |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
171 #Run MIRA |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
172 child = subprocess.Popen(cmd_list, |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
173 stdout=handle, |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
174 stderr=subprocess.STDOUT) |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
175 except Exception, err: |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
176 log_manifest(manifest) |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
177 sys.stderr.write("Error invoking command:\n%s\n\n%s\n" % (cmd, err)) |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
178 #TODO - call clean up? |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
179 handle.write("Error invoking command:\n%s\n\n%s\n" % (cmd, err)) |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
180 handle.close() |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
181 sys.exit(1) |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
182 #Use .communicate as can get deadlocks with .wait(), |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
183 stdout, stderr = child.communicate() |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
184 assert not stdout and not stderr #Should be empty as sent to handle |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
185 run_time = time.time() - start_time |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
186 return_code = child.returncode |
4 | 187 handle.write("\n") |
188 handle.write("============================ MIRA has finished ===============================\n") | |
189 handle.write("MIRA took %0.2f hours\n" % (run_time / 3600.0)) | |
0
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
190 if return_code: |
9 | 191 print "MIRA took %0.2f hours" % (run_time / 3600.0) |
0
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
192 handle.write("Return error code %i from command:\n" % return_code) |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
193 handle.write(cmd + "\n") |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
194 handle.close() |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
195 clean_up(temp, name) |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
196 log_manifest(manifest) |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
197 stop_err("Return error code %i from command:\n%s" % (return_code, cmd), |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
198 return_code) |
4 | 199 handle.flush() |
200 | |
201 if os.path.isfile("MIRA_assembly/MIRA_d_results/ec.log"): | |
202 handle.write("\n") | |
203 handle.write("====================== Extract Large Contigs failed ==========================\n") | |
204 e = open("MIRA_assembly/MIRA_d_results/ec.log", "rU") | |
205 for line in e: | |
206 handle.write(line) | |
207 e.close() | |
208 handle.write("============================ (end of ec.log) =================================\n") | |
209 handle.flush() | |
0
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
210 |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
211 #print "Collecting output..." |
9 | 212 start_time = time.time() |
4 | 213 collect_output(temp, name, handle) |
9 | 214 collect_time = time.time() - start_time |
215 handle.write("MIRA took %0.2f hours; collecting output %0.2f minutes\n" % (run_time / 3600.0, collect_time / 60.0)) | |
216 print("MIRA took %0.2f hours; collecting output %0.2f minutes\n" % (run_time / 3600.0, collect_time / 60.0)) | |
4 | 217 |
218 if os.path.isfile("MIRA_assembly/MIRA_d_results/ec.log"): | |
219 #Treat as an error, but doing this AFTER collect_output | |
220 sys.stderr.write("Extract Large Contigs failed\n") | |
221 handle.write("Extract Large Contigs failed\n") | |
222 handle.close() | |
223 sys.exit(1) | |
0
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
224 |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
225 #print "Cleaning up..." |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
226 clean_up(temp, name) |
32f693f6e741
Uploaded v0.0.1 preview0, very much a work in progress, primarily checking mira_datatypes dependency
peterjc
parents:
diff
changeset
|
227 |
9 | 228 handle.write("\nDone\n") |
4 | 229 handle.close() |
230 print("Done") |