/***************************************************************************** * Sun Public License Notice * * The contents of this file are subject to the Sun Public License Version * 1.0 (the "License"). You may not use this file except in compliance with * the License. A copy of the License is available at http://www.sun.com/ * The Original Code is the CVS Client Library. * The Initial Developer of the Original Code is Robert Greig. * Portions created by Robert Greig are Copyright (C) 2000. * All Rights Reserved. * Contributor(s): Robert Greig. *****************************************************************************/ package org.netbeans.lib.cvsclient.command.status; import org.netbeans.lib.cvsclient.IClientEnvironment; import org.netbeans.lib.cvsclient.IRequestProcessor; import org.netbeans.lib.cvsclient.connection.AuthenticationException; import org.netbeans.lib.cvsclient.command.AbstractCommand; import org.netbeans.lib.cvsclient.command.CommandException; import org.netbeans.lib.cvsclient.command.ICvsFiles; import org.netbeans.lib.cvsclient.command.IOCommandException; import org.netbeans.lib.cvsclient.event.DualListener; import org.netbeans.lib.cvsclient.event.ICvsListener; import org.netbeans.lib.cvsclient.event.ICvsListenerRegistry; import org.netbeans.lib.cvsclient.event.IEventSender; import org.netbeans.lib.cvsclient.progress.IProgressViewer; import org.netbeans.lib.cvsclient.progress.RangeProgressViewer; import org.netbeans.lib.cvsclient.progress.receiving.FileInfoAndMessageResponseProgressHandler; import org.netbeans.lib.cvsclient.progress.sending.FileStateRequestsProgressHandler; import org.netbeans.lib.cvsclient.progress.sending.IRequestsProgressHandler; import org.netbeans.lib.cvsclient.request.CommandRequest; import org.netbeans.lib.cvsclient.request.Requests; import org.jetbrains.annotations.NonNls; import java.io.IOException; /** * The status command looks up the status of files in the repository * @author Robert Greig */ public final class StatusCommand extends AbstractCommand { // Constants ============================================================== @NonNls static final String EXAM_DIR = "server: Examining "; // Fields ================================================================= private boolean includeTags; // Setup ================================================================== public StatusCommand() { } /** * Execute a command * @param requestProcessor the client services object that provides any necessary * services to this command, including the ability to actually process * all the requests. */ public boolean execute(IRequestProcessor requestProcessor, IEventSender eventSender, ICvsListenerRegistry listenerRegistry, IClientEnvironment clientEnvironment, IProgressViewer progressViewer) throws CommandException, AuthenticationException { final ICvsFiles cvsFiles; try { cvsFiles = scanFileSystem(clientEnvironment); } catch (IOException ex) { throw new IOCommandException(ex); } final Requests requests = new Requests(CommandRequest.STATUS, clientEnvironment); requests.addArgumentRequest(includeTags, "-v"); addFileRequests(cvsFiles, requests, clientEnvironment); requests.addLocalPathDirectoryRequest(); addArgumentRequests(requests); final IRequestsProgressHandler requestsProgressHandler = new FileStateRequestsProgressHandler(new RangeProgressViewer(progressViewer, 0.0, 0.5), cvsFiles); final ICvsListener responseProgressHandler = new FileInfoAndMessageResponseProgressHandler(new RangeProgressViewer(progressViewer, 0.5, 1.0), cvsFiles, EXAM_DIR); final ICvsListener statusMessageParser = new StatusMessageParser(eventSender, getFileObjects(), clientEnvironment.getCvsFileSystem()); final ICvsListener listener = new DualListener(statusMessageParser, responseProgressHandler); listener.registerListeners(listenerRegistry); try { return requestProcessor.processRequests(requests, requestsProgressHandler); } finally { listener.unregisterListeners(listenerRegistry); } } /** * resets all switches in the command. After calling this method, * the command should have no switches defined and should behave defaultly. */ public void resetCvsCommand() { super.resetCvsCommand(); setRecursive(true); setIncludeTags(false); } /** * This method returns how the command would looklike when typed on the command line. * Each command is responsible for constructing this information. */ public String getCvsCommandLine() { @NonNls final StringBuffer cvsCommand = new StringBuffer("status "); cvsCommand.append(getCVSArguments()); appendFileArguments(cvsCommand); return cvsCommand.toString(); } // Accessing ============================================================== private boolean isIncludeTags() { return includeTags; } public void setIncludeTags(boolean includeTags) { this.includeTags = includeTags; } // Utils ================================================================== private String getCVSArguments() { @NonNls final StringBuilder toReturn = new StringBuilder(); if (isIncludeTags()) { toReturn.append("-v "); } if (!isRecursive()) { toReturn.append("-l "); } return toReturn.toString(); } }