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

org.mozilla.javascript.ast.XmlLiteral Maven / Gradle / Ivy

Go to download

Rhino is an open-source implementation of JavaScript written entirely in Java. It is typically embedded into Java applications to provide scripting to end users.

The newest version!
/* -*- Mode: java; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 4 -*-
 *
 * 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/. */

package org.mozilla.javascript.ast;

import java.util.ArrayList;
import java.util.List;
import org.mozilla.javascript.Token;

/**
 * AST node for an E4X (Ecma-357) embedded XML literal. Node type is {@link Token#XML}. The parser
 * generates a simple list of strings and expressions. In the future we may parse the XML and
 * produce a richer set of nodes, but for now it's just a set of expressions evaluated to produce a
 * string to pass to the {@code XML} constructor function.
 */
public class XmlLiteral extends AstNode {

    private List fragments = new ArrayList<>();

    {
        type = Token.XML;
    }

    public XmlLiteral() {}

    public XmlLiteral(int pos) {
        super(pos);
    }

    public XmlLiteral(int pos, int len) {
        super(pos, len);
    }

    /** Returns fragment list - a list of expression nodes. */
    public List getFragments() {
        return fragments;
    }

    /**
     * Sets fragment list, removing any existing fragments first. Sets the parent pointer for each
     * fragment in the list to this node.
     *
     * @param fragments fragment list. Replaces any existing fragments.
     * @throws IllegalArgumentException} if {@code fragments} is {@code null}
     */
    public void setFragments(List fragments) {
        assertNotNull(fragments);
        this.fragments.clear();
        for (XmlFragment fragment : fragments) addFragment(fragment);
    }

    /**
     * Adds a fragment to the fragment list. Sets its parent to this node.
     *
     * @throws IllegalArgumentException} if {@code fragment} is {@code null}
     */
    public void addFragment(XmlFragment fragment) {
        assertNotNull(fragment);
        fragments.add(fragment);
        fragment.setParent(this);
    }

    @Override
    public String toSource(int depth) {
        StringBuilder sb = new StringBuilder(250);
        for (XmlFragment frag : fragments) {
            sb.append(frag.toSource(0));
        }
        return sb.toString();
    }

    /** Visits this node, then visits each child fragment in lexical order. */
    @Override
    public void visit(NodeVisitor v) {
        if (v.visit(this)) {
            for (XmlFragment frag : fragments) {
                frag.visit(v);
            }
        }
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy