Lastest releases (note that it may take up to 1-2 days to be in Maven Central repository):
- 4.0.rc2 (2020-08-16) - see issues and pull requests
- 4.0.rc1 (2020-06-09) - see issues and pull requests
- 3.0 (2016-08-20) - see issues and pull requests
- 3.0.rc1 (2016-04-26) - see issues and pull requests
- 2.11 (2015-04-20) - see issues and pull requests
- 2.10 (2015-03-16) - see issues and pull requests
Table of Contents
Basically, when you are developing a project either in open source or in a company, you often need to add at the top of your source files a license to protect your work. I didn't find any maven plugin on Internet to help you maintain these license headers. By maintaining, i mean checking if the header is here or not, generating a report and of course having the possibility to update / reformat missing license headers.
Features:
-
check
: check if header is missing in some source file -
format
: add headers if missing -
remove
: can remove existing header -
update
: update existing header with a new one -
custom mappings
: enables easy support of new file extensions -
variable replacement
: You can add some variable in your header, such as ${year}, ${owner} and they will be replaced by the corresponding values taken from the pom or system properties.
Project:
- Build Status:
- Issues: https://github.com/mycila/license-maven-plugin/issues
- License: Apache License 2.0
Contributors
- @mathieucarbou
- @sebhoss
- @ppalaga
- @McFoggy
- @eincs
- @mcculls
- @stain
- @adamretter
- @vromero
- @hgschmie
- @mirabilos
Releases
Available in Maven Central Repository: https://repo1.maven.org/maven2/com/mycila/license-maven-plugin/
Snapshots
Available in OSS Repository: https://oss.sonatype.org/content/repositories/snapshots/com/mycila/license-maven-plugin/
Plugin declaration
<plugin>
<groupId>com.mycila</groupId>
<artifactId>license-maven-plugin</artifactId>
<version>X.Y.ga</version>
<configuration>
<licenseSets>
<licenseSet>
<header>com/mycila/maven/plugin/license/templates/APACHE-2.txt</header>
<excludes>
<exclude>**/README</exclude>
<exclude>src/test/resources/**</exclude>
<exclude>src/main/resources/**</exclude>
</excludes>
</licenseSet>
</licenseSets>
<properties>
<owner>Mycila</owner>
<email>[email protected]</email>
</properties>
</configuration>
<executions>
<execution>
<goals>
<goal>check</goal>
</goals>
</execution>
</executions>
</plugin>
Plugin declaration (Multi-Licensing)
If your source code makes use of multi-licensing, then instead of
a <header>
or <inlineHeader>
element in the configuration
you can use a <multi>
element.
The <multi>
element allows you to specify an optional preamble,
one or more header (or inlineHeader) and separators between them. These
options are concatenated together to produce a header template.
<plugin>
<groupId>com.mycila</groupId>
<artifactId>license-maven-plugin</artifactId>
<version>X.Y.ga</version>
<configuration>
<licenseSets>
<licenseSet>
<multi>
<preamble><![CDATA[This product is dual-licensed under both the GPLv2 and Apache 2.0 License.]]></preamble>
<header>GPL-2.txt</header>
<separator>======================================================================</separator>
<header>com/mycila/maven/plugin/license/templates/APACHE-2.txt</header>
</multi>
<excludes>
<exclude>**/README</exclude>
<exclude>src/test/resources/**</exclude>
<exclude>src/main/resources/**</exclude>
</excludes>
</licenseSet>
</licenseSets>
<properties>
<owner>Mycila</owner>
<email>[email protected]</email>
</properties>
</configuration>
<executions>
<execution>
<goals>
<goal>check</goal>
</goals>
</execution>
</executions>
</plugin>
The detailed Maven Plugin Documentation generated for each build is available here:
NOTE: Between versions 4.0 and 3.0 the configuration syntax has been changed. The
plugin now has the concept of License Sets, which allow you to work with one or
more license configurations in a single execution of the plugin. In simple terms, a <licenseSet>
wraps the previous configuration options for a license. The previous
configuration syntax is still supported but deprecated, and may be removed in future.
WARNING: there is good chances the latest version is greater than latest documentation, if nothing has changed concerning the plugin configurations.
license:check
: verify if some files miss license header. This goal is attached to the verify phase if declared in your pom.xml like above.license:format
: add the license header when missing. If a header is existing, it is updated to the new one.license:remove
: remove existing license header
The table below shows all the available options you can use in the configure section of the plugin. A lot of are also available from the command-line. To use them, simply launch your maven command with a property like -Dproperty=value
(i.e. mvn license:check -Dlicense.header=src/etc/header.txt
)
All plugin configuration options are described in the Detailed Maven documentation but here are some details.
useDefaultExcludes
: The default exclusion list can be found here
Maven license plugin comes with the following license templates:
- AGPL 3
- APACHE 2
- BSD 2, 3, 4
- Business Source License 1.1
- Commons Clause
- CPAL 1
- GPL 2-ONLY, 2, 3-ONLY, 3
- LGPL 2.1-ONLY, 2.1, 3-ONLY, 3
- MirOS
- MIT
- MPL 1, 2
- Server Side Public License
- UNLICENSE
- WTFPL
You can find those license templates with preconfigured placeholders here
Properties which can be used as placeholder comes from:
- Environment variables
- POM properties
project.groupId
project.artifactId
project.version
project.name
project.description
project.inceptionYear
project.url
- Per-Document properties
file.name
- Plugin configuration properties (from
<properties>
tag) - System properties
Properties are built per-document. You can provide a dependency JAR file to the plugin which contains an implementation of com.mycila.maven.plugin.license.PropertiesProvider
:
public interface PropertiesProvider {
Map<String, String> getAdditionalProperties(AbstractLicenseMojo mojo, Properties currentProperties, Document document);
}
You have access to the Mojo, the current built properties and the document being checked or formatted. The plugin uses the JDK ServiceLoader mechanism to find all PropertiesProvider
implementations on the plugin classpath and execute them. Thus, just add the implementation class name in the file META-INF/services/com.mycila.maven.plugin.license.PropertiesProvider
in your JAR file.
The plugin has been designed so that it is very easy to add new supports for new sorts of comment. The plugin currently support these types of comment:
-
JAVADOC_STYLE
(Java-like comments): *.groovy, *.css, *.cs, *.as, *.aj, *.c, *.h, *.cpp/** * My comment */
-
JAVAPKG_STYLE
(like Javadoc, but only for files that are in a Java package, skips the first line): not assigned to a file extension by default (see Java packages below for how to enable it)package com.example; /*- * My comment */
-
XML_STYLE
(XML-like comments): *.pom, *.xml, *.xhtml, *.mxml, *.dtd, *.xsd, *.jspx, *.fml, *.xsl, *.html, *.htm, *.kml, *.gsp, *.tld<!-- My comment -->
-
XML_PER_LINE
(alternate XML-like comments)<!-- My first comment --> <!-- My second comment -->
(automatically right-adjusts the closing comment)
-
DOUBLETILDE_STYLE
(APT-like comments): *.apt~~ My comment
-
SCRIPT_STYLE
(Property file or shell comments): *.properties, *.sh, *.py, *.rb, *.pl, *.pm, *.yml, *.yaml# My comment
-
HAML_STYLE
: *.haml, *.scaml-# My comment
-
BATCH
(Windows batch comments): *.bat, *.cmd@REM My comment
-
TEXT
(Text like comments): *.txt==== My comment ====
(4 spaces, then the lines of the header)
-
DOUBLEDASHES_STYLE
(Sql like comments): *.sql, *.adb, *.ads, *.e-- -- test comment --
-
DYNASCRIPT_STYLE
(JSP like comments): *.jsp<%-- comment --%>
-
FTL
(FreeMarker like comments): *.ftl<#-- comment -->
-
FTL_ALT
(FreeMarker Alternative Syntax comments)[#ftl ...] [#-- comment --]
-
SHARPSTAR_STYLE
(Velocity templates comments): *.vm#* comment *#
-
SEMICOLON_STYLE
(Assembler like comments): *.asm; ; comment ;
-
BRACESSTAR_STYLE
(Delphi like comments): *.pas{* * comment *}
-
APOSTROPHE_STYLE
(VisualBasic like comments): *.bas' ' comment '
-
EXCLAMATION_STYLE
(Fortran like comments): *.f! ! comment !
-
SLASHSTAR_STYLE
(JavaScript like comments): *.js, *.java, *.fx/* * comment */
-
DYNASCRIPT3_STYLE
(Coldfusion like comments): *.cfc, *.cfm<!--- comment --->
-
PERCENT_STYLE
(Teχ like comments): *.cls, *.sty, *.tex% comment
-
PERCENT3_STYLE
(Erlang like comments): *.erl, *.hrl%%% %%% comment %%%
-
EXCLAMATION3_STYLE
(Lisp like comments): *.el!!! !!! comment !!!
-
LUA
(Lua like comments): *.lua--[[ comment ]]
-
ASP
(Asp like comments): *.asp<% ' comment %>
-
PHP
(PHP comments): *.php/* * comment */
(inserted after the <?php> tag)
-
DOUBLESLASH_STYLE
(often used comments style)// // comment //
Custom mapping
The plugin enables you to add any other mapping you want.* I.e., if you are developing a Tapestry web application, you may need to add license header in .jwc files and .application files. since these files are xml files, you only need to add in your project pom the following mapping for the license-maven-plugin:
<mapping>
<jwc>XML_STYLE</jwc>
<application>XML_STYLE</application>
<apt.vm>DOUBLETILDE_STYLE</apt.vm>
<vm>SHARPSTAR_STYLE</vm>
<apt>DOUBLETILDE_STYLE</apt>
</mapping>
You can use composed-extensions like *.apt.vm and redefine them, but you will have to nake sure that the mapping of apt.vm
is before the mapping of the vm
extension. The order in the mapping section is important: extensions seen first take precedence.
Java packages
Another use case for custom mappings is when writing Java code in packages; the licence header should come after the package declaration line in this case. Simply add this to the plugin configuration:
<mapping>
<java>JAVAPKG_STYLE</java>
</mapping>
In license-maven-plugin, each header style is defined by patterns to detect it and also strings to insert it correctly in files. If we take for example the Javadoc style header definition. It is defined as follow:
<?xml version="1.0" encoding="ISO-8859-1"?>
<additionalHeaders>
<javadoc_style>
<firstLine>/**</firstLine>
<beforeEachLine> * </beforeEachLine>
<endLine> */</endLine>
<afterEachLine></afterEachLine>
<!--skipLine></skipLine-->
<firstLineDetectionPattern>(\s|\t)*/\*.*$</firstLineDetectionPattern>
<lastLineDetectionPattern>.*\*/(\s|\t)*$</lastLineDetectionPattern>
<allowBlankLines>false</allowBlankLines>
<isMultiline>true</isMultiline>
<padLines>false</padLines>
</javadoc_style>
</additionalHeaders>
And for XML:
<?xml version="1.0" encoding="ISO-8859-1"?>
<additionalHeaders>
<javadoc_style>
<firstLine><![CDATA[<!--\n]]></firstLine>
<beforeEachLine> </beforeEachLine>
<endLine><![CDATA[-->]]></endLine>
<afterEachLine></afterEachLine>
<skipLine><![CDATA[^<\?xml.*>$]]></skipLine>
<firstLineDetectionPattern><![CDATA[(\s|\t)*<!--.*$]]></firstLineDetectionPattern>
<lastLineDetectionPattern><![CDATA[.*-->(\s|\t)*$]]></lastLineDetectionPattern>
<allowBlankLines>false</allowBlankLines>
<isMultiline>true</isMultiline>
<padLines>false</padLines>
</javadoc_style>
</additionalHeaders>
With the headerDefinitions
option, you can redefine existing header styles and also add some if we do not support the styles you want yet. You just have to provide a list of headerDefinition
containing a resource name. Like the header, the resource is searched on the file system, in the classpath of the project, the plugin and also as a URL.
Full Example
This page will show you how you can define extended header definitions to fit your needs. The next example will define headers in a region area allowed in C# source files:
<?xml version="1.0" encoding="ISO-8859-1"?>
<additionalHeaders>
<csregion_style>
<firstLine>#region LicenseEOL/**</firstLine>
<beforeEachLine> * </beforeEachLine>
<endLine> */EOL#endregion</endLine>
<firstLineDetectionPattern>#region.*^EOL/\*\*.*$</firstLineDetectionPattern>
<lastLineDetectionPattern>\*/EOL#endregion"</lastLineDetectionPattern>
<allowBlankLines>true</allowBlankLines>
<isMultiline>true</isMultiline>
</csregion_style>
</additionalHeaders>
- The
EOL
string will be replaced with the proper end of line depending the file format your are processing. - We also have defined the skipLine attribute to skip the region tags (which starts with a '#')
allowBlankLines
allows you to define if this header style supports blank lines in it or not. In example, in XML headers, you could have blank lines after the because XML delimiters delimit a multiline block. When you work with script style comments like in Ruby, Porperties files, the # character delimit a comment for only one line. So when you create the header, for it to be uniform, you place # on each line. So allowBlankLines will be false.isMultiline
specifies if your header has tokens to delimit a multiline comment of if the tokens are a one-line comment. I.E.: XML style comments are multiline whereas script style comment where each line starts with # are not multiline
You now have to add this new header definition file to the plugin configuration. It is done as the following in your pom:
<headerDefinitions>
<headerDefinition>yourdefinition.xml</headerDefinition>
</headerDefinitions>
You now have to add the new mapping for *.cs
files to use this new header definition. It is done as the following in your pom:
<mapping>
<cs>CSREGION_STYLE</cs>
</mapping>
And it should generate headers like:
#region License
/**
* Copyright (C) 2008 http://code.google.com/p/license-maven-plugin/
*
* Licensed 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.
*/
#endregion
- Java 1.8
- Verify with:
mvn -v
that the right version is used - Replace my GPG key (EDEA921A) by yours
Example: 4.0.rc1
mvn release:prepare -DreleaseVersion=4.0.rc1 -Dtag=license-maven-plugin-4.0.rc1 -DdevelopmentVersion=4.0-SNAPSHOT
mvn release:perform -Darguments="-Dgpg.keyname=EDEA921A"
Example: 4.0.rc2
mvn release:prepare -DreleaseVersion=4.0.rc2 -Dtag=license-maven-plugin-4.0.rc2 -DdevelopmentVersion=4.0-SNAPSHOT
mvn release:perform -Darguments="-Dgpg.keyname=EDEA921A -Dgpg.passphrase=XYZ"
Example: 4.0
mvn release:prepare -DreleaseVersion=4.0 -Dtag=license-maven-plugin-4.0 -DdevelopmentVersion=4.1-SNAPSHOT
mvn release:perform -Darguments="-Dgpg.keyname=EDEA921A -Dgpg.passphrase=XYZ"
Then, go to https://oss.sonatype.org/ to "close and release". Then you should see a few minutes later the new version at https://repo1.maven.org/maven2/com/mycila/license-maven-plugin/
mvn clean verify site -DperformRelease=true -Dgpg.skip=true