From 93169df5132b6767930a8b98526c5ff5b1f387b9 Mon Sep 17 00:00:00 2001 From: Athijegannathan Sundararajan Date: Mon, 28 Mar 2016 23:05:01 +0530 Subject: [PATCH] 8152533: ant octane target fails with "Unable to load a script engine manager (org.apache.bsf.BSFManager or javax.script.ScriptEngineManager)" Reviewed-by: jlaskey --- nashorn/buildtools/nashorntask/README | 1 + nashorn/buildtools/nashorntask/build.xml | 57 ++++++++++++++ .../buildtools/nashorntask/project.properties | 40 ++++++++++ .../src/jdk/nashorn/ant/NashornTask.java | 76 +++++++++++++++++++ nashorn/make/build-benchmark.xml | 30 ++++---- nashorn/make/project.properties | 5 +- 6 files changed, 190 insertions(+), 19 deletions(-) create mode 100644 nashorn/buildtools/nashorntask/README create mode 100644 nashorn/buildtools/nashorntask/build.xml create mode 100644 nashorn/buildtools/nashorntask/project.properties create mode 100644 nashorn/buildtools/nashorntask/src/jdk/nashorn/ant/NashornTask.java diff --git a/nashorn/buildtools/nashorntask/README b/nashorn/buildtools/nashorntask/README new file mode 100644 index 00000000000..569250190ef --- /dev/null +++ b/nashorn/buildtools/nashorntask/README @@ -0,0 +1 @@ +This project implements an ant task to run Nashorn scripts from ant projects. diff --git a/nashorn/buildtools/nashorntask/build.xml b/nashorn/buildtools/nashorntask/build.xml new file mode 100644 index 00000000000..612d39db769 --- /dev/null +++ b/nashorn/buildtools/nashorntask/build.xml @@ -0,0 +1,57 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/nashorn/buildtools/nashorntask/project.properties b/nashorn/buildtools/nashorntask/project.properties new file mode 100644 index 00000000000..dde10f7b03c --- /dev/null +++ b/nashorn/buildtools/nashorntask/project.properties @@ -0,0 +1,40 @@ +# +# Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. +# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. +# +# This code is free software; you can redistribute it and/or modify it +# under the terms of the GNU General Public License version 2 only, as +# published by the Free Software Foundation. +# +# This code is distributed in the hope that it will be useful, but WITHOUT +# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or +# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License +# version 2 for more details (a copy is included in the LICENSE file that +# accompanied this code). +# +# You should have received a copy of the GNU General Public License version +# 2 along with this work; if not, write to the Free Software Foundation, +# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. +# +# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA +# or visit www.oracle.com if you need additional information or have any +# questions. +# +application.title=nashorntask + +# source and target levels +build.compiler=modern +javac.source=1.8 +javac.target=1.8 + +build.classes.dir=${build.dir}/classes + +# This directory is removed when the project is cleaned: +build.dir=build +# This directory is removed when the project is cleaned: +dist.dir=dist +dist.jar=${dist.dir}/nashorntask.jar +dist.javadoc.dir=${dist.dir}/javadoc + +javac.debug=true +src.dir=src diff --git a/nashorn/buildtools/nashorntask/src/jdk/nashorn/ant/NashornTask.java b/nashorn/buildtools/nashorntask/src/jdk/nashorn/ant/NashornTask.java new file mode 100644 index 00000000000..c417f731d1a --- /dev/null +++ b/nashorn/buildtools/nashorntask/src/jdk/nashorn/ant/NashornTask.java @@ -0,0 +1,76 @@ +/* + * Copyright (c) 2010, 2013, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. Oracle designates this + * particular file as subject to the "Classpath" exception as provided + * by Oracle in the LICENSE file that accompanied this code. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +package jdk.nashorn.ant; + +import javax.script.ScriptEngine; +import javax.script.ScriptEngineManager; +import javax.script.ScriptException; +import org.apache.tools.ant.Project; +import org.apache.tools.ant.Task; +import org.apache.tools.ant.BuildException; + +/** + * This class implements an ant task to evaluate nashorn scripts + * from ant projects. + */ +public final class NashornTask extends Task { + // Underlying nashorn script engine + private final ScriptEngine engine; + // the current ant project + private Project project; + // the script evaluated by this task + private String script; + + public NashornTask() { + final ScriptEngineManager m = new ScriptEngineManager(); + this.engine = m.getEngineByName("nashorn"); + } + + @Override + public void setProject(Project proj) { + this.project = proj; + } + + // set the script to be evaluated + public void addText(String text) { + this.script = text; + } + + @Override + public void execute() { + // expose project as "project" variable + engine.put("project", project); + // expose this task as "self" variable + engine.put("self", this); + + // evaluate specified script + try { + engine.eval(script); + } catch (final ScriptException se) { + throw new BuildException(se); + } + } +} diff --git a/nashorn/make/build-benchmark.xml b/nashorn/make/build-benchmark.xml index cda125367e3..9bc7b4d893e 100644 --- a/nashorn/make/build-benchmark.xml +++ b/nashorn/make/build-benchmark.xml @@ -217,14 +217,20 @@ + + + + + - + - + ]]> @@ -278,14 +284,8 @@ --> - - + + @@ -318,9 +318,7 @@ - + fork="true"> @@ -391,9 +389,7 @@ - + fork="true"> diff --git a/nashorn/make/project.properties b/nashorn/make/project.properties index 9b4bdbd2be4..16b809af64c 100644 --- a/nashorn/make/project.properties +++ b/nashorn/make/project.properties @@ -47,14 +47,15 @@ build.classes.dir=${build.dir}/classes build.zip=${build.dir}/nashorn.zip build.gzip=${build.dir}/nashorn.tar.gz +# project directory of ant task +nashorntask.dir=buildtools/nashorntask + # nashorn Shell tool nashorn.shell.tool=jdk.nashorn.tools.Shell # nasgen tool nasgen.tool=jdk.nashorn.internal.tools.nasgen.Main -nasgen.module.imports=\ - nasgen.module.imports=\ java.base/jdk.internal.org.objectweb.asm=ALL-UNNAMED,\ java.base/jdk.internal.org.objectweb.asm.util=ALL-UNNAMED