OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [tags/] [gnu-src/] [gcc-4.5.1/] [gcc-4.5.1-or32-1.0rc1/] [gcc/] [testsuite/] [g++.dg/] [cpp0x/] [rv-trivial-bug.C] - Blame information for rev 338

Details | Compare with Previous | View Log

Line No. Rev Author Line
1 301 jeremybenn
// { dg-do "run" }
2
// { dg-options "-std=c++0x" }
3
// PR c++/33235
4
#include 
5
 
6
int move_construct = 0;
7
int move_assign = 0;
8
 
9
struct base2
10
{
11
    base2() {}
12
    base2(base2&&) {++move_construct;}
13
    base2& operator=(base2&&) {++move_assign; return *this;}
14
};
15
 
16
int test2()
17
{
18
    base2 b;
19
    base2 b2(b);
20
    assert(move_construct == 0);
21
    base2 b3(static_cast(b));
22
    base2 b4 = static_cast(b);
23
    assert(move_construct == 2);
24
    b = b2;
25
    assert(move_assign == 0);
26
    b = static_cast(b2);
27
    assert(move_assign == 1);
28
}
29
 
30
int main()
31
{
32
    test2();
33
    return 0;
34
}

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.