Messages.java

  1. /*
  2.  *   Copyright (C) 2016 Christian Schulte <cs@schulte.it>
  3.  *   All rights reserved.
  4.  *
  5.  *   Redistribution and use in source and binary forms, with or without
  6.  *   modification, are permitted provided that the following conditions
  7.  *   are met:
  8.  *
  9.  *     o Redistributions of source code must retain the above copyright
  10.  *       notice, this list of conditions and the following disclaimer.
  11.  *
  12.  *     o Redistributions in binary form must reproduce the above copyright
  13.  *       notice, this list of conditions and the following disclaimer in
  14.  *       the documentation and/or other materials provided with the
  15.  *       distribution.
  16.  *
  17.  *   THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES,
  18.  *   INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY
  19.  *   AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
  20.  *   THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY DIRECT, INDIRECT,
  21.  *   INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
  22.  *   NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
  23.  *   DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
  24.  *   THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  25.  *   (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
  26.  *   THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  27.  *
  28.  *   $JOMC: Messages.java 5215 2016-04-24 06:54:04Z schulte $
  29.  *
  30.  */
  31. package org.jomc.cli.commands;

  32. import java.text.MessageFormat;
  33. import java.util.MissingResourceException;
  34. import java.util.ResourceBundle;

  35. /**
  36.  * Utilities for accessing messages.
  37.  *
  38.  * @author <a href="mailto:cs@schulte.it">Christian Schulte</a>
  39.  * @version $JOMC: Messages.java 5215 2016-04-24 06:54:04Z schulte $
  40.  */
  41. abstract class Messages
  42. {

  43.     /**
  44.      * Creates a new {@code Messages} instance.
  45.      */
  46.     Messages()
  47.     {
  48.         super();
  49.     }

  50.     /**
  51.      * Gets a message for a given key from the resource bundle backing the tasks formatted using the given arguments.
  52.      *
  53.      * @param key The key of the string to get.
  54.      * @param arguments The arguments to format the string with.
  55.      *
  56.      * @return The string matching {@code key} formatted using {@code arguments}.
  57.      *
  58.      * @throws NullPointerException if {@code key} is {@code null}.
  59.      */
  60.     static String getMessage( final String key, final Object... arguments )
  61.     {
  62.         if ( key == null )
  63.         {
  64.             throw new NullPointerException( "key" );
  65.         }

  66.         try
  67.         {
  68.             return MessageFormat.format( ResourceBundle.getBundle( Messages.class.getName() ).getString( key ),
  69.                                          arguments );

  70.         }
  71.         catch ( final MissingResourceException e )
  72.         {
  73.             throw new AssertionError( e );
  74.         }
  75.         catch ( final ClassCastException e )
  76.         {
  77.             throw new AssertionError( e );
  78.         }
  79.         catch ( final IllegalArgumentException e )
  80.         {
  81.             throw new AssertionError( e );
  82.         }
  83.     }

  84.     /**
  85.      * Gets the message of a given {@code Throwable} recursively.
  86.      *
  87.      * @param t The {@code Throwable} to get the message of or {@code null}.
  88.      *
  89.      * @return The message of {@code t} or {@code null}.
  90.      */
  91.     static String getMessage( final Throwable t )
  92.     {
  93.         return t != null
  94.                    ? t.getMessage() != null && t.getMessage().trim().length() > 0
  95.                          ? t.getMessage()
  96.                          : getMessage( t.getCause() )
  97.                    : null;

  98.     }

  99. }