Skip to content

RainerXE/rapaio-jupyter-kernel

 
 

Repository files navigation

rapaio-jupyter-kernel

Jupyter kernel for Java language based on JShell. It implements Jupyter message specification version 5.4, and it requires Java = 22.

REX:

The aim of this for here is for:

a) work with the most recent version of Java (at the moment Java 23

b) be used with GraalVM for multi-languega support via Truffle

c) work on MacOS on an Mx machine

Introduction

I started implementing this kernel since I believe Java deserves a full feature and properly maintained jupyter kernel. Personally, I need that kernel to use features from a library I contribute to for statistics, ML, and data manipulation. However, this kernel has no connection with this library, and it is a general-purpose Java kernel.

Currently, this project is in a production mode, and it contains the features I need and some other requested features. As such, I am the only maintainer. If the kernel prove useful and additional contributors jump into this boat, an organization can be created and a shared ownership can also be added, all of those for the sole purpose of continuity of improvements. The plan is to add new features if requested, so please add issues if you want this tool to be better and fit your needs. If possible you can contribute with code. Any feedback is appreciated.

Features

Follow issues, vote on them, and create new ones, if you need improvements. Below are listed some features, besides running Java code, since this is the main purpose of the kernel:

  • Display Javadoc documentation (need styling and HTML postprocessing to make it nicer)
  • Console output with ANSI code colors
  • Autocompletion and documentation
  • Magic help function to facilitate navigation through the magic functions
  • Placeholders in magic commands
  • Display items and update items based on references
  • JShell commands (not all commands are implemented since some of them are not applicable)
  • Loading notebooks and JShell scripts
  • Loading jar or jars from the directory to the classpath
  • Adding directories with compiled classes to the classpath
  • Display image from local file systems or URL
  • Manage dependencies (with transitivity). More details: DEPENDENCY-MANAGEMENT.md.

For a brief tour of the features check out the example notebook here.

Installation

The latest version can be found as a download in the releases section. Rapaio Jupyter Kernel contains an installing tool which allows users to quickly set up the kernel. The installer is contained in the jar distribution archive and can be called with:

java -jar ./rapaio-jupyter-kernel-2.1.1.jar -i -auto

The -auto option uses an automatic mode for installing the kernel. The installer has also an interactive mode, and the kernel installation can be realized manually, also. For more details, you can follow INSTALL.md.

Maven central

No Maven support yet.


This is unnecessary, since the kernel is packaged as a self-contained jar archive (including all dependencies), 
and can be downloaded from releases. In the future, it would be possible to introduce a plug-in mechanism to allow others to 
extend the library for their own purposes. I see possibilities to allow others to create custom display code for objects of their 
own type or to implement new magic features. This kind of notebook extension can work for custom features, for generic features 
one can consider contributing to this project.

About

Java jupyter kernel

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Jupyter Notebook 94.7%
  • Java 5.3%