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.jellytools.modules.javacvs;
042:
043: import org.netbeans.jellytools.Bundle;
044: import org.netbeans.jellytools.WizardOperator;
045: import org.netbeans.jellytools.modules.javacvs.actions.ImportAction;
046: import org.netbeans.jellytools.nodes.Node;
047: import org.netbeans.jemmy.JemmyException;
048:
049: /**
050: * Class implementing all necessary methods for handling "Import into Repository" wizard.
051: * It is opened from main menu CVS|Import into Repository.
052: * <br>
053: * Usage:<br>
054: * <pre>
055: * ImportWizardOperator.invoke();
056: * CVSRootStepOperator cvsRootOper = new CVSRootStepOperator();
057: * cvsRootOper.setPassword("password");
058: * cvsRootOper.setCVSRoot(":pserver:user@host:repository");
059: * cvsRootOper.next();
060: * FolderToImportStepOperator folderToImportOper = new FolderToImportStepOperator();
061: * folderToImportOper.setFolderToImport("/tmp/myLocalfolder");
062: * folderToImportOper.setImportMessage("Import message");
063: * folderToImportOper.setRepositoryFolder("folder");
064: * folderToImportOper.finish();
065: * </pre>
066: *
067: *
068: * @author Jiri.Skrivanek@sun.com
069: * @see BrowseRepositoryFolderOperator
070: * @see CVSRootStepOperator
071: * @see FolderToImportStepOperator
072: * @see org.netbeans.jellytools.modules.javacvs.actions.ImportAction
073: */
074: public class ImportWizardOperator extends WizardOperator {
075:
076: /** Waits for dialog with "Import Project Options" title. */
077: public ImportWizardOperator() {
078: super (
079: Bundle
080: .getString(
081: "org.netbeans.modules.versioning.system.cvss.ui.actions.project.Bundle",
082: "BK0007"));
083: }
084:
085: /** Invokes new wizard and returns instance of ImportWizardOperator.
086: * @return instance of ImportWizardOperator
087: */
088: public static ImportWizardOperator invoke() {
089: new ImportAction().perform();
090: return new ImportWizardOperator();
091: }
092:
093: /** Invokes new wizard on given node and returns instance of ImportWizardOperator.
094: * @param node node on which to invoke wizard
095: * @return instance of ImportWizardOperator
096: */
097: public static ImportWizardOperator invoke(Node node) {
098: new ImportAction().perform(node);
099: return new ImportWizardOperator();
100: }
101:
102: //*****************************************
103: // High-level functionality definition part
104: //*****************************************
105:
106: /**
107: * Goes through the wizard and fill supplied parameter.
108: * @param cvsRoot CVS root.
109: * @param password password - can be null
110: * @param folderToImport local folder to import
111: * @param importMessage import message
112: * @param repositoryFolder repository folder
113: */
114: public void doImport(String cvsRoot, String password,
115: String folderToImport, String importMessage,
116: String repositoryFolder) {
117: if (cvsRoot == null) {
118: throw new JemmyException("CVS root must not be null."); // NOI18N
119: }
120: if (folderToImport == null) {
121: throw new JemmyException(
122: "Folder to Import must not be null."); // NOI18N
123: }
124: if (importMessage == null) {
125: throw new JemmyException("Import message must not be null."); // NOI18N
126: }
127: if (repositoryFolder == null) {
128: throw new JemmyException(
129: "Repository Folder must not be null."); // NOI18N
130: }
131: ImportWizardOperator.invoke();
132: CVSRootStepOperator cvsRootOper = new CVSRootStepOperator();
133: if (password != null) {
134: cvsRootOper.setPassword(password);
135: }
136: cvsRootOper.setCVSRoot(cvsRoot);
137: cvsRootOper.next();
138: FolderToImportStepOperator folderToImportOper = new FolderToImportStepOperator();
139: folderToImportOper.setFolderToImport(folderToImport);
140: folderToImportOper.setImportMessage(importMessage);
141: folderToImportOper.setRepositoryFolder(repositoryFolder);
142: folderToImportOper.finish();
143: }
144: }
|