
org.apache.maven.plugin.eclipse.EclipseSourceDir Maven / Gradle / Ivy
package org.apache.maven.plugin.eclipse;
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
import java.util.ArrayList;
import java.util.LinkedHashSet;
import java.util.List;
import java.util.Set;
import org.apache.maven.plugin.MojoExecutionException;
import org.apache.maven.plugin.ide.IdeUtils;
import org.codehaus.plexus.util.StringUtils;
/**
* Represent an eclipse source dir. Eclipse has no "main", "test" or "resource" concepts, so two source dirs with the
* same path are equal.
*
* source directories should always have a null output value.
*
* @author Fabrizio Giustina
* @version $Id$
*/
public class EclipseSourceDir
implements Comparable
{
private static final String PATTERN_SEPARATOR = "|";
private String path;
/**
* source directories should always have a null output value.
*/
private String output;
private List include;
private List exclude;
private boolean isResource;
private boolean test;
private boolean filtering;
private boolean attached;
/**
* @param path the eclipse source directory
* @param output path output directory
* @param isResource true if the directory only contains resources, false if a compilation directory
* @param test true if is a test directory, false otherwise
* @param include a string in the eclipse pattern format for the include filter
* @param exclude a string in the eclipse pattern format for the exclude filter
* @param filtering true if filtering should be applied, false otherwise. Note: Filtering will only be applied if
* this become a "special directory" by being nested within the default output directory.
* @param attached true if a a directory attached by a plugin or build helper, false if directly
* configured in the build section of the pom
*/
public EclipseSourceDir( String path, String output, boolean isResource, boolean test, List include,
List exclude, boolean filtering, boolean attached )
{
setPath( path );
this.output = output;
this.isResource = isResource;
this.test = test;
setInclude( include );
setExclude( exclude );
this.filtering = filtering;
this.attached = attached;
}
/**
* Getter for exclude
.
*
* @return Returns the exclude. Never null.
*/
public List getExclude()
{
return this.exclude;
}
/**
* Setter for exclude
.
*
* @param exclude The exclude to set.
*/
public void setExclude( List exclude )
{
this.exclude = new ArrayList<>();
if ( exclude != null )
{
this.exclude.addAll( exclude );
}
}
/**
* Getter for include
.
*
* @return Returns the include. Never null.
*/
public List getInclude()
{
return this.include;
}
/**
* Setter for include
.
*
* @param include The include to set.
*/
public void setInclude( List include )
{
this.include = new ArrayList<>();
if ( include != null )
{
this.include.addAll( include );
}
}
/**
* @return Returns the exclude as a string pattern suitable for eclipse
*/
public String getExcludeAsString()
{
return StringUtils.join( exclude.iterator(), PATTERN_SEPARATOR );
}
/**
* @return Returns the include as a string pattern suitable for eclipse
*/
public String getIncludeAsString()
{
return StringUtils.join( include.iterator(), PATTERN_SEPARATOR );
}
/**
* Getter for output
.
*
* source directories should always have a null output value.
*
* @return Returns the output.
*/
public String getOutput()
{
return this.output;
}
/**
* Setter for output
.
*
* @param output The output to set.
*/
public void setOutput( String output )
{
this.output = output;
}
/**
* Getter for path
.
*
* @return Returns the path.
*/
public String getPath()
{
return this.path;
}
/**
* Setter for path
. Converts \\ to / in path.
*
* @param path The path to set.
*/
public void setPath( String path )
{
this.path = IdeUtils.fixSeparator( path );
}
/**
* Getter for test
.
*
* @return Returns the test.
*/
public boolean isTest()
{
return this.test;
}
/**
* Setter for test
.
*
* @param test The test to set.
*/
public void setTest( boolean test )
{
this.test = test;
}
/**
* Getter for isResource
.
*
* @return the isResource
*/
public boolean isResource()
{
return this.isResource;
}
/**
* Whether this resource should be copied with filtering.
*
* @return whether this resource should be copied with filtering
*/
public boolean isFiltering()
{
return filtering;
}
/**
* Whether this resource should be copied with filtering.
*
* @param filtering filter resources
*/
public void setFiltering( boolean filtering )
{
this.filtering = filtering;
}
/**
* Getter for attached
.
*
* @return the attached
*/
public boolean isAttached()
{
return attached;
}
/**
* Setter for attached
.
*
* @param attached The attached to set.
*/
public void setAttached( boolean attached )
{
this.attached = attached;
}
/**
* @see java.lang.Object#equals(java.lang.Object)
*/
@Override
public boolean equals( Object obj )
{
if ( obj == this )
{
return true;
}
if ( !(obj instanceof EclipseSourceDir) )
{
return false;
}
EclipseSourceDir other = (EclipseSourceDir) obj;
return this.path.equals( other.path );
}
/**
* @see java.lang.Object#hashCode()
*/
@Override
public int hashCode()
{
return this.path.hashCode();
}
/**
* @see java.lang.Comparable#compareTo(java.lang.Object)
*/
@Override
public int compareTo( EclipseSourceDir obj )
{
return this.path.compareTo( obj.path );
}
/**
* {@inheritDoc}
*/
@Override
public String toString()
{
return ( isResource ? "resource " : "source " ) + path + ": "
+ "output=" + output + ", "
+ "include=[" + getIncludeAsString() + "], "
+ "exclude=[" + getExcludeAsString() + "], "
+ "test=" + test + ", "
+ "filtering=" + filtering + ", "
+ "attached=" + attached;
}
/**
* Merge with the provided directory.
*
* If one directory is a source and the other is a resource directory then the result will be a source directory and
* any includes or excludes will be removed since Eclipse has no "main", "test" or "resource" concepts. The output
* directory will be the source directories value.
*
* If the two directories are the same resources type (i.e isResource is equal) then the result will be the same
* resource type with the includes from each merged together (duplicates will be removed), similarly for the
* excludes. No effort is made to ensure that the includes and excludes are disjointed sets. Please fix your pom
* instead.
*
* No support for cases where the test, or filtering values are not identical.
*
* @param mergeWith the directory to merge with
* @throws MojoExecutionException test or filtering values are not identical, or isResource true and output are not
* identical
* @return whether the merge was successful
*/
public boolean merge( EclipseSourceDir mergeWith )
throws MojoExecutionException
{
if ( isResource != mergeWith.isResource )
{
if ( isResource )
{
// the output directory is set to the source directory's value
output = mergeWith.output;
}
isResource = false;
setInclude( null );
setExclude( null );
}
else
{
Set includesAsSet = new LinkedHashSet<>();
// if the orginal or merged dir have an empty "include" this means all is included,
// so merge includes only if both are not empty
if ( !include.isEmpty() && !mergeWith.include.isEmpty() )
{
includesAsSet.addAll( include );
includesAsSet.addAll( mergeWith.include );
}
include = new ArrayList<>( includesAsSet );
Set excludesAsSet = new LinkedHashSet<>();
excludesAsSet.addAll( exclude );
excludesAsSet.addAll( mergeWith.exclude );
exclude = new ArrayList<>( excludesAsSet );
}
if ( !StringUtils.equals( output, mergeWith.output ) )
{
// Request to merge when 'output' is not identical
return false;
}
if ( test != mergeWith.test )
{
// Request to merge when 'test' is not identical
return false;
}
if ( filtering != mergeWith.filtering )
{
// Request to merge when 'filtering' is not identical
return false;
}
return true;
}
}