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

com.basistech.util.Pathnames Maven / Gradle / Ivy

/*
* Copyright 2014 Basis Technology Corp.
*
* 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.basistech.util;

import java.io.File;
import java.io.FileFilter;
import java.text.MessageFormat;

/**
 * This class retrieves pathnames commonly used in Basis products. It is non-static to allow for some control
 * of initialization order.
 */
public class Pathnames {

    private static String btRootDirectory;

    /**
     * Default constructor.
     */
    public Pathnames() {
    }

    /**
     * Set the Basis root directory (the root of an SDK or runtime installation). This is the parent of the
     * 'rlp' directory. Calling this overrides any setting of the 'bt.root' system property. This operation is
     * typically performed once per application. The value set the first time this is called persists for the
     * duration of the process.
     * 
     * @param path to the BT root directory
     */
    public static void setBTRootDirectory(String path) {
        btRootDirectory = path;
    }
    
    static void reset() {
        btRootDirectory = null; // tests need to put this in a known state.
    }

    static String binOrLib() {
        return System.getProperty("os.name").toLowerCase().indexOf("windows") != -1 ? "bin" : "lib";
    }

    static String debugSuffix() {
        return System.getProperty("debug.level", "").equals("2") ? "_g" : "";
    }

    String getLibraryParentDir() {
        return getBTRootDirectory() + "/rlp/" + binOrLib() + debugSuffix();
    }

    /**
     * Returns the platform string in use by the application. If the bt.arch system property is set, use that.
     * Otherwise, if there is only one directory under btroot/rlp/{bin|lib}, use that. Otherwise, multiple
     * directories exist and IllegalStateException is thrown.
     * 
     * @return the platform string in use
     * @throws IllegalStateException when the platform is undefined
     */
    String getPlatform() {
        String s = System.getProperty("bt.arch");
        if (s == null) {
            String dir = getLibraryParentDir();
            File[] platformDirs = new File(dir).listFiles(new FileFilter() {
                public boolean accept(File f) {
                    return f.isDirectory() & !f.isHidden();
                }
            });
            if (platformDirs == null || platformDirs.length == 0) {
                throw new IllegalStateException(MessageFormat
                    .format("\"{0}\" has no platform subdirectories.  "
                            + "This may be the result of an incorrect setting of bt.root.", dir));
            } else if (platformDirs.length == 1) {
                s = platformDirs[0].getName();
            } else {
                throw new IllegalStateException(MessageFormat
                    .format("Multiple platform subdirectories found under \"{0}\".  "
                            + "bt.arch system property is required.", dir));
            }
        } else if (s.trim().length() == 0) {
            throw new IllegalStateException("bt.arch system property cannot be blank.");
        }

        File dir = new File(getLibraryParentDir() + File.separator + s);
        if (!dir.isDirectory()) {
            throw new IllegalStateException(MessageFormat
                .format("\"{0}\" is not a directory.  "
                        + "This may be the result of an incorrect setting of bt.root or bt.arch.", dir));
        }
        return s;
    }

    /**
     * Retrieve the root of an SDK or runtime installation. This is the parent directory of the 'rlp'
     * directory. If not previously set by calling setBTRootDirectory, this will default to the value of the
     * 'bt.root' system property.
     * 
     * @return the BT root directory
     * @throws NoRootDirectoryException if no root directory has been set.
     */
    public String getBTRootDirectory() {
        if (btRootDirectory != null) {
            return btRootDirectory;
        }
        String r = System.getProperty("bt.root", null);
        if (r == null || r.length() == 0) {
            throw new NoRootDirectoryException();
        }
        return r;
    }

    /**
     * Retrieve the directory within the Basis Technology installation directory where native code libraries
     * are located.
     * 
     * @return the directory for native code libraries
     */
    public String getJNIModuleDirectory() {
        return getLibraryParentDir() + File.separator + getPlatform();
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy