Skip to content

Commit

Permalink
1. add list lineMagic and time cellMagic;
Browse files Browse the repository at this point in the history
2. load print.jshell by default.
  • Loading branch information
potoo0 committed Jun 2, 2022
1 parent 8a5ec06 commit 625cbfb
Show file tree
Hide file tree
Showing 14 changed files with 295 additions and 73 deletions.
32 changes: 24 additions & 8 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,18 +1,36 @@
# IJava

[![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)
Fork from [SpencerPark](https://github.com/SpencerPark)/[IJava](https://github.com/SpencerPark/IJava), but with some new
features and magics:

![display-img](docs/img/display-img.png)
* Upgrade to jdk 17 and gradle 7.3.3
* Print with variable name or source
![timeout](docs/img/print-with-var-name.png)
* add `print` function and `printerPrefix` line magic
![timeout](docs/img/print-func-line-magic.png)
* add `list` line magic
![timeout](docs/img/line-magic-list.png)
* add `time` cell magic
![timeout](docs/img/cell-magic-time.png)

[//]: # ([![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))

A [Jupyter](http://jupyter.org/) kernel for executing Java code. The kernel executes code via the new [JShell tool](https://docs.oracle.com/javase/9/jshell/introduction-jshell.htm). Some of the additional commands should be supported as needed via a syntax similar to the ipython magics.
[//]: # (![display-img](docs/img/display-img.png))

The kernel is fully functional. Check out the [list of features](#features) further down in the README. Any requests for new ones or prioritizing current requests are welcomed in the [issues](https://github.com/SpencerPark/IJava/issues) along with bug requests, installation help, or other questions.
A [Jupyter](http://jupyter.org/) kernel for executing Java code. The kernel executes code via the
new [JShell tool](https://docs.oracle.com/javase/9/jshell/introduction-jshell.htm). Some of the additional commands
should be supported as needed via a syntax similar to the ipython magics.

If you are interested in building your own kernel that runs on the JVM check out the related project that this kernel is build on, [jupyter-jvm-basekernel](https://github.com/SpencerPark/jupyter-jvm-basekernel).
The kernel is fully functional. Check out the [list of features](#features) further down in the README. Any requests for
new ones or prioritizing current requests are welcomed in the [issues](https://github.com/SpencerPark/IJava/issues)
along with bug requests, installation help, or other questions.

If you are interested in building your own kernel that runs on the JVM check out the related project that this kernel is
build on, [jupyter-jvm-basekernel](https://github.com/SpencerPark/jupyter-jvm-basekernel).

### Contents

* [Try online](#try-online)
* [Try online](#try-online)
* [Features](#features)
* [Requirements](#requirements)
* [Installing](#installing)
Expand Down Expand Up @@ -56,8 +74,6 @@ Currently the kernel supports
![eval](docs/img/eval.png)
* Configurable evaluation timeout
![timeout](docs/img/timeout.png)
* Print with variable name or source
![timeout](docs/img/print-with-var-name.png)

### Requirements

Expand Down
11 changes: 11 additions & 0 deletions UPGRADE.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
Upgrade Note:

* Upgrade to jdk 17 and gradle 7.3.3
* Print with variable name or source
![timeout](docs/img/print-with-var-name.png)
* add `print` function and `printerPrefix` line magic
![timeout](docs/img/print-func-line-magic.png)
* add `list` line magic
![timeout](docs/img/line-magic-list.png)
* add `time` cell magic
![timeout](docs/img/cell-magic-time.png)
3 changes: 2 additions & 1 deletion build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -116,8 +116,9 @@ tasks.register('packDist', Zip) {
into "java/dependency-license"
}

dependsOn generateLicenseReport
dependsOn build
}

// execute task after build
build.finalizedBy(packDist)
//build.finalizedBy(packDist)
Binary file added docs/img/cell-magic-time.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added docs/img/line-magic-list.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added docs/img/print-func-line-magic.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file modified docs/img/print-with-var-name.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
1 change: 1 addition & 0 deletions src/main/java/io/github/spencerpark/ijava/IJava.java
Original file line number Diff line number Diff line change
Expand Up @@ -46,6 +46,7 @@ public class IJava {
public static final String STARTUP_SCRIPT_KEY = "IJAVA_STARTUP_SCRIPT";

public static final String DEFAULT_SHELL_INIT_RESOURCE_PATH = "ijava-jshell-init.jshell";
public static final String SHELL_INIT_RESOURCE_PATH_PRINTER = "print.jshell";

public static final String VERSION;

Expand Down
27 changes: 14 additions & 13 deletions src/main/java/io/github/spencerpark/ijava/JavaKernel.java
Original file line number Diff line number Diff line change
Expand Up @@ -24,9 +24,7 @@
package io.github.spencerpark.ijava;

import io.github.spencerpark.ijava.execution.*;
import io.github.spencerpark.ijava.magics.ClasspathMagics;
import io.github.spencerpark.ijava.magics.MavenResolver;
import io.github.spencerpark.ijava.magics.PrinterMagics;
import io.github.spencerpark.ijava.magics.*;
import io.github.spencerpark.jupyter.kernel.BaseKernel;
import io.github.spencerpark.jupyter.kernel.LanguageInfo;
import io.github.spencerpark.jupyter.kernel.ReplacementOptions;
Expand Down Expand Up @@ -70,7 +68,7 @@ public static String maybeCompleteCodeSignifier() {
private final MavenResolver mavenResolver;

private final MagicsSourceTransformer magicsTransformer;
private final Magics magics;
private static final Magics magics = new Magics();

private final LanguageInfo languageInfo;
private final String banner;
Expand All @@ -82,6 +80,7 @@ public static String maybeCompleteCodeSignifier() {
// jupyter support ANSI_escape_code, java ansi code demo: https://stackoverflow.com/a/5762502
private static String varNamePattern = "\u001B[36m%s\u001B[0m: ";
private Long snippetId = 0L;
private static final List<String> COMMENT_PATTERNS = List.of("/\\*(.|\\s)*?\\*/", "//.*\\n*", "\\s+");

public JavaKernel() {
// todo for debug
Expand All @@ -96,6 +95,7 @@ public JavaKernel() {
.addClasspathFromString(System.getenv(IJava.CLASSPATH_KEY))
.compilerOptsFromString(System.getenv(IJava.COMPILER_OPTS_KEY))
.startupScript(IJava.resource(IJava.DEFAULT_SHELL_INIT_RESOURCE_PATH))
.startupScript(IJava.resource(IJava.SHELL_INIT_RESOURCE_PATH_PRINTER))
.startupScriptFiles(System.getenv(IJava.STARTUP_SCRIPTS_KEY))
.startupScript(System.getenv(IJava.STARTUP_SCRIPT_KEY))
.timeoutFromString(System.getenv(IJava.TIMEOUT_DURATION_KEY))
Expand All @@ -106,11 +106,12 @@ public JavaKernel() {
this.mavenResolver = new MavenResolver(this::addToClasspath);

this.magicsTransformer = new MagicsSourceTransformer();
this.magics = new Magics();
this.magics.registerMagics(this.mavenResolver);
this.magics.registerMagics(new ClasspathMagics(this::addToClasspath));
this.magics.registerMagics(new Load(List.of(".jsh", ".jshell", ".java", ".ijava"), this::eval));
this.magics.registerMagics(new PrinterMagics());
magics.registerMagics(this.mavenResolver);
magics.registerMagics(new ClasspathMagics(this::addToClasspath));
magics.registerMagics(new Load(List.of(".jsh", ".jshell", ".java", ".ijava"), this::eval));
magics.registerMagics(new PrinterMagics());
magics.registerMagics(new MagicsTool());
magics.registerMagics(new TimeItMagics());

this.languageInfo = new LanguageInfo.Builder("Java")
.version(Runtime.version().toString())
Expand Down Expand Up @@ -149,8 +150,8 @@ public MavenResolver getMavenResolver() {
return this.mavenResolver;
}

public Magics getMagics() {
return this.magics;
public static Magics getMagics() {
return magics;
}

@Override
Expand Down Expand Up @@ -283,7 +284,6 @@ public Object evalRaw(String expr) throws Exception {
public DisplayData eval(String expr) throws Exception {
Object result = this.evalRaw(expr);

// last snippet is ExpressSnippet or VarSnippet -> getSource().replaceAll("\s+", "")
if (result == null) return null;
if (result instanceof DisplayData displayData) return displayData;

Expand All @@ -293,7 +293,8 @@ public DisplayData eval(String expr) throws Exception {
Snippet snippet = lastSnippet.get();
if (snippet instanceof ExpressionSnippet || snippet instanceof VarSnippet) {
snippetId = snippet.id().matches("\\d+") ? (Long.parseLong(snippet.id()) - 1) : (snippetId + 1);
String sourceStr = snippet.source().replaceAll("\\s+", "");
String sourceStr = snippet.source();
for (String pattern : COMMENT_PATTERNS) sourceStr = sourceStr.replaceAll(pattern, "");
if (sourceStr.length() > 32) sourceStr = sourceStr.substring(0, 32) + "...";
return this.getRenderer().render(String.format(varNamePattern, sourceStr) + result);
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,6 @@
*/
package io.github.spencerpark.ijava.execution;

import io.github.spencerpark.ijava.utils.FileUtils;
import io.github.spencerpark.jupyter.kernel.util.GlobFinder;
import jdk.jshell.JShell;

Expand Down Expand Up @@ -149,13 +148,13 @@ public CodeEvaluatorBuilder startupScript(InputStream scriptStream) {

public CodeEvaluatorBuilder startupScriptFiles(String paths) {
// todo debug
try {
String glob1 = "glob:*";
String path1 = ".";
System.out.println("------------- startup: " + FileUtils.listMatchedFilePath(glob1, path1));
} catch (Exception e) {
e.printStackTrace();
}
//try {
// String glob1 = "glob:*";
// String path1 = ".";
// System.out.println("------------- startup: " + FileUtils.listMatchedFilePath(glob1, path1));
//} catch (Exception e) {
// e.printStackTrace();
//}

if (paths == null) return this;
if (BLANK.matcher(paths).matches()) return this;
Expand All @@ -182,6 +181,8 @@ public CodeEvaluatorBuilder startupScriptFile(Path path) {
if (!Files.isReadable(path))
return this;

// debug
System.out.printf("found startup file: %s%n", path);
try {
String script = Files.readString(path);
this.startupScripts.add(script);
Expand Down
Loading

0 comments on commit 625cbfb

Please sign in to comment.