File: main.cpp

package info (click to toggle)
cbmc 5.2-1~bpo8%2B1
  • links: PTS
  • area: main
  • in suites: jessie-backports
  • size: 84,268 kB
  • sloc: cpp: 177,758; ansic: 32,485; yacc: 3,550; lex: 1,778; makefile: 1,071; java: 1,039; sh: 717; python: 649; perl: 246; pascal: 141
file content (26 lines) | stat: -rw-r--r-- 592 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
struct A {
	int i;
	A():i(0){}
	int get_i(){return i;}
};

A factory(){
	return A();
}

int main()
{
	// Altough the returned value of `factory' is an
	// rvalue, gcc accepts to bind it to the `this'
	// parameter of the method `get_i'. Note that when used,
	// a returned value is stored in a temporary
	// (see goto_convertt::remove_function_call). Thus,
	// the value returned by a function call can be treated
	// as an lvalue.
	//
	// It's not clear what the best is. Should this code be rejected?
	// Is the compatibility with gcc more important?
	
	assert(factory().get_i() == 0);
	
}