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.UncheckedIOException; 019import java.net.URI; 020import java.net.URL; 021import java.nio.file.Path; 022import org.jspecify.annotations.Nullable; 023 024/** 025 * A path-like object that can provide a {@link Path Java NIO Path}. 026 * 027 * <p>This enables wrapping various implementations and providers of {@link Path} objects 028 * in a translucent façade that enables representing paths in a hierarchical format. 029 * 030 * @author Ashley Scopes 031 * @since 0.0.1 032 */ 033@SuppressWarnings("unused") 034public interface PathRoot { 035 036 /** 037 * Convert the given path root into a JAR and return the byte contents of the JAR. 038 * 039 * <p>You can use this to create JAR files from existing path roots, if you want to package 040 * some compiled outputs into a JAR to use them as inputs to another build. 041 * 042 * @return the byte contents of the JAR. 043 * @throws UncheckedIOException if the JAR cannot be created. 044 * @throws UnsupportedOperationException if the operation is not supported. 045 * @since 0.4.0 046 */ 047 byte[] asJar(); 048 049 /** 050 * Determine if two path roots are equivalent. If the provided object is {@code null} or not an 051 * instance of a {@link PathRoot}, then this will return {@code false} unless otherwise 052 * specified. 053 * 054 * @param other the object to compare with. 055 * @return {@code true} if semantically equal, or {@code false} otherwise. 056 */ 057 @Override 058 boolean equals(@Nullable Object other); 059 060 /** 061 * Determine the hash-code for the object. 062 * 063 * @return the hash code. 064 */ 065 @Override 066 int hashCode(); 067 068 /** 069 * Get the {@link Path Java NIO Path} for this path-like object. 070 * 071 * @return the path. 072 * @see #getUri() 073 * @see #getUrl() 074 */ 075 Path getPath(); 076 077 /** 078 * Get a URI representation of this path-like object. 079 * 080 * @return the URI. 081 * @see #getUrl() 082 * @see #getPath() 083 */ 084 URI getUri(); 085 086 /** 087 * Get a URL representation of this path-like object. 088 * 089 * @return the URL. 090 * @see #getUri() 091 * @see #getPath() 092 */ 093 URL getUrl(); 094 095 /** 096 * Get the parent path root, if there is one. 097 * 098 * @return the parent path root, or {@code null} if no parent root exists. 099 */ 100 @Nullable 101 PathRoot getParent(); 102}