2 // { dg-options "-g -O0" }
4 // Copyright (C) 2014-2025 Free Software Foundation, Inc.
6 // This file is part of the GNU ISO C++ Library. This library is free
7 // software; you can redistribute it and/or modify it under the
8 // terms of the GNU General Public License as published by the
9 // Free Software Foundation; either version 3, or (at your option)
12 // This library is distributed in the hope that it will be useful,
13 // but WITHOUT ANY WARRANTY; without even the implied warranty of
14 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 // GNU General Public License for more details.
17 // You should have received a copy of the GNU General Public License along
18 // with this library; see the file COPYING3. If not see
19 // <http://www.gnu.org/licenses/>.
23 const int max_deque_node_size
= 512;
28 std::deque
<int> q0
, q1
, q2
, q3
;
29 int int_size
= sizeof (int);
31 // The xmethod logic is exercised differently for deques of different size.
32 // Let q1 be a deque requiring only 1 node. Let q2 be a deque filling up
33 // exactly 2 nodes. Let q3 be of size which would require 1 node and part
34 // of the second node.
35 int q1_size
= max_deque_node_size
/ int_size
/ 2;
36 int q2_size
= max_deque_node_size
/ int_size
* 2;
37 int q3_size
= max_deque_node_size
/ int_size
* 3 / 2;
39 for (int i
= 0; i
< q1_size
; i
++)
40 q1
.push_back (100 + i
);
42 for (int i
= 0; i
< q2_size
; i
++)
43 q2
.push_back (200 + i
);
45 for (int i
= 0; i
< q3_size
; i
++)
46 q3
.push_back (300 + i
);
48 // { dg-final { note-test q0.empty() true } }
49 // { dg-final { note-test q1.empty() false } }
50 // { dg-final { note-test q0.size() 0 } }
51 // { dg-final { note-test q1.size()==q1_size true } }
52 // { dg-final { note-test q2.size()==q2_size true } }
53 // { dg-final { note-test q3.size()==q3_size true } }
54 // { dg-final { note-test q1.front() 100 } }
55 // { dg-final { note-test q2.front() 200 } }
56 // { dg-final { note-test q3.front() 300 } }
57 // { dg-final { note-test q1.back()==(100+q1_size-1) true } }
58 // { dg-final { note-test q2.back()==(200+q2_size-1) true } }
59 // { dg-final { note-test q3.back()==(300+q3_size-1) true } }
60 // { dg-final { note-test q3\[0\] 300 } }
61 // { dg-final { note-test q3\[q3_size/2\]==(300+q3_size/2) true } }
62 // { dg-final { note-test q3\[q3_size-1]==(300+q3_size-1) true } }
64 // { dg-final { whatis-test q0.empty() bool } }
65 // { dg-final { whatis-test q0.size() std::size_t } }
66 // { dg-final { whatis-test q1.front() int } }
67 // { dg-final { whatis-test q1.back() int } }
68 // { dg-final { whatis-test q3\[0\] int } }
70 // PR libstdc++/112491
73 // { dg-final { note-test q5.size() 1 } }
74 // { dg-final { note-test q5\[0\] 5 } }
75 std::deque
<int> q6
= q1
;
77 // { dg-final { note-test {q6.size() == (q1_size-1)} true } }
78 // { dg-final { note-test q6\[1\] 102 } }
79 std::deque
<int> q7
= q2
;
82 // { dg-final { note-test {q7.size() == (q2_size-2)} true } }
83 // { dg-final { note-test q7\[1\] 203 } }
84 std::deque
<int> q8
= q3
;
88 // { dg-final { note-test {q8.size() == (q3_size-3)} true } }
89 // { dg-final { note-test q8\[1\] 304 } }
90 std::deque
<int> q9
= q8
;
92 // { dg-final { note-test q9.size() 0 } }
94 return 0; // Mark SPOT
97 // { dg-final { gdb-test SPOT {} 1 } }