001package 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 022import java.util.ArrayList; 023import java.util.Collections; 024import java.util.HashMap; 025import java.util.HashSet; 026import java.util.Iterator; 027import java.util.List; 028import java.util.Map; 029import java.util.Set; 030 031import org.apache.maven.artifact.ArtifactUtils; 032import org.apache.maven.execution.MavenSession; 033import org.apache.maven.project.MavenProject; 034 035/** 036 * A list of project segments, ordered so that all ProjectSegments from first TaskSegment come before any 037 * subsequent TaskSegments. 038 * 039 * @since 3.0 040 * @author Kristian Rosenvold 041 * <p/> 042 * NOTE: This class is not part of any public api and can be changed or deleted without prior notice. 043 */ 044public class ProjectBuildList 045 implements Iterable<ProjectSegment> 046{ 047 private final List<ProjectSegment> items; 048 049 public ProjectBuildList( List<ProjectSegment> items ) 050 { 051 this.items = Collections.unmodifiableList( items ); 052 } 053 054 // TODO: Optimize; or maybe just rewrite the whole way aggregating mojos are being run. 055 /** 056 * Returns aProjectBuildList that contains only items for the specified taskSegment 057 * @param taskSegment the requested tasksegment 058 * @return a project build list for the supplied task segment 059 */ 060 public ProjectBuildList getByTaskSegment( TaskSegment taskSegment ) 061 { 062 List<ProjectSegment> currentSegment = new ArrayList<>(); 063 for ( ProjectSegment projectBuild : items ) 064 { 065 if ( taskSegment == projectBuild.getTaskSegment() ) 066 { // NOTE: There's no notion of taskSegment equality. 067 currentSegment.add( projectBuild ); 068 } 069 } 070 return new ProjectBuildList( currentSegment ); 071 } 072 073 public Map<MavenProject, ProjectSegment> selectSegment( TaskSegment taskSegment ) 074 { 075 Map<MavenProject, ProjectSegment> result = new HashMap<>(); 076 for ( ProjectSegment projectBuild : items ) 077 { 078 if ( taskSegment == projectBuild.getTaskSegment() ) 079 { // NOTE: There's no notion of taskSegment equality. 080 result.put( projectBuild.getProject(), projectBuild ); 081 } 082 } 083 return result; 084 } 085 086 /** 087 * Finds the first ProjectSegment matching the supplied project 088 * @param mavenProject the requested project 089 * @return The projectSegment or null. 090 */ 091 public ProjectSegment findByMavenProject( MavenProject mavenProject ) 092 { 093 for ( ProjectSegment projectBuild : items ) 094 { 095 if ( mavenProject.equals( projectBuild.getProject() ) ) 096 { 097 return projectBuild; 098 } 099 } 100 return null; 101 } 102 103 public Iterator<ProjectSegment> iterator() 104 { 105 return items.iterator(); 106 } 107 108 public void closeAll() 109 { 110 for ( ProjectSegment item : items ) 111 { 112 MavenSession sessionForThisModule = item.getSession(); 113 sessionForThisModule.setCurrentProject( null ); 114 } 115 } 116 117 public int size() 118 { 119 return items.size(); 120 } 121 122 public ProjectSegment get( int index ) 123 { 124 return items.get( index ); 125 } 126 127 public Set<String> getReactorProjectKeys() 128 { 129 Set<String> projectKeys = new HashSet<>( items.size() * 2 ); 130 for ( ProjectSegment projectBuild : items ) 131 { 132 MavenProject project = projectBuild.getProject(); 133 String key = ArtifactUtils.key( project.getGroupId(), project.getArtifactId(), project.getVersion() ); 134 projectKeys.add( key ); 135 } 136 return projectKeys; 137 } 138 139 140 public boolean isEmpty() 141 { 142 return items.isEmpty(); 143 } 144 145 /** 146 * @return a set of all the projects managed by the build 147 */ 148 public Set<MavenProject> getProjects() 149 { 150 Set<MavenProject> projects = new HashSet<>(); 151 152 for ( ProjectSegment s : items ) 153 { 154 projects.add( s.getProject() ); 155 } 156 return projects; 157 } 158}