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

org.gradle.api.resources.TextResourceFactory Maven / Gradle / Ivy

/*
 * Copyright 2014 the original author or authors.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package org.gradle.api.resources;

/**
 * Creates {@code TextResource}s backed by sources such as strings, files, and archive entries.
 *
 * 

Example usages: * *

 * def sourcedFromString = resources.text.fromString("some text content")
 *
 * def sourcedFromFile = resources.text.fromFile("path/to/file.txt")
 *
 * task someTask {} // assumption: produces a text file and declares it as output
 * def sourcedFromTask = resources.text.fromFile(someTask)
 *
 * def sourcedFromArchiveEntry =
 *   resources.text.fromArchiveEntry("path/to/archive.zip", "path/to/archive/entry.txt")
 *
 * configurations { someConfig } // assumption: contains a single archive
 * def sourcedFromConfiguration =
 *   resources.text.fromArchiveEntry(configurations.someConfig, "path/to/archive/entry.txt")
 *
 * def sourceFromUri = resources.text.fromUri("https://example.com/resource")
 *
 * def sourceFromInsecureUri = resources.text.fromInsecureUri("http://example.com/resource")
 * 
* * File based factory methods optionally accept a character encoding. If no encoding is specified, * the platform's default encoding is used. * * @since 2.2 */ public interface TextResourceFactory { /** * Creates a text resource backed by the given string. * * @param string a string * @return a text resource backed by the given string */ TextResource fromString(String string); /** * Creates a text resource backed by the given file. * * @param file a text file evaluated as per {@link org.gradle.api.Project#files(Object...)} * @param charset the file's character encoding (e.g. {@code "utf-8"}) * @return a text resource backed by the given file */ TextResource fromFile(Object file, String charset); /** * Same as {@code fromFile(file, Charset.defaultCharset())}. * * @see #fromFile(Object, String) */ TextResource fromFile(Object file); /** * Creates a text resource backed by the archive entry at the given path within the given archive. * The archive format is determined based on the archive's file extension. If the archive format * is not supported or cannot be determined, any attempt to access the resource will fail with an exception. * * @param archive an archive file evaluated as per {@link org.gradle.api.Project#files(Object...)} * @param entryPath the path to an archive entry * @param charset the archive entry's character encoding (e.g. {@code "utf-8"}) * * @return a text resource backed by the archive entry at the given path within the given archive */ TextResource fromArchiveEntry(Object archive, String entryPath, String charset); /** * Same as {@code fromArchiveEntry(archive, path, Charset.defaultCharset().name())}. */ TextResource fromArchiveEntry(Object archive, String path); /** * Creates a text resource backed by the given uri. * * @param uri a URI as evaluated by {@link org.gradle.api.Project#uri(Object)} * * @return a text resource backed by the given uri * @since 4.8 */ TextResource fromUri(Object uri); /** * Creates a text resource backed by the given uri. * * NOTE: This method allows insecure protocols (like HTTP) to be used. Only use this method if you're comfortable with the dangers. * * @param uri a URI as evaluated by {@link org.gradle.api.Project#uri(Object)} * * @return a text resource backed by the given uri * @since 6.0 * @see #fromUri(Object) */ TextResource fromInsecureUri(Object uri); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy