001 package org.apache.maven.lifecycle.internal; 002 003 /* 004 * Licensed to the Apache Software Foundation (ASF) under one 005 * or more contributor license agreements. See the NOTICE file 006 * distributed with this work for additional information 007 * regarding copyright ownership. The ASF licenses this file 008 * to you under the Apache License, Version 2.0 (the 009 * "License"); you may not use this file except in compliance 010 * with the License. You may obtain a copy of the License at 011 * 012 * http://www.apache.org/licenses/LICENSE-2.0 013 * 014 * Unless required by applicable law or agreed to in writing, 015 * software distributed under the License is distributed on an 016 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 017 * KIND, either express or implied. See the License for the 018 * specific language governing permissions and limitations 019 * under the License. 020 */ 021 022 import org.apache.maven.lifecycle.Schedule; 023 import org.apache.maven.model.Plugin; 024 import org.apache.maven.plugin.MojoExecution; 025 import org.apache.maven.plugin.descriptor.MojoDescriptor; 026 027 import java.util.concurrent.CountDownLatch; 028 029 /** 030 * Wraps individual MojoExecutions, containing information about completion status and scheduling. 031 * <p/> 032 * NOTE: This class is not part of any public api and can be changed or deleted without prior notice. 033 * 034 * @since 3.0 035 * @author Kristian Rosenvold 036 */ 037 public class ExecutionPlanItem 038 { 039 private final MojoExecution mojoExecution; 040 041 private final Schedule schedule; 042 // Completeness just indicates that it has been run or failed 043 044 private final CountDownLatch done = new CountDownLatch( 1 ); 045 046 public ExecutionPlanItem( MojoExecution mojoExecution, Schedule schedule ) 047 { 048 this.mojoExecution = mojoExecution; 049 this.schedule = schedule; 050 } 051 052 public MojoExecution getMojoExecution() 053 { 054 return mojoExecution; 055 } 056 057 public String getLifecyclePhase() 058 { 059 return mojoExecution.getLifecyclePhase(); 060 } 061 062 public void setComplete() 063 { 064 done.countDown(); 065 } 066 067 public boolean isDone() 068 { 069 return done.getCount() < 1; 070 } 071 072 public void forceComplete() 073 { 074 setComplete(); 075 } 076 077 public void waitUntilDone() 078 throws InterruptedException 079 { 080 done.await(); 081 } 082 083 public Schedule getSchedule() 084 { 085 return schedule; 086 } 087 088 public Plugin getPlugin() 089 { 090 final MojoDescriptor mojoDescriptor = getMojoExecution().getMojoDescriptor(); 091 return mojoDescriptor.getPluginDescriptor().getPlugin(); 092 } 093 094 @Override 095 public String toString() 096 { 097 return "ExecutionPlanItem{" + ", mojoExecution=" + mojoExecution + ", schedule=" + schedule + '}' 098 + super.toString(); 099 } 100 101 }