Submitted by: Les Hughes [mailto:leslie.hughes@rubus.com] git-svn-id: https://svn.apache.org/repos/asf/ant/core/trunk@269393 13f79535-47bb-0310-9956-ffa450edef68master
| @@ -64,6 +64,16 @@ You will also need the Perforce client executable (p4 or p4.exe but not p4win.ex | |||
| <td><a href="#p4counter">P4Counter</a></td> | |||
| <td>Obtain or set the value of a counter</td> | |||
| </tr> | |||
| <tr> | |||
| <td><a href="#p4reopen">P4Reopen</a></td> | |||
| <td>Move files between changelists</td> | |||
| </tr> | |||
| <tr> | |||
| <td><a href="#p4revert">P4Revert</a></td> | |||
| <td>Revert files</td> | |||
| </tr> | |||
| </table> | |||
| <h3>General P4 Properties</h3> | |||
| @@ -148,6 +158,8 @@ available from the <a href="http://www.perforce.com/" target="_top">Perforce web | |||
| <taskdef name="p4have" classname="org.apache.tools.ant.taskdefs.optional.perforce.P4Have" /> | |||
| <taskdef name="p4label" classname="org.apache.tools.ant.taskdefs.optional.perforce.P4Label" /> | |||
| <taskdef name="p4counter" classname="org.apache.tools.ant.taskdefs.optional.perforce.P4Counter" /> | |||
| <taskdef name="p4reopen" classname="org.apache.tools.ant.taskdefs.optional.perforce.P4Reopen" /> | |||
| <taskdef name="p4revert" classname="org.apache.tools.ant.taskdefs.optional.perforce.P4Revert" /> | |||
| </pre> | |||
| <hr> | |||
| @@ -400,6 +412,79 @@ value of the "last-clean-build" counter: | |||
| <hr> | |||
| <h2><a name="p4reopen">P4Reopen</a></h2> | |||
| <h3>Description:</h3> | |||
| <p> | |||
| Move (or reopen in Perforce speak) checkout files between changelists. | |||
| </p> | |||
| <h3>Parameters</h3> | |||
| <table border="1" cellpadding="2" cellspacing="0"> | |||
| <tr> | |||
| <td valign="top"><b>Attribute</b></td> | |||
| <td valign="top"><b>Description</b></td> | |||
| <td align="center" valign="top"><b>Required</b></td> | |||
| </tr> | |||
| <tr> | |||
| <td valign="top">tochange</td> | |||
| <td valign="top">The changelist to move files to.</td> | |||
| <td valign="top" align="center">Yes</td> | |||
| </tr> | |||
| </table> | |||
| <h3>Examples</h3> | |||
| Move all open files to the default changelist | |||
| <pre> | |||
| <p4reopen view="//..." tochange="default" /> | |||
| </PRE> | |||
| Create a new changelist then reopen into it, any files from the view //projects/foo/main/... | |||
| <PRE> | |||
| <p4change description="Move files out of the way" /> | |||
| <p4reopen view="//projects/foo/main/..." tochange="${p4.change}" /> | |||
| </pre> | |||
| <hr> | |||
| <h2><a name="p4revert">P4Revert</a></h2> | |||
| <h3>Description:</h3> | |||
| <p> | |||
| Reverts files. | |||
| </p> | |||
| <h3>Parameters</h3> | |||
| <table border="1" cellpadding="2" cellspacing="0"> | |||
| <tr> | |||
| <td valign="top"><b>Attribute</b></td> | |||
| <td valign="top"><b>Description</b></td> | |||
| <td align="center" valign="top"><b>Required</b></td> | |||
| </tr> | |||
| <tr> | |||
| <td valign="top">change</td> | |||
| <td valign="top">The changelist to revert.</td> | |||
| <td valign="top" align="center">No</td> | |||
| </tr> | |||
| <tr> | |||
| <td valign="top">revertOnlyUnchanged</td> | |||
| <td valign="top">Revert only unchanged files (p4 revert -a)</td> | |||
| <td valign="top" align="center">No</td> | |||
| </tr> | |||
| </table> | |||
| <h3>Examples</h3> | |||
| Revert everything! | |||
| <pre> | |||
| <p4revert view="//..." /> | |||
| </PRE> | |||
| Revert any unchanged files in the default change | |||
| <PRE> | |||
| <p4revert change="default" revertonlyunchanged="true" /> | |||
| </pre> | |||
| <hr> | |||
| <h2><a name="changes">Change History</a></h2> | |||
| <table border="1" cellpadding="2" cellspacing="0"> | |||
| <tr> | |||
| @@ -0,0 +1,82 @@ | |||
| /* | |||
| * The Apache Software License, Version 1.1 | |||
| * | |||
| * Copyright (c) 2000 The Apache Software Foundation. All rights | |||
| * reserved. | |||
| * | |||
| * Redistribution and use in source and binary forms, with or without | |||
| * modification, are permitted provided that the following conditions | |||
| * are met: | |||
| * | |||
| * 1. Redistributions of source code must retain the above copyright | |||
| * notice, this list of conditions and the following disclaimer. | |||
| * | |||
| * 2. Redistributions in binary form must reproduce the above copyright | |||
| * notice, this list of conditions and the following disclaimer in | |||
| * the documentation and/or other materials provided with the | |||
| * distribution. | |||
| * | |||
| * 3. The end-user documentation included with the redistribution, if | |||
| * any, must include the following acknowlegement: | |||
| * "This product includes software developed by the | |||
| * Apache Software Foundation (http://www.apache.org/)." | |||
| * Alternately, this acknowlegement may appear in the software itself, | |||
| * if and wherever such third-party acknowlegements normally appear. | |||
| * | |||
| * 4. The names "The Jakarta Project", "Ant", and "Apache Software | |||
| * Foundation" must not be used to endorse or promote products derived | |||
| * from this software without prior written permission. For written | |||
| * permission, please contact apache@apache.org. | |||
| * | |||
| * 5. Products derived from this software may not be called "Apache" | |||
| * nor may "Apache" appear in their names without prior written | |||
| * permission of the Apache Group. | |||
| * | |||
| * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED | |||
| * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES | |||
| * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | |||
| * DISCLAIMED. IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR | |||
| * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | |||
| * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | |||
| * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF | |||
| * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | |||
| * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | |||
| * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT | |||
| * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF | |||
| * SUCH DAMAGE. | |||
| * ==================================================================== | |||
| * | |||
| * This software consists of voluntary contributions made by many | |||
| * individuals on behalf of the Apache Software Foundation. For more | |||
| * information on the Apache Software Foundation, please see | |||
| * <http://www.apache.org/>. | |||
| * | |||
| * Portions of this software are based upon public domain software | |||
| * originally written at the National Center for Supercomputing Applications, | |||
| * University of Illinois, Urbana-Champaign. | |||
| */ | |||
| package org.apache.tools.ant.taskdefs.optional.perforce; | |||
| import org.apache.tools.ant.*; | |||
| /* P4Reopen - move files to a new changelist | |||
| * | |||
| * @author <A HREF="mailto:leslie.hughes@rubus.com">Les Hughes</A> | |||
| */ | |||
| public class P4Reopen extends P4Base { | |||
| private String toChange = ""; | |||
| public void setToChange(String toChange) throws BuildException { | |||
| if(toChange == null && !toChange.equals("")) | |||
| throw new BuildException("P4Reopen: tochange cannot be null or empty"); | |||
| this.toChange = toChange; | |||
| } | |||
| public void execute() throws BuildException { | |||
| if(P4View == null) if(P4View == null) throw new BuildException("No view specified to reopen"); | |||
| execP4Command("-s reopen -c "+toChange+" "+P4View, new SimpleP4OutputHandler(this)); | |||
| } | |||
| } | |||
| @@ -0,0 +1,100 @@ | |||
| /* | |||
| * The Apache Software License, Version 1.1 | |||
| * | |||
| * Copyright (c) 2000 The Apache Software Foundation. All rights | |||
| * reserved. | |||
| * | |||
| * Redistribution and use in source and binary forms, with or without | |||
| * modification, are permitted provided that the following conditions | |||
| * are met: | |||
| * | |||
| * 1. Redistributions of source code must retain the above copyright | |||
| * notice, this list of conditions and the following disclaimer. | |||
| * | |||
| * 2. Redistributions in binary form must reproduce the above copyright | |||
| * notice, this list of conditions and the following disclaimer in | |||
| * the documentation and/or other materials provided with the | |||
| * distribution. | |||
| * | |||
| * 3. The end-user documentation included with the redistribution, if | |||
| * any, must include the following acknowlegement: | |||
| * "This product includes software developed by the | |||
| * Apache Software Foundation (http://www.apache.org/)." | |||
| * Alternately, this acknowlegement may appear in the software itself, | |||
| * if and wherever such third-party acknowlegements normally appear. | |||
| * | |||
| * 4. The names "The Jakarta Project", "Ant", and "Apache Software | |||
| * Foundation" must not be used to endorse or promote products derived | |||
| * from this software without prior written permission. For written | |||
| * permission, please contact apache@apache.org. | |||
| * | |||
| * 5. Products derived from this software may not be called "Apache" | |||
| * nor may "Apache" appear in their names without prior written | |||
| * permission of the Apache Group. | |||
| * | |||
| * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED | |||
| * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES | |||
| * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | |||
| * DISCLAIMED. IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR | |||
| * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | |||
| * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | |||
| * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF | |||
| * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | |||
| * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | |||
| * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT | |||
| * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF | |||
| * SUCH DAMAGE. | |||
| * ==================================================================== | |||
| * | |||
| * This software consists of voluntary contributions made by many | |||
| * individuals on behalf of the Apache Software Foundation. For more | |||
| * information on the Apache Software Foundation, please see | |||
| * <http://www.apache.org/>. | |||
| * | |||
| * Portions of this software are based upon public domain software | |||
| * originally written at the National Center for Supercomputing Applications, | |||
| * University of Illinois, Urbana-Champaign. | |||
| */ | |||
| package org.apache.tools.ant.taskdefs.optional.perforce; | |||
| import org.apache.tools.ant.*; | |||
| /* P4Revert - revert open files or files in a changelist | |||
| * | |||
| * @author <A HREF="mailto:leslie.hughes@rubus.com">Les Hughes</A> | |||
| */ | |||
| public class P4Revert extends P4Base { | |||
| private String revertChange = null; | |||
| private boolean onlyUnchanged = false; | |||
| public void setChange(String revertChange) throws BuildException { | |||
| if(revertChange == null && !revertChange.equals("")) | |||
| throw new BuildException("P4Revert: change cannot be null or empty"); | |||
| this.revertChange = revertChange; | |||
| } | |||
| public void setRevertOnlyUnchanged(boolean onlyUnchanged) { | |||
| this.onlyUnchanged = onlyUnchanged; | |||
| } | |||
| public void execute() throws BuildException { | |||
| /* Here we can either revert any unchanged files in a changelist | |||
| * or | |||
| * any files regardless of whether they have been changed or not | |||
| * | |||
| * | |||
| * The whole process also accepts a p4 filespec | |||
| */ | |||
| String p4cmd = "-s revert"; | |||
| if(onlyUnchanged) p4cmd+=" -a"; | |||
| if (revertChange != null) p4cmd += " -c "+revertChange; | |||
| execP4Command(p4cmd+" "+P4View, new SimpleP4OutputHandler(this)); | |||
| } | |||
| } | |||