|
What this is
Other links
The source code/* * 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 NetBeans. The Initial Developer of the Original * Code is Sun Microsystems, Inc. Portions Copyright 1997-2000 Sun * Microsystems, Inc. All Rights Reserved. */ package org.netbeans.lib.cvsclient.command; import java.io.*; import java.util.*; import org.netbeans.lib.cvsclient.*; import org.netbeans.lib.cvsclient.admin.*; import org.netbeans.lib.cvsclient.connection.*; import org.netbeans.lib.cvsclient.event.*; import org.netbeans.lib.cvsclient.request.*; /** * A class that provides common functionality for CVS commands that * operate upon the repository. * * @author Martin Entlicher */ public abstract class RepositoryCommand extends BuildableCommand { /** * The requests that are sent and processed. */ protected List requests = new LinkedList(); /** * The client services that are provided to this command. */ protected ClientServices clientServices; /** * Whether to process recursively. */ private boolean recursive = true; /** * The modules to process. These names are unexpanded and will be passed * to a module-expansion request. */ protected final List modules = new LinkedList(); /** * The expanded modules. */ protected final List expandedModules = new LinkedList(); /** * Gets the value of the recursive option. * @return true if recursive, false if not */ public boolean isRecursive() { return recursive; } /** * Sets the value of the recursive option. * @param r true if the command should recurse, false otherwise */ public void setRecursive(boolean recursive) { this.recursive = recursive; } /** * Add a module to process. * @param module the name of the module to process */ public void addModule(String module) { modules.add(module); } /** * Set the modules to process. * @param modules the names of the modules to process */ public void setModules(String[] modules) { clearModules(); if (modules == null) { return; } for (int i = 0; i < modules.length; i++) { String module = modules[i]; this.modules.add(module); } } /** * Get the array of modules that are set to be processed. */ public String[] getModules() { String[] mods = new String[modules.size()]; mods = (String[])modules.toArray(mods); return mods; } /** * Clear the list of modules. */ public void clearModules() { this.modules.clear(); } /** * Add the argument requests. The argument requests are created using * the expanded set of modules passed in. Subclasses of this * class should call this method at the appropriate point in their * postExpansionExecute() method. Note that arguments are appended to the list. */ protected final void addArgumentRequests() { if (expandedModules.size() == 0) { return; } for (Iterator it = expandedModules.iterator(); it.hasNext(); ) { final String module = (String) it.next(); addRequest(new ArgumentRequest(module)); } } /** * This is called when the server has responded to an expand-modules * request. */ public final void moduleExpanded(ModuleExpansionEvent e) { expandedModules.add(e.getModule()); } /** * Execute this command. This method sends the ExpandModulesRequest in order * to expand the modules that were set. The actual execution is performed by * {@link #postExpansionExecute} method. * @param client the client services object that provides any necessary * services to this command, including the ability to actually process * all the requests */ public final void execute(ClientServices client, EventManager em) throws CommandException, AuthenticationException { client.ensureConnection(); requests.clear(); super.execute(client, em); clientServices = client; if (client.isFirstCommand()) { requests.add(new RootRequest(client.getRepository())); } for (Iterator it = modules.iterator(); it.hasNext();) { String module = (String)it.next(); requests.add(new ArgumentRequest(module)); } expandedModules.clear(); requests.add(new DirectoryRequest(".", client.getRepository())); //NOI18N requests.add(new ExpandModulesRequest()); try { client.processRequests(requests); } catch (CommandException ex) { throw ex; } catch (Exception ex) { throw new CommandException(ex, ex.getLocalizedMessage()); } requests.clear(); postExpansionExecute(client, em); } /** * Execute this command * @param client the client services object that provides any necessary * services to this command, including the ability to actually process * all the requests */ protected abstract void postExpansionExecute(ClientServices client, EventManager em) throws CommandException, AuthenticationException; /** * Adds the specified request to the request list. */ protected final void addRequest(Request request) { requests.add(request); } /** * Adds the request for the current working directory. */ protected final void addRequestForWorkingDirectory(ClientServices clientServices) throws IOException { addRequest(new DirectoryRequest(".", //NOI18N clientServices.getRepositoryForDirectory(getLocalDirectory()))); } /** * If the specified value is true, add a ArgumentRequest for the specified * argument. */ protected final void addArgumentRequest(boolean value, String argument) { if (!value) { return; } addRequest(new ArgumentRequest(argument)); } /** * Appends the file's names to the specified buffer. */ protected final void appendModuleArguments(StringBuffer buffer) { if (expandedModules.size() == 0) { return; } Iterator it = expandedModules.iterator(); buffer.append((String) it.next()); while (it.hasNext()) { buffer.append(' '); buffer.append((String) it.next()); } } } |
... this post is sponsored by my books ... | |
#1 New Release! |
FP Best Seller |
Copyright 1998-2024 Alvin Alexander, alvinalexander.com
All Rights Reserved.
A percentage of advertising revenue from
pages under the /java/jwarehouse
URI on this website is
paid back to open source projects.