xref: /freebsd/contrib/libcxxrt/stdexcept.cc (revision ff0ba87247820afbdfdc1b307c803f7923d0e4d3)
1 /*
2  * Copyright 2010-2011 PathScale, Inc. All rights reserved.
3  *
4  * Redistribution and use in source and binary forms, with or without
5  * modification, are permitted provided that the following conditions are met:
6  *
7  * 1. Redistributions of source code must retain the above copyright notice,
8  *    this list of conditions and the following disclaimer.
9  *
10  * 2. Redistributions in binary form must reproduce the above copyright notice,
11  *    this list of conditions and the following disclaimer in the documentation
12  *    and/or other materials provided with the distribution.
13  *
14  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS ``AS
15  * IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
16  * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
17  * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR
18  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
19  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
20  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
21  * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
22  * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
23  * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
24  * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
25  */
26 
27 /**
28  * stdexcept.cc - provides stub implementations of the exceptions required by the runtime.
29  */
30 #include "stdexcept.h"
31 
32 namespace std {
33 
34 exception::exception() throw() {}
35 exception::~exception() {}
36 exception::exception(const exception&) throw() {}
37 exception& exception::operator=(const exception&) throw()
38 {
39 	return *this;
40 }
41 const char* exception::what() const throw()
42 {
43 	return "std::exception";
44 }
45 
46 bad_alloc::bad_alloc() throw() {}
47 bad_alloc::~bad_alloc() {}
48 bad_alloc::bad_alloc(const bad_alloc&) throw() {}
49 bad_alloc& bad_alloc::operator=(const bad_alloc&) throw()
50 {
51 	return *this;
52 }
53 const char* bad_alloc::what() const throw()
54 {
55 	return "cxxrt::bad_alloc";
56 }
57 
58 
59 
60 bad_cast::bad_cast() throw() {}
61 bad_cast::~bad_cast() {}
62 bad_cast::bad_cast(const bad_cast&) throw() {}
63 bad_cast& bad_cast::operator=(const bad_cast&) throw()
64 {
65 	return *this;
66 }
67 const char* bad_cast::what() const throw()
68 {
69 	return "std::bad_cast";
70 }
71 
72 bad_typeid::bad_typeid() throw() {}
73 bad_typeid::~bad_typeid() {}
74 bad_typeid::bad_typeid(const bad_typeid &__rhs) throw() {}
75 bad_typeid& bad_typeid::operator=(const bad_typeid &__rhs) throw()
76 {
77 	return *this;
78 }
79 
80 const char* bad_typeid::what() const throw()
81 {
82 	return "std::bad_typeid";
83 }
84 
85 __attribute__((weak))
86 bad_array_new_length::bad_array_new_length() throw() {}
87 __attribute__((weak))
88 bad_array_new_length::~bad_array_new_length() {}
89 __attribute__((weak))
90 bad_array_new_length::bad_array_new_length(const bad_array_new_length&) throw() {}
91 __attribute__((weak))
92 bad_array_new_length& bad_array_new_length::operator=(const bad_array_new_length&) throw()
93 {
94 	return *this;
95 }
96 
97 __attribute__((weak))
98 const char *bad_array_new_length::what() const throw()
99 {
100 	return "std::bad_array_new_length";
101 }
102 
103 } // namespace std
104 
105