io.github.mmm.code.api.source.CodeSourceDescriptor 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.source;
/**
* Descriptor with details of a {@link CodeSource}.
*
* @see CodeSource#getDescriptor()
*
* @author Joerg Hohwiller (hohwille at users.sourceforge.net)
* @since 1.0.0
*/
public interface CodeSourceDescriptor {
/** The undefined {@link #getVersion() version}. */
String VERSION_UNDEFINED = "undefined";
/**
* @return the unique ID of this source. E.g. "«{@link #getGroupId() groupId}»:«{@link #getArtifactId()
* artifactId}»:«{@link #getVersion() version}»" (GAV coordinates) for a maven project. May be the
* {@link CodeSource}-{@link CodeSource#getId() ID} if no other information is available.
*/
String getId();
/**
* @return the group ID of the {@link CodeSource} or {@code null} if undefined.
*/
String getGroupId();
/**
* @return the artifact ID of the {@link CodeSource}. Never {@code null}.
*/
String getArtifactId();
/**
* @return the version of the {@link CodeSource} if available or {@link #VERSION_UNDEFINED}.
*/
String getVersion();
/**
* @return the optional scope of the {@link CodeSource} (e.g. "compile" for sub-source "src/main/java" or
* "test" for sub-source "src/test/java"). May be {@code null} (default for entire project).
*/
String getScope();
/**
* @return the base URL of the JavaDoc for this source. May be {@code null} if unavailable.
*/
String getDocUrl();
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy