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

io.github.mmm.code.api.CodePathElements Maven / Gradle / Ivy

There is a newer version: 0.9.10
Show newest version
/* 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 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