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

src.main.lombok.ast.Node Maven / Gradle / Ivy

Go to download

This is a very small fork of lombok.ast as some Android tools needed a few modifications. The normal repository for lombok.ast is here https://github.com/rzwitserloot/lombok.ast and our changes for 0.2.3 are in this pull request: https://github.com/rzwitserloot/lombok.ast/pull/8

The newest version!
/*
 * Copyright (C) 2010 The Project Lombok Authors.
 * 
 * Permission is hereby granted, free of charge, to any person obtaining a copy
 * of this software and associated documentation files (the "Software"), to deal
 * in the Software without restriction, including without limitation the rights
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 * copies of the Software, and to permit persons to whom the Software is
 * furnished to do so, subject to the following conditions:
 * 
 * The above copyright notice and this permission notice shall be included in
 * all copies or substantial portions of the Software.
 * 
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
 * THE SOFTWARE.
 */
package lombok.ast;

import java.util.List;

public interface Node {
	/**
	 * Returns {@code true} if this node is generated (not actually present in the source).
	 */
	boolean isGenerated();
	
	/**
	 * Returns the node that is responsible for generating this node. Returns {@code null} if this node is not generated.
	 */
	Node getGeneratedBy();
	
	boolean hasParent();
	
	List getChildren();
	
	/**
	 * If the provided child node is a child of this node, the child/parent link will be deleted. The replacement node,
	 * if it is non-null, will take its place, and a new child/parent link will be created between this node and the replacement.
	 * 
	 * @return {@code true} if {@code child} was indeed a direct child of this node (it will have been replaced).
	 * @throws AstException If the replacement is of the wrong type and the location for the replacement does not allow off-type assignments,
	 *    which is true for those nodes that only have an {@code astName()} method and not a {@code rawName()} method.
	 */
	boolean replaceChild(Node child, Node replacement) throws AstException;
	
	/**
	 * If the provided child node is a child of this node, the child/parent link will be deleted. The child's parentage is set to unparented,
	 * and whichever property in this node is linking to the child is cleared. If child is not a child of this node, nothing happens.
	 * 
	 * @see #unparent()
	 * @return {@code true} if {@code child} was indeed a direct child of this node (it will have been detached).
	 */
	boolean detach(Node child);
	
	/**
	 * Replaces this node with the replacement.
	 * 
	 * @return {@code true} if the node was indeed replaced. Replacement fails if this node has no parent.
	 * @throws AstException If the replacement is of the wrong type and the location for the replacement does not allow off-type assignments,
	 *    which is true for those nodes that only have an {@code astName()} method and not a {@code rawName()} method.
	 */
	boolean replace(Node replacement) throws AstException;
	
	/**
	 * Severs the child/parent link between this node and its parent. This node's parentage will be set to unparented, and whichever property
	 * in the parent node is linking to this node is cleared. If this node is already unparented nothing happens.
	 * 
	 * @see #detach(Node)
	 */
	void unparent();
	
	Node setPosition(Position position);
	
	void accept(AstVisitor visitor);
	
	Node copy();
	
	String toString();
	
	Node getParent();
	
	Position getPosition();
	
	Node addMessage(Message message);
	
	boolean hasMessage(String key);
	
	List getMessages();
	
	/**
	 * Gets the associated "native" node. If this Lombok AST was created as
	 * a transformation from another AST, such as the ECJ one, the corresponding
	 * ECJ node can be stored here. This can be used by the {@link PositionFactory}
	 * to lazily compute positions, or by a type resolver to perform type resolution
	 * also using the native data structures.
	 *
	 * @return the corresponding native node, or null if not set
	 */
	Object getNativeNode();
	
	/**
	 * Sets the associated "native" node. See {@link #getNativeNode()} for details.
	 *
	 * @param node the native node to associate with this Lombok AST node
	 */
	void setNativeNode(Object node);
	
	/**
	 * Gets the position factory associated with this node. See
	 * {@link #setPositionFactory(PositionFactory)} for details
	 *
	 * @return the position factory, or null if not set
	 */
	PositionFactory getPositionFactory();
	
	/**
	 * Sets the {@link PositionFactory} associated with nodes of this type.
	 * This allows the {@link #getPosition()} method to lazily create {@link Position}
	 * objects from the {@link #getNativeNode()} instances. The native nodes
	 * can be used for other purposes too, such as type resolution, but the
	 * position factory is stored directly on the node such that it can make
	 * the {@link #getPosition()} method use it transparently without the client
	 * needing to pass the node to an external helper
	 *
	 * @param factory the factory to use to get positions for the current node
	 */
	void setPositionFactory(PositionFactory factory);
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy