/* * NOTICE: THE FILE HAS BEEN MODIFIED TO SUIT THE NEEDS OF THE PROJECT. * * 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. */ /* * THE FILE HAS BEEN AUTOGENERATED BY MSGTOOL TOOL. * All changes made to this file manually will be overwritten * if this tool runs again. Better make changes in the template file. */ package org.robobinding.internal.java_beans; import java.security.AccessController; import java.security.PrivilegedAction; import java.util.Locale; import java.util.MissingResourceException; import java.util.ResourceBundle; /** * This class retrieves strings from a resource bundle and returns them, * formatting them with MessageFormat when required. * <p> * It is used by the system classes to provide national language support, by * looking up messages in the <code> * org.apache.harmony.beans.internal.nls.messages * </code> resource bundle. Note that if this file is not available, or an * invalid key is looked up, or resource bundle support is not available, the * key itself will be returned as the associated message. This means that the * <em>KEY</em> should a reasonable human-readable (english) string. * */ public class Messages { private Messages() { } // ResourceBundle holding the system messages. private static ResourceBundle bundle = null; /** * Retrieves a message which has no arguments. * * @param msg * String the key to look up. * @return String the message for that key in the system message bundle. */ public static String getString(String msg) { if (bundle == null) return msg; try { return bundle.getString(msg); } catch (MissingResourceException e) { return "Missing message: " + msg; //$NON-NLS-1$ } } /** * Retrieves a message which takes 1 argument. * * @param msg * String the key to look up. * @param arg * Object the object to insert in the formatted output. * @return String the message for that key in the system message bundle. */ public static String getString(String msg, Object arg) { return getString(msg, new Object[] { arg }); } /** * Retrieves a message which takes 1 integer argument. * * @param msg * String the key to look up. * @param arg * int the integer to insert in the formatted output. * @return String the message for that key in the system message bundle. */ public static String getString(String msg, int arg) { return getString(msg, new Object[] { Integer.toString(arg) }); } /** * Retrieves a message which takes 1 character argument. * * @param msg * String the key to look up. * @param arg * char the character to insert in the formatted output. * @return String the message for that key in the system message bundle. */ public static String getString(String msg, char arg) { return getString(msg, new Object[] { String.valueOf(arg) }); } /** * Retrieves a message which takes 2 arguments. * * @param msg * String the key to look up. * @param arg1 * Object an object to insert in the formatted output. * @param arg2 * Object another object to insert in the formatted output. * @return String the message for that key in the system message bundle. */ public static String getString(String msg, Object arg1, Object arg2) { return getString(msg, new Object[] { arg1, arg2 }); } /** * Retrieves a message which takes several arguments. * * @param msg * String the key to look up. * @param args * Object[] the objects to insert in the formatted output. * @return String the message for that key in the system message bundle. */ public static String getString(String msg, Object[] args) { String format = msg; if (bundle != null) { try { format = bundle.getString(msg); } catch (MissingResourceException e) { } } return format(format, args); } /** * Generates a formatted text string given a source string containing * "argument markers" of the form "{argNum}" where each argNum must be in * the range 0..9. The result is generated by inserting the toString of each * argument into the position indicated in the string. * <p> * To insert the "{" character into the output, use a single backslash * character to escape it (i.e. "\{"). The "}" character does not need to be * escaped. * * @param format * String the format to use when printing. * @param args * Object[] the arguments to use. * @return String the formatted message. */ public static String format(String format, Object[] args) { StringBuilder answer = new StringBuilder(format.length() + (args.length * 20)); String[] argStrings = new String[args.length]; for (int i = 0; i < args.length; ++i) { if (args[i] == null) argStrings[i] = "<null>"; //$NON-NLS-1$ else argStrings[i] = args[i].toString(); } int lastI = 0; for (int i = format.indexOf('{', 0); i >= 0; i = format.indexOf('{', lastI)) { if (i != 0 && format.charAt(i - 1) == '\\') { // It's escaped, just print and loop. if (i != 1) answer.append(format.substring(lastI, i - 1)); answer.append('{'); lastI = i + 1; } else { // It's a format character. if (i > format.length() - 3) { // Bad format, just print and loop. answer.append(format.substring(lastI, format.length())); lastI = format.length(); } else { int argnum = (byte) Character.digit(format.charAt(i + 1), 10); if (argnum < 0 || format.charAt(i + 2) != '}') { // Bad format, just print and loop. answer.append(format.substring(lastI, i + 1)); lastI = i + 1; } else { // Got a good one! answer.append(format.substring(lastI, i)); if (argnum >= argStrings.length) answer.append("<missing argument>"); //$NON-NLS-1$ else answer.append(argStrings[argnum]); lastI = i + 3; } } } } if (lastI < format.length()) answer.append(format.substring(lastI, format.length())); return answer.toString(); } /** * Changes the locale of the messages. * * @param locale * Locale the locale to change to. */ public static ResourceBundle setLocale(final Locale locale, final String resource) { try { final ClassLoader loader = null; return (ResourceBundle) AccessController.doPrivileged(new PrivilegedAction<Object>() { public Object run() { return ResourceBundle.getBundle(resource, locale, loader != null ? loader : ClassLoader.getSystemClassLoader()); } }); } catch (MissingResourceException e) { } return null; } static { // Attempt to load the messages. try { bundle = setLocale(Locale.getDefault(), "robobinding.internal.java_beans.messages"); //$NON-NLS-1$ } catch (Throwable e) { e.printStackTrace(); } } }