Skip to content

Commit 782e9ce

Browse files
authored
Merge pull request #3136 from takluyver/i3135
Find available kernelspecs more efficiently
2 parents 354cfb8 + 3f035c5 commit 782e9ce

File tree

2 files changed

+19
-13
lines changed

2 files changed

+19
-13
lines changed

notebook/services/kernelspecs/handlers.py

Lines changed: 18 additions & 12 deletions
Original file line numberDiff line numberDiff line change
@@ -16,17 +16,19 @@
1616
from ...base.handlers import APIHandler
1717
from ...utils import url_path_join, url_unescape
1818

19-
def kernelspec_model(handler, name):
19+
def kernelspec_model(handler, name, spec_dict, resource_dir):
2020
"""Load a KernelSpec by name and return the REST API model"""
21-
ksm = handler.kernel_spec_manager
22-
spec = ksm.get_kernel_spec(name)
23-
d = {'name': name}
24-
d['spec'] = spec.to_dict()
25-
d['resources'] = resources = {}
26-
resource_dir = spec.resource_dir
21+
d = {
22+
'name': name,
23+
'spec': spec_dict,
24+
'resources': {}
25+
}
26+
27+
# Add resource files if they exist
28+
resource_dir = resource_dir
2729
for resource in ['kernel.js', 'kernel.css']:
2830
if os.path.exists(pjoin(resource_dir, resource)):
29-
resources[resource] = url_path_join(
31+
d['resources'][resource] = url_path_join(
3032
handler.base_url,
3133
'kernelspecs',
3234
name,
@@ -35,7 +37,7 @@ def kernelspec_model(handler, name):
3537
for logo_file in glob.glob(pjoin(resource_dir, 'logo-*')):
3638
fname = os.path.basename(logo_file)
3739
no_ext, _ = os.path.splitext(fname)
38-
resources[no_ext] = url_path_join(
40+
d['resources'][no_ext] = url_path_join(
3941
handler.base_url,
4042
'kernelspecs',
4143
name,
@@ -52,9 +54,10 @@ def get(self):
5254
model = {}
5355
model['default'] = km.default_kernel_name
5456
model['kernelspecs'] = specs = {}
55-
for kernel_name in ksm.find_kernel_specs():
57+
for kernel_name, kernel_info in ksm.get_all_specs().items():
5658
try:
57-
d = kernelspec_model(self, kernel_name)
59+
d = kernelspec_model(self, kernel_name, kernel_info['spec'],
60+
kernel_info['resource_dir'])
5861
except Exception:
5962
self.log.error("Failed to load kernel spec: '%s'", kernel_name, exc_info=True)
6063
continue
@@ -67,10 +70,13 @@ class KernelSpecHandler(APIHandler):
6770

6871
@web.authenticated
6972
def get(self, kernel_name):
73+
ksm = self.kernel_spec_manager
74+
kernel_name = url_unescape(kernel_name)
7075
try:
71-
model = kernelspec_model(self, url_unescape(kernel_name))
76+
spec = ksm.get_kernel_spec(kernel_name)
7277
except KeyError:
7378
raise web.HTTPError(404, u'Kernel spec %s not found' % kernel_name)
79+
model = kernelspec_model(self, kernel_name, spec.to_dict(), spec.resource_dir)
7480
self.set_header("Content-Type", 'application/json')
7581
self.finish(json.dumps(model))
7682

setup.py

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -148,7 +148,7 @@
148148
'ipython_genutils',
149149
'traitlets>=4.2.1',
150150
'jupyter_core>=4.4.0',
151-
'jupyter_client',
151+
'jupyter_client>=5.2.0',
152152
'nbformat',
153153
'nbconvert',
154154
'ipykernel', # bless IPython kernel for now

0 commit comments

Comments
 (0)