| %line | %branch | |||||||||
|---|---|---|---|---|---|---|---|---|---|---|
| nl.toolforge.karma.core.vc.PatchLine |
|
|
| 1 | /* |
|
| 2 | Karma core - Core of the Karma application |
|
| 3 | Copyright (C) 2004 Toolforge <www.toolforge.nl> |
|
| 4 | ||
| 5 | This library is free software; you can redistribute it and/or |
|
| 6 | modify it under the terms of the GNU Lesser General Public |
|
| 7 | License as published by the Free Software Foundation; either |
|
| 8 | version 2.1 of the License, or (at your option) any later version. |
|
| 9 | ||
| 10 | This library is distributed in the hope that it will be useful, |
|
| 11 | but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
| 12 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
|
| 13 | Lesser General Public License for more details. |
|
| 14 | ||
| 15 | You should have received a copy of the GNU Lesser General Public |
|
| 16 | License along with this library; if not, write to the Free Software |
|
| 17 | Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
|
| 18 | */ |
|
| 19 | package nl.toolforge.karma.core.vc; |
|
| 20 | ||
| 21 | import nl.toolforge.karma.core.Patch; |
|
| 22 | import nl.toolforge.karma.core.Version; |
|
| 23 | ||
| 24 | /** |
|
| 25 | * A <code>PatchLine</code> is a special type of <code>DevelopmentLine</code>, used when a module has been released to |
|
| 26 | * (for example) the test department. NIET_WEG. |
|
| 27 | * |
|
| 28 | * @author D.A. Smedes |
|
| 29 | * @version $Id: PatchLine.java,v 1.8 2004/10/26 22:45:21 hippe Exp $ |
|
| 30 | */ |
|
| 31 | public class PatchLine extends DevelopmentLine { |
|
| 32 | ||
| 33 | /** |
|
| 34 | * Name prefix for the symbolic name that is applied to the module when a patchline is created. A symbolic name |
|
| 35 | * would look like this : <code>PATCHLINE_0-2</code>, indicating that a patchline is created for |
|
| 36 | * version <code>0-2</code>. |
|
| 37 | */ |
|
| 38 | public static final String NAME_PREFIX = "PATCHLINE"; |
|
| 39 | ||
| 40 | public static final String VERSION_SEPARATOR_PATTERN = "_"; |
|
| 41 | public static final String VERSION_SEPARATOR = "_"; |
|
| 42 | ||
| 43 | public static final String PATCH_SEPARATOR_PATTERN = "_"; |
|
| 44 | public static final String PATCH_SEPARATOR = "_"; |
|
| 45 | ||
| 46 | 165 | private Version version = null; |
| 47 | ||
| 48 | /** |
|
| 49 | * Creates a PatchLine for version <code>version</code>. |
|
| 50 | * |
|
| 51 | * @param version The version for which a PatchLine must be created. |
|
| 52 | */ |
|
| 53 | public PatchLine(Version version) { |
|
| 54 | 165 | super(NAME_PREFIX + VERSION_SEPARATOR + version.getVersionNumber()); |
| 55 | ||
| 56 | 165 | this.version = version; |
| 57 | 165 | } |
| 58 | ||
| 59 | public String getPatternString() { |
|
| 60 | 165 | return NAME_PREFIX + VERSION_SEPARATOR_PATTERN + Version.VERSION_PATTERN_STRING; |
| 61 | } |
|
| 62 | ||
| 63 | /** |
|
| 64 | * Given the patch line for a module, a matching pattern is required to select the corresponding patch versions. A |
|
| 65 | * patch line <code>PATCHLINE_0-0</code> will generate patch versions like <code>PATCHLINE_0-0-1</code>, |
|
| 66 | * <code>PATCHLINE_0-0-2</code> etc. This method will then return the following pattern string : |
|
| 67 | * <code>PATCHLINE_0-0-\d{1,4}</code> |
|
| 68 | * |
|
| 69 | * @return See the method description. |
|
| 70 | */ |
|
| 71 | public String getMatchingPattern() { |
|
| 72 | // Something like should be returned, where 0-0 is the version to which the patch applies: PATCHLINE_0-0-{1}\\d{1,2} |
|
| 73 | 0 | return NAME_PREFIX + PATCH_SEPARATOR_PATTERN + version.getVersionNumber() + Patch.PATCH_PATTERN_POSTFIX; |
| 74 | } |
|
| 75 | } |
| This report is generated by jcoverage, Maven and Maven JCoverage Plugin. |