/*

   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.

 */
package org.apache.batik;

This class defines the Batik version number.
Author:Vincent Hardy
Version:$Id: Version.java 1808978 2017-09-20 09:23:26Z ssteiner $
/** * This class defines the Batik version number. * * @author <a href="mailto:vincent.hardy@sun.com">Vincent Hardy</a> * @version $Id: Version.java 1808978 2017-09-20 09:23:26Z ssteiner $ */
public final class Version {
Returns the Batik version.

This is based on the Implementation-Version attribute in the batik-util.jar (which is where this Version class lives) and the 'HeadURL' SVN keyword. The keyword be substituted with the URL of this file, which is then inspected to determine if this file was compiled from the trunk, a tag (a release version), or a branch. The format of the returned string will be one of the following:

Source Version string
Release version version
Trunk version+rrevision
Branch version+rrevision; branch-name
Unknown development version

Prior to release 1.7, the version string would be the straight tag (e.g. "batik-1_6") or the string "development.version". revision is the Subversion working copy's revision number.

/** * Returns the Batik version. * <p> * This is based on the Implementation-Version attribute in the * batik-util.jar (which is where this Version class lives) and * the 'HeadURL' SVN keyword. The keyword be substituted with * the URL of this file, which is then inspected to determine if this * file was compiled from the trunk, a tag (a release version), or a * branch. The format of the returned string will be one of the * following: * </p> * <table summary=""> * <tr> * <th>Source</th> * <th>Version string</th> * </tr> * <tr> * <td>Release version</td> * <td><em>version</em></td> * </tr> * <tr> * <td>Trunk</td> * <td><em>version</em>+r<em>revision</em></td> * </tr> * <tr> * <td>Branch</td> * <td><em>version</em>+r<em>revision</em>; <em>branch-name</em></td> * </tr> * <tr> * <td>Unknown</td> * <td>development version</td> * </tr> * </table> * <p> * Prior to release 1.7, the version string would * be the straight tag (e.g. <code>"batik-1_6"</code>) or the * string <code>"development.version"</code>. <em>revision</em> is the * Subversion working copy's revision number. * </p> */
public static String getVersion() { Package pkg = Version.class.getPackage(); String version = null; if (pkg != null) { version = pkg.getImplementationVersion(); } String headURL = "$HeadURL: https://svn.apache.org/repos/asf/xmlgraphics/batik/branches/maven/batik-util" + "/src/main/java/org/apache/batik/Version.java $"; String prefix = "$HeadURL: "; String suffix = "/sources/org/apache/batik/Version.java $"; if (headURL.startsWith(prefix) && headURL.endsWith(suffix)) { headURL = headURL.substring (prefix.length(), headURL.length() - suffix.length()); if (!headURL.endsWith("/trunk")) { int index1 = headURL.lastIndexOf('/'); int index2 = headURL.lastIndexOf('/', index1 - 1); String name = headURL.substring(index1 + 1); String type = headURL.substring(index2 + 1, index1); String tagPrefix = "batik-"; if (type.equals("tags") && name.startsWith(tagPrefix)) { // Release, just use the tag name version = name.substring(tagPrefix.length()) .replace('_', '.'); } else if (type.equals("branches")) { // SVN branch version += "; " + name; } } } if (version == null) { version = "development version"; } return version; } }