FileDocCategorySizeDatePackage
Notifier.javaAPI DocphoneME MR2 API (J2ME)5909Wed May 02 18:00:40 BST 2007com.sun.satsa.jcrmic.utils

Notifier.java

/*
 *   
 *
 * Copyright  1990-2007 Sun Microsystems, Inc. All Rights Reserved.
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER
 * 
 * This program is free software; you can redistribute it and/or
 * modify it under the terms of the GNU General Public License version
 * 2 only, as published by the Free Software Foundation.
 * 
 * This program is distributed in the hope that it will be useful, but
 * WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
 * General Public License version 2 for more details (a copy is
 * included at /legal/license.txt).
 * 
 * You should have received a copy of the GNU General Public License
 * version 2 along with this work; if not, write to the Free Software
 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
 * 02110-1301 USA
 * 
 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa
 * Clara, CA 95054 or visit www.sun.com if you need additional
 * information or have any questions.
 */

package com.sun.satsa.jcrmic.utils;

import java.util.*;
import java.io.*;

/**
 *  This class is responsible for reporting any messages (error, warning,
 *  progress, banner and status messages) during the compilation.
 */
public class Notifier {

    /**
     * The stream where error messages are printed.
     */
    OutputStream out;

    /**
     * Constructor.
     * @param out output stream
     */
    public Notifier(OutputStream out) {

        this.out = out;
    }

    /**
     * Output a message.
     * @param msg the message
     */
    public void output(String msg) {

        if (this.out instanceof PrintStream) {
            ((PrintStream) out).println(msg);
        } else {
            OutputStreamWriter osw = new OutputStreamWriter(this.out);
            PrintWriter pw = new PrintWriter(osw, true);
            pw.println(msg);
            try {
                osw.flush();
            } catch (IOException phooey) {
            }
        }
    }

    /**
     * Prints error message.
     * @param msg the message
     */
    public void error(String msg) {
        output(getText(msg));
    }

    /**
     * Prints error message.
     * @param msg the message
     * @param arg1 argument
     */
    public void error(String msg, String arg1) {
        output(getText(msg, arg1));
    }

    /**
     * Prints error message.
     * @param msg the message
     * @param arg1 argument
     * @param arg2 argument
     */
    public void error(String msg, String arg1, String arg2) {
        output(getText(msg, arg1, arg2));
    }

    /**
     * Prints error message.
     * @param msg the message
     * @param arg1 argument
     * @param arg2 argument
     * @param arg3 argument
     */
    public void error(String msg, String arg1, String arg2, String arg3) {
        output(getText(msg, arg1, arg2, arg3));
    }

    /**
     * Return the string value of a named resource in the rmic.properties
     * resource bundle.  If the resource is not found, null is returned.
     * @param key resource name
     * @return the value
     */
    public static String getString(String key) {

        if (!resourcesInitialized) {
            initResources();
        }

        try {
            return resources.getString(key);
        } catch (MissingResourceException ignore) {
        }
        return null;
    }

    /**
     * Flag that indicates that resoyrces were initialized.
     */
    private static boolean resourcesInitialized = false;

    /**
     * Resource bundle.
     */
    private static ResourceBundle resources;

    /**
     * Initializes resource bundle.
     */
    private static void initResources() {

        try {
            resources = ResourceBundle.getBundle("com/sun/satsa/jcrmic/jcrmic");
            resourcesInitialized = true;
        } catch (MissingResourceException e) {
            throw new Error("fatal: missing resource bundle: " +
                    e.getClassName());
        }
    }

    /**
     * Returns the string for given key.
     * @param key the key
     * @return the string
     */
    public static String getText(String key) {

        String message = getString(key);

        if (message == null) {
            message = "no text found: \"" + key + "\"";
        }

        return message;
    }

    /**
     * Returns the message.
     * @param key the key
     * @param num parameter
     * @return the message
     */
    public static String getText(String key, int num) {
        return getText(key, Integer.toString(num), null, null);
    }

    /**
     * Returns the message.
     * @param key the key
     * @param arg0 parameter
     * @return the message
     */
    public static String getText(String key, String arg0) {
        return getText(key, arg0, null, null);
    }

    /**
     * Returns the message.
     * @param key the key
     * @param arg0 parameter
     * @param arg1 parameter
     * @return the message
     */
    public static String getText(String key, String arg0, String arg1) {
        return getText(key, arg0, arg1, null);
    }

    /**
     * Returns the message.
     * @param key the key
     * @param arg0 parameter
     * @param arg1 parameter
     * @param arg2 parameter
     * @return the message
     */
    public static String getText(String key,
                                 String arg0, String arg1, String arg2) {

        String format = getString(key);
        if (format == null) {
            format = "no text found: " +
                    "key = \"{0}\", arguments = \"{1}\", \"{2}\", \"{3}\"";
        }

        String[] args = new String[3];
        args[0] = (arg0 != null ? arg0.toString() : "null");
        args[1] = (arg1 != null ? arg1.toString() : "null");
        args[2] = (arg2 != null ? arg2.toString() : "null");

        return java.text.MessageFormat.format(format, args);
    }
}