All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.openjpa.conf.Specification Maven / Gradle / Ivy

/*
 * 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.openjpa.conf;

import java.util.Locale;
import java.util.Objects;

import org.apache.openjpa.lib.util.Localizer;
import org.apache.openjpa.util.UserException;

/**
 * An immutable representation of a Specification supported by OpenJPA.
 * 
 * Available via {@linkplain OpenJPAConfiguration#getSpecificationInstance()()} 
 * for configuration that may depend on Specification version.
 * 
 * @author Pinaki Poddar
 *
 */
public class Specification {
    private String _name = "";
    private int    _major = 1;
    private String _minor = "0";
    private String _description = "";
    private Compatibility _compatibility;

    private static Localizer _loc = Localizer.forPackage(Specification.class);
    
    /**
     * Construct from a String that encodes name and version fields.
     * 
     * @param fullName a encoded string in the following prescribed format.
     * name major.minor e.g. JPA 2.0-draft
     * Only the 'name' field is mandatory. 
     * 'major' version defaults to 1 and must be an integer. 
     * 'minor' version defaults to 0 and can be a String. 
     */
    public Specification(String fullName) {
        try {
            Object[] tokens = parse(fullName);
            _name = tokens[0].toString();
            _major = tokens.length > 1 ? 
                Integer.parseInt(tokens[1].toString()) : 1;
            _minor = tokens.length > 2 ? tokens[2].toString() : "0";
        } catch (Exception e) {
            throw new UserException(_loc.get("spec-wrong-format", fullName));
        }
    }
    
    public String getName() {
        return _name;
    }
    
    public int getVersion() {
        return _major;
    }
    
    public String getMinorVersion() {
        return _minor;
    }
    
    public String getDescription() {
        return _description;
    }
    
    public Specification setDescription(String description) {
        this._description = description;
        return this;
    }
    
    /**
     * Affirms if the given argument is equal to this receiver.
     */
    public boolean equals(Object other) {
        if (this == other)
            return true;
        if (other == null || !this.getClass().isInstance(other))
            return false;
        Specification that = (Specification)other;
        return Objects.equals(_name, this._name) && _major == that._major
            && Objects.equals(_minor, this._minor);
    }    
    
    /**
     * Affirms if the given specification has the same name of this receiver,
     * ignoring the case.
     */
    public boolean isSame(Specification other) {
        return this == other 
            || (other != null && _name.equalsIgnoreCase(other._name));
    }
    
    /**
     * Affirms if the given string equals name of this receiver, ignoring the 
     * case.
     */
    public boolean isSame(String other) {
        return _name.equalsIgnoreCase(other);
    }
    
    /**
     * Compares major version number of the given Specification with this 
     * receiver.

     * @return 0 if they are equal.
     *       > 0 if this receiver is higher version.
     *       < 0 if this receiver is lower version.
     */
    public int compareVersion(Specification other) {
        return _major > other._major ? 1 : _major == other._major ? 0 : -1;
    }
    
    public String toString() {
        return _name.toUpperCase(Locale.ENGLISH) + " " + _major + "." + _minor;
    }
    
    private Object[] parse(String str) {
        int space = str.indexOf(' ');
        
        if (space == -1)
            return new Object[]{str};
        String name = str.substring(0,space);
        String version = str.substring(space+1);
        int dot = version.indexOf('.');
        if (dot == -1)
            return new Object[] {name, version};
        return new Object[] {name, 
            version.substring(0,dot), version.substring(dot+1)};
    }
    
    /**
     * Associate a compatibility object with this Specification instance
     * @param compatibility a Compatibility object with flags set in compliance
     * with this Specification instance.
     */
    public void setCompatibility(Compatibility compatibility) {
        _compatibility = compatibility;
    }
    
    /**
     * Return the compatibility object associated with this Specification instance.
     */
    public Compatibility getCompatibility() {
        return _compatibility;
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy