2 * jSite - a tool for uploading websites into Freenet
3 * Copyright (C) 2006 David Roden
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation; either version 2 of the License, or
8 * (at your option) any later version.
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
15 * You should have received a copy of the GNU General Public License
16 * along with this program; if not, write to the Free Software
17 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
20 package de.todesbaum.jsite.i18n;
22 import java.util.Locale;
23 import java.util.MissingResourceException;
24 import java.util.ResourceBundle;
27 * Maps i18n keys to translated texts, depending on a current locale.
29 * @author David ‘Bombe’ Roden <bombe@freenetproject.org>
33 /** The default locale, English. */
34 private static Locale defaultLocale = new Locale("en");
36 /** The current locale. */
37 private static Locale currentLocale;
40 * Returns the currently set locale.
42 * @return The current locale
44 public static Locale getLocale() {
45 if (currentLocale == null) {
46 currentLocale = Locale.getDefault();
52 * Sets the current locale.
55 * The new current locale
57 public static void setLocale(Locale locale) {
58 currentLocale = locale;
59 Locale.setDefault(locale);
63 * Returns the resource bundle for the current locale.
65 * @return The resource bundle for the current locale
67 public static ResourceBundle getResourceBundle() {
68 return getResourceBundle(getLocale());
72 * Returns the resource bundle for the given locale.
75 * The locale to get the resource bundle for
76 * @return The resource bundle for the given locale
78 public static ResourceBundle getResourceBundle(Locale locale) {
79 return ResourceBundle.getBundle("de.todesbaum.jsite.i18n.jSite", locale);
83 * Retrieves a translated text for the given i18n key. If the resource
84 * bundle for the current locale does not have a translation for the given
85 * key, the default locale is tried. If that fails, the key is returned.
88 * The key to get the translation for
89 * @return The translated value, or the key itself if not translation can be
92 public static String getMessage(String key) {
94 return getResourceBundle().getString(key);
95 } catch (MissingResourceException mre1) {
97 return getResourceBundle(defaultLocale).getString(key);
98 } catch (MissingResourceException mre2) {