depot/third_party/copybara/java/com/google/copybara/Transformation.java
Default email dfee7b6196 Project import generated by Copybara.
GitOrigin-RevId: b578e69f18a543889ded9c57a8f0dffacdb103d8
2020-05-15 16:19:19 -04:00

70 lines
2.4 KiB
Java

/*
* Copyright (C) 2016 Google Inc.
*
* 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.google.copybara;
import com.google.copybara.exception.ValidationException;
import com.google.devtools.build.lib.skylarkinterface.StarlarkBuiltin;
import com.google.devtools.build.lib.skylarkinterface.StarlarkDocumentationCategory;
import com.google.devtools.build.lib.syntax.Location;
import com.google.devtools.build.lib.syntax.StarlarkValue;
import java.io.IOException;
/** Interface implemented by all source code transformations. */
@StarlarkBuiltin(
name = "transformation",
doc = "A transformation to the workdir",
category = StarlarkDocumentationCategory.TOP_LEVEL_TYPE,
documented = false)
public interface Transformation extends StarlarkValue {
/**
* Transforms the files inside the checkout dir specified by {@code work}.
*
* @throws IOException if an error occur during the access to the files
* @throws ValidationException if an error attributable to the user happened
*/
void transform(TransformWork work) throws IOException, ValidationException;
/**
* Returns a transformation which runs this transformation in reverse.
*
* @throws NonReversibleValidationException if the transform is not reversible
*/
Transformation reverse() throws NonReversibleValidationException;
/**
* Return a high level description of what the transform is doing. Note that this should not be
* {@link #toString()} method but something more user friendly.
*/
String describe();
/**
* Starlark location of the transformation.
*/
default Location location() {
return Location.BUILTIN;
}
default boolean canJoin(Transformation transformation) {
return false;
}
default Transformation join(Transformation next) {
throw new IllegalStateException(String.format(
"Unexpected join call for %s and %s", this, next));
}
}