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

com.caoccao.javet.values.IV8Value Maven / Gradle / Ivy

Go to download

Javet is Java + V8 (JAVa + V + EighT). It is an awesome way of embedding Node.js and V8 in Java.

There is a newer version: 4.0.0
Show newest version
/*
 * Copyright (c) 2021-2024. caoccao.com Sam Cao
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package com.caoccao.javet.values;

import com.caoccao.javet.exceptions.JavetException;
import com.caoccao.javet.interfaces.IJavetClosable;
import com.caoccao.javet.interop.IV8Cloneable;
import com.caoccao.javet.interop.V8Runtime;
import com.caoccao.javet.values.primitive.V8ValueNull;
import com.caoccao.javet.values.primitive.V8ValueUndefined;

/**
 * The interface V8 value.
 *
 * @since 0.7.0
 */
public interface IV8Value extends IJavetClosable, IV8Cloneable {
    /**
     * A simulation of the JS if (variable)
     *
     * @return true : yes, false : no
     * @throws JavetException the javet exception
     * @since 3.0.4
     */
    default boolean asBoolean() throws JavetException {
        // All objects become true.
        return true;
    }

    /**
     * As double.
     *
     * @return the double value
     * @throws JavetException the javet exception
     * @since 3.0.4
     */
    default double asDouble() throws JavetException {
        return asInt();
    }

    /**
     * As int.
     *
     * @return the int value
     * @throws JavetException the javet exception
     * @since 3.0.4
     */
    default int asInt() throws JavetException {
        return 0;
    }

    /**
     * As long.
     *
     * @return the long value
     * @throws JavetException the javet exception
     * @since 3.0.4
     */
    default long asLong() throws JavetException {
        return asInt();
    }

    /**
     * As string.
     *
     * @return the string value
     * @throws JavetException the javet exception
     * @since 3.0.4
     */
    default String asString() throws JavetException {
        return toString();
    }

    /**
     * Equals.
     * 

* The behavior is different from JS behavior but is the same as Java behavior. * * @param v8Value the V8 value * @return the boolean * @throws JavetException the javet exception * @since 0.7.2 */ boolean equals(V8Value v8Value) throws JavetException; /** * Gets V8 runtime. * * @return the V8 runtime * @since 0.9.1 */ V8Runtime getV8Runtime(); /** * Is null. * * @return true : null, false : not null * @since 0.7.2 */ default boolean isNull() { return this instanceof V8ValueNull; } /** * Is null or undefined. * * @return true : null or undefined, false : not null and not undefined * @since 0.8.4 */ default boolean isNullOrUndefined() { return isNull() || isUndefined(); } /** * Is undefined. * * @return true : undefined, false : not undefined * @since 0.7.2 */ default boolean isUndefined() { return this instanceof V8ValueUndefined; } /** * Same value. *

* The behavior is different from JS behavior but is the same as Java behavior. * * @param v8Value the V8 value * @return true : same, false : different * @throws JavetException the javet exception * @since 0.7.2 */ boolean sameValue(V8Value v8Value) throws JavetException; /** * Strict equals. *

* The behavior is different from JS behavior but is the same as Java behavior. * * @param v8Value the V8 value * @return true : strict equals, false : different * @throws JavetException the javet exception * @since 0.7.2 */ boolean strictEquals(V8Value v8Value) throws JavetException; }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy