src.com.ibm.as400.access.ResourceBundleLoader Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jt400 Show documentation
Show all versions of jt400 Show documentation
The Open Source version of the IBM Toolbox for Java
///////////////////////////////////////////////////////////////////////////////
//
// JTOpen (AS/400 Toolbox for Java - OSS version)
//
// Filename: ResourceBundleLoader.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.access;
import java.util.Locale;
import java.util.MissingResourceException;
import java.util.ResourceBundle;
import javax.swing.Icon;
import javax.swing.ImageIcon;
import java.io.File;
import java.net.URL;
// A class representing the ResourceBundleLoader object which is used to load the resource bundle.
class ResourceBundleLoader
{
private static final boolean DEBUG = false;
private static MissingResourceException resourceException_; // Set if there is an exception during the loading of the resource bundle
private static ResourceBundle coreResources_; // Core toolbox resources @B2A
private static ResourceBundle resources_; // Base toolbox resources needed in proxy jar file @B1C
private static ResourceBundle resources2_; // Base toolbox resources NOT needed in proxy jar file @B1A
private static ResourceBundle systemValueResource_; // resource bundle for system value.
private static String genericDescription_ = null;
static
{
try { // @B2A
coreResources_ = ResourceBundle.getBundle("com.ibm.as400.access.CoreMRI"); // @B2A
} // @B2A
catch(MissingResourceException e) { // @B2A
resourceException_ = e; // @B2A
} // @B2A
try {
resources_ = ResourceBundle.getBundle("com.ibm.as400.access.MRI");
systemValueResource_ = ResourceBundle.getBundle("com.ibm.as400.access.SVMRI");
}
catch (MissingResourceException e) {
// Save the exception and rethrow it later. This is because exceptions thrown from static initializers are hard to debug.
resourceException_ = e;
}
try { // @B1A
resources2_ = ResourceBundle.getBundle ("com.ibm.as400.access.MRI2"); // @B1A
} // @B1A
catch (MissingResourceException e) { // @B1A
// This resource bundle may not be found if we are running with only // @B1A
// the proxy jar file. Do not flag an exception. // @B1A
if (Trace.isTraceOn ()) // @B1A
Trace.log (Trace.INFORMATION, "MRI2 not found. This is expected behavior when using the proxy jar file."); // @B1A
} // @B1A
}
// No need to create instances of this class, all methods are static
private ResourceBundleLoader()
{
}
// Returns the text associated with the exception. // @B2A
// @param textId the id which identifies the message text to return. // @B2A
// @return the translatable text which describes the exception. // @B2A
static final String getCoreText(String textId) // @B2A
{ // @B2A
if (coreResources_ == null) // @B2A
throw resourceException_; // @B2A
return coreResources_.getString(textId); // @B2A
} // @B2A
/**
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 ("ResourceBundleLoader: 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"); // TBD: copy MRI from VMRI to MRI2
description = genericDescription_;
}
URL url = ResourceBundleLoader.class.getResource (fileName);
if (url == null)
{
fileName = "com" + File.separator + "ibm" + File.separator +
"as400" + File.separator + "access" + File.separator +
fileName;
icon = new ImageIcon (fileName, description);
}
else
{
icon = new ImageIcon (url, description);
}
}
catch (Exception e) {
if (DEBUG)
System.out.println ("ResourceBundleLoader: Error: " + e + ".");
Trace.log (Trace.ERROR, "Icon " + fileName + " not loaded: " + e.getMessage() + ".");
}
return icon;
}
// Returns the system value MRI text.
// @param textId the id which identifies the text to return.
// @return the translatable system value MRI text.
static final String getSystemValueText(String textId)
{
if (systemValueResource_ == null) {
throw resourceException_;
}
return systemValueResource_.getString(textId).trim();
}
// Returns the system value MRI text for the specified Locale.
// @param textId the id which identifies the text to return.
// @param locale The locale to use.
// @return the translatable system value MRI text.
static final String getSystemValueText(String textId, Locale locale)
{
ResourceBundle bundle = ResourceBundle.getBundle("com.ibm.as400.access.SVMRI", locale);
if (bundle != null)
{
return bundle.getString(textId);
}
if (systemValueResource_ == null) {
throw resourceException_;
}
return systemValueResource_.getString(textId).trim();
}
// Returns the text associated with the exception.
// @param textId the id which identifies the message text to return.
// @return the translatable text which describes the exception.
static final String getText(String textId)
{
if (resources_ == null) {
throw resourceException_;
}
try { // @B1A
return resources_.getString(textId);
} // @B1A
catch (MissingResourceException e) { // @B1A
try { // @B2A
return getCoreText(textId); // @B2A
} // @B2A
catch(MissingResourceException e2) { // @B2A
if (resources2_ == null) // @B1A
throw e; // @B1A
else // @B1A
return resources2_.getString (textId); // @B1A
} // @B2A
} // @B1A
}
// @B0A
// Returns the text associated with an MRI key, with subsitution variables.
// @param textId the id which identifies the message text to return.
// @param value The replacement value.
// @return The text string with the substitution variable replaced.
static String getText (String textId, Object value)
{
String text = getText (textId);
return substitute (text, value);
}
// @B0A
// Returns the text associated with an MRI key, with subsitution variables.
// @param textId the id which identifies the message text to return.
// @param value0 The first replacement value.
// @param value1 The second replacement value.
// @return The text string with the substitution variable replaced.
static String getText (String textId, Object value0, Object value1)
{
String text = getText (textId);
return substitute (text, new Object[] { value0, value1 });
}
// @B0A
// Returns the text associated with an MRI key, with subsitution variables.
// @param textId the id which identifies the message text to return.
// @param values The replacement values.
// @return The text string with all substitution variables replaced.
static String getText (String textId, Object[] values)
{
String text = getText (textId);
return substitute (text, values);
}
// 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, Object value)
{
return substitute(text, new Object[] { value});
}
// @B0A
// 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 value0 The first replacement value.
// @param value1 The second replacement value.
// @return The text string with the substitution variable replaced.
static String substitute(String text, Object value0, Object value1)
{
return substitute(text, new Object[] { value0, value1 });
}
// 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, Object[] 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].toString ());
buffer.append(result.substring(j + variable.length ()));
result = buffer.toString ();
}
}
return result;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy