View Javadoc

1   /**
2    * Copyright 2010-2013 The Kuali Foundation
3    *
4    * Licensed under the Educational Community License, Version 2.0 (the "License");
5    * you may not use this file except in compliance with the License.
6    * You may obtain a copy of the License at
7    *
8    * http://www.opensource.org/licenses/ecl2.php
9    *
10   * Unless required by applicable law or agreed to in writing, software
11   * distributed under the License is distributed on an "AS IS" BASIS,
12   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13   * See the License for the specific language governing permissions and
14   * limitations under the License.
15   */
16  package org.kuali.common.jdbc.convert;
17  
18  import java.io.File;
19  import java.util.List;
20  
21  /**
22   * This post conversion processor deletes each file used as input for the conversion, and renames the newly created file by removing the
23   * ".converted" extension
24   *
25   * @author andrewlubbers
26   */
27  public class ReplaceWithConvertedProcessor implements PostConversionProcessor {
28  	@Override
29  	public void process(List<ConversionResult> conversionResults) {
30  		for (ConversionResult result : conversionResults) {
31  			if (!result.getOldFile().delete()) {
32  				throw new IllegalStateException("Unable to delete file " + result.getOldFile().getAbsolutePath());
33  			}
34  
35  			String newFilePath = result.getNewFile().getAbsolutePath().replace(DirectoryConverter.CONVERTED_EXTENSION, "");
36  
37  			if (!result.getNewFile().renameTo(new File(newFilePath))) {
38  				throw new IllegalStateException("Unable to rename file " + result.getNewFile().getAbsolutePath());
39  			}
40  		}
41  	}
42  }