io.github.mmm.code.api.CodePathElements Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of mmm-code-api Show documentation
Show all versions of mmm-code-api Show documentation
The API to parse, analyze, transform and generate code.
/* Copyright (c) The m-m-m Team, Licensed under the Apache License, Version 2.0
* http://www.apache.org/licenses/LICENSE-2.0 */
package io.github.mmm.code.api;
import java.util.List;
import io.github.mmm.code.api.copy.CodeCopyMapper;
import io.github.mmm.code.api.copy.CodeNodeItemCopyable;
import io.github.mmm.code.api.node.CodeNodeItemContainerFlat;
import io.github.mmm.code.api.type.CodeType;
/**
* {@link CodeNodeItemContainerFlat} containing the {@link CodePathElement}s of a {@link CodePackage}.
*
* @author Joerg Hohwiller (hohwille at users.sourceforge.net)
* @since 1.0.0
*/
public interface CodePathElements extends CodeNodeItemContainerFlat, CodeNodeItemCopyable {
@Override
CodePackage getParent();
/**
* Attention:
* This method can trigger expensive classpath scanning (or filesystem traversal) on its first call.
*/
@Override
List extends CodePathElement> getDeclared();
/**
* @param simpleName the {@link CodePathElement#getSimpleName() simple name} of the requested {@link CodePathElement}.
* @return the {@link CodePathElement} from {@link #getDeclared() all items} with the given {@code name} or
* {@code null} if not found.
*/
CodePathElement get(String simpleName);
/**
* @param simpleName the {@link CodeFile#getSimpleName() simple name} of the requested {@link CodeFile}.
* @return the {@link CodeFile} with the given {@code name} or {@code null} if not found.
*/
CodeFile getFile(String simpleName);
/**
* @param path the {@link CodeName} to traverse.
* @return the traversed {@link CodeFile} or {@code null} if not found.
*/
CodeFile getFile(CodeName path);
/**
* Attention: This method is just a factory operation. It will not add the created {@link CodeFile}. Use
* {@link #getOrCreateFile(String)} instead to also add.
*
* @param simpleName the {@link CodeFile#getSimpleName() simple name} of the new {@link CodeFile}.
* @return a new {@link CodeFile} containing an empty top-level {@link CodeType} of the same name.
*/
CodeFile createFile(String simpleName);
/**
* @see #getOrCreateFile(CodeName, boolean)
* @param path the simple name or a relative {@link CodeName path} to the requested {@link CodeFile}.
* @return the {@link #getFile(String) existing} or {@link #createFile(String) newly created} and added
* {@link CodeFile}.
*/
default CodeFile getOrCreateFile(String path) {
return getOrCreateFile(getContext().parseName(path), true);
}
/**
* @param path the {@link CodeName} leading to the requested child relative to the {@link #getParent() package of this
* children}. Will typically be invoked on the {@link CodePackage#getChildren() children} of a
* {@link io.github.mmm.code.api.source.CodeSource#getRootPackage() root package} with a
* {@link io.github.mmm.code.api.item.CodeItemWithQualifiedName#getQualifiedName() qualified name} parsed via
* {@link io.github.mmm.code.api.source.CodeSource#parseName(String)}.
* @param add - {@code true} to add a newly created {@link CodeFile}, {@code false} otherwise.
* @return the {@link #getFile(String) existing} or {@link #createFile(String) newly created} {@link CodeFile}.
*/
CodeFile getOrCreateFile(CodeName path, boolean add);
/**
* @param simpleName the {@link CodePackage#getSimpleName() simple name} of the requested {@link CodePackage}.
* @return the {@link CodePackage} with the given {@code name} or {@code null} if not found.
*/
CodePackage getPackage(String simpleName);
/**
* @param path the {@link CodeName} leading to the requested child relative to the {@link #getParent() package of this
* children}. Will typically be invoked on the {@link CodePackage#getChildren() children} of a
* {@link io.github.mmm.code.api.source.CodeSource#getRootPackage() root package} with a
* {@link io.github.mmm.code.api.item.CodeItemWithQualifiedName#getQualifiedName() qualified name} parsed via
* {@link io.github.mmm.code.api.source.CodeSource#parseName(String)}.
* @return the traversed {@link CodePackage} or {@code null} if not found.
*/
CodePackage getPackage(CodeName path);
/**
* @param path the {@link CodeName} leading to the requested child relative to the {@link #getParent() package of this
* children}. Will typically be invoked on the {@link CodePackage#getChildren() children} of a
* {@link io.github.mmm.code.api.source.CodeSource#getRootPackage() root package} with a
* {@link io.github.mmm.code.api.item.CodeItemWithQualifiedName#getQualifiedName() qualified name} parsed via
* {@link io.github.mmm.code.api.source.CodeSource#parseName(String)}.
* @param add - {@code true} to add newly created packages, {@code false} otherwise.
* @return the traversed {@link CodePackage}. Has been created if it did not already exist.
*/
CodePackage getOrCreatePackage(CodeName path, boolean add);
/**
* @param path the simple name or a relative {@link CodeName path} to the requested {@link CodePackage}.
* @return the traversed {@link CodePackage}. Has been created and added if it did not already exist.
*/
default CodePackage getOrCreatePackage(String path) {
return getOrCreatePackage(getContext().parseName(path), true);
}
/**
* Attention: This method is just a factory operation. It will not add the created {@link CodePackage}.
* Use {@link #getOrCreatePackage(String)} instead to also add.
*
* @param simpleName the {@link CodePackage#getSimpleName() simple name} of the new {@link CodePackage}.
* @return a new empty {@link CodePackage}.
*/
CodePackage createPackage(String simpleName);
/**
* @param simpleName the {@link CodeType#getSimpleName() simple name} of the requested {@link CodeType}.
* @return the {@link CodeType} with the given {@code name} or {@code null} if not found.
*/
CodeType getType(String simpleName);
/**
* Attention: This method is just a factory operation. It will not add the {@link CodeFile} of the
* created {@link CodeType}. Use {@link #getOrCreateFile(String)} instead to also add and then call
* {@link CodeFile#getType()}.
*
* @param simpleName the {@link CodeType#getSimpleName() simple name} of the requested {@link CodeType}.
* @return the top-level {@link CodeType} that has been created together with its {@link CodeFile}.
* @see #createFile(String)
*/
CodeType createType(String simpleName);
/**
* Attention: This method is only for advanced usage. Whenever suitable prefer to use methods such as
* {@link #getOrCreatePackage(CodeName, boolean)} or {@link #getOrCreateFile(CodeName, boolean)} instead.
*
* @param child the {@link CodePathElement} to add as child.
*/
void add(CodePathElement child);
/**
* @param child the potential sub-{@link CodePackage package}.
* @return {@code true} if the given {@link CodePackage} is equal to the {@link #getParent() owning package} or is a
* {@link #getDeclared() direct} or {@link CodePackage#getParentPackage() indirect} sub-{@link CodePackage
* package} of this {@link CodePackage}, {@code false} otherwise.
*/
boolean containsPackage(CodePackage child);
/**
* @param child the potential sub-{@link CodePackage package}.
* @return {@code true} if the given {@link CodePackage} is a {@link #getDeclared() direct} or
* {@link CodePackage#getParentPackage() indirect} sub-{@link CodePackage package} of this
* {@link CodePackage}, {@code false} otherwise.
*/
boolean containsSubPackage(CodePackage child);
@Override
CodePathElements copy();
@Override
CodePathElements copy(CodeCopyMapper mapper);
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy