Esempio n. 1
0
void produce() 
	{
	Foo * foo = new Foo;
	int I=0;
	int * PI;
	int const * CPI;
	foo->func1(i_);
	foo->func1(ci_);
	foo->func1(ir_);
	foo->func1(icr_);
	foo->func1(I);
	foo->func2(i_);
	foo->func2(ir_);
	foo->func2(I);
	foo->func6(i_);
	foo->func6(ir_);
	foo->func6(I);
	foo->nonConstFunc();
	foo_.nonConstFunc(); //should fail member data (object) call non const functions 
	foo_.constFunc(); //OK because const won't modify self
	method1(i_);
	method1(I);
	modifyStatic(I);
	modifyMember();
	indirectModifyMember();
	recursiveCaller(1);
	PI=foo_.nonConstAccess(); //should fail returns pointer to member data that is non const qualified
	CPI=foo_.constAccess(); // OK because returns pointer to member data that is const qualified
	if (*PI==*CPI) I++;
	}
Esempio n. 2
0
void method3() const
	{
	Foo foo;
	int I=0;
	Bar bar;
	foo.func1(i_);
	foo.func1(ci_);
	foo.func1(ir_);
	foo.func1(icr_);
	foo.func1(I);
	foo.func2(ir_);
	foo.func2(I);
	foo.func6(i_);
	foo.func6(ir_);
	foo.func6(I);
	foo_.nonConstRefAccess();
	foo_.constRefAccess();
//	foo_.nonConstFunc();
	foo_.nonConstAccess();
	foo_.constAccess();
	if (i_) method2(i_);
	bar.produce();
// will produce a warning only by ConstCastAwayChecker
	int & ir = (int &) (icr_);
	int & cir = const_cast<int &>(icr_);
	int * ip = (int *) (icp_);
	int * cip = const_cast<int *>(icp_);
// must not produce a warning
	int const& ira = (int const&)(icr_);
// will produce a warning by StaticLocalChecker
        static int evilStaticLocal = 0;
	static int & intRef = evilStaticLocal;
	static int * intPtr = & evilStaticLocal;
// no warnings here
	static const int c_evilStaticLocal = 0;
	static int const& c_intRef = evilStaticLocal;
	static int const* c_intPtr = &evilStaticLocal;
	static const int * c_intPtr_equivalent = &evilStaticLocal;
	static int const* const* c_intPtrPtr = &( c_intPtr);
	g_static=23;
	si_=23;
	modifyStatic(I);
	}