View Javadoc

1   /*
2    *   Copyright (C) Christian Schulte, 2005-206
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 4760 2013-04-08 17:56:26Z schulte $
29   *
30   */
31  package org.jomc.ant;
32  
33  import java.text.MessageFormat;
34  import java.util.MissingResourceException;
35  import java.util.ResourceBundle;
36  
37  /**
38   * Utilities for accessing messages.
39   *
40   * @author <a href="mailto:cs@schulte.it">Christian Schulte</a>
41   * @version $JOMC: Messages.java 4760 2013-04-08 17:56:26Z schulte $
42   */
43  abstract class Messages
44  {
45  
46      /** Constant for the name of the resource bundle backing the tasks. */
47      private static final String RESOURCE_BUNDLE_NAME =
48          Messages.class.getPackage().getName().replace( '.', '/' ) + "/Messages";
49  
50      /** Creates a new {@code Messages} instance. */
51      Messages()
52      {
53          super();
54      }
55  
56      /**
57       * Gets a message for a given key from the resource bundle backing the tasks formatted using the given arguments.
58       *
59       * @param key The key of the string to get.
60       * @param arguments The arguments to format the string with.
61       *
62       * @return The string matching {@code key} formatted using {@code arguments}.
63       *
64       * @throws NullPointerException if {@code key} is {@code null}.
65       */
66      static String getMessage( final String key, final Object... arguments )
67      {
68          if ( key == null )
69          {
70              throw new NullPointerException( "key" );
71          }
72  
73          try
74          {
75              return MessageFormat.format( ResourceBundle.getBundle( RESOURCE_BUNDLE_NAME ).getString( key ), arguments );
76          }
77          catch ( final MissingResourceException e )
78          {
79              throw new AssertionError( e );
80          }
81          catch ( final ClassCastException e )
82          {
83              throw new AssertionError( e );
84          }
85          catch ( final IllegalArgumentException e )
86          {
87              throw new AssertionError( e );
88          }
89      }
90  
91      /**
92       * Gets the message of a given {@code Throwable} recursively.
93       *
94       * @param t The {@code Throwable} to get the message of or {@code null}.
95       *
96       * @return The message of {@code t} or {@code null}.
97       */
98      static String getMessage( final Throwable t )
99      {
100         return t != null
101                ? t.getMessage() != null && t.getMessage().trim().length() > 0
102                  ? t.getMessage()
103                  : getMessage( t.getCause() )
104                : null;
105 
106     }
107 
108 }