1adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project/*
2adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *  Licensed to the Apache Software Foundation (ASF) under one or more
3adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *  contributor license agreements.  See the NOTICE file distributed with
4adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *  this work for additional information regarding copyright ownership.
5adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *  The ASF licenses this file to You under the Apache License, Version 2.0
6adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *  (the "License"); you may not use this file except in compliance with
7adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *  the License.  You may obtain a copy of the License at
8adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *
9adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *     http://www.apache.org/licenses/LICENSE-2.0
10adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *
11adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *  Unless required by applicable law or agreed to in writing, software
12adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *  distributed under the License is distributed on an "AS IS" BASIS,
13adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *  See the License for the specific language governing permissions and
15adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *  limitations under the License.
16adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */
17adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project
18adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Projectpackage java.lang;
19adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project
20adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project/**
21adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * Thrown when an assertion has failed.
22f5597e626ecf7949d249dea08c1a2964d890ec11Jesse Wilson *
23f5597e626ecf7949d249dea08c1a2964d890ec11Jesse Wilson * @since 1.4
24adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */
25adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Projectpublic class AssertionError extends Error {
26adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project
27adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    private static final long serialVersionUID = -5013299493970297370L;
28adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project
29adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    /**
30adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * Constructs a new {@code AssertionError} with no message.
31adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     */
32adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    public AssertionError() {
33adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    }
34adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project
35adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    /**
36e9dfb3473d9c2cceaf55c86ac9f4296e7535a175Elliott Hughes     * Constructs a new {@code AssertionError} with the given detail message and cause.
37e9dfb3473d9c2cceaf55c86ac9f4296e7535a175Elliott Hughes     * @since 1.7
38e9dfb3473d9c2cceaf55c86ac9f4296e7535a175Elliott Hughes     * @hide 1.7
39e9dfb3473d9c2cceaf55c86ac9f4296e7535a175Elliott Hughes     */
40e9dfb3473d9c2cceaf55c86ac9f4296e7535a175Elliott Hughes    public AssertionError(String detailMessage, Throwable cause) {
41e9dfb3473d9c2cceaf55c86ac9f4296e7535a175Elliott Hughes        super(detailMessage, cause);
42e9dfb3473d9c2cceaf55c86ac9f4296e7535a175Elliott Hughes    }
43e9dfb3473d9c2cceaf55c86ac9f4296e7535a175Elliott Hughes
44e9dfb3473d9c2cceaf55c86ac9f4296e7535a175Elliott Hughes    /**
45adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * Constructs a new {@code AssertionError} with a message based on calling
46adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * {@link String#valueOf(Object)} with the specified object. If the object
47adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * is an instance of {@link Throwable}, then it also becomes the cause of
48adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * this error.
49f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes     *
50adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * @param detailMessage
51adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     *            the object to be converted into the detail message and
52adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     *            optionally the cause.
53adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     */
54adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    public AssertionError(Object detailMessage) {
55f3d07392d4fbeb7b6762b08a523431c34fef750aElliott Hughes        super(String.valueOf(detailMessage));
56f3d07392d4fbeb7b6762b08a523431c34fef750aElliott Hughes        if (detailMessage instanceof Throwable) {
57f3d07392d4fbeb7b6762b08a523431c34fef750aElliott Hughes            initCause((Throwable) detailMessage);
58f3d07392d4fbeb7b6762b08a523431c34fef750aElliott Hughes        }
59adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    }
60adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project
61adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    /**
62adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * Constructs a new {@code AssertionError} with a message based on calling
63adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * {@link String#valueOf(boolean)} with the specified boolean value.
64f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes     *
65adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * @param detailMessage
66adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     *            the value to be converted into the message.
67adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     */
68adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    public AssertionError(boolean detailMessage) {
69adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project        this(String.valueOf(detailMessage));
70adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    }
71adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project
72adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    /**
73adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * Constructs a new {@code AssertionError} with a message based on calling
74adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * {@link String#valueOf(char)} with the specified character value.
75f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes     *
76adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * @param detailMessage
77adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     *            the value to be converted into the message.
78adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     */
79adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    public AssertionError(char detailMessage) {
80adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project        this(String.valueOf(detailMessage));
81adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    }
82adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project
83adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    /**
84adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * Constructs a new {@code AssertionError} with a message based on calling
85adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * {@link String#valueOf(int)} with the specified integer value.
86f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes     *
87adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * @param detailMessage
88adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     *            the value to be converted into the message.
89adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     */
90adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    public AssertionError(int detailMessage) {
91adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project        this(Integer.toString(detailMessage));
92adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    }
93adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project
94adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    /**
95adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * Constructs a new {@code AssertionError} with a message based on calling
96adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * {@link String#valueOf(long)} with the specified long value.
97f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes     *
98adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * @param detailMessage
99adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     *            the value to be converted into the message.
100adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     */
101adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    public AssertionError(long detailMessage) {
102adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project        this(Long.toString(detailMessage));
103adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    }
104adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project
105adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    /**
106adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * Constructs a new {@code AssertionError} with a message based on calling
107adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * {@link String#valueOf(float)} with the specified float value.
108f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes     *
109adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * @param detailMessage
110adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     *            the value to be converted into the message.
111adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     */
112adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    public AssertionError(float detailMessage) {
113adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project        this(Float.toString(detailMessage));
114adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    }
115adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project
116adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    /**
117adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * Constructs a new {@code AssertionError} with a message based on calling
118adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * {@link String#valueOf(double)} with the specified double value.
119f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes     *
120adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * @param detailMessage
121adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     *            the value to be converted into the message.
122adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     */
123adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    public AssertionError(double detailMessage) {
124adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project        this(Double.toString(detailMessage));
125adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    }
126adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project}
127