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.workspaces;
017
018import java.io.Closeable;
019import java.io.IOException;
020import java.util.List;
021
022/**
023 * Base interface for a managed directory, including the interfaces for creating fluent-style
024 * builders.
025 *
026 * @author Ashley Scopes
027 * @since 0.0.1
028 */
029public interface ManagedDirectory extends DirectoryBuilder, PathRoot {
030
031  /**
032   * Method that returns the object it is called upon to enable creating fluent-language builders.
033   *
034   * <p>For example:
035   *
036   * <pre><code>
037   *   thisDirectory
038   *       .createFile("foo", "bar", "baz.txt").withContents(...)
039   *       .and().also()
040   *       .createFile("foo", "bar", "bork.txt").withContents(...);
041   * </code></pre>
042   *
043   * @return this object.
044   * @see #and
045   * @see #then
046   */
047  default ManagedDirectory also() {
048    return this;
049  }
050
051  /**
052   * Method that returns the object it is called upon to enable creating fluent-language builders.
053   *
054   * <p>For example:
055   *
056   * <pre><code>
057   *   thisDirectory
058   *       .createFile("foo", "bar", "baz.txt").withContents(...)
059   *       .and()
060   *       .createFile("foo", "bar", "bork.txt").withContents(...);
061   * </code></pre>
062   *
063   * @return this object.
064   * @see #also
065   * @see #then
066   */
067  default ManagedDirectory and() {
068    return this;
069  }
070
071  /**
072   * Close the resource.
073   *
074   * <p>This specifically is not provided by implementing {@link Closeable} as to prevent IDEs
075   * giving false linting errors about not closing resources.
076   *
077   * <p>Users should not need to call this directly if they are using instances produced from a
078   * {@link Workspace} implementation.
079   *
080   * @throws IOException if an IO exception occurs.
081   */
082  void close() throws IOException;
083
084  /**
085   * Create a directory builder for the given path in this RAM file system.
086   *
087   * <p>Examples:
088   *
089   * <pre><code>
090   *   // Using platform-specific separators.
091   *   dir.createDirectory("foo/bar/baz")...;
092   *
093   *   // Letting JCT infer the correct path separators to use (recommended).
094   *   dir.createDirectory("foo", "bar", "baz")...;
095   * </code></pre>
096   *
097   * @param fragments the parts of the path.
098   * @return the directory builder.
099   * @throws IllegalArgumentException if no path fragments are provided.
100   * @throws NullPointerException     if any of the path fragments are {@code null}.
101   */
102  default DirectoryBuilder createDirectory(String... fragments) {
103    return createDirectory(List.of(fragments));
104  }
105
106  /**
107   * Create a directory builder for the given path in this RAM file system.
108   *
109   * <p>Examples:
110   *
111   * <pre><code>
112   *   // Using platform-specific separators.
113   *   dir.createDirectory(List.of("foo/bar/baz"))...;
114   *
115   *   // Letting JCT infer the correct path separators to use (recommended).
116   *   dir.createDirectory(List.of("foo", "bar", "baz"))...;
117   * </code></pre>
118   *
119   * @param fragments the parts of the path.
120   * @return the directory builder.
121   * @throws IllegalArgumentException if no path fragments are provided.
122   * @throws NullPointerException     if any of the path fragments are {@code null}.
123   * @since 4.0.0
124   */
125  DirectoryBuilder createDirectory(List<String> fragments);
126
127  /**
128   * Create a file builder for the given path in this RAM file system.
129   *
130   * <pre><code>
131   *   // Using platform-specific separators.
132   *   dir.createFile("foo/bar/baz.txt")...;
133   *
134   *   // Letting JCT infer the correct path separators to use (recommended).
135   *   dir.createFile("foo", "bar", "baz.txt")...;
136   * </code></pre>
137   *
138   * @param fragments the parts of the path.
139   * @return the file builder.
140   * @throws IllegalArgumentException if no path fragments are provided.
141   * @throws NullPointerException     if any of the path fragments are {@code null}.
142   */
143  default FileBuilder createFile(String... fragments) {
144    return createFile(List.of(fragments));
145  }
146
147  /**
148   * Create a file builder for the given path in this RAM file system.
149   *
150   * <pre><code>
151   *   // Using platform-specific separators.
152   *   dir.createFile(List.of("foo/bar/baz.txt"))...;
153   *
154   *   // Letting JCT infer the correct path separators to use (recommended).
155   *   dir.createFile(List.of("foo", "bar", "baz.txt"))...;
156   * </code></pre>
157   *
158   * @param fragments the parts of the path.
159   * @return the file builder.
160   * @throws IllegalArgumentException if no path fragments are provided.
161   * @throws NullPointerException     if any of the path fragments are {@code null}.
162   * @since 4.0.0
163   */
164  FileBuilder createFile(List<String> fragments);
165
166  /**
167   * Get the identifying name of the temporary file system.
168   *
169   * @return the identifier string.
170   */
171  String getName();
172
173  /**
174   * Method that returns the object it is called upon to enable creating fluent-language builders.
175   *
176   * <p>For example:
177   *
178   * <pre><code>
179   *   thisDirectory
180   *       .createFile("foo", "bar", "baz.txt").withContents(...)
181   *       .and().then()
182   *       .createFile("foo", "bar", "bork.txt").withContents(...);
183   * </code></pre>
184   *
185   * @return this object.
186   * @see #and
187   * @see #also
188   */
189  default ManagedDirectory then() {
190    return this;
191  }
192
193}