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

src.com.ibm.as400.vaccess.ResourceLoader Maven / Gradle / Ivy

///////////////////////////////////////////////////////////////////////////////
//                                                                             
// JTOpen (IBM Toolbox for Java - OSS version)                              
//                                                                             
// Filename: ResourceLoader.java
//                                                                             
// The source code contained herein is licensed under the IBM Public License   
// Version 1.0, which has been approved by the Open Source Initiative.         
// Copyright (C) 1997-2000 International Business Machines Corporation and     
// others. All rights reserved.                                                
//                                                                             
///////////////////////////////////////////////////////////////////////////////

package com.ibm.as400.vaccess;

import com.ibm.as400.access.Trace;
import javax.swing.Icon;
import javax.swing.ImageIcon;
import java.io.File;
import java.net.URL;
import java.util.MissingResourceException;
import java.util.ResourceBundle;



/**
The ResourceLoader class is used to load the MRI resources.
**/
class ResourceLoader
{
  private static final String copyright = "Copyright (C) 1997-2000 International Business Machines Corporation and others.";




    // Debug flag.  This can be helpful in debugging
    // ExceptionInInitializerError exceptions, which are ususally
    // caused by a resource not being found.  Set this to
    // true and recompile.
    private static final boolean DEBUG_ = false;



    // Private data.
    private static String           genericDescription_         = null;
    private static ResourceBundle   resources_                  = null;
    private static ResourceBundle   printResources_             = null;
    private static ResourceBundle   queryResources_             = null;



/**
Returns an icon.

@param  fileName    The icon file name.
@return             The icon.
**/
    static final Icon getIcon (String fileName)
    {
        return getIcon (fileName, null);
    }



/**
Returns an icon.

@param  fileName    The icon file name.
@param  description The icon description.
@return             The icon.
**/
    static final Icon getIcon (String fileName, String description)
    {
        Icon icon = null;

        if (DEBUG_)
            System.out.println ("ResourceLoader: Loading icon " + fileName + ".");

        try {

            // The generic description is for loading icons.  Aparantly, the
            // description is used in cases like presenting an icon to blind
            // users, etc.  In some cases, we just don't have a description,
            // so we will put up a canned description.
            if (description == null) {
                if (genericDescription_ == null)
                    genericDescription_ = getText ("PRODUCT_TITLE");
                description = genericDescription_;
            }

            URL url = ResourceLoader.class.getResource (fileName);
            if (url == null)
            {
                fileName = "com" + File.separator + "ibm" + File.separator +
                    "as400" + File.separator + "vaccess" + File.separator +
                    fileName;
                icon = new ImageIcon (fileName, description);
            }
            else
            {
                icon = new ImageIcon (url, description);
            }
        }
        catch (Exception e) {
            if (DEBUG_)
                System.out.println ("ResourceLoader: Error: " + e + ".");

            Trace.log (Trace.ERROR, "Icon " + fileName + " not loaded: " + e.getMessage() + ".");
        }

        return icon;
    }



/**
Returns a resource string.

@param key      The key in the MRI resource bundle.
@return         The translatable text.
**/
    static final String getPrintText (String key)
    {
        if (DEBUG_)
            System.out.println ("ResourceLoader: Loading text " + key + ".");

        try {
            // Load the resource bundle the first time.
            if (printResources_ == null)
                printResources_ = ResourceBundle.getBundle ("com.ibm.as400.vaccess.VNPMRI");

            // Load the resource.
            return printResources_.getString (key);
        }
        catch (MissingResourceException e) {
            if (DEBUG_)
                System.out.println ("ResourceLoader: Error: " + e + ".");

            Trace.log (Trace.ERROR, "Error while loading print MRI resource: " + key + ".");
            throw e;
        }
    }



/**
Returns a resource string from the VQRYMRI properties file.

@param key      The key in the MRI resource bundle.
@return         The translatable text.
**/
    static final String getQueryText (String key)
    {
        if (DEBUG_)
            System.out.println ("ResourceLoader: Loading text " + key + ".");

        try {
            // Load the resource bundle the first time.
            if (queryResources_ == null)
                queryResources_ = ResourceBundle.getBundle ("com.ibm.as400.vaccess.VQRYMRI");

            // Load the resource.
            return queryResources_.getString (key);
        }
        catch (MissingResourceException e) {
            if (DEBUG_)
                System.out.println ("ResourceLoader: Error: " + e + ".");

            Trace.log (Trace.ERROR, "Error while loading query MRI resource: " + key + ".");
            throw e;
        }
    }



/**
Returns a resource string.

@param key      The key in the MRI resource bundle.
@return         The translatable text.
**/
    static final String getText (String key)
    {
        if (DEBUG_)
            System.out.println ("ResourceLoader: Loading text " + key + ".");

        try {
            // Load the resource bundle the first time.
            if (resources_ == null)
                resources_ = ResourceBundle.getBundle ("com.ibm.as400.vaccess.VMRI");

            // Load the resource.
            return resources_.getString (key);
        }
        catch (MissingResourceException e) {
            if (DEBUG_)
                System.out.println ("ResourceLoader: Error: " + e + ".");

            Trace.log (Trace.ERROR, "Error while loading MRI resource: " + key + ".");
            throw e;
        }
    }



// @A1A
/**
Replaces a single substitution variable in a string.

@param text     The text string, with a single substitution variable
                (e.g. "Error &0 has occurred.");
@param value    The replacement value.
@return         The text string with the substitution variable
                replaced.
**/
    static String substitute (String text, String value)
    {
        return substitute (text, new String[] { value });
    }



// @A1A
/**
Replaces substitution variables in a string.

@param text     The text string, with substitution variables
                (e.g. "Error &0 in table &1.");
@param values   The replacement values.
@return         The text string with all substitution variables
                replaced.
**/
    static String substitute (String text, String[] values)
    {
        String result = text;
        for (int i = 0; i < values.length; ++i) {
            String variable = "&" + i;
            int j = result.indexOf (variable);
            if (j >= 0) {
                StringBuffer buffer = new StringBuffer ();
                buffer.append (result.substring (0, j));
                buffer.append (values[i]);
                buffer.append (result.substring (j + variable.length ()));
                result = buffer.toString ();
            }
        }
        return result;
    }



}





© 2015 - 2025 Weber Informatics LLC | Privacy Policy