001: /*
002: * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
003: *
004: * Copyright 1997-2007 Sun Microsystems, Inc. All rights reserved.
005: *
006: * The contents of this file are subject to the terms of either the GNU
007: * General Public License Version 2 only ("GPL") or the Common
008: * Development and Distribution License("CDDL") (collectively, the
009: * "License"). You may not use this file except in compliance with the
010: * License. You can obtain a copy of the License at
011: * http://www.netbeans.org/cddl-gplv2.html
012: * or nbbuild/licenses/CDDL-GPL-2-CP. See the License for the
013: * specific language governing permissions and limitations under the
014: * License. When distributing the software, include this License Header
015: * Notice in each file and include the License file at
016: * nbbuild/licenses/CDDL-GPL-2-CP. Sun designates this
017: * particular file as subject to the "Classpath" exception as provided
018: * by Sun in the GPL Version 2 section of the License file that
019: * accompanied this code. If applicable, add the following below the
020: * License Header, with the fields enclosed by brackets [] replaced by
021: * your own identifying information:
022: * "Portions Copyrighted [year] [name of copyright owner]"
023: *
024: * Contributor(s):
025: *
026: * The Original Software is NetBeans. The Initial Developer of the Original
027: * Software is Sun Microsystems, Inc. Portions Copyright 1997-2006 Sun
028: * Microsystems, Inc. All Rights Reserved.
029: *
030: * If you wish your version of this file to be governed by only the CDDL
031: * or only the GPL Version 2, indicate your decision by adding
032: * "[Contributor] elects to include this software in this distribution
033: * under the [CDDL or GPL Version 2] license." If you do not indicate a
034: * single choice of license, a recipient has the option to distribute
035: * your version of this file under either the CDDL, the GPL Version 2 or
036: * to extend the choice of license to its licensees as provided above.
037: * However, if you add GPL Version 2 code and therefore, elected the GPL
038: * Version 2 license, then the option applies only if the new code is
039: * made subject to such option by the copyright holder.
040: */
041: package org.netbeans.lib.cvsclient.command.watch;
042:
043: import org.netbeans.lib.cvsclient.request.*;
044:
045: /**
046: * @author Thomas Singer
047: * @version Dec 29, 2001
048: */
049: public class WatchMode {
050: /**
051: * This is the WatchMode that enables watching.
052: */
053: public static final WatchMode ON = new WatchMode("on", // NOI18N
054: CommandRequest.WATCH_ON, false);
055:
056: /**
057: * This is the WatchMode that disables watching.
058: */
059: public static final WatchMode OFF = new WatchMode("off", // NOI18N
060: CommandRequest.WATCH_OFF, false);
061:
062: /**
063: * This is the WatchMode that adds watching for the specified Watch.
064: */
065: public static final WatchMode ADD = new WatchMode("add", // NOI18N
066: CommandRequest.WATCH_ADD, true);
067:
068: /**
069: * This is the WatchMode that removes watching for the specified Watch.
070: */
071: public static final WatchMode REMOVE = new WatchMode("remove", // NOI18N
072: CommandRequest.WATCH_REMOVE, true);
073:
074: private final String name;
075: private final CommandRequest command;
076: private final boolean watchOptionAllowed;
077:
078: private WatchMode(String name, CommandRequest command,
079: boolean watchOptionAllowed) {
080: this .name = name;
081: this .command = command;
082: this .watchOptionAllowed = watchOptionAllowed;
083: }
084:
085: /**
086: * Returns the CommandRequest that is used when executing the WatchCommand
087: * with this WatchMode.
088: */
089: public CommandRequest getCommand() {
090: return command;
091: }
092:
093: /**
094: * Indicated, whether a non-null watch-option is allowed in the WatchCommand.
095: */
096: public boolean isWatchOptionAllowed() {
097: return watchOptionAllowed;
098: }
099:
100: /**
101: * Returns the name of this WatchMode ("on", "off", "add", "remove").
102: */
103: public String toString() {
104: return name;
105: }
106: }
|