/*
* Copyright 2015-present Facebook, 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.facebook.buck.zip;
import com.facebook.buck.step.ExecutionContext;
import com.facebook.buck.step.Step;
import com.facebook.buck.step.StepExecutionResult;
import com.facebook.buck.util.immutables.BuckStyleStep;
import com.google.common.base.Preconditions;
import java.io.IOException;
import java.nio.file.Path;
import org.immutables.value.Value;
@Value.Immutable
@BuckStyleStep
abstract class AbstractZipScrubberStep implements Step {
@Value.Parameter
protected abstract Path getZipAbsolutePath();
@Value.Check
protected void check() {
Preconditions.checkArgument(
getZipAbsolutePath().isAbsolute(), "ZipScrubberStep must take an absolute path");
}
@Override
public String getShortName() {
return "zip-scrub";
}
@Override
public String getDescription(ExecutionContext context) {
return "zip-scrub " + getZipAbsolutePath();
}
@Override
public StepExecutionResult execute(ExecutionContext context) throws InterruptedException {
try {
ZipScrubber.scrubZip(getZipAbsolutePath());
} catch (RuntimeException e) {
context.logError(
e, "Error scrubbing non-deterministic metadata from %s", getZipAbsolutePath());
throw e;
} catch (IOException e) {
context.logError(
e, "Error scrubbing non-deterministic metadata from %s", getZipAbsolutePath());
return StepExecutionResult.ERROR;
}
return StepExecutionResult.SUCCESS;
}
}