| %line | %branch | |||||||||
|---|---|---|---|---|---|---|---|---|---|---|
| nl.toolforge.karma.core.manifest.ReleaseManifest |
|
|
| 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.manifest; |
|
| 20 | ||
| 21 | import nl.toolforge.karma.core.boot.WorkingContext; |
|
| 22 | import nl.toolforge.karma.core.location.LocationException; |
|
| 23 | import nl.toolforge.karma.core.module.Module; |
|
| 24 | import nl.toolforge.karma.core.vc.cvsimpl.threads.PatchLineThread; |
|
| 25 | import nl.toolforge.karma.core.vc.threads.ParallelRunner; |
|
| 26 | ||
| 27 | /** |
|
| 28 | * A <code>ReleaseManifest</code> is created when the Release Manager collects all stable versions of modules. |
|
| 29 | * Effectively, the latest promoted version of all modules in. |
|
| 30 | * |
|
| 31 | * @author W.H. Schraal |
|
| 32 | * @author D.A. Smedes |
|
| 33 | * @version $Id: ReleaseManifest.java,v 1.20 2004/11/10 23:53:09 asmedes Exp $ |
|
| 34 | */ |
|
| 35 | public final class ReleaseManifest extends AbstractManifest { |
|
| 36 | ||
| 37 | public ReleaseManifest(WorkingContext context, ManifestStructure structure) throws LocationException { |
|
| 38 | 0 | super(context, structure); |
| 39 | ||
| 40 | 20 | // For a release manifest, we need to know if patch lines are available. |
| 41 | // |
|
| 42 | 0 | checkForPatchLines(); |
| 43 | 0 | } |
| 44 | 20 | |
| 45 | 20 | /** |
| 46 | * Checks (in parallel) if modules have a <code>PatchLine</code> associated. |
|
| 47 | */ |
|
| 48 | private void checkForPatchLines() { |
|
| 49 | 0 | ParallelRunner runner = new ParallelRunner(this, PatchLineThread.class); |
| 50 | ||
| 51 | 30 | long delay = 100; |
| 52 | 0 | runner.execute(delay); |
| 53 | 20 | } |
| 54 | 20 | |
| 55 | 20 | public String getType() { |
| 56 | 0 | return Manifest.RELEASE_MANIFEST; |
| 57 | } |
|
| 58 | ||
| 59 | /** |
|
| 60 | * <p>Applies the current working context to a module in this release manifest. |
|
| 61 | * |
|
| 62 | * <p>This method also checks if the module is available locally. If so, the module will be matched with the module |
|
| 63 | * on disk to check if they are equal. This is to ensure that a changed manifest-definition is reflected on disk. If |
|
| 64 | * the manifest shows another module (which is in fact determined by its location), the version on disk will be |
|
| 65 | * removed. |
|
| 66 | */ |
|
| 67 | protected void applyWorkingContext(WorkingContext context, Module module) { |
|
| 68 | 0 | |
| 69 | 0 | module.markDevelopmentLine(false); |
| 70 | 0 | |
| 71 | 50 | if (!isLocal(module)) { |
| 72 | // Module is static by definition when it is not locally available. |
|
| 73 | 50 | // |
| 74 | 0 | setState(module, Module.STATIC); |
| 75 | 0 | } |
| 76 | 50 | } |
| 77 | ||
| 78 | 50 | } |
| This report is generated by jcoverage, Maven and Maven JCoverage Plugin. |