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

io.github.mmm.code.api.source.CodeSourceDescriptor 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.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