From f9b3f7eb20b636e0c61a4de13283127e56f32450 Mon Sep 17 00:00:00 2001 From: Nicolas Riesco Date: Wed, 27 Jan 2016 17:13:17 +0000 Subject: [PATCH] doc: Add overview of IJavascript source code --- doc/navbar.json | 5 +++-- doc/overview.md | 46 ++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 49 insertions(+), 2 deletions(-) create mode 100644 doc/overview.md diff --git a/doc/navbar.json b/doc/navbar.json index d9f1352..e204708 100644 --- a/doc/navbar.json +++ b/doc/navbar.json @@ -10,8 +10,9 @@ }, "Tutorials": { "N. Riesco": { - "01. Global object": "n-riesco.global.ipynb", - "02. Keyword this": "n-riesco.this.ipynb" + "01. IJavascript source code overview": "overview.md", + "02. Global object": "n-riesco.global.ipynb", + "03. Keyword this": "n-riesco.this.ipynb" } } } diff --git a/doc/overview.md b/doc/overview.md new file mode 100644 index 0000000..21883c1 --- /dev/null +++ b/doc/overview.md @@ -0,0 +1,46 @@ +# IJavascript source code overview + +IJavascript provides a Javascript kernel for the [Jupyter +project](http://jupyter.org/). Its code is currently split into 3 `npm` +packages: [ijavascript](https://www.npmjs.com/package/ijavascript), +[nel](https://www.npmjs.com/package/nel) and +[jmp](https://www.npmjs.com/package/jmp). + +## Package `ijavascript` + +IJavascript provides the command, `ijs`, which is a link to `bin/ijavascript.js` +and is used to install the Javascript kernel and invoke the Jupyter notebook. + +The Javascript kernel is implemented in `lib/kernel.js` by means of the `Kernel` +class. The CoffeeScript kernel, +[jp-coffeescript](https://github.com/n-riesco/jp-coffeescript), and the Babel +kernel, [jp-babel](https://github.com/n-riesco/jp-babel), share a significant +amount of the code with `lib/kernel.js`. To facilitate the reuse of this shared +code, the `Kernel` class will be moved into its own `npm` package in the near +future. + +The `Kernel` class depends on the `npm` packages, `nel` and `jmp`. + +## Package `nel` + +The `nel` package defines `Session`, a class that upon instantiation starts a +small `Node.js` server, `lib/nel_server.js`. The `Session` instance and +`lib/nel_server.js` communicate by means of an IPC channel. The `Session` +instance sends `lib/nel_server.js` a pair of strings, `action` and `code`. +`action` is a string that determines the type of request: execution, completion +or inspection. And `code` is a string with the Javascript code to be executed, +completed or inspected. `lib/nel_server.js` responds to the request with either +a +[SuccessResult](http://n-riesco.github.io/nel/module-nel.html#~SuccessResult) +or an +[ErrorResult](http://n-riesco.github.io/nel/module-nel.html#~ErrorResult). + +The interface between the classes `Kernel` and `Session` is documented +[here](http://n-riesco.github.io/nel/module-nel-Session.html). + +## Package `jmp` + +The `jmp` package is wrapper around the package `node-zmq` that transparently +encodes/decodes Jupyter-protocol messages over a ZMQ socket. See the +JSDoc-generated documentation [here](http://n-riesco.github.io/jmp) for further +details.