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

com.android.build.api.transform.TransformOutputProvider Maven / Gradle / Ivy

/*
 * Copyright (C) 2015 The Android Open Source Project
 *
 * 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 com.android.build.api.transform;

import com.android.annotations.NonNull;
import com.google.common.annotations.Beta;

import java.io.File;
import java.io.IOException;
import java.util.Set;

/**
 * The output of a transform.
 * 

* There is no direct access to a location to write. Instead, Transforms can ask to get the * location for given scopes, content-types and a format. *

* This API is non final and is subject to change. We are looking for feedback, and will * attempt to stabilize it in the 1.6 time frame. */ @Beta public interface TransformOutputProvider { /** * Delete all content. This is useful when running in non-incremental mode * @throws IOException */ void deleteAll() throws IOException; /** * Returns the location of content for a given set of Scopes, Content Types, and Format. *

* If the format is {@link Format#DIRECTORY} then the result is the file location of the * directory.
* If the format is {@link Format#JAR} then the result is a file representing the jar to create. *

* Non of the directories or files are created by querying this method, and there is * no checks regarding the existence of content in this location. *

* In case of incremental processing of removed files, it is safe to query the method to get * the location of the files to removed. * * @param name a unique name for the content. For a given set of scopes/types/format it must * be unique. * @param types the content types associated with this content. * @param scopes the scopes associated with this content. * @param format the format of the content. * @return the location of the content. */ @NonNull File getContentLocation(@NonNull String name, @NonNull Set types, @NonNull Set scopes, @NonNull Format format); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy