/*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* 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 General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor,
* Boston, MA 02110-1301, USA.
*
* For information about the authors of this project Have a look
* at the AUTHORS file in the root of this project.
*/
package net.sourceforge.fullsync.impl;
import net.sourceforge.fullsync.DataParseException;
import net.sourceforge.fullsync.FileComparer;
import net.sourceforge.fullsync.State;
import net.sourceforge.fullsync.fs.File;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
public class StateDecider implements net.sourceforge.fullsync.StateDecider {
private static final Logger logger = LoggerFactory.getLogger(StateDecider.class.getSimpleName());
protected FileComparer comparer;
public StateDecider(FileComparer comparer) {
this.comparer = comparer;
}
@Override
public State getState(final File source, final File destination) throws DataParseException {
logger.debug(source + " vs. " + destination);
if (!source.exists()) {
if (!destination.exists()) {
logger.debug("both missing"); // FIXME: impossible?!
return State.InSync;
}
else {
logger.debug("source missing");
return State.OrphanDestination;
}
}
else if (!destination.exists()) {
logger.debug("destination missing");
return State.OrphanSource;
}
if (source.isDirectory()) {
if (destination.isDirectory()) {
logger.debug("both are dirs");
return State.InSync;
}
else {
logger.debug("source directory, destination file");
return State.DirSourceFileDestination;
}
}
else if (destination.isDirectory()) {
logger.debug("source file, destination directory");
return State.FileSourceDirDestination;
}
return comparer.compareFiles(source, destination);
}
}