1. /*
  2. * $Header: /home/cvs/jakarta-commons/httpclient/src/java/org/apache/commons/httpclient/util/ExceptionUtil.java,v 1.4 2004/05/13 04:01:22 mbecke Exp $
  3. * $Revision: 1.4 $
  4. * $Date: 2004/05/13 04:01:22 $
  5. *
  6. * ====================================================================
  7. *
  8. * Copyright 1999-2004 The Apache Software Foundation
  9. *
  10. * Licensed under the Apache License, Version 2.0 (the "License");
  11. * you may not use this file except in compliance with the License.
  12. * You may obtain a copy of the License at
  13. *
  14. * http://www.apache.org/licenses/LICENSE-2.0
  15. *
  16. * Unless required by applicable law or agreed to in writing, software
  17. * distributed under the License is distributed on an "AS IS" BASIS,
  18. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  19. * See the License for the specific language governing permissions and
  20. * limitations under the License.
  21. * ====================================================================
  22. *
  23. * This software consists of voluntary contributions made by many
  24. * individuals on behalf of the Apache Software Foundation. For more
  25. * information on the Apache Software Foundation, please see
  26. * <http://www.apache.org/>.
  27. *
  28. */
  29. package org.apache.commons.httpclient.util;
  30. import java.lang.reflect.Method;
  31. import org.apache.commons.logging.Log;
  32. import org.apache.commons.logging.LogFactory;
  33. /**
  34. * The home for utility methods that handle various exception-related tasks.
  35. *
  36. * @author <a href="mailto:oleg@ural.ru">Oleg Kalnichevski</a>
  37. * @author <a href="mailto:laura@lwerner.org">Laura Werner</a>
  38. *
  39. * @since 3.0
  40. */
  41. public class ExceptionUtil {
  42. /** Log object for this class. */
  43. private static final Log LOG = LogFactory.getLog(ExceptionUtil.class);
  44. /** A reference to Throwable's initCause method, or null if it's not there in this JVM */
  45. static private final Method initCause = getInitCauseMethod();
  46. /**
  47. * Returns a <code>Method<code> allowing access to
  48. * {@link Throwable.initCause(Throwable) initCause} method of {@link Throwable},
  49. * or <code>null</code> if the method
  50. * does not exist.
  51. *
  52. * @return A <code>Method<code> for <code>Throwable.initCause</code>, or
  53. * <code>null</code> if unavailable.
  54. */
  55. static private Method getInitCauseMethod() {
  56. try {
  57. Class[] paramsClasses = new Class[] { Throwable.class };
  58. return Throwable.class.getMethod("initCause", paramsClasses);
  59. } catch (NoSuchMethodException e) {
  60. return null;
  61. }
  62. }
  63. /**
  64. * If we're running on JDK 1.4 or later, initialize the cause for the given throwable.
  65. *
  66. * @param throwable The throwable.
  67. * @param cause The cause of the throwable.
  68. */
  69. public static void initCause(Throwable throwable, Throwable cause) {
  70. if (initCause != null) {
  71. try {
  72. initCause.invoke(throwable, new Object[] { cause });
  73. } catch (Exception e) {
  74. LOG.warn("Exception invoking Throwable.initCause", e);
  75. }
  76. }
  77. }
  78. }