/* * Copyright (C) 2009-2010 Alfresco Software Limited. * * This file is part of Alfresco * * Alfresco 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. * * Alfresco 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 Alfresco. If not, see . */ package org.alfresco.service.cmr.transfer; import java.util.Arrays; import java.util.Collections; import java.util.HashSet; import java.util.Set; /** * @author brian * */ public class TransferProgress { public enum Status { PRE_COMMIT, COMMIT_REQUESTED, COMMITTING, COMPLETE, ERROR, CANCELLED }; private static Set terminalStatuses = Collections.unmodifiableSet(new HashSet(Arrays.asList( Status.COMPLETE, Status.ERROR, Status.CANCELLED))); private Status status; private int currentPosition; private int endPosition; private Throwable error; /** * * @return The statuses that mark the end of the transfer. Once a transfer reaches one of these statuses * it can never move into a different status. */ public static Set getTerminalStatuses() { return terminalStatuses; } /** * * @return true if the current status is one of the terminal statuses. */ public boolean isFinished() { return terminalStatuses.contains(status); } /** * @return the status */ public Status getStatus() { return status; } /** * @param status * the status to set */ public void setStatus(Status status) { this.status = status; } /** * @return the currentPosition */ public int getCurrentPosition() { return currentPosition; } /** * @param currentPosition * the currentPosition to set */ public void setCurrentPosition(int currentPosition) { this.currentPosition = currentPosition; } /** * @return the endPosition */ public int getEndPosition() { return endPosition; } /** * @param endPosition * the endPosition to set */ public void setEndPosition(int endPosition) { this.endPosition = endPosition; } /** * @return the error */ public Throwable getError() { return error; } /** * @param error * the error to set */ public void setError(Throwable error) { this.error = error; } }