01: /********************************************************************************
02: * CruiseControl, a Continuous Integration Toolkit
03: * Copyright (c) 2001, ThoughtWorks, Inc.
04: * 200 E. Randolph, 25th Floor
05: * Chicago, IL 60601 USA
06: * All rights reserved.
07: *
08: * Redistribution and use in source and binary forms, with or without
09: * modification, are permitted provided that the following conditions
10: * are met:
11: *
12: * + Redistributions of source code must retain the above copyright
13: * notice, this list of conditions and the following disclaimer.
14: *
15: * + Redistributions in binary form must reproduce the above
16: * copyright notice, this list of conditions and the following
17: * disclaimer in the documentation and/or other materials provided
18: * with the distribution.
19: *
20: * + Neither the name of ThoughtWorks, Inc., CruiseControl, nor the
21: * names of its contributors may be used to endorse or promote
22: * products derived from this software without specific prior
23: * written permission.
24: *
25: * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
26: * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
27: * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
28: * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR
29: * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
30: * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
31: * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
32: * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
33: * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
34: * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
35: * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
36: ********************************************************************************/package net.sourceforge.cruisecontrol;
37:
38: import net.sourceforge.cruisecontrol.util.threadpool.WorkerThread;
39:
40: import org.apache.log4j.Logger;
41:
42: /**
43: * A thin wrapper around a Project object
44: * all it is designed to do is run the Project in it's own thread
45: *
46: * @author Jared Richardson
47: */
48:
49: public class ProjectWrapper implements WorkerThread {
50:
51: private ProjectInterface myProject = null;
52: private static final Logger LOG = Logger
53: .getLogger(ProjectWrapper.class);
54: private boolean doneBuilding;
55: private Object doneBuildingMutex = new Object();
56:
57: public ProjectWrapper(ProjectInterface this Project) {
58: if (this Project == null) {
59: throw new IllegalArgumentException("null thisProject");
60: }
61: LOG.debug("Project " + this Project.getName()
62: + " is being wrapped");
63: myProject = this Project;
64: }
65:
66: public void run() {
67: LOG.debug("executing project " + myProject.getName());
68: try {
69: myProject.execute();
70: } finally {
71: setDoneBuilding(true);
72: }
73: }
74:
75: public Object getResult() {
76: if (doneBuilding()) {
77: return "finished";
78: } else {
79: return null;
80: }
81: }
82:
83: private void setDoneBuilding(boolean done) {
84: synchronized (doneBuildingMutex) {
85: doneBuilding = done;
86: }
87: }
88:
89: private boolean doneBuilding() {
90: synchronized (doneBuildingMutex) {
91: return doneBuilding;
92: }
93: }
94:
95: public String getName() {
96: return myProject.getName();
97: }
98:
99: }
|