001 /**
002 * Copyright 2010-2013 The Kuali Foundation
003 *
004 * Licensed under the Educational Community License, Version 2.0 (the "License");
005 * you may not use this file except in compliance with the License.
006 * You may obtain a copy of the License at
007 *
008 * http://www.opensource.org/licenses/ecl2.php
009 *
010 * Unless required by applicable law or agreed to in writing, software
011 * distributed under the License is distributed on an "AS IS" BASIS,
012 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
013 * See the License for the specific language governing permissions and
014 * limitations under the License.
015 */
016 package org.kuali.common.jdbc.convert;
017
018 import java.io.File;
019 import java.util.List;
020
021 /**
022 * This post conversion processor deletes each file used as input for the conversion, and renames the newly created file by removing the
023 * ".converted" extension
024 *
025 * @author andrewlubbers
026 */
027 public class ReplaceWithConvertedProcessor implements PostConversionProcessor {
028 @Override
029 public void process(List<ConversionResult> conversionResults) {
030 for (ConversionResult result : conversionResults) {
031 if (!result.getOldFile().delete()) {
032 throw new IllegalStateException("Unable to delete file " + result.getOldFile().getAbsolutePath());
033 }
034
035 String newFilePath = result.getNewFile().getAbsolutePath().replace(DirectoryConverter.CONVERTED_EXTENSION, "");
036
037 if (!result.getNewFile().renameTo(new File(newFilePath))) {
038 throw new IllegalStateException("Unable to rename file " + result.getNewFile().getAbsolutePath());
039 }
040 }
041 }
042 }