/**
* This file is part of Waarp Project.
*
* Copyright 2009, Frederic Bregier, and individual contributors by the @author tags. See the
* COPYRIGHT.txt in the distribution for a full listing of individual contributors.
*
* All Waarp Project 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 3 of
* the License, or (at your option) any later version.
*
* Waarp 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 Waarp . If not, see
* <http://www.gnu.org/licenses/>.
*/
package org.waarp.common.file;
import org.waarp.common.command.exception.CommandAbstractException;
import org.waarp.common.exception.NoRestartException;
/**
* Restart object that implements the REST command.<br>
* Note that if necessary, according to the implementation of {@link DirInterface} and {@link FileInterface}, one could want to
* implement a way to store or retrieve Marker from/to the
* client specification.
*
* @author Frederic Bregier
*
*/
public abstract class Restart {
/**
* SessionInterface
*/
private final SessionInterface session;
/**
* Is the current Restart object in context set
*/
private boolean isSet = false;
/**
* Default constructor
*
* @param session
*/
protected Restart(SessionInterface session) {
isSet = false;
this.session = session;
}
/**
* @return the isSet
*/
protected boolean isSet() {
return isSet;
}
/**
* @param isSet
* the isSet to set
*/
public void setSet(boolean isSet) {
this.isSet = isSet;
}
/**
* @return the session
*/
protected SessionInterface getSession() {
return session;
}
/**
* Restart from a Marker for the next FileInterface
*
* @param marker
* @return True if the Marker is OK
* @exception CommandAbstractException
*/
public abstract boolean restartMarker(String marker)
throws CommandAbstractException;
/**
*
* @return the position from a previous REST command
* @throws NoRestartException
* if no REST command was issued before
*/
public abstract long getPosition() throws NoRestartException;
// FIXME Additionally the implementation should implement a way to get the
// values
/**
*
* @param nextBlock
* @return the max between the available size and the nextblock size
*/
public abstract int getMaxSize(int nextBlock);
}