|
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.