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 io.github.ascopes.jct.compilers.JctCompiler; 019import io.github.ascopes.jct.utils.UtilityClass; 020import io.github.ascopes.jct.workspaces.impl.WorkspaceImpl; 021 022/** 023 * Helpers to create new workspaces. 024 * 025 * @author Ashley Scopes 026 * @since 0.0.1 027 */ 028public final class Workspaces extends UtilityClass { 029 030 private Workspaces() { 031 // Do nothing. 032 } 033 034 /** 035 * Create a new default workspace instance using the default path strategy. 036 * 037 * <p>This workspace must be closed after use. Ideally, you should use a try-with-resources 038 * to achieve this. Failing to do this will lead to resources being leaked and tests not being 039 * cleared up correctly. 040 * 041 * <p>The workspace can be passed to {@link JctCompiler#compile(Workspace)} to run the compiler 042 * across this workspace of code. 043 * 044 * <p>For example: 045 * 046 * <pre><code> 047 * try (var workspace = Workspaces.newWorkspace()) { 048 * workspace 049 * .createSourcePathPackage() 050 * .copyContentsFrom("src", "test", "resources", "test-data"); 051 * 052 * var compilation = someCompiler.compile(workspace); 053 * 054 * assertThat(compilation).isSuccessful(); 055 * } 056 * </code></pre> 057 * 058 * @return the workspace. 059 */ 060 public static Workspace newWorkspace() { 061 return newWorkspace(PathStrategy.defaultStrategy()); 062 } 063 064 /** 065 * Create a new default workspace instance using the given path strategy. 066 * 067 * <p>This workspace must be closed after use. Ideally, you should use a try-with-resources 068 * to achieve this. Failing to do this will lead to resources being leaked and tests not being 069 * cleared up correctly. 070 * 071 * <p>The workspace can be passed to {@link JctCompiler#compile(Workspace)} to run the compiler 072 * across this workspace of code. 073 * 074 * <p>For example: 075 * 076 * <pre><code> 077 * try (var workspace = Workspaces.newWorkspace(PathStrategy.TEMP_DIRECTORIES)) { 078 * workspace 079 * .createSourcePathPackage() 080 * .copyContentsFrom("src", "test", "resources", "test-data"); 081 * 082 * var compilation = someCompiler.compile(workspace); 083 * 084 * assertThat(compilation).isSuccessful(); 085 * } 086 * </code></pre> 087 * 088 * @param pathStrategy the path strategy to use. 089 * @return the workspace. 090 */ 091 public static Workspace newWorkspace(PathStrategy pathStrategy) { 092 return new WorkspaceImpl(pathStrategy); 093 } 094}