/* * Copyright (c) 2004, PostgreSQL Global Development Group * See the LICENSE file in the project root for more information. */ package org.postgresql.util; import java.text.MessageFormat; import java.util.MissingResourceException; import java.util.ResourceBundle; /** * This class provides a wrapper around a gettext message catalog that can provide a localized * version of error messages. The caller provides a message String in the standard * java.text.MessageFormat syntax and any arguments it may need. The returned String is the * localized version if available or the original if not. */ public class GT { private final static GT _gt = new GT(); private final static Object noargs[] = new Object[0]; public static String tr(String message, Object... args) { return _gt.translate(message, args); } private ResourceBundle _bundle; private GT() { try { _bundle = ResourceBundle.getBundle("org.postgresql.translation.messages"); } catch (MissingResourceException mre) { // translation files have not been installed _bundle = null; } } private String translate(String message, Object args[]) { if (_bundle != null && message != null) { try { message = _bundle.getString(message); } catch (MissingResourceException mre) { // If we can't find a translation, just // use the untranslated message. } } // If we don't have any parameters we still need to run // this through the MessageFormat(ter) to allow the same // quoting and escaping rules to be used for all messages. // if (args == null) { args = noargs; } // Replace placeholders with arguments // if (message != null) { message = MessageFormat.format(message, args); } return message; } }