com.google.code.mojo.license.header.AdditionalHeaderDefinition Maven / Gradle / Ivy
/**
* Copyright (C) 2008 http://code.google.com/p/maven-license-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.
*/
package com.google.code.mojo.license.header;
import com.google.code.xmltool.CallBack;
import com.google.code.xmltool.XMLDocument;
import java.util.HashMap;
import java.util.Map;
/**
* The class AdditionalHeaderDefinition
is used to collect header definitions declared in an "external" XML
* document configuration.
*
* The XML document must respect the following XML schema:
* <?xml version="1.0" encoding="UTF-8"?>
* <xs:schema attributeFormDefault="unqualified" elementFormDefault="qualified"
* xmlns:xs="http://www.w3.org/2001/XMLSchema">
* <xs:element name="additionalHeaders" type="additionalHeadersType"/>
* <xs:complexType name="additionalHeadersType">
* <xs:sequence>
* <xs:annotation>
* <xs:documentation>
* Replace typeName tag name with the name of the type of header definition you are defining.
* </xs:documentation>
* </xs:annotation>
* <xs:element type="textType" name="typeName"/>
* </xs:sequence>
* </xs:complexType>
* <xs:complexType name="textType">
* <xs:sequence>
* <xs:annotation>
* <xs:documentation>
* Do not forget that you can use CDATA format as element value.
* </xs:documentation>
* </xs:annotation>
* <xs:element type="xs:string" name="firstLine" minOccurs="1" maxOccurs="1"/>
* <xs:element type="xs:string" name="beforeEachLine" minOccurs="1" maxOccurs="1"/>
* <xs:element type="xs:string" name="endLine" minOccurs="1" maxOccurs="1"/>
* <xs:element type="xs:string" name="skipLine" minOccurs="0" maxOccurs="1"/>
* <xs:element type="xs:string" name="firstLineDetectionPattern" minOccurs="1" maxOccurs="1"/>
* <xs:element type="xs:string" name="lastLineDetectionPattern" minOccurs="1" maxOccurs="1"/>
* </xs:sequence>
* </xs:complexType>
* </xs:schema>
*
*
*
* @author Cedric Pronzato
*/
public final class AdditionalHeaderDefinition {
private final Map definitions = new HashMap();
/**
* Construct an AdditionalHeaderDefinition object using the given XML document as header definitions
* input.
*
* @param doc The XML definition to read.
*/
public AdditionalHeaderDefinition(XMLDocument doc) {
if (doc == null) {
throw new IllegalArgumentException("The header definition XML document cannot be null");
}
doc.gotoRoot().forEachChild(new CallBack() {
public void execute(XMLDocument doc) {
final String type = doc.getCurrentTagName().toLowerCase();
HeaderDefinition definition = definitions.get(type);
if (definition == null) {
definition = new HeaderDefinition(type);
definitions.put(type, definition);
}
doc.forEachChild(new FeedProperty(definition));
definition.validate();
}
});
}
/**
* Returns the header definitions declared by the external header definition as a map using the header type name as
* key.
*
* @return The header definitions declared.
*/
public Map getDefinitions() {
return definitions;
}
private static final class FeedProperty implements CallBack {
private final HeaderDefinition definition;
private FeedProperty(HeaderDefinition definition) {
this.definition = definition;
}
public void execute(XMLDocument xmlDocument) {
String value = xmlDocument.getText();
if ("".equals(value)) // value can't be null
{
value = xmlDocument.getCDATA();
}
definition.setPropertyFromString(xmlDocument.getCurrentTagName(), value);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy