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><a href="#p4counter">P4Counter</a></td> | ||||
<td>Obtain or set the value of a counter</td> | <td>Obtain or set the value of a counter</td> | ||||
</tr> | </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> | </table> | ||||
<h3>General P4 Properties</h3> | <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="p4have" classname="org.apache.tools.ant.taskdefs.optional.perforce.P4Have" /> | ||||
<taskdef name="p4label" classname="org.apache.tools.ant.taskdefs.optional.perforce.P4Label" /> | <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="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> | </pre> | ||||
<hr> | <hr> | ||||
@@ -400,6 +412,79 @@ value of the "last-clean-build" counter: | |||||
<hr> | <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> | <h2><a name="changes">Change History</a></h2> | ||||
<table border="1" cellpadding="2" cellspacing="0"> | <table border="1" cellpadding="2" cellspacing="0"> | ||||
<tr> | <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)); | |||||
} | |||||
} |