Clover coverage report - Ant Coverage
Coverage timestamp: Tue Apr 8 2003 20:43:55 EST
file stats: LOC: 167   Methods: 7
NCLOC: 41   Classes: 1
 
 Source file Conditionals Statements Methods TOTAL
MSVSSADD.java 0% 0% 0% 0%
 1   
 /*
 2   
  * The Apache Software License, Version 1.1
 3   
  *
 4   
  * Copyright (c) 2002-2003 The Apache Software Foundation.  All rights
 5   
  * reserved.
 6   
  *
 7   
  * Redistribution and use in source and binary forms, with or without
 8   
  * modification, are permitted provided that the following conditions
 9   
  * are met:
 10   
  *
 11   
  * 1. Redistributions of source code must retain the above copyright
 12   
  *    notice, this list of conditions and the following disclaimer.
 13   
  *
 14   
  * 2. Redistributions in binary form must reproduce the above copyright
 15   
  *    notice, this list of conditions and the following disclaimer in
 16   
  *    the documentation and/or other materials provided with the
 17   
  *    distribution.
 18   
  *
 19   
  * 3. The end-user documentation included with the redistribution, if
 20   
  *    any, must include the following acknowlegement:
 21   
  *       "This product includes software developed by the
 22   
  *        Apache Software Foundation (http://www.apache.org/)."
 23   
  *    Alternately, this acknowlegement may appear in the software itself,
 24   
  *    if and wherever such third-party acknowlegements normally appear.
 25   
  *
 26   
  * 4. The names "Ant" and "Apache Software
 27   
  *    Foundation" must not be used to endorse or promote products derived
 28   
  *    from this software without prior written permission. For written
 29   
  *    permission, please contact apache@apache.org.
 30   
  *
 31   
  * 5. Products derived from this software may not be called "Apache"
 32   
  *    nor may "Apache" appear in their names without prior written
 33   
  *    permission of the Apache Group.
 34   
  *
 35   
  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
 36   
  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
 37   
  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
 38   
  * DISCLAIMED.  IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR
 39   
  * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
 40   
  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
 41   
  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
 42   
  * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
 43   
  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
 44   
  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
 45   
  * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
 46   
  * SUCH DAMAGE.
 47   
  * ====================================================================
 48   
  *
 49   
  * This software consists of voluntary contributions made by many
 50   
  * individuals on behalf of the Apache Software Foundation.  For more
 51   
  * information on the Apache Software Foundation, please see
 52   
  * <http://www.apache.org/>.
 53   
  */
 54   
 
 55   
 package org.apache.tools.ant.taskdefs.optional.vss;
 56   
 
 57   
 import org.apache.tools.ant.BuildException;
 58   
 import org.apache.tools.ant.types.Commandline;
 59   
 import org.apache.tools.ant.types.Path;
 60   
 
 61   
 /**
 62   
  * Performs Add commands to Microsoft Visual SourceSafe.
 63   
  * Based on the VSS Checkin code by Martin Poeschl
 64   
  *
 65   
  * @author Nigel Magnay
 66   
  * @author Jesse Stockall
 67   
  *
 68   
  * @ant.task name="vssadd" category="scm"
 69   
  */
 70   
 public class MSVSSADD extends MSVSS {
 71   
 
 72   
     private String m_LocalPath = null;
 73   
 
 74   
     /**
 75   
      * Builds a command line to execute ss.
 76   
      * @return     The constructed commandline.
 77   
      */
 78  0
     protected Commandline buildCmdLine() {
 79  0
         Commandline commandLine = new Commandline();
 80   
 
 81   
         // first off, make sure that we've got a command and a localPath ...
 82  0
         if (getLocalpath() == null) {
 83  0
             String msg = "localPath attribute must be set!";
 84  0
             throw new BuildException(msg, getLocation());
 85   
         }
 86   
 
 87   
         // build the command line from what we got the format is
 88   
         // ss Add VSS items [-B] [-C] [-D-] [-H] [-I-] [-K] [-N] [-O] [-R] [-W] [-Y] [-?]
 89   
         // as specified in the SS.EXE help
 90  0
         commandLine.setExecutable(getSSCommand());
 91  0
         commandLine.createArgument().setValue(COMMAND_ADD);
 92   
 
 93   
         // VSS items
 94  0
         commandLine.createArgument().setValue(getLocalpath());
 95   
         // -I- or -I-Y or -I-N
 96  0
         commandLine.createArgument().setValue(getAutoresponse());
 97   
         // -R
 98  0
         commandLine.createArgument().setValue(getRecursive());
 99   
         // -W
 100  0
         commandLine.createArgument().setValue(getWritable());
 101   
         // -Y
 102  0
         commandLine.createArgument().setValue(getLogin());
 103   
         // -C
 104  0
         commandLine.createArgument().setValue(getComment());
 105   
 
 106  0
         return commandLine;
 107   
     }
 108   
 
 109   
     /**
 110   
      * Returns the local path without the flag.; required
 111   
      * @todo See why this returns the local path without the flag.
 112   
      * @return The local path value.
 113   
      */
 114  0
     protected String getLocalpath() {
 115  0
         return m_LocalPath;
 116   
     }
 117   
 
 118   
     /**
 119   
      * Flag to tell the task to recurse down the tree;
 120   
      * optional, default false.
 121   
      * @param recursive  The boolean value for recursive.
 122   
      */
 123  0
     public void setRecursive(boolean recursive) {
 124  0
         super.setInternalRecursive(recursive);
 125   
     }
 126   
 
 127   
     /**
 128   
      * Leave checked in files writable? Default: false.
 129   
      * @param   writable The boolean value for writable.
 130   
      */
 131  0
     public final void setWritable(boolean writable) {
 132  0
         super.setInternalWritable(writable);
 133   
     }
 134   
 
 135   
     /**
 136   
      * Set the autoresponce behaviour; optional.
 137   
      * <p>
 138   
      * Valid options are Y and N.
 139   
      * @param response The auto response value.
 140   
      */
 141  0
     public void setAutoresponse(String response){
 142  0
         super.setInternalAutoResponse(response);
 143   
     }
 144   
 
 145   
     /**
 146   
      * Set the comment to apply; optional.
 147   
      * <p>
 148   
      * If this is null or empty, it will be replaced with "-" which
 149   
      * is what SourceSafe uses for an empty comment.
 150   
      * @param comment The comment to apply in SourceSafe
 151   
      */
 152  0
     public void setComment(String comment) {
 153  0
         super.setInternalComment(comment);
 154   
     }
 155   
 
 156   
     /**
 157   
      * Set the local path; optional.
 158   
      * <p>
 159   
      * This is the path to override the project
 160   
      * working directory.
 161   
      * @param   localPath   The path on disk.
 162   
      */
 163  0
     public void setLocalpath(Path localPath) {
 164  0
         m_LocalPath = localPath.toString();
 165   
     }
 166   
 }
 167