All Downloads are FREE. Search and download functionalities are using the official Maven repository.

net.sf.saxon.s9api.XdmExternalObject Maven / Gradle / Ivy

There is a newer version: 12.5
Show newest version
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
// Copyright (c) 2018-2022 Saxonica Limited
// This Source Code Form is subject to the terms of the Mozilla Public License, v. 2.0.
// If a copy of the MPL was not distributed with this file, You can obtain one at http://mozilla.org/MPL/2.0/.
// This Source Code Form is "Incompatible With Secondary Licenses", as defined by the Mozilla Public License, v. 2.0.
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

package net.sf.saxon.s9api;

import net.sf.saxon.value.AnyExternalObject;
import net.sf.saxon.value.ObjectValue;

/**
 * The class XdmExternalObject represents an XDM item that wraps an external (Java or .NET) object.
 * As such, it is outside the scope of the XDM specification (but permitted as an extension).
 * 

In releases prior to 9.5, external objects in Saxon were represented as atomic values. From * 9.5 they are represented as a fourth kind of item, alongside nodes, atomic values, and functions.

*/ public class XdmExternalObject extends XdmItem { /** * Create an XdmExternalObject that wraps a supplied Java object * @param value the supplied Java object. Must not be null. * @throws NullPointerException if the supplied value is null. */ public XdmExternalObject(Object value) { super(value instanceof AnyExternalObject ? (AnyExternalObject)value : new ObjectValue<>(value)); } /** * Get the wrapped Java object * * @return the wrapped object */ public Object getExternalObject() { return ((AnyExternalObject) getUnderlyingValue()).getWrappedObject(); } /** * Get the result of converting the external value to a string. * @return the result of applying toString() to the wrapped external object. */ public String toString() { return getExternalObject().toString(); } /** * Compare two external objects for equality. Two instances of {@code XdmExternalObject} are equal * if the Java objects that they wrap are equal. * @param other the object to be compared * @return true if the other object is an {@code XdmExternalObject} and the two wrapped objects * are equal under the {@code equals()} method. */ public boolean equals(Object other) { return other instanceof XdmExternalObject && getUnderlyingValue().equals(((XdmExternalObject)other).getUnderlyingValue()); } /** * Return a hash code for the object. This respects the semantics of {@link #equals(Object)}; * @return a suitable hash code */ public int hashCode() { return getUnderlyingValue().hashCode(); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy