/*
Copyright 2008-2010 Gephi
Authors : Mathieu Bastian <mathieu.bastian@gephi.org>
Website : http://www.gephi.org
This file is part of Gephi.
Gephi 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.
Gephi 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 Gephi. If not, see <http://www.gnu.org/licenses/>.
*/
package org.gephi.utils.progress;
/**
* Progress functionalities accessor.
*
* @author Mathieu Bastian
*/
public class Progress {
/**
* Finish the progress task.
* @param progressTicket the progress ticket of the task
*/
public static void finish(ProgressTicket progressTicket) {
if (progressTicket != null) {
progressTicket.finish();
}
}
/**
* Notify the user about a new completed unit. Equivalent to incrementing workunits by one.
* @param progressTicket the progress ticket of the task
*/
public static void progress(ProgressTicket progressTicket) {
if (progressTicket != null) {
progressTicket.progress();
}
}
/**
* Notify the user about completed workunits.
* @param progressTicket the progress ticket of the task
* @param workunit a cumulative number of workunits completed so far
*/
public static void progress(ProgressTicket progressTicket, int workunit) {
if (progressTicket != null) {
progressTicket.progress(workunit);
}
}
/**
* Notify the user about progress by showing message with details.
* @param progressTicket the progress ticket of the task
* @param message details about the status of the task
*/
public static void progress(ProgressTicket progressTicket, String message) {
if (progressTicket != null) {
progressTicket.progress(message);
}
}
/**
* Notify the user about completed workunits and show additional detailed message.
* @param progressTicket the progress ticket of the task
* @param message details about the status of the task
* @param workunit a cumulative number of workunits completed so far
*/
public static void progress(ProgressTicket progressTicket, String message, int workunit) {
if (progressTicket != null) {
progressTicket.progress(message, workunit);
}
}
/**
* Change the display name of the progress task. Use with care, please make sure the changed name is not completely different, or otherwise it might appear to the user as a different task.
* @param progressTicket the progress ticket of the task
* @param newDisplayName the new display name
*/
public static void setDisplayName(ProgressTicket progressTicket, String newDisplayName) {
if (progressTicket != null) {
progressTicket.setDisplayName(newDisplayName);
}
}
/**
* Start the progress indication for indeterminate task.
* @param progressTicket the progress ticket of the task
*/
public static void start(ProgressTicket progressTicket) {
if (progressTicket != null) {
progressTicket.start();
}
}
/**
* Start the progress indication for a task with known number of steps.
* @param progressTicket the progress ticket of the task
* @param workunits total number of workunits that will be processed
*/
public static void start(ProgressTicket progressTicket, int workunits) {
if (progressTicket != null) {
progressTicket.start(workunits);
}
}
/**
* Currently indeterminate task can be switched to show percentage completed.
* @param progressTicket the progress ticket of the task
* @param workunits workunits total number of workunits that will be processed
*/
public static void switchToDeterminate(ProgressTicket progressTicket, int workunits) {
if (progressTicket != null) {
progressTicket.switchToDeterminate(workunits);
}
}
/**
* Currently determinate task can be switched to indeterminate mode.
* @param progressTicket the progress ticket of the task
*/
public static void switchToIndeterminate(ProgressTicket progressTicket) {
if (progressTicket != null) {
progressTicket.switchToIndeterminate();
}
}
}