/hg/icedtea-web: 2 new changesets
jvanek at icedtea.classpath.org
jvanek at icedtea.classpath.org
Sat Feb 3 13:42:45 UTC 2018
changeset f9eb692bac54 in /hg/icedtea-web
details: http://icedtea.classpath.org/hg/icedtea-web?cmd=changeset;node=f9eb692bac54
author: Jiri Vanek <jvanek at redhat.com>
date: Sat Feb 03 11:43:05 2018 +0100
netx/net/sourceforge/jnlp/Parser.java: auto-formatted
changeset bef3e4ec4b00 in /hg/icedtea-web
details: http://icedtea.classpath.org/hg/icedtea-web?cmd=changeset;node=bef3e4ec4b00
author: Jiri Vanek <jvanek at redhat.com>
date: Sat Feb 03 14:42:07 2018 +0100
made OmegaT run - Made ITW to load resources from j2se/java tag too
* netx/net/sourceforge/jnlp/Parser.java: constructors/methods made public to help unittests
* netx/net/sourceforge/jnlp/ShortcutDesc.java: same
* netx/net/sourceforge/jnlp/ResourcesDesc.java: getJars made to iterate recursively over content of j2se
* tests/netx/unit/net/sourceforge/jnlp/ParserBasic.java: added testcase
* tests/netx/unit/net/sourceforge/jnlp/jarsInJreDesc.jnlp: testfile copied form omegat which have this strange resources
diffstat:
ChangeLog | 12 +
netx/net/sourceforge/jnlp/Parser.java | 560 ++++++++-------
netx/net/sourceforge/jnlp/ResourcesDesc.java | 25 +-
netx/net/sourceforge/jnlp/ShortcutDesc.java | 2 +-
tests/netx/unit/net/sourceforge/jnlp/ParserBasic.java | 27 +-
tests/netx/unit/net/sourceforge/jnlp/jarsInJreDesc.jnlp | 100 ++
6 files changed, 469 insertions(+), 257 deletions(-)
diffs (truncated from 1359 to 500 lines):
diff -r e9b895388a5a -r bef3e4ec4b00 ChangeLog
--- a/ChangeLog Mon Dec 18 13:22:40 2017 +0100
+++ b/ChangeLog Sat Feb 03 14:42:07 2018 +0100
@@ -1,3 +1,15 @@
+2018-02-03 Jiri Vanek <jvanek at redhat.com>
+
+ Made ITW to load resources from j2se/java tag too
+ * netx/net/sourceforge/jnlp/Parser.java: constructors/methods made public to help unittests
+ * netx/net/sourceforge/jnlp/ShortcutDesc.java: same
+ * netx/net/sourceforge/jnlp/ResourcesDesc.java: getJars made to iterate recursively over content of j2se
+ * tests/netx/unit/net/sourceforge/jnlp/ParserBasic.java: added testcase
+ * tests/netx/unit/net/sourceforge/jnlp/jarsInJreDesc.jnlp: testfile copied form omegat which have this strange resources
+
+2018-02-03 Jiri Vanek <jvanek at redhat.com>
+ * netx/net/sourceforge/jnlp/Parser.java: auto-formatted
+
2017-12-11 Jiri Vanek <jvanek at redhat.com>
* Makefile.am: preprocessing hardoced_paths.rs.in for each binary and creating libs
diff -r e9b895388a5a -r bef3e4ec4b00 netx/net/sourceforge/jnlp/Parser.java
--- a/netx/net/sourceforge/jnlp/Parser.java Mon Dec 18 13:22:40 2017 +0100
+++ b/netx/net/sourceforge/jnlp/Parser.java Sat Feb 03 14:42:07 2018 +0100
@@ -14,7 +14,6 @@
// You should have received a copy of the GNU Lesser General Public
// License along with this library; if not, write to the Free Software
// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
-
package net.sourceforge.jnlp;
import static net.sourceforge.jnlp.runtime.Translator.R;
@@ -33,26 +32,25 @@
import net.sourceforge.jnlp.util.logging.OutputController;
/**
- * Contains methods to parse an XML document into a JNLPFile.
- * Implements JNLP specification version 1.0.
+ * Contains methods to parse an XML document into a JNLPFile. Implements JNLP
+ * specification version 1.0.
*
- * @author <a href="mailto:jmaxwell at users.sourceforge.net">Jon A. Maxwell (JAM)</a> - initial author
+ * @author <a href="mailto:jmaxwell at users.sourceforge.net">Jon A. Maxwell
+ * (JAM)</a> - initial author
* @version $Revision: 1.13 $
*/
public final class Parser {
-
+
private static String CODEBASE = "codebase";
private static String MAINCLASS = "main-class";
private static final Pattern anyWhiteSpace = Pattern.compile("\\s");
// defines netx.jnlp.Node class if using Tiny XML or Nano XML
-
// Currently uses the Nano XML parse. Search for "SAX" or
// "TINY" or "NANO" and uncomment those blocks and comment the
// active ones (if any) to switch XML parsers. Also
// (un)comment appropriate Node class at end of this file and
// do a clean build.
-
/**
* Ensure consistent error handling.
*/
@@ -69,66 +67,81 @@
OutputController.getLogger().log(OutputController.Level.ERROR_ALL, exception);
}
};
- */
-
+ */
// fix: some descriptors need to use the jnlp file at a later
// date and having file ref lets us pass it to their
// constructors
//
- /** the file reference */
+ /**
+ * the file reference
+ */
private final JNLPFile file; // do not use (uninitialized)
- /** the root node */
+ /**
+ * the root node
+ */
private final Node root;
- /** the specification version */
+ /**
+ * the specification version
+ */
private final Version spec;
- /** the base URL that all hrefs are relative to */
+ /**
+ * the base URL that all hrefs are relative to
+ */
private final URL base;
- /** the codebase URL */
+ /**
+ * the codebase URL
+ */
private URL codebase;
- /** the file URL */
+ /**
+ * the file URL
+ */
private final URL fileLocation;
- /** whether to throw errors on non-fatal errors. */
+ /**
+ * whether to throw errors on non-fatal errors.
+ */
private final boolean strict; // if strict==true parses a file with no error then strict==false should also
- /** whether to allow extensions to the JNLP specification */
+ /**
+ * whether to allow extensions to the JNLP specification
+ */
private final boolean allowExtensions; // true if extensions to JNLP spec are ok
-
+
/**
- * Create a parser for the JNLP file. If the location
- * parameters is not null it is used as the default codebase
- * (does not override value of jnlp element's href
- * attribute).
+ * Create a parser for the JNLP file. If the location parameters is not null
+ * it is used as the default codebase (does not override value of jnlp
+ * element's href attribute).
* <p>
- * The root node may be normalized as a side effect of this
- * constructor.
+ * The root node may be normalized as a side effect of this constructor.
* </p>
+ *
* @param file the (uninitialized) file reference
- * @param base if codebase is not specified, a default base for relative URLs
+ * @param base if codebase is not specified, a default base for relative
+ * URLs
* @param root the root node
* @param settings the parser settings to use when parsing the JNLP file
* @throws ParseException if the JNLP file is invalid
*/
- Parser(JNLPFile file, URL base, Node root, ParserSettings settings) throws ParseException {
- this(file, base, root, settings, null);
+ public Parser(JNLPFile file, URL base, Node root, ParserSettings settings) throws ParseException {
+ this(file, base, root, settings, null);
}
/**
- * Create a parser for the JNLP file. If the location
- * parameters is not null it is used as the default codebase
- * (does not override value of jnlp element's href
- * attribute).
+ * Create a parser for the JNLP file. If the location parameters is not null
+ * it is used as the default codebase (does not override value of jnlp
+ * element's href attribute).
* <p>
- * The root node may be normalized as a side effect of this
- * constructor.
+ * The root node may be normalized as a side effect of this constructor.
* </p>
+ *
* @param file the (uninitialized) file reference
- * @param base if codebase is not specified, a default base for relative URLs
+ * @param base if codebase is not specified, a default base for relative
+ * URLs
* @param root the root node
* @param settings the parser settings to use when parsing the JNLP file
* @param codebase codebase to use if we did not parse one from JNLP file.
@@ -141,8 +154,9 @@
this.allowExtensions = settings.isExtensionAllowed();
// ensure it's a JNLP node
- if (root == null || !root.getNodeName().equals("jnlp"))
+ if (root == null || !root.getNodeName().equals("jnlp")) {
throw new ParseException(R("PInvalidRoot"));
+ }
// JNLP tag information
this.spec = getVersion(root, "spec", "1.0+");
@@ -154,7 +168,9 @@
}
if (this.codebase == null) // Codebase is overwritten if codebase was not specified in file or if parsing of it failed
+ {
this.codebase = codebase;
+ }
this.base = (this.codebase != null) ? this.codebase : base; // if codebase not specified use default codebase
fileLocation = getURL(root, "href", this.base);
@@ -165,6 +181,7 @@
/**
* Returns the file version.
+ *
* @return version of file
*/
public Version getFileVersion() {
@@ -173,6 +190,7 @@
/**
* Returns the file location.
+ *
* @return url of source file
*/
public URL getFileLocation() {
@@ -188,7 +206,7 @@
/**
* @return the specification version.
- *
+ *
*/
public Version getSpecVersion() {
return spec;
@@ -254,16 +272,15 @@
//
// This section loads the resources elements
//
-
/**
- * @return all of the ResourcesDesc elements under the specified
- * node (jnlp or j2se).
+ * @return all of the ResourcesDesc elements under the specified node (jnlp
+ * or j2se).
*
* @param parent the parent node (either jnlp or j2se)
* @param j2se true if the resources are located under a j2se or java node
* @throws ParseException if the JNLP file is invalid
*/
- List<ResourcesDesc> getResources(Node parent, boolean j2se)
+ public List<ResourcesDesc> getResources(Node parent, boolean j2se)
throws ParseException {
List<ResourcesDesc> result = new ArrayList<>();
Node resources[] = getChildNodes(parent, "resources");
@@ -285,15 +302,15 @@
* @param j2se true if the resources are located under a j2se or java node
* @throws ParseException if the JNLP file is invalid
*/
- private ResourcesDesc getResourcesDesc(Node node, boolean j2se) throws ParseException {
+ private ResourcesDesc getResourcesDesc(Node node, boolean j2se) throws ParseException {
boolean mainFlag = false; // if found a main tag
// create resources
- ResourcesDesc resources =
- new ResourcesDesc(file,
- getLocales(node),
- splitString(getAttribute(node, "os", null)),
- splitString(getAttribute(node, "arch", null)));
+ ResourcesDesc resources
+ = new ResourcesDesc(file,
+ getLocales(node),
+ splitString(getAttribute(node, "os", null)),
+ splitString(getAttribute(node, "arch", null)));
// step through the elements
Node child = node.getFirstChild();
@@ -301,18 +318,23 @@
String name = child.getNodeName();
// check for nativelib but no trusted environment
- if ("nativelib".equals(name))
- if (!isTrustedEnvironment())
+ if ("nativelib".equals(name)) {
+ if (!isTrustedEnvironment()) {
throw new ParseException(R("PUntrustedNative"));
+ }
+ }
if ("j2se".equals(name) || "java".equals(name)) {
- if (getChildNode(root, "component-desc") != null)
- if (strict)
+ if (getChildNode(root, "component-desc") != null) {
+ if (strict) {
throw new ParseException(R("PExtensionHasJ2SE"));
- if (!j2se)
+ }
+ }
+ if (!j2se) {
resources.addResource(getJRE(child));
- else
+ } else {
throw new ParseException(R("PInnerJ2SE"));
+ }
}
if ("jar".equals(name) || "nativelib".equals(name)) {
@@ -331,14 +353,17 @@
resources.addResource(jar);
}
- if ("extension".equals(name))
+ if ("extension".equals(name)) {
resources.addResource(getExtension(child));
+ }
- if ("property".equals(name))
+ if ("property".equals(name)) {
resources.addResource(getProperty(child));
+ }
- if ("package".equals(name))
+ if ("package".equals(name)) {
resources.addResource(getPackage(child));
+ }
child = child.getNextSibling();
}
@@ -385,9 +410,11 @@
boolean main = "true".equals(getAttribute(node, "main", "false"));
boolean lazy = "lazy".equals(getAttribute(node, "download", "eager"));
- if (nativeJar && main)
- if (strict)
+ if (nativeJar && main) {
+ if (strict) {
throw new ParseException(R("PNativeHasMain"));
+ }
+ }
return new JARDesc(location, version, part, lazy, main, nativeJar, true);
@@ -445,14 +472,15 @@
//
// This section loads the information elements
//
-
/**
* Make sure a title and vendor are present and nonempty and localized as
* best matching as possible for the JVM's current locale. Fallback to a
- * generalized title and vendor otherwise. If none is found, throw an exception.
+ * generalized title and vendor otherwise. If none is found, throw an
+ * exception.
*
- * Additionally prints homepage, description, title and vendor to stdout
- * if in Debug mode.
+ * Additionally prints homepage, description, title and vendor to stdout if
+ * in Debug mode.
+ *
* @throws RequiredElementException
*/
void checkForInformation() throws RequiredElementException {
@@ -462,30 +490,34 @@
String title = file.getTitle();
String vendor = file.getVendor();
- if (title == null || title.trim().isEmpty())
+ if (title == null || title.trim().isEmpty()) {
throw new MissingTitleException();
- else OutputController.getLogger().log("Acceptable title tag found, contains: " + title);
+ } else {
+ OutputController.getLogger().log("Acceptable title tag found, contains: " + title);
+ }
- if (vendor == null || vendor.trim().isEmpty())
+ if (vendor == null || vendor.trim().isEmpty()) {
throw new MissingVendorException();
- else OutputController.getLogger().log("Acceptable vendor tag found, contains: " + vendor);
+ } else {
+ OutputController.getLogger().log("Acceptable vendor tag found, contains: " + vendor);
+ }
}
/**
- * @return all of the information elements under the specified
- * node.
+ * @return all of the information elements under the specified node.
*
* @param parent the parent node (jnlp)
* @throws ParseException if the JNLP file is invalid
*/
- List<InformationDesc> getInfo(Node parent)
+ public List<InformationDesc> getInfo(Node parent)
throws ParseException {
List<InformationDesc> result = new ArrayList<>();
Node info[] = getChildNodes(parent, "information");
// ensure that there are at least one information section present
- if (info.length == 0)
+ if (info.length == 0) {
throw new MissingInformationException();
+ }
// create objects from the info sections
for (Node infoNode : info) {
@@ -501,7 +533,7 @@
* @param node the information node
* @throws ParseException if the JNLP file is invalid
*/
- InformationDesc getInformationDesc(Node node) throws ParseException {
+ InformationDesc getInformationDesc(Node node) throws ParseException {
List<String> descriptionsUsed = new ArrayList<>();
// locale
@@ -515,28 +547,36 @@
while (child != null) {
String name = child.getNodeName();
- if ("title".equals(name))
+ if ("title".equals(name)) {
addInfo(info, child, null, getSpanText(child, false));
- if ("vendor".equals(name))
+ }
+ if ("vendor".equals(name)) {
addInfo(info, child, null, getSpanText(child, false));
+ }
if ("description".equals(name)) {
String kind = getAttribute(child, "kind", "default");
- if (descriptionsUsed.contains(kind))
- if (strict)
+ if (descriptionsUsed.contains(kind)) {
+ if (strict) {
throw new ParseException(R("PTwoDescriptions", kind));
+ }
+ }
descriptionsUsed.add(kind);
addInfo(info, child, kind, getSpanText(child, false));
}
- if ("homepage".equals(name))
+ if ("homepage".equals(name)) {
addInfo(info, child, null, getRequiredURL(child, "href", base));
- if ("icon".equals(name))
+ }
+ if ("icon".equals(name)) {
addInfo(info, child, getAttribute(child, "kind", "default"), getIcon(child));
- if ("offline-allowed".equals(name))
+ }
+ if ("offline-allowed".equals(name)) {
addInfo(info, child, null, Boolean.TRUE);
+ }
if ("sharing-allowed".equals(name)) {
- if (strict && !allowExtensions)
+ if (strict && !allowExtensions) {
throw new ParseException(R("PSharing"));
+ }
addInfo(info, child, null, Boolean.TRUE);
}
if ("association".equals(name)) {
@@ -566,8 +606,9 @@
protected void addInfo(InformationDesc info, Node node, String mod, Object value) {
String modStr = (mod == null) ? "" : "-" + mod;
- if (node == null)
+ if (node == null) {
return;
+ }
info.addItem(node.getNodeName() + modStr, value);
}
@@ -592,22 +633,23 @@
//
// This section loads the security descriptor element
//
-
/**
- * @return the security descriptor element. If no security
- * element was specified in the JNLP file then a SecurityDesc
- * with applet permissions is returned.
+ * @return the security descriptor element. If no security element was
+ * specified in the JNLP file then a SecurityDesc with applet permissions is
+ * returned.
*
* @param parent the parent node
* @throws ParseException if the JNLP file is invalid
*/
- SecurityDesc getSecurity(Node parent) throws ParseException {
+ public SecurityDesc getSecurity(Node parent) throws ParseException {
Node nodes[] = getChildNodes(parent, "security");
// test for too many security elements
- if (nodes.length > 1)
- if (strict)
+ if (nodes.length > 1) {
+ if (strict) {
throw new ParseException(R("PTwoSecurity"));
+ }
+ }
Object type = SecurityDesc.SANDBOX_PERMISSIONS;
RequestedPermissionLevel requestedPermissionLevel = RequestedPermissionLevel.NONE;
@@ -633,16 +675,17 @@
}
/**
- * Returns whether the JNLP file requests a trusted execution
- * environment.
+ * Returns whether the JNLP file requests a trusted execution environment.
*/
private boolean isTrustedEnvironment() {
Node security = getChildNode(root, "security");
- if (security != null)
+ if (security != null) {
if (getChildNode(security, "all-permissions") != null
- || getChildNode(security, "j2ee-application-client-permissions") != null)
+ || getChildNode(security, "j2ee-application-client-permissions") != null) {
return true;
More information about the distro-pkg-dev
mailing list