]> git.ipfire.org Git - thirdparty/gcc.git/blame - libstdc++-v3/include/debug/formatter.h
Update copyright years.
[thirdparty/gcc.git] / libstdc++-v3 / include / debug / formatter.h
CommitLineData
285b36d6
BK
1// Debug-mode error formatting implementation -*- C++ -*-
2
a945c346 3// Copyright (C) 2003-2024 Free Software Foundation, Inc.
285b36d6
BK
4//
5// This file is part of the GNU ISO C++ Library. This library is free
6// software; you can redistribute it and/or modify it under the
7// terms of the GNU General Public License as published by the
748086b7 8// Free Software Foundation; either version 3, or (at your option)
285b36d6
BK
9// any later version.
10
11// This library is distributed in the hope that it will be useful,
12// but WITHOUT ANY WARRANTY; without even the implied warranty of
13// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14// GNU General Public License for more details.
15
748086b7
JJ
16// Under Section 7 of GPL version 3, you are granted additional
17// permissions described in the GCC Runtime Library Exception, version
18// 3.1, as published by the Free Software Foundation.
285b36d6 19
748086b7
JJ
20// You should have received a copy of the GNU General Public License and
21// a copy of the GCC Runtime Library Exception along with this program;
22// see the files COPYING3 and COPYING.RUNTIME respectively. If not, see
23// <http://www.gnu.org/licenses/>.
285b36d6 24
78a53887
BK
25/** @file debug/formatter.h
26 * This file is a GNU debug extension to the Standard C++ Library.
27 */
28
285b36d6
BK
29#ifndef _GLIBCXX_DEBUG_FORMATTER_H
30#define _GLIBCXX_DEBUG_FORMATTER_H 1
31
b8add594 32#include <bits/c++config.h>
fa5cc2db 33
4d566090 34#if _GLIBCXX_HAVE_STACKTRACE
4d566090
FD
35extern "C"
36{
3ad0f470 37 struct __glibcxx_backtrace_state*
4d566090
FD
38 __glibcxx_backtrace_create_state(const char*, int,
39 void(*)(void*, const char*, int),
40 void*);
4d566090
FD
41 int
42 __glibcxx_backtrace_full(
3ad0f470
JW
43 struct __glibcxx_backtrace_state*, int,
44 int (*)(void*, __UINTPTR_TYPE__, const char *, int, const char*),
45 void (*)(void*, const char*, int),
4d566090
FD
46 void*);
47}
48#endif
49
fa5cc2db
FD
50#if __cpp_rtti
51# include <typeinfo>
52# define _GLIBCXX_TYPEID(_Type) &typeid(_Type)
53#else
54namespace std
55{
56 class type_info;
57}
58# define _GLIBCXX_TYPEID(_Type) 0
59#endif
285b36d6 60
6c882d0f
FD
61#if __cplusplus >= 201103L
62namespace __gnu_cxx
63{
64_GLIBCXX_BEGIN_NAMESPACE_VERSION
65
66template<typename _Iterator, typename _Container>
67 class __normal_iterator;
68
69_GLIBCXX_END_NAMESPACE_VERSION
70}
71
72namespace std
73{
74_GLIBCXX_BEGIN_NAMESPACE_VERSION
75
76template<typename _Iterator>
77 class reverse_iterator;
78
79template<typename _Iterator>
80 class move_iterator;
81
82_GLIBCXX_END_NAMESPACE_VERSION
83}
84#endif
85
285b36d6
BK
86namespace __gnu_debug
87{
45f388bb
BK
88 using std::type_info;
89
1f5ca1a1 90 template<typename _Iterator>
38b17c27
FD
91 _GLIBCXX_CONSTEXPR
92 bool __check_singular(_Iterator const&);
1f5ca1a1 93
285b36d6
BK
94 class _Safe_sequence_base;
95
e9afbed0 96 template<typename _Iterator, typename _Sequence, typename _Category>
285b36d6
BK
97 class _Safe_iterator;
98
77e0bf4e
FD
99 template<typename _Iterator, typename _Sequence>
100 class _Safe_local_iterator;
101
526da49c 102 template<typename _Sequence>
285b36d6
BK
103 class _Safe_sequence;
104
105 enum _Debug_msg_id
106 {
107 // General checks
108 __msg_valid_range,
109 __msg_insert_singular,
110 __msg_insert_different,
111 __msg_erase_bad,
112 __msg_erase_different,
113 __msg_subscript_oob,
114 __msg_empty,
115 __msg_unpartitioned,
116 __msg_unpartitioned_pred,
117 __msg_unsorted,
118 __msg_unsorted_pred,
119 __msg_not_heap,
120 __msg_not_heap_pred,
121 // std::bitset checks
122 __msg_bad_bitset_write,
123 __msg_bad_bitset_read,
124 __msg_bad_bitset_flip,
125 // std::list checks
126 __msg_self_splice,
127 __msg_splice_alloc,
128 __msg_splice_bad,
129 __msg_splice_other,
130 __msg_splice_overlap,
131 // iterator checks
132 __msg_init_singular,
133 __msg_init_copy_singular,
134 __msg_init_const_singular,
135 __msg_copy_singular,
136 __msg_bad_deref,
137 __msg_bad_inc,
138 __msg_bad_dec,
139 __msg_iter_subscript_oob,
140 __msg_advance_oob,
141 __msg_retreat_oob,
142 __msg_iter_compare_bad,
143 __msg_compare_different,
144 __msg_iter_order_bad,
145 __msg_order_different,
146 __msg_distance_bad,
147 __msg_distance_different,
148 // istream_iterator
149 __msg_deref_istream,
150 __msg_inc_istream,
151 // ostream_iterator
152 __msg_output_ostream,
153 // istreambuf_iterator
154 __msg_deref_istreambuf,
b8b4301e
PC
155 __msg_inc_istreambuf,
156 // forward_list
157 __msg_insert_after_end,
158 __msg_erase_after_bad,
77e0bf4e 159 __msg_valid_range2,
7181e991 160 // unordered container local iterators
a8028a3e 161 __msg_local_iter_compare_bad,
739fd6a6 162 __msg_non_empty_range,
c2fb0a1a 163 // self move assign (no longer used)
7181e991
FD
164 __msg_self_move_assign,
165 // unordered container buckets
14cbb5d8 166 __msg_bucket_index_oob,
e77c9aed 167 __msg_valid_load_factor,
5720787a
FD
168 // others
169 __msg_equal_allocs,
630a286a
FD
170 __msg_insert_range_from_self,
171 __msg_irreflexive_ordering
285b36d6
BK
172 };
173
174 class _Error_formatter
175 {
814e52ca
FD
176 // Tags denoting the type of parameter for construction
177 struct _Is_iterator { };
178 struct _Is_iterator_value_type { };
179 struct _Is_sequence { };
180 struct _Is_instance { };
181
182 public:
285b36d6
BK
183 /// Whether an iterator is constant, mutable, or unknown
184 enum _Constness
185 {
186 __unknown_constness,
187 __const_iterator,
188 __mutable_iterator,
189 __last_constness
526da49c 190 };
285b36d6
BK
191
192 // The state of the iterator (fine-grained), if we know it.
193 enum _Iterator_state
194 {
195 __unknown_state,
fa5cc2db
FD
196 __singular, // singular, may still be attached to a sequence
197 __begin, // dereferenceable, and at the beginning
198 __middle, // dereferenceable, not at the beginning
199 __end, // past-the-end, may be at beginning if sequence empty
200 __before_begin, // before begin
6c882d0f
FD
201 __rbegin, // dereferenceable, and at the reverse-beginning
202 __rmiddle, // reverse-dereferenceable, not at the reverse-beginning
203 __rend, // reverse-past-the-end
01b1afdc 204 __singular_value_init, // singular, value initialized
285b36d6
BK
205 __last_state
206 };
207
285b36d6
BK
208 // A parameter that may be referenced by an error message
209 struct _Parameter
210 {
526da49c
BI
211 enum
212 {
213 __unused_param,
214 __iterator,
215 __sequence,
285b36d6 216 __integer,
adad2a7d
FD
217 __string,
218 __instance,
219 __iterator_value_type
285b36d6 220 } _M_kind;
526da49c 221
a42220f0 222 struct _Named
adad2a7d
FD
223 {
224 const char* _M_name;
a42220f0
FD
225 };
226
227 struct _Type : _Named
228 {
adad2a7d
FD
229 const type_info* _M_type;
230 };
231
232 struct _Instance : _Type
233 {
234 const void* _M_address;
235 };
236
285b36d6
BK
237 union
238 {
239 // When _M_kind == __iterator
adad2a7d 240 struct : _Instance
285b36d6 241 {
fa5cc2db
FD
242 _Constness _M_constness;
243 _Iterator_state _M_state;
244 const void* _M_sequence;
245 const type_info* _M_seq_type;
285b36d6 246 } _M_iterator;
526da49c 247
285b36d6 248 // When _M_kind == __sequence
adad2a7d 249 _Instance _M_sequence;
285b36d6
BK
250
251 // When _M_kind == __integer
a42220f0 252 struct : _Named
285b36d6 253 {
fa5cc2db 254 long _M_value;
285b36d6
BK
255 } _M_integer;
256
257 // When _M_kind == __string
a42220f0 258 struct : _Named
285b36d6 259 {
fa5cc2db 260 const char* _M_value;
285b36d6 261 } _M_string;
adad2a7d
FD
262
263 // When _M_kind == __instance
264 _Instance _M_instance;
265
266 // When _M_kind == __iterator_value_type
267 _Type _M_iterator_value_type;
285b36d6
BK
268 } _M_variant;
269
26c691a8 270 _Parameter() : _M_kind(__unused_param), _M_variant() { }
526da49c 271
fa5cc2db 272 _Parameter(long __value, const char* __name)
26c691a8 273 : _M_kind(__integer), _M_variant()
526da49c 274 {
285b36d6 275 _M_variant._M_integer._M_name = __name;
526da49c 276 _M_variant._M_integer._M_value = __value;
285b36d6
BK
277 }
278
fa5cc2db 279 _Parameter(const char* __value, const char* __name)
26c691a8 280 : _M_kind(__string), _M_variant()
285b36d6
BK
281 {
282 _M_variant._M_string._M_name = __name;
526da49c 283 _M_variant._M_string._M_value = __value;
285b36d6
BK
284 }
285
e9afbed0
FD
286 template<typename _Iterator, typename _Sequence, typename _Category>
287 _Parameter(_Safe_iterator<_Iterator, _Sequence, _Category> const& __it,
285b36d6 288 const char* __name, _Is_iterator)
26c691a8 289 : _M_kind(__iterator), _M_variant()
fa5cc2db 290 {
285b36d6 291 _M_variant._M_iterator._M_name = __name;
200fcd33 292 _M_variant._M_iterator._M_address = std::__addressof(__it);
6c882d0f 293 _M_variant._M_iterator._M_type = _GLIBCXX_TYPEID(_Iterator);
526da49c 294 _M_variant._M_iterator._M_constness =
6c882d0f 295 __it._S_constant() ? __const_iterator : __mutable_iterator;
285b36d6 296 _M_variant._M_iterator._M_sequence = __it._M_get_sequence();
fa5cc2db 297 _M_variant._M_iterator._M_seq_type = _GLIBCXX_TYPEID(_Sequence);
285b36d6
BK
298
299 if (__it._M_singular())
01b1afdc
FD
300 {
301 if (__it._M_value_initialized())
302 _M_variant._M_iterator._M_state = __singular_value_init;
303 else
304 _M_variant._M_iterator._M_state = __singular;
305 }
285b36d6
BK
306 else
307 {
b8b4301e
PC
308 if (__it._M_is_before_begin())
309 _M_variant._M_iterator._M_state = __before_begin;
310 else if (__it._M_is_end())
285b36d6 311 _M_variant._M_iterator._M_state = __end;
b8b4301e 312 else if (__it._M_is_begin())
285b36d6
BK
313 _M_variant._M_iterator._M_state = __begin;
314 else
315 _M_variant._M_iterator._M_state = __middle;
316 }
317 }
318
77e0bf4e 319 template<typename _Iterator, typename _Sequence>
adad2a7d 320 _Parameter(_Safe_local_iterator<_Iterator, _Sequence> const& __it,
77e0bf4e
FD
321 const char* __name, _Is_iterator)
322 : _M_kind(__iterator), _M_variant()
323 {
324 _M_variant._M_iterator._M_name = __name;
200fcd33 325 _M_variant._M_iterator._M_address = std::__addressof(__it);
6c882d0f 326 _M_variant._M_iterator._M_type = _GLIBCXX_TYPEID(_Iterator);
77e0bf4e 327 _M_variant._M_iterator._M_constness =
6c882d0f 328 __it._S_constant() ? __const_iterator : __mutable_iterator;
77e0bf4e 329 _M_variant._M_iterator._M_sequence = __it._M_get_sequence();
fa5cc2db 330 _M_variant._M_iterator._M_seq_type = _GLIBCXX_TYPEID(_Sequence);
77e0bf4e
FD
331
332 if (__it._M_singular())
01b1afdc
FD
333 {
334 if (__it._M_value_initialized())
335 _M_variant._M_iterator._M_state = __singular_value_init;
336 else
337 _M_variant._M_iterator._M_state = __singular;
338 }
77e0bf4e
FD
339 else
340 {
341 if (__it._M_is_end())
342 _M_variant._M_iterator._M_state = __end;
343 else if (__it._M_is_begin())
344 _M_variant._M_iterator._M_state = __begin;
345 else
346 _M_variant._M_iterator._M_state = __middle;
347 }
348 }
349
285b36d6 350 template<typename _Type>
adad2a7d 351 _Parameter(const _Type* const& __it, const char* __name, _Is_iterator)
fa5cc2db
FD
352 : _M_kind(__iterator), _M_variant()
353 {
285b36d6 354 _M_variant._M_iterator._M_name = __name;
200fcd33 355 _M_variant._M_iterator._M_address = std::__addressof(__it);
fa5cc2db 356 _M_variant._M_iterator._M_type = _GLIBCXX_TYPEID(__it);
adad2a7d
FD
357 _M_variant._M_iterator._M_constness = __const_iterator;
358 _M_variant._M_iterator._M_state = __it ? __unknown_state : __singular;
285b36d6
BK
359 _M_variant._M_iterator._M_sequence = 0;
360 _M_variant._M_iterator._M_seq_type = 0;
361 }
362
363 template<typename _Type>
adad2a7d 364 _Parameter(_Type* const& __it, const char* __name, _Is_iterator)
fa5cc2db
FD
365 : _M_kind(__iterator), _M_variant()
366 {
285b36d6 367 _M_variant._M_iterator._M_name = __name;
200fcd33 368 _M_variant._M_iterator._M_address = std::__addressof(__it);
fa5cc2db 369 _M_variant._M_iterator._M_type = _GLIBCXX_TYPEID(__it);
adad2a7d
FD
370 _M_variant._M_iterator._M_constness = __mutable_iterator;
371 _M_variant._M_iterator._M_state = __it ? __unknown_state : __singular;
285b36d6
BK
372 _M_variant._M_iterator._M_sequence = 0;
373 _M_variant._M_iterator._M_seq_type = 0;
374 }
526da49c 375
285b36d6 376 template<typename _Iterator>
adad2a7d 377 _Parameter(_Iterator const& __it, const char* __name, _Is_iterator)
fa5cc2db
FD
378 : _M_kind(__iterator), _M_variant()
379 {
285b36d6 380 _M_variant._M_iterator._M_name = __name;
200fcd33 381 _M_variant._M_iterator._M_address = std::__addressof(__it);
fa5cc2db 382 _M_variant._M_iterator._M_type = _GLIBCXX_TYPEID(__it);
285b36d6 383 _M_variant._M_iterator._M_constness = __unknown_constness;
526da49c 384 _M_variant._M_iterator._M_state =
adad2a7d 385 __gnu_debug::__check_singular(__it) ? __singular : __unknown_state;
285b36d6
BK
386 _M_variant._M_iterator._M_sequence = 0;
387 _M_variant._M_iterator._M_seq_type = 0;
388 }
389
6c882d0f
FD
390#if __cplusplus >= 201103L
391 // The following constructors are only defined in C++11 to take
392 // advantage of the constructor delegation feature.
393 template<typename _Iterator, typename _Container>
394 _Parameter(
395 __gnu_cxx::__normal_iterator<_Iterator, _Container> const& __it,
396 const char* __name, _Is_iterator)
397 : _Parameter(__it.base(), __name, _Is_iterator{})
398 { _M_variant._M_iterator._M_type = _GLIBCXX_TYPEID(__it); }
399
400 template<typename _Iterator>
401 _Parameter(std::reverse_iterator<_Iterator> const& __it,
402 const char* __name, _Is_iterator)
403 : _Parameter(__it.base(), __name, _Is_iterator{})
404 {
405 _M_variant._M_iterator._M_type = _GLIBCXX_TYPEID(__it);
406 _M_variant._M_iterator._M_state
407 = _S_reverse_state(_M_variant._M_iterator._M_state);
408 }
409
e9afbed0
FD
410 template<typename _Iterator, typename _Sequence, typename _Category>
411 _Parameter(std::reverse_iterator<_Safe_iterator<_Iterator, _Sequence,
412 _Category>> const& __it,
413 const char* __name, _Is_iterator)
6c882d0f
FD
414 : _Parameter(__it.base(), __name, _Is_iterator{})
415 {
416 _M_variant._M_iterator._M_type
417 = _GLIBCXX_TYPEID(std::reverse_iterator<_Iterator>);
418 _M_variant._M_iterator._M_state
419 = _S_reverse_state(_M_variant._M_iterator._M_state);
420 }
421
422 template<typename _Iterator>
423 _Parameter(std::move_iterator<_Iterator> const& __it,
424 const char* __name, _Is_iterator)
425 : _Parameter(__it.base(), __name, _Is_iterator{})
426 { _M_variant._M_iterator._M_type = _GLIBCXX_TYPEID(__it); }
427
e9afbed0
FD
428 template<typename _Iterator, typename _Sequence, typename _Category>
429 _Parameter(std::move_iterator<_Safe_iterator<_Iterator, _Sequence,
430 _Category>> const& __it,
431 const char* __name, _Is_iterator)
6c882d0f
FD
432 : _Parameter(__it.base(), __name, _Is_iterator{})
433 {
434 _M_variant._M_iterator._M_type
435 = _GLIBCXX_TYPEID(std::move_iterator<_Iterator>);
436 }
437
438 private:
439 _Iterator_state
440 _S_reverse_state(_Iterator_state __state)
441 {
442 switch (__state)
443 {
444 case __begin:
445 return __rend;
446 case __middle:
447 return __rmiddle;
448 case __end:
449 return __rbegin;
450 default:
451 return __state;
452 }
453 }
454
455 public:
456#endif
457
285b36d6 458 template<typename _Sequence>
fa5cc2db 459 _Parameter(const _Safe_sequence<_Sequence>& __seq,
285b36d6 460 const char* __name, _Is_sequence)
fa5cc2db
FD
461 : _M_kind(__sequence), _M_variant()
462 {
285b36d6 463 _M_variant._M_sequence._M_name = __name;
526da49c 464 _M_variant._M_sequence._M_address =
200fcd33 465 static_cast<const _Sequence*>(std::__addressof(__seq));
fa5cc2db 466 _M_variant._M_sequence._M_type = _GLIBCXX_TYPEID(_Sequence);
285b36d6
BK
467 }
468
469 template<typename _Sequence>
fa5cc2db
FD
470 _Parameter(const _Sequence& __seq, const char* __name, _Is_sequence)
471 : _M_kind(__sequence), _M_variant()
472 {
285b36d6 473 _M_variant._M_sequence._M_name = __name;
200fcd33 474 _M_variant._M_sequence._M_address = std::__addressof(__seq);
fa5cc2db 475 _M_variant._M_sequence._M_type = _GLIBCXX_TYPEID(_Sequence);
285b36d6 476 }
526da49c 477
adad2a7d
FD
478 template<typename _Iterator>
479 _Parameter(const _Iterator& __it, const char* __name,
480 _Is_iterator_value_type)
481 : _M_kind(__iterator_value_type), _M_variant()
482 {
483 _M_variant._M_iterator_value_type._M_name = __name;
484 _M_variant._M_iterator_value_type._M_type =
485 _GLIBCXX_TYPEID(typename std::iterator_traits<_Iterator>::value_type);
486 }
487
488 template<typename _Type>
489 _Parameter(const _Type& __inst, const char* __name, _Is_instance)
490 : _M_kind(__instance), _M_variant()
491 {
492 _M_variant._M_instance._M_name = __name;
493 _M_variant._M_instance._M_address = &__inst;
494 _M_variant._M_instance._M_type = _GLIBCXX_TYPEID(_Type);
495 }
496
dc4dd7f6 497#if !_GLIBCXX_INLINE_VERSION
285b36d6 498 void
526da49c 499 _M_print_field(const _Error_formatter* __formatter,
814e52ca 500 const char* __name) const _GLIBCXX_DEPRECATED;
526da49c 501
285b36d6 502 void
814e52ca
FD
503 _M_print_description(const _Error_formatter* __formatter)
504 const _GLIBCXX_DEPRECATED;
dc4dd7f6 505#endif
285b36d6
BK
506 };
507
285b36d6 508 template<typename _Iterator>
814e52ca
FD
509 _Error_formatter&
510 _M_iterator(const _Iterator& __it, const char* __name = 0)
285b36d6 511 {
8fc81078 512 if (_M_num_parameters < std::size_t(__max_parameters))
285b36d6
BK
513 _M_parameters[_M_num_parameters++] = _Parameter(__it, __name,
514 _Is_iterator());
515 return *this;
516 }
517
adad2a7d 518 template<typename _Iterator>
814e52ca 519 _Error_formatter&
adad2a7d 520 _M_iterator_value_type(const _Iterator& __it,
814e52ca 521 const char* __name = 0)
adad2a7d 522 {
814e52ca 523 if (_M_num_parameters < __max_parameters)
adad2a7d
FD
524 _M_parameters[_M_num_parameters++] =
525 _Parameter(__it, __name, _Is_iterator_value_type());
526 return *this;
527 }
528
814e52ca
FD
529 _Error_formatter&
530 _M_integer(long __value, const char* __name = 0)
285b36d6 531 {
814e52ca 532 if (_M_num_parameters < __max_parameters)
285b36d6
BK
533 _M_parameters[_M_num_parameters++] = _Parameter(__value, __name);
534 return *this;
535 }
536
814e52ca
FD
537 _Error_formatter&
538 _M_string(const char* __value, const char* __name = 0)
285b36d6 539 {
814e52ca 540 if (_M_num_parameters < __max_parameters)
285b36d6
BK
541 _M_parameters[_M_num_parameters++] = _Parameter(__value, __name);
542 return *this;
543 }
544
545 template<typename _Sequence>
814e52ca
FD
546 _Error_formatter&
547 _M_sequence(const _Sequence& __seq, const char* __name = 0)
285b36d6 548 {
814e52ca 549 if (_M_num_parameters < __max_parameters)
526da49c 550 _M_parameters[_M_num_parameters++] = _Parameter(__seq, __name,
285b36d6
BK
551 _Is_sequence());
552 return *this;
553 }
554
adad2a7d 555 template<typename _Type>
814e52ca
FD
556 _Error_formatter&
557 _M_instance(const _Type& __inst, const char* __name = 0)
adad2a7d 558 {
814e52ca 559 if (_M_num_parameters < __max_parameters)
adad2a7d
FD
560 _M_parameters[_M_num_parameters++] = _Parameter(__inst, __name,
561 _Is_instance());
562 return *this;
563 }
564
814e52ca
FD
565 _Error_formatter&
566 _M_message(const char* __text)
285b36d6
BK
567 { _M_text = __text; return *this; }
568
814e52ca
FD
569 // Kept const qualifier for backward compatibility, to keep the same
570 // exported symbol.
571 _Error_formatter&
5d51b87a 572 _M_message(_Debug_msg_id __id) const throw ();
285b36d6 573
b8add594 574 _GLIBCXX_NORETURN void
285b36d6
BK
575 _M_error() const;
576
dc4dd7f6 577#if !_GLIBCXX_INLINE_VERSION
9dc420e6 578 template<typename _Tp>
4be58168 579 void
814e52ca
FD
580 _M_format_word(char*, int, const char*, _Tp)
581 const throw () _GLIBCXX_DEPRECATED;
4be58168 582
526da49c 583 void
814e52ca 584 _M_print_word(const char* __word) const _GLIBCXX_DEPRECATED;
285b36d6 585
526da49c 586 void
814e52ca 587 _M_print_string(const char* __string) const _GLIBCXX_DEPRECATED;
dc4dd7f6 588#endif
285b36d6 589
adad2a7d 590 private:
a5277405
FD
591 _Error_formatter(const char* __file, unsigned int __line,
592 const char* __function)
814e52ca 593 : _M_file(__file), _M_line(__line), _M_num_parameters(0), _M_text(0)
a5277405 594 , _M_function(__function)
4d566090
FD
595#if _GLIBCXX_HAVE_STACKTRACE
596# ifdef _GLIBCXX_DEBUG_BACKTRACE
3ad0f470 597 , _M_backtrace_state(__glibcxx_backtrace_create_state(0, 1, _S_err, 0))
4d566090
FD
598 , _M_backtrace_full(&__glibcxx_backtrace_full)
599# else
3ad0f470 600 , _M_backtrace_state(0)
4d566090
FD
601# endif
602#endif
814e52ca 603 { }
fa5cc2db 604
dc4dd7f6 605#if !_GLIBCXX_INLINE_VERSION
5dddb7e5 606 void
814e52ca 607 _M_get_max_length() const throw () _GLIBCXX_DEPRECATED;
dc4dd7f6 608#endif
5dddb7e5 609
285b36d6
BK
610 enum { __max_parameters = 9 };
611
fa5cc2db 612 const char* _M_file;
814e52ca
FD
613 unsigned int _M_line;
614 _Parameter _M_parameters[__max_parameters];
615 unsigned int _M_num_parameters;
616 const char* _M_text;
a5277405 617 const char* _M_function;
4d566090 618#if _GLIBCXX_HAVE_STACKTRACE
3ad0f470
JW
619 struct __glibcxx_backtrace_state* _M_backtrace_state;
620 // TODO: Remove _M_backtrace_full after __glibcxx_backtrace_full is moved
621 // from libstdc++_libbacktrace.a to libstdc++.so:
622 __decltype(&__glibcxx_backtrace_full) _M_backtrace_full;
623
624 static void _S_err(void*, const char*, int) { }
4d566090 625#endif
285b36d6
BK
626
627 public:
814e52ca 628 static _Error_formatter&
a5277405 629 _S_at(const char* __file, unsigned int __line, const char* __function)
814e52ca 630 {
a5277405 631 static _Error_formatter __formatter(__file, __line, __function);
814e52ca
FD
632 return __formatter;
633 }
285b36d6
BK
634 };
635} // namespace __gnu_debug
636
fa5cc2db
FD
637#undef _GLIBCXX_TYPEID
638
526da49c 639#endif