Skip to content

Nashorn Javascript Extension Pack for Approaching ECMAScript 2015

License

Notifications You must be signed in to change notification settings

efwGrp/nashorn-ext-for-es6

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

18 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

nashorn-ext-for-es6

Nashorn has 100% support for ECMAScript 5.1, but not full support for ECMAScript 2015 and after version. It will be a painful experience if you want to use some third-party library that requires CMAScript 2015 in nashorn.This extension pack may be able to ease your pain.

Implemented Features

FeatureECMAScriptExplication
Math
log102015The Math.log10() static method returns the base 10 logarithm of a number.
log22015The Math.log2() static method returns the base 2 logarithm of a number.
log1p2015The Math.log1p() static method returns the natural logarithm (base e) of 1 + x, where x is the argument.
expm12015Math.expm1The Math.expm1() static method returns e raised to the power of a number, subtracted by 1.
sinh2015The Math.sinh() static method returns the hyperbolic sine of a number.
cosh2015The Math.cosh() static method returns the hyperbolic cosine of a number.
tanh2015The Math.tanh() static method returns the hyperbolic tangent of a number.
asinh2015The Math.asinh() static method returns the inverse hyperbolic sine of a number.
acosh2015The Math.acosh() static method returns the inverse hyperbolic cosine of a number.
atanh2015The Math.atanh() static method returns the inverse hyperbolic tangent of a number.
hypot2015The Math.hypot() static method returns the square root of the sum of squares of its arguments.
trunc2015The Math.trunc() static method returns the integer part of a number by removing any fractional digits.
sign2015The Math.sign() static method returns 1 or -1, indicating the sign of the number passed as argument.
cbrt2015The Math.cbrt() static method returns the cube root of a number.
imul2015The Math.imul() static method returns the result of the C-like 32-bit multiplication of the two parameters.
fround2015The Math.fround() static method returns the nearest 32-bit single precision float representation of a number.
clz322015The Math.clz32() static method returns the number of leading zero bits in the 32-bit binary representation of a number.
Number
EPSILON2015The Number.EPSILON static data property represents the difference between 1 and the smallest floating point number greater than 1.
isFinite2015The Number.isFinite() static method determines whether the passed value is a finite number.
isInteger2015The Number.isInteger() static method determines whether the passed value is an integer.
isNaN2015The Number.isNaN() static method determines whether the passed value is the number value NaN, and returns false if the input is not of the Number type.
parseFloat2015The Number.parseFloat() static method parses an argument and returns a floating point number.
parseInt2015The Number.parseInt() static method parses a string argument and returns an integer of the specified radix or base.
String
codePointAt2015The codePointAt() method of String values returns a non-negative integer that is the Unicode code point value of the character starting at the given index.
fromCodePoint2015The String.fromCodePoint() static method returns a string created from the specified sequence of code points.
includes2015The includes() method of String values performs a case-sensitive search to determine whether a given string may be found within this string, returning true or false as appropriate.
repeat2015The repeat() method of String values constructs and returns a new string which contains the specified number of copies of this string, concatenated together.
trimStart2019The trimStart() method of String values removes whitespace from the beginning of this string and returns a new string, without modifying the original string.
trimEnd2019The trimEnd() method of String values removes whitespace from the end of this string and returns a new string, without modifying the original string. trimRight() is an alias of this method.
padStart2017The padStart() method of String values pads this string with another string (multiple times, if needed) until the resulting string reaches the given length. The padding is applied from the start of this string.
padEnd2017The padEnd() method of String values pads this string with a given string (repeated, if needed) so that the resulting string reaches a given length. The padding is applied from the end of this string.
Array
of2015The Array.of() static method creates a new Array instance from a variable number of arguments, regardless of number or type of the arguments.
copyWithin2015The copyWithin() method of Array instances shallow copies part of this array to another location in the same array and returns this array without modifying its length.
includes2016The includes() method of Array instances determines whether an array includes a certain value among its entries, returning true or false as appropriate.
flatMap2019The flatMap() method of Array instances returns a new array formed by applying a given callback function to each element of the array, and then flattening the result by one level.
from2015The Array.from() static method creates a new, shallow-copied Array instance from an iterable or array-like object. nashorn15.4 is required.
flat2015The flat() method of Array instances creates a new array with all sub-array elements concatenated into it recursively up to the specified depth. nashorn15.4 is required.
Object
assign2015The Object.assign() static method copies all enumerable own properties from one or more source objects to a target object. It returns the modified target object.
is2015The Object.is() static method determines whether two values are the same value.
values2017The Object.values() static method returns an array of a given object's own enumerable string-keyed property values.
getOwnPropertyDescriptors2017The Object.getOwnPropertyDescriptors() static method returns all own property descriptors of a given object.
entries2017The Object.entries() static method returns an array of a given object's own enumerable string-keyed property key-value pairs. nashorn15.4 is required.
This module mimics the browser's timeout functionality.I added it to make Promise work. Idears from https://github.com/nikku/nashorn-async
[global]
setTimeout(fn, millis)The global setTimeout() method sets a timer which executes a function or specified piece of code once the timer expires.
clearTimeout(task)The global clearTimeout() method cancels a timeout previously established by calling setTimeout().
setInterval(fn, millis)The setInterval() method, offered on the Window and Worker interfaces, repeatedly calls a function or executes a code snippet, with a fixed time delay between each call.
clearInterval(task)The global clearInterval() method cancels a timed, repeating action which was previously established by a call to setInterval().
This module provides a simple Promise functionality implementation. Referenced from https://www.promisejs.org
Promise
new Promise(fn) The Promise() constructor creates Promise objects. It is primarily used to wrap callback-based APIs that do not already support promises.
Promise.resolve(value) The Promise.resolve() static method "resolves" a given value to a Promise. If the value is a promise, that promise is returned; if the value is a thenable, Promise.resolve() will call the then() method with two callbacks it prepared; otherwise the returned promise will be fulfilled with the value.
Promise.reject(value) The Promise.reject() static method returns a Promise object that is rejected with a given reason.
then(onFulfilled, onRejected) The then() method of Promise instances takes up to two arguments: callback functions for the fulfilled and rejected cases of the Promise. It immediately returns an equivalent Promise object, allowing you to chain calls to other promise methods.
Promise.all(arr) The Promise.all() static method takes an iterable of promises as input and returns a single Promise. This returned promise fulfills when all of the input's promises fulfill (including when an empty iterable is passed), with an array of the fulfillment values. It rejects when any of the input's promises rejects, with this first rejection reason.
catch(onRejected) The catch() method of Promise instances schedules a function to be called when the promise is rejected. It immediately returns an equivalent Promise object, allowing you to chain calls to other promise methods. It is a shortcut for Promise.prototype.then(undefined, onRejected).
Promise.race(values) The Promise.race() static method takes an iterable of promises as input and returns a single Promise. This returned promise settles with the eventual state of the first promise that settles.
catch(onRejected)catch metod is equival to calling Promise.prototype.then(undefined, onRejected)
async/await These functions are similar, but not identical, to the original in ECMAScript 2015.
async(fnc)The async() method changes fnc to a Promise instanse and returns it.If fnc has been a Promise instanse,it will be returned without changing.
await(prms)The await() method calls prms.then() method and waits till fulfill is executed, then returns the value of fulfill.
And I added a simple window mock implementation to cheat pdfmake environment checking.
context.console={log:function(v){
		if (typeof v =="object"){
			java.lang.System.out.println(JSON.stringify(v));
		}else{
			java.lang.System.out.println(v);
		}
	}
}
context.navigator={
	//to cheat the checker of pdfmake
	userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/116.0.0.0 Safari/537.36"
};
context.self=context;
context.window=context;

Samples

A

The sample about async/await. It is amizing for nashorn, isn't it?

load("nashorn-ext-for-es6.min.js");
var f = async(function(){
	java.lang.System.out.println(new Date()+" The async started.");
	return new Promise(function(resolve, reject){
		setTimeout(function(param){resolve("hello world,"+param);},1000,"hello tokyo");
	});
});
var ret=await(f);
java.lang.System.out.println(new Date()+" The await return value is : "+ret);

image

B

The sample about Promise.all. It is added for running pdfmake. And you can use console.log() for output.

load("nashorn-ext-for-es6.min.js");
const promise1 = Promise.resolve(3);
const promise2 = 42;
const promise3 = new Promise((resolve, reject) => {
setTimeout(resolve, 100, 'foo');
});
var a=await(Promise.all([promise1, promise2, promise3]));
console.log(a);

image

C

The sample to creat pdf using pdf-lib. Besure your nashorn is 15.4 or later. To run the sample in JDK8 will be error. You can download pdf-lib.min.js from https://pdf-lib.js.org/ or https://unpkg.com/pdf-lib@1.17.1/dist/pdf-lib.min.js.

load("nashorn-ext-for-es6.min.js");
load("pdf-lib.min.js");
var pdfDoc=await(PDFLib.PDFDocument.create());
var page = pdfDoc.addPage([350, 400]);
page.moveTo(110, 200);
page.drawText("Hello World!");
var pdfDataUri=await(pdfDoc.saveAsBase64({ dataUri: true }));
java.lang.System.out.println(pdfDataUri);

Try to send the pdfDataUri to the src attribute of iframe, you will see your pdf. image image

D

The sample to creat pdf using pdfmake. Besure your nashorn is 15.4 or later. To run the sample in JDK8 will be error. You can download pdfmake.min.js from http://pdfmake.org/ or https://cdnjs.com/libraries/pdfmake .

load("nashorn-ext-for-es6.min.js");
load("pdfmake.min.js");
load("vfs_fonts.min.js");
var docDefinition = {
	content: [
		"This is a standard paragraph, using default style",
		{ text: "This paragraph will have a bigger font", fontSize: 15 },
		{
			text: [
				"This paragraph is defined as an array of elements to make it possible to ",
				{ text: "restyle part of it and make it bigger ", fontSize: 15 },
				"than the rest.",
			],
		},
	],
};
var pdfDataUri;
var doc=pdfMake.createPdf(docDefinition);
pdfDataUri=await(
	new Promise(function(resolve,reject){
		doc.getDataUrl(function(data){
			resolve(data);
		});
	})
);
console.log(pdfDataUri);

Try to send the pdfDataUri to the src attribute of iframe, you will see your pdf. image image