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

com.erigir.wrench.drigo.processor.AbstractFileProcessor Maven / Gradle / Ivy

There is a newer version: 2.2.16+16
Show newest version
package com.erigir.wrench.drigo.processor;

import com.erigir.wrench.drigo.DrigoException;
import com.erigir.wrench.drigo.DrigoResults;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import java.io.File;
import java.io.IOException;

/**
 * Copyright 2014 Christopher Weiss
 * 

* 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. **/ public abstract class AbstractFileProcessor implements FileProcessor { public boolean process(File src, DrigoResults results) { log().info("Applying {} to {}", getClass().getSimpleName(), src.getName()); try { if (!src.exists() || !src.isFile()) { throw new DrigoException(src + " doesnt exist or isnt a file"); } File tmp = File.createTempFile("tst", "tst"); boolean rval = innerProcess(src, tmp, results); if (rval) { logDeltaIfExists(src, tmp); src.delete(); tmp.renameTo(src); } else { tmp.delete(); } return rval; } catch (IOException ioe) { throw new DrigoException("Process failure on :" + src, ioe); } } /** * Return false if the file was modified * @param src File to read from to process * @param dst File to write the results of the process to * @param results DrigoResults object to collect any processing metadata * @return boolean true if anything changed, false otherwise * @throws IOException on failure to read/write files */ public abstract boolean innerProcess(File src, File dst, DrigoResults results) throws IOException; public void logDeltaIfExists(File src, File dst) throws IOException { long srcL = src.length(); long dstL = dst.length(); long delta = Math.abs(dstL - srcL); int pct = (int) (100.0 * ((double) delta / (double) srcL)); if (srcL != dstL) { log().info("Proc " + getClass().getSimpleName() + " mod file " + src.getName() + " from " + srcL + " to " + dstL + " (" + delta + " bytes " + pct + "%)"); } } public Logger log() { return LoggerFactory.getLogger(getClass()); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy