/*
* RapidMiner
*
* Copyright (C) 2001-2014 by RapidMiner and the contributors
*
* Complete list of developers available at our web site:
*
* http://rapidminer.com
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see http://www.gnu.org/licenses/.
*/
package com.rapidminer.operator.filesystem;
import java.io.File;
import java.util.List;
import com.rapidminer.operator.Operator;
import com.rapidminer.operator.OperatorDescription;
import com.rapidminer.operator.OperatorException;
import com.rapidminer.operator.UserError;
import com.rapidminer.operator.ports.PortPairExtender;
import com.rapidminer.parameter.ParameterType;
import com.rapidminer.parameter.ParameterTypeBoolean;
import com.rapidminer.parameter.ParameterTypeFile;
/**
*
* This Operator moves a file to another location. If the destination is a directory, the file is moved in there.
* If the target already exists and overwriting is enabled, the existing file will be overwritten. Else, an exception is thrown.
*
* @author Philipp Kersting
*
*/
public class MoveFileOperator extends Operator {
public static final String PARAMETER_FILE = "file";
public static final String PARAMETER_DESTINATION = "destination";
public static final String PARAMETER_OVERWRITE = "overwrite";
private PortPairExtender dummyPorts = new PortPairExtender("through", getInputPorts(), getOutputPorts());
public MoveFileOperator(OperatorDescription description) {
super(description);
dummyPorts.start();
getTransformer().addRule(dummyPorts.makePassThroughRule());
}
@Override
public List<ParameterType> getParameterTypes(){
List <ParameterType> types = super.getParameterTypes();
types.add(new ParameterTypeFile(PARAMETER_FILE, "The file to be moved", "*", false, false));
types.add(new ParameterTypeFile(PARAMETER_DESTINATION, "The destination of the file.", "*", false, false));
types.add(new ParameterTypeBoolean(PARAMETER_OVERWRITE, "Determines whether an already existing file should be overwritten.", false, false));
return types;
}
@Override
public void doWork() throws OperatorException{
String fileName = getParameterAsString(PARAMETER_FILE);
String destination = getParameter(PARAMETER_DESTINATION);
Boolean overwrite = getParameterAsBoolean(PARAMETER_OVERWRITE);
File file = new File(fileName);
File destinationFile = new File (destination);
if (!destinationFile.getParentFile().exists()){
destinationFile.getParentFile().mkdirs();
}
if (destinationFile.isDirectory()){
destinationFile = new File(destinationFile.getAbsoluteFile() + "/" + new File(fileName).getName());
}
if ((!destinationFile.exists() || overwrite) && file.exists()){
if (destinationFile.exists() && overwrite){
if (!destinationFile.delete()){
throw new UserError(this, "303", destinationFile, "Existing file could not be deleted.");
}
}
if (!file.renameTo(destinationFile)){
throw new UserError (this, "move_file.failure", file, destinationFile);
}
}else if(!file.exists()){
throw new UserError (this, "301", file);
}else if(!destinationFile.isDirectory()){
throw new UserError (this, "move_file.exists", destinationFile);
}
dummyPorts.passDataThrough();
}
}