annotate libcxxabi/test/unwind_03.pass.cpp @ 266:00f31e85ec16 default tip

Added tag current for changeset 31d058e83c98
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Sat, 14 Oct 2023 10:13:55 +0900
parents c4bab56944e8
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
236
c4bab56944e8 LLVM 16
kono
parents: 223
diff changeset
1 //===----------------------------------------------------------------------===//
150
anatofuz
parents:
diff changeset
2 //
anatofuz
parents:
diff changeset
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
anatofuz
parents:
diff changeset
4 // See https://llvm.org/LICENSE.txt for license information.
anatofuz
parents:
diff changeset
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
anatofuz
parents:
diff changeset
6 //
anatofuz
parents:
diff changeset
7 //===----------------------------------------------------------------------===//
anatofuz
parents:
diff changeset
8
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
9 // UNSUPPORTED: no-exceptions
221
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
10 // REQUIRES: c++03 || c++11 || c++14
150
anatofuz
parents:
diff changeset
11
anatofuz
parents:
diff changeset
12 #include <exception>
anatofuz
parents:
diff changeset
13 #include <stdlib.h>
anatofuz
parents:
diff changeset
14 #include <assert.h>
anatofuz
parents:
diff changeset
15
anatofuz
parents:
diff changeset
16 #if defined(__GNUC__)
anatofuz
parents:
diff changeset
17 #pragma GCC diagnostic ignored "-Wunreachable-code"
223
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 221
diff changeset
18 #pragma GCC diagnostic ignored "-Wdeprecated" // dynamic exception specifications are deprecated
150
anatofuz
parents:
diff changeset
19 #endif
anatofuz
parents:
diff changeset
20
anatofuz
parents:
diff changeset
21 struct A
anatofuz
parents:
diff changeset
22 {
anatofuz
parents:
diff changeset
23 static int count;
anatofuz
parents:
diff changeset
24 int id_;
anatofuz
parents:
diff changeset
25 A() : id_(++count) {}
anatofuz
parents:
diff changeset
26 ~A() {assert(id_ == count--);}
anatofuz
parents:
diff changeset
27
anatofuz
parents:
diff changeset
28 private:
anatofuz
parents:
diff changeset
29 A(const A&);
anatofuz
parents:
diff changeset
30 A& operator=(const A&);
anatofuz
parents:
diff changeset
31 };
anatofuz
parents:
diff changeset
32
anatofuz
parents:
diff changeset
33 int A::count = 0;
anatofuz
parents:
diff changeset
34
anatofuz
parents:
diff changeset
35 struct B
anatofuz
parents:
diff changeset
36 {
anatofuz
parents:
diff changeset
37 static int count;
anatofuz
parents:
diff changeset
38 int id_;
anatofuz
parents:
diff changeset
39 B() : id_(++count) {}
anatofuz
parents:
diff changeset
40 ~B() {assert(id_ == count--);}
anatofuz
parents:
diff changeset
41
anatofuz
parents:
diff changeset
42 private:
anatofuz
parents:
diff changeset
43 B(const B&);
anatofuz
parents:
diff changeset
44 B& operator=(const B&);
anatofuz
parents:
diff changeset
45 };
anatofuz
parents:
diff changeset
46
anatofuz
parents:
diff changeset
47 int B::count = 0;
anatofuz
parents:
diff changeset
48
anatofuz
parents:
diff changeset
49 struct C
anatofuz
parents:
diff changeset
50 {
anatofuz
parents:
diff changeset
51 static int count;
anatofuz
parents:
diff changeset
52 int id_;
anatofuz
parents:
diff changeset
53 C() : id_(++count) {}
anatofuz
parents:
diff changeset
54 ~C() {assert(id_ == count--);}
anatofuz
parents:
diff changeset
55
anatofuz
parents:
diff changeset
56 private:
anatofuz
parents:
diff changeset
57 C(const C&);
anatofuz
parents:
diff changeset
58 C& operator=(const C&);
anatofuz
parents:
diff changeset
59 };
anatofuz
parents:
diff changeset
60
anatofuz
parents:
diff changeset
61 int C::count = 0;
anatofuz
parents:
diff changeset
62
anatofuz
parents:
diff changeset
63 void f2()
anatofuz
parents:
diff changeset
64 {
anatofuz
parents:
diff changeset
65 C c;
anatofuz
parents:
diff changeset
66 A a;
anatofuz
parents:
diff changeset
67 throw 55;
anatofuz
parents:
diff changeset
68 B b;
anatofuz
parents:
diff changeset
69 }
anatofuz
parents:
diff changeset
70
anatofuz
parents:
diff changeset
71 void f1() throw (long, char, double)
anatofuz
parents:
diff changeset
72 {
anatofuz
parents:
diff changeset
73 A a;
anatofuz
parents:
diff changeset
74 B b;
anatofuz
parents:
diff changeset
75 f2();
anatofuz
parents:
diff changeset
76 C c;
anatofuz
parents:
diff changeset
77 }
anatofuz
parents:
diff changeset
78
anatofuz
parents:
diff changeset
79 void u_handler()
anatofuz
parents:
diff changeset
80 {
anatofuz
parents:
diff changeset
81 exit(0);
anatofuz
parents:
diff changeset
82 }
anatofuz
parents:
diff changeset
83
221
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
84 int main(int, char**)
150
anatofuz
parents:
diff changeset
85 {
anatofuz
parents:
diff changeset
86 std::set_unexpected(u_handler);
anatofuz
parents:
diff changeset
87 try
anatofuz
parents:
diff changeset
88 {
anatofuz
parents:
diff changeset
89 f1();
anatofuz
parents:
diff changeset
90 assert(false);
anatofuz
parents:
diff changeset
91 }
anatofuz
parents:
diff changeset
92 catch (int* i)
anatofuz
parents:
diff changeset
93 {
anatofuz
parents:
diff changeset
94 assert(false);
anatofuz
parents:
diff changeset
95 }
anatofuz
parents:
diff changeset
96 catch (long i)
anatofuz
parents:
diff changeset
97 {
anatofuz
parents:
diff changeset
98 assert(false);
anatofuz
parents:
diff changeset
99 }
anatofuz
parents:
diff changeset
100 catch (int i)
anatofuz
parents:
diff changeset
101 {
anatofuz
parents:
diff changeset
102 assert(i == 55);
anatofuz
parents:
diff changeset
103 }
anatofuz
parents:
diff changeset
104 catch (...)
anatofuz
parents:
diff changeset
105 {
anatofuz
parents:
diff changeset
106 assert(false);
anatofuz
parents:
diff changeset
107 }
anatofuz
parents:
diff changeset
108 assert(false);
221
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
109
79ff65ed7e25 LLVM12 Original
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
110 return 0;
150
anatofuz
parents:
diff changeset
111 }