001/*
002 * Copyright (C) 2022 - 2025, the original author or authors.
003 *
004 * Licensed under the Apache License, Version 2.0 (the "License");
005 * you may not use this file except in compliance with the License.
006 * You may obtain a copy of the License at
007 *
008 *    http://www.apache.org/licenses/LICENSE-2.0
009 *
010 * Unless required by applicable law or agreed to in writing, software
011 * distributed under the License is distributed on an "AS IS" BASIS,
012 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
013 * See the License for the specific language governing permissions and
014 * limitations under the License.
015 */
016package io.github.ascopes.jct.containers;
017
018import io.github.ascopes.jct.workspaces.PathRoot;
019import java.util.List;
020import javax.tools.JavaFileManager.Location;
021
022/**
023 * A base definition for an output-oriented container group.
024 *
025 * <p>These can behave as if they are module-oriented, or non-module-oriented.
026 * It is down to the implementation to mediate access between modules and their files.
027 *
028 * <p>Operations on modules should first {@link #getModule(String) get} or
029 * {@link #getOrCreateModule(String) create} the module, and then operate on that sub-container
030 * group. Operations on non-module packages should operate on this container group directly.
031 *
032 * <p>Note that each container group will usually only support one package container group
033 * in the outputs. This is due to the JSR-199 API not providing a method for specifying which output
034 * location to write files to for legacy-style packages.
035 *
036 * @author Ashley Scopes
037 * @since 0.0.1
038 */
039public interface OutputContainerGroup extends PackageContainerGroup, ModuleContainerGroup {
040
041  /**
042   * {@inheritDoc}
043   *
044   * <p>Note that this implementation will only ever allow a single container in the package
045   * container groups. If a container is already present, then an exception will be thrown.
046   *
047   * @param path the path to add.
048   * @throws IllegalStateException if a package already exists in this location.
049   */
050  @Override
051  void addPackage(PathRoot path);
052
053  /**
054   * {@inheritDoc}
055   *
056   * <p>Note that this implementation will only ever allow a single container in the package
057   * container groups. If a container is already present, then an exception will be thrown.
058   *
059   * @param container the container to add.
060   * @throws IllegalStateException if a package already exists in this location.
061   */
062  @Override
063  void addPackage(Container container);
064
065  /**
066   * Get the output-oriented location.
067   *
068   * @return the output-oriented location.
069   */
070  @Override
071  Location getLocation();
072
073  /**
074   * {@inheritDoc}
075   *
076   * <p>Note that this implementation will only ever return one container in the list due to
077   * JSR-199 limitations.
078   *
079   * @return the list containing the package container, if it exists. Otherwise, an empty list is
080   *     returned instead.
081   */
082  @Override
083  List<Container> getPackages();
084}