annotate ipynb.py @ 0:7ae1c661a86c draft

Uploaded
author iuc
date Mon, 28 Jul 2014 03:21:07 -0400
parents
children 8e8555ca07f9
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
1 # -*- coding: utf-8 -*-
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
2
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
3 from galaxy.datatypes.json import Json
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
4 from galaxy.datatypes.data import get_file_peek
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
5 import subprocess
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
6 import tempfile
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
7 import json
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
8 import os
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
9
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
10 class Ipynb( Text ):
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
11 file_ext = "ipynb"
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
12
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
13 def set_peek( self, dataset, is_multi_byte=False ):
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
14 if not dataset.dataset.purged:
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
15 dataset.peek = get_file_peek( dataset.file_name, is_multi_byte=is_multi_byte )
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
16 dataset.blurb = "IPython Notebook"
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
17 else:
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
18 dataset.peek = 'file does not exist'
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
19 dataset.blurb = 'file purged from disc'
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
20
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
21 def sniff( self, filename ):
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
22 """
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
23 Try to load the string with the json module. If successful it's a json file.
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
24 """
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
25 try:
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
26 json.load( filename )
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
27 if a.get('nbformat', False) != False and a.get('metadata', False):
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
28 return True
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
29 else:
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
30 return False
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
31 except:
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
32 return False
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
33
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
34 def display_data(self, trans, dataset, preview=False, filename=None, to_ext=None, chunk=None, **kwd):
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
35 preview = util.string_as_bool( preview )
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
36 if chunk:
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
37 return self.get_chunk(trans, dataset, chunk)
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
38 elif to_ext or not preview:
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
39 return self._serve_raw(trans, dataset, to_ext)
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
40 else:
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
41 ofile_handle = tempfile.NamedTemporaryFile(delete=False)
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
42 ofilename = file_handle.name
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
43 ofile_handle.close()
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
44 try:
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
45 cmd = 'ipython nbconvert --to html --template basic %s %s' % (dataset.file_name, ofilename)
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
46 subprocess.call(cmd)
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
47 ofilename = '%s.html' % ofilename
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
48 except:
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
49 ofilename = dataset.file_name
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
50 log.exception( 'Command "%s" failed. Could not convert the IPython Notebook to HTML, defaulting to plain text.' % cmd )
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
51 return open( ofilename )
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
52 """return trans.fill_template( "/dataset/tabular_chunked.mako",
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
53 dataset = dataset,
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
54 chunk = self.get_chunk(trans, dataset, 0),
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
55 column_number = column_number,
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
56 column_names = column_names,
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
57 column_types = column_types )"""
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
58
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
59 def set_meta( self, dataset, **kwd ):
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
60 """
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
61 Set the number of models in dataset.
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
62 """
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
63 pass
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
64
7ae1c661a86c Uploaded
iuc
parents:
diff changeset
65