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 the CVS Client Library.
027: * The Initial Developer of the Original Software is Robert Greig.
028: * Portions created by Robert Greig are Copyright (C) 2000.
029: * All Rights Reserved.
030: *
031: * If you wish your version of this file to be governed by only the CDDL
032: * or only the GPL Version 2, indicate your decision by adding
033: * "[Contributor] elects to include this software in this distribution
034: * under the [CDDL or GPL Version 2] license." If you do not indicate a
035: * single choice of license, a recipient has the option to distribute
036: * your version of this file under either the CDDL, the GPL Version 2 or
037: * to extend the choice of license to its licensees as provided above.
038: * However, if you add GPL Version 2 code and therefore, elected the GPL
039: * Version 2 license, then the option applies only if the new code is
040: * made subject to such option by the copyright holder.
041:
042: * Contributor(s): Robert Greig.
043: *****************************************************************************/package org.netbeans.lib.cvsclient.request;
044:
045: import org.netbeans.lib.cvsclient.admin.*;
046:
047: /**
048: * Sends an entry to the server, to tell the server which version of a file
049: * is on the local machine. The filename is relative to the most recent
050: * Directory request. Note that if an <pre>Entry</pre> request is sent
051: * without <pre>Modified</pre>, <pre>Is-Modified</pre> or <pre>Unchanged</pre>
052: * it means that the file is lost. Also note that if <pre>Modified</pre>,
053: * <pre>Is-Modified</pre> or </pre>Unchanged</pre> is sent with <pre>Entry
054: * </pre> then </pre>Entry</pre> must be sent first.
055: * @author Robert Greig
056: * @see org.netbeans.lib.cvsclient.request.DirectoryRequest
057: * @see org.netbeans.lib.cvsclient.request.ModifiedRequest
058: * @see org.netbeans.lib.cvsclient.request.ModifiedRequest
059: * @see org.netbeans.lib.cvsclient.request.UnchangedRequest
060: */
061: public class EntryRequest extends Request {
062: /**
063: * The Entry sent by this request
064: */
065: private Entry entry;
066:
067: /**
068: * Create an EntryRequest
069: * @param theEntry the Entry to send
070: */
071: public EntryRequest(Entry theEntry) {
072: if (theEntry == null)
073: throw new IllegalArgumentException(
074: "EntryRequest: Entry must not " + "be null");
075: entry = theEntry;
076: }
077:
078: /**
079: * Get the request String that will be passed to the server
080: * @return the request String
081: * @throws UnconfiguredRequestException if the request has not been
082: * properly configured
083: */
084: public String getRequestString()
085: throws UnconfiguredRequestException {
086: return "Entry " + entry.toString() + "\n"; //NOI18N
087: }
088:
089: /**
090: * Is a response expected from the server?
091: * @return true if a response is expected, false if no response if
092: * expected
093: */
094: public boolean isResponseExpected() {
095: return false;
096: }
097:
098: public Entry getEntry() {
099: return entry;
100: }
101:
102: }
|