From 98386ad554c120827cb410478fc05a63d8347411 Mon Sep 17 00:00:00 2001 From: SpencerPark Date: Sun, 25 Nov 2018 23:04:54 -0500 Subject: [PATCH] Update install/configuration instructions based on the new installer plugin. --- README.md | 74 ++++++++++++++++++++-------------------------------- build.gradle | 3 +-- 2 files changed, 29 insertions(+), 48 deletions(-) diff --git a/README.md b/README.md index 085067f..a39a6aa 100644 --- a/README.md +++ b/README.md @@ -1,6 +1,6 @@ # IJava -[![Binder](https://mybinder.org/badge.svg)](https://mybinder.org/v2/gh/SpencerPark/ijava-binder/master) ([JupyterLab ![Binder](https://mybinder.org/badge.svg)](https://mybinder.org/v2/gh/SpencerPark/ijava-binder/master?urlpath=lab)) +[![badge](https://img.shields.io/badge/launch-binder-E66581.svg?logo=)](https://mybinder.org/v2/gh/SpencerPark/ijava-binder/master) [![badge](https://img.shields.io/badge/launch-binder%20lab-579ACA.svg?logo=)](https://mybinder.org/v2/gh/SpencerPark/ijava-binder/master?urlpath=lab) ![display-img](docs/img/display-img.png) @@ -28,7 +28,7 @@ For Maven dependency resolution, the kernel is using [ShrinkWrap resolvers](http ### Try Online -Clicking on the [![Binder](https://mybinder.org/badge.svg)](https://mybinder.org/v2/gh/SpencerPark/ijava-binder/master) ([JupyterLab ![Binder](https://mybinder.org/badge.svg)](https://mybinder.org/v2/gh/SpencerPark/ijava-binder/master?urlpath=lab)) badge at the top (or right here) will spawn a jupyter server running this kernel. The binder base is the [ijava-binder project](https://github.com/SpencerPark/ijava-binder). +Clicking on the [![badge](https://img.shields.io/badge/launch-binder-E66581.svg?logo=)](https://mybinder.org/v2/gh/SpencerPark/ijava-binder/master) [![badge](https://img.shields.io/badge/launch-binder%20lab-579ACA.svg?logo=)](https://mybinder.org/v2/gh/SpencerPark/ijava-binder/master?urlpath=lab) badges at the top (or right here) will spawn a jupyter server running this kernel. The binder base is the [ijava-binder project](https://github.com/SpencerPark/ijava-binder). ### Features @@ -55,7 +55,7 @@ Currently the kernel supports ### Requirements -1. [Java JDK >=9](http://www.oracle.com/technetwork/java/javase/downloads/index.html). **Not the JRE** +1. [Java JDK >= 9](http://www.oracle.com/technetwork/java/javase/downloads/index.html). **Not the JRE**. Java 11 is the current release and should be considered if selecting a version but if a java 9 or 10 build is installed, everything _should_ still be working fine. 1. Ensure that the `java` command is in the PATH and is using version 9. For example: ```bash @@ -85,13 +85,13 @@ Currently the kernel supports A non-exhaustive list of options: - * [Jupyter](http://jupyter.org/install) - main option + * [Jupyter](http://jupyter.org/install) * [JupyterLab](http://jupyterlab.readthedocs.io/en/stable/getting_started/installation.html) * [nteract](https://nteract.io/desktop) ### Installing -After meeting the [requirements](#requirements), the kernel can be installed locally. Any time you wish to remove a kernel you may use `jupyter kernelspec remove java`. +After meeting the [requirements](#requirements), the kernel can be installed locally. Any time you wish to remove a kernel you may use `jupyter kernelspec remove java`. If you have installed the kernel to multiple directories, this command may need to be run multiple times as it might only remove 1 installation at a time. #### Install pre-built binary @@ -131,30 +131,21 @@ Get the latest version of the kernel but possibly run into some issues with inst On windows `gradlew installKernel` + See all available options for configuring the install path with `gradlew -q help --task installKernel`. Pass the `--default`, `--user`, `--sys-prefix`, `--prefix`, `--path`, or `--legacy` options to change the install location. Also use the `--param` flag (repeatedly) to set (or add) parameter values with the parameter names (not environment variable) specified in the configuration section below. For example `--param classpath:/my/classpath/root` to append to the classpath list. + ### Configuring -Configuring the kernel can be done via environment variables. These can be set on the system or inside the `kernel.json`. To find where the kernel is installed run - -```bash -> jupyter kernelspec list -Available kernels: - java .../kernels/java - python3 .../python35/share/jupyter/kernels/python3 -``` - -and the `kernel.json` file will be in the given directory. +Configuring the kernel can be done via environment variables. These can be set on the system or inside the `kernel.json`. The configuration can be done at install time, which may be repeated as often as desired. The parameters are listed with `python3 install.py -h` as well as below in the list of options. Configuration done via the installer (or `gradlew installKernel --param ...:...`) should use the names in the _Parameter name_ column. #### List of options -`IJAVA_COMPILER_OPTS` - **default: `""`** - A space delimited list of command line options that would be passed to the `javac` command when compiling a project. For example `-parameters` to enable retaining parameter names for reflection. - -`IJAVA_TIMEOUT` - **default: `"-1"`** - A duration specifying a timeout (in milliseconds by default) for a _single top level statement_. If less than `1` then there is no timeout. If desired a time may be specified with a [`TimeUnit`](https://docs.oracle.com/javase/9/docs/api/java/util/concurrent/TimeUnit.html) may be given following the duration number (ex `"30 SECONDS"`). - -`IJAVA_CLASSPATH` - **default: `""`** - A file path separator delimited list of classpath entries that should be available to the user code. **Important:** no matter what OS, this should use forward slash "/" as the file separator. Also each path may actually be a [simple glob](#simple-glob-syntax). - -`IJAVA_STARTUP_SCRIPTS_PATH` - **default: `""`** - A file path seperator delimited list of `.jshell` scripts to run on startup. This includes [ijava-jshell-init.jshell](src/main/resources/ijava-jshell-init.jshell) and [ijava-display-init.jshell](src/main/resources/ijava-display-init.jshell). **Important:** no matter what OS, this should use forward slash "/" as the file separator. Also each path may actually be a [simple glob](#simple-glob-syntax). - -`IJAVA_STARTUP_SCRIPT` - **default: `""`** - A block of java code to run when the kernel starts up. This may be something like `import my.utils;` to setup some default imports or even `void sleep(long time) { try {Thread.sleep(time); } catch (InterruptedException e) { throw new RuntimeException(e); }}` to declare a default utility method to use in the notebook. +| Environment variable | Parameter name | Default | Description | +|----------------------|----------------|---------|-------------| +| `IJAVA_COMPILER_OPTS` | `comp-opts` | `""` | A space delimited list of command line options that would be passed to the `javac` command when compiling a project. For example `-parameters` to enable retaining parameter names for reflection. | +| `IJAVA_TIMEOUT` | `timeout` | `"-1"` | A duration specifying a timeout (in milliseconds by default) for a _single top level statement_. If less than `1` then there is no timeout. If desired a time may be specified with a [`TimeUnit`](https://docs.oracle.com/javase/9/docs/api/java/util/concurrent/TimeUnit.html) may be given following the duration number (ex `"30 SECONDS"`). | +| `IJAVA_CLASSPATH` | `classpath` | `""` | A file path separator delimited list of classpath entries that should be available to the user code. **Important:** no matter what OS, this should use forward slash "/" as the file separator. Also each path may actually be a [simple glob](#simple-glob-syntax). | +| `IJAVA_STARTUP_SCRIPTS_PATH` | `startup-scripts-path` | `""` | A file path seperator delimited list of `.jshell` scripts to run on startup. This includes [ijava-jshell-init.jshell](src/main/resources/ijava-jshell-init.jshell) and [ijava-display-init.jshell](src/main/resources/ijava-display-init.jshell). **Important:** no matter what OS, this should use forward slash "/" as the file separator. Also each path may actually be a [simple glob](#simple-glob-syntax). | +| `IJAVA_STARTUP_SCRIPT` | `startup-script` | `""` | A block of java code to run when the kernel starts up. This may be something like `import my.utils;` to setup some default imports or even `void sleep(long time) { try {Thread.sleep(time); } catch (InterruptedException e) { throw new RuntimeException(e); }}` to declare a default utility method to use in the notebook. | ##### Simple glob syntax @@ -172,11 +163,20 @@ Any relative paths are resolved from the notebook server's working directory. Fo See the [List of options](#list-of-options) section for all of the configuration options. -To change compiler options use the `IJAVA_COMPILER_OPTS` environment variable with a string of flags as if running the `javac` command. +To change compiler options use the `IJAVA_COMPILER_OPTS` environment variable (or `--comp-opts` parameter during installation) with a string of flags as if running the `javac` command. -The `IJAVA_COMPILER_OPTS` and kernel VM parameters can be assigned in the `kernel.json` by adding/editing a JSON dictionary at the `env` key and changing the `argv` list. +The kernel VM parameters must currently be assigned in the `kernel.json` by adding/editing a JSON dictionary at the `env` key and changing the `argv` list. To find where the kernel is installed run -For example to enable assertions, set a limit on the heap size to `128m`, and enable parameter names in reflection: +```bash +> jupyter kernelspec list +Available kernels: + java .../kernels/java + python3 .../python35/share/jupyter/kernels/python3 +``` + +and the `kernel.json` file will be in the given directory. + +For example to enable assertions, set a limit on the heap size to `128m`. ```diff { @@ -184,30 +184,12 @@ For example to enable assertions, set a limit on the heap size to `128m`, and en + "argv": [ "java", "-ea", "-Xmx128m", "-jar", "{connection_file}"], "display_name": "Java", "language": "java", + "interrupt_mode": "message", "env": { -+ "IJAVA_COMPILER_OPTS" : "-parameters" } } ``` -#### Configuring startup scripts - -See the [List of options](#list-of-options) section for all of the configuration options. - -To setup a startup script such as an `init.jshell` script, set the `IJAVA_STARTUP_SCRIPTS_PATH` to `init.jshell` in the `kernel.json`. This will try to execute an `init.jshell` script in the working directory of kernel. - -If desired use an absolute path to use a global init file. - -```diff -{ - "argv": [ "java", "-jar", "{connection_file}"], - "display_name": "Java", - "language": "java", - "env": { -+ "IJAVA_STARTUP_SCRIPTS_PATH": "init.jshell" - } -``` - ### Run This is where the documentation diverges, each environment has it's own way of selecting a kernel. To test from command line with Jupyter's console application run: diff --git a/build.gradle b/build.gradle index d8fb7dc..afac722 100644 --- a/build.gradle +++ b/build.gradle @@ -2,7 +2,7 @@ plugins { id 'java' id 'maven-publish' id('com.github.hierynomus.license') version '0.14.0' - id('io.github.spencerpark.jupyter-kernel-installer') version '2.0.0' + id('io.github.spencerpark.jupyter-kernel-installer') version '2.1.0' id('com.github.jk1.dependency-license-report') } @@ -140,7 +140,6 @@ jupyter { } installKernel { - //pythonExecutable = 'python' kernelInstallPath = commandLineSpecifiedPath(userInstallPath) }