##// END OF EJS Templates
Better describe functions in kernelspec module
Thomas Kluyver -
Show More
@@ -1,91 +1,105 b''
1 1 import io
2 2 import json
3 3 import os
4 4 import sys
5 5
6 6 pjoin = os.path.join
7 7
8 8 from IPython.utils.path import get_ipython_dir
9 9 from IPython.utils.py3compat import PY3
10 10 from IPython.utils.traitlets import HasTraits, List, Unicode
11 11
12 12 USER_KERNEL_DIR = pjoin(get_ipython_dir(), 'kernels')
13 13
14 14 if os.name == 'nt':
15 15 programdata = os.environ.get('PROGRAMDATA', None)
16 16 if programdata:
17 17 SYSTEM_KERNEL_DIR = pjoin(programdata, 'ipython', 'kernels')
18 18 else: # PROGRAMDATA is not defined by default on XP.
19 19 SYSTEM_KERNEL_DIR = None
20 20 else:
21 21 SYSTEM_KERNEL_DIR = "/usr/share/ipython/kernels"
22 22
23 23 NATIVE_KERNEL_NAME = 'python3' if PY3 else 'python2'
24 24
25 25 class KernelSpec(HasTraits):
26 26 argv = List()
27 27 display_name = Unicode()
28 28 language = Unicode()
29 29 codemirror_mode = Unicode()
30 30
31 31 resource_dir = Unicode()
32 32
33 33 def __init__(self, resource_dir, argv, display_name, language,
34 34 codemirror_mode=None):
35 35 super(KernelSpec, self).__init__(resource_dir=resource_dir, argv=argv,
36 36 display_name=display_name, language=language,
37 37 codemirror_mode=codemirror_mode)
38 38 if not self.codemirror_mode:
39 39 self.codemirror_mode = self.language
40 40
41 41 @classmethod
42 42 def from_resource_dir(cls, resource_dir):
43 kernel_file = os.path.join(resource_dir, 'kernel.json')
43 """Create a KernelSpec object by reading kernel.json
44
45 Pass the path to the *directory* containing kernel.json.
46 """
47 kernel_file = pjoin(resource_dir, 'kernel.json')
44 48 with io.open(kernel_file, 'r', encoding='utf-8') as f:
45 49 kernel_dict = json.load(f)
46 50 return cls(resource_dir=resource_dir, **kernel_dict)
47 51
48 52 def _is_kernel_dir(path):
53 """Is ``path`` a kernel directory?"""
49 54 return os.path.isdir(path) and os.path.isfile(pjoin(path, 'kernel.json'))
50 55
51 56 def _list_kernels_in(dir):
57 """Ensure dir exists, and return a mapping of kernel names to resource
58 directories from it.
59 """
52 60 if dir is None:
53 61 return {}
54 62 if not os.path.isdir(dir):
55 63 os.makedirs(dir, mode=0o644)
56 64 return {f.lower(): pjoin(dir, f) for f in os.listdir(dir)
57 65 if _is_kernel_dir(pjoin(dir, f))}
58 66
59 67 def _make_native_kernel_dir():
68 """Makes a kernel directory for the native kernel.
69
70 The native kernel is the kernel using the same Python runtime as this
71 process. This will put its informatino in the user kernels directory.
72 """
60 73 path = pjoin(USER_KERNEL_DIR, NATIVE_KERNEL_NAME)
61 74 os.mkdir(path)
62 75 with io.open(pjoin(path, 'kernel.json'), 'w', encoding='utf-8') as f:
63 76 json.dump({'argv':[NATIVE_KERNEL_NAME, '-c',
64 77 'from IPython.kernel.zmq.kernelapp import main; main()',
65 78 '-f', '{connection_file}'],
66 79 'display_name': 'Python 3' if PY3 else 'Python 2',
67 80 'language': 'python',
68 81 'codemirror_mode': {'name': 'python',
69 82 'version': sys.version_info[0]},
70 83 },
71 84 f)
72 85 # TODO: Copy icons into directory
73 86 return path
74 87
75 88 def list_kernel_specs():
76 """Returns a dict mapping kernels to resource directories."""
89 """Returns a dict mapping kernel names to resource directories."""
77 90 d = _list_kernels_in(SYSTEM_KERNEL_DIR)
78 91 d.update(_list_kernels_in(USER_KERNEL_DIR))
79 92
80 93 if NATIVE_KERNEL_NAME not in d:
81 94 d[NATIVE_KERNEL_NAME] = _make_native_kernel_dir()
82 95 return d
96 # TODO: Caching?
83 97
84 98 def get_kernel_spec(kernel_name):
85 """Returns a KernelSpec instance for the given kernel_name.
99 """Returns a :class:`KernelSpec` instance for the given kernel_name.
86 100
87 101 Raises KeyError if the given kernel name is not found.
88 102 """
89 103 d = list_kernel_specs()
90 104 resource_dir = d[kernel_name.lower()]
91 105 return KernelSpec.from_resource_dir(resource_dir) No newline at end of file
General Comments 0
You need to be logged in to leave comments. Login now