2010-12-30 09:46:44 +01:00
/*
* Cppcheck - A tool for static C / C + + code analysis
2016-01-01 14:34:45 +01:00
* Copyright ( C ) 2007 - 2016 Cppcheck team .
2010-12-30 09:46:44 +01:00
*
* This program is free software : you can redistribute it and / or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation , either version 3 of the License , or
* ( at your option ) any later version .
*
* This program is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
* GNU General Public License for more details .
*
* You should have received a copy of the GNU General Public License
* along with this program . If not , see < http : //www.gnu.org/licenses/>.
*/
# include "testsuite.h"
# include "testutils.h"
# include "symboldatabase.h"
2015-11-29 10:49:10 +01:00
# include "utils.h"
2012-10-30 15:48:06 +01:00
# include <sstream>
2015-01-15 18:52:11 +01:00
# include <stdexcept>
2010-12-30 09:46:44 +01:00
2011-01-28 08:33:02 +01:00
# define GET_SYMBOL_DB(code) \
Tokenizer tokenizer ( & settings , this ) ; \
2015-10-08 12:53:56 +02:00
const SymbolDatabase * db = getSymbolDB_inner ( tokenizer , code , " test.cpp " ) ;
2011-01-28 08:33:02 +01:00
2012-01-28 01:24:01 +01:00
# define GET_SYMBOL_DB_C(code) \
Tokenizer tokenizer ( & settings , this ) ; \
2015-10-08 12:53:56 +02:00
const SymbolDatabase * db = getSymbolDB_inner ( tokenizer , code , " test.c " ) ;
2012-01-28 01:24:01 +01:00
2011-10-13 20:53:06 +02:00
class TestSymbolDatabase : public TestFixture {
2010-12-30 09:46:44 +01:00
public :
TestSymbolDatabase ( )
: TestFixture ( " TestSymbolDatabase " )
2014-02-16 10:32:10 +01:00
, si ( nullptr , nullptr , nullptr )
, vartok ( nullptr )
, typetok ( nullptr )
, t ( nullptr )
2014-11-20 14:20:09 +01:00
, found ( false ) {
2013-08-07 16:27:37 +02:00
}
2010-12-30 09:46:44 +01:00
private :
2011-01-17 18:29:19 +01:00
const Scope si ;
2010-12-30 09:46:44 +01:00
const Token * vartok ;
2010-12-30 22:57:43 +01:00
const Token * typetok ;
2011-01-02 00:36:22 +01:00
const Token * t ;
2012-05-11 17:56:47 +02:00
bool found ;
2015-01-30 21:56:27 +01:00
Settings settings ;
2016-02-04 20:49:13 +01:00
Settings settings2 ;
2010-12-30 22:57:43 +01:00
2014-11-20 14:20:09 +01:00
void reset ( ) {
2014-02-16 10:32:10 +01:00
vartok = nullptr ;
typetok = nullptr ;
t = nullptr ;
2012-05-11 17:56:47 +02:00
found = false ;
2010-12-30 22:57:43 +01:00
}
2010-12-30 09:46:44 +01:00
2015-10-08 12:53:56 +02:00
const SymbolDatabase * getSymbolDB_inner ( Tokenizer & tokenizer , const char * code , const char * filename ) {
errout . str ( " " ) ;
std : : istringstream istr ( code ) ;
tokenizer . tokenize ( istr , filename ) ;
return tokenizer . getSymbolDatabase ( ) ;
}
2014-11-20 14:20:09 +01:00
static const Scope * findFunctionScopeByToken ( const SymbolDatabase * db , const Token * tok ) {
2013-01-28 06:47:48 +01:00
std : : list < Scope > : : const_iterator scope ;
for ( scope = db - > scopeList . begin ( ) ; scope ! = db - > scopeList . end ( ) ; + + scope ) {
if ( scope - > type = = Scope : : eFunction ) {
if ( scope - > classDef = = tok )
return & ( * scope ) ;
}
}
return 0 ;
}
2014-11-20 14:20:09 +01:00
static const Function * findFunctionByName ( const char str [ ] , const Scope * startScope ) {
2013-01-28 06:47:48 +01:00
const Scope * currScope = startScope ;
while ( currScope & & currScope - > isExecutable ( ) ) {
if ( currScope - > functionOf )
currScope = currScope - > functionOf ;
else
currScope = currScope - > nestedIn ;
}
while ( currScope ) {
for ( std : : list < Function > : : const_iterator i = currScope - > functionList . begin ( ) ; i ! = currScope - > functionList . end ( ) ; + + i ) {
if ( i - > tokenDef - > str ( ) = = str )
return & * i ;
}
currScope = currScope - > nestedIn ;
}
return 0 ;
}
2014-11-20 14:20:09 +01:00
void run ( ) {
2015-01-30 21:56:27 +01:00
LOAD_LIB_2 ( settings . library , " std.cfg " ) ;
2016-02-04 20:49:13 +01:00
settings2 . platform ( Settings : : Unspecified ) ;
2015-01-30 21:56:27 +01:00
2012-08-10 11:01:12 +02:00
TEST_CASE ( array ) ;
2015-01-30 21:56:27 +01:00
TEST_CASE ( stlarray ) ;
2012-08-10 11:01:12 +02:00
2010-12-30 09:46:44 +01:00
TEST_CASE ( test_isVariableDeclarationCanHandleNull ) ;
TEST_CASE ( test_isVariableDeclarationIdentifiesSimpleDeclaration ) ;
2014-08-05 15:33:57 +02:00
TEST_CASE ( test_isVariableDeclarationIdentifiesInitialization ) ;
TEST_CASE ( test_isVariableDeclarationIdentifiesCpp11Initialization ) ;
2010-12-30 09:46:44 +01:00
TEST_CASE ( test_isVariableDeclarationIdentifiesScopedDeclaration ) ;
TEST_CASE ( test_isVariableDeclarationIdentifiesStdDeclaration ) ;
TEST_CASE ( test_isVariableDeclarationIdentifiesScopedStdDeclaration ) ;
TEST_CASE ( test_isVariableDeclarationIdentifiesManyScopes ) ;
2010-12-30 22:57:43 +01:00
TEST_CASE ( test_isVariableDeclarationIdentifiesPointers ) ;
2010-12-30 09:46:44 +01:00
TEST_CASE ( test_isVariableDeclarationDoesNotIdentifyConstness ) ;
TEST_CASE ( test_isVariableDeclarationIdentifiesFirstOfManyVariables ) ;
2010-12-30 22:57:43 +01:00
TEST_CASE ( test_isVariableDeclarationIdentifiesScopedPointerDeclaration ) ;
TEST_CASE ( test_isVariableDeclarationIdentifiesDeclarationWithIndirection ) ;
TEST_CASE ( test_isVariableDeclarationIdentifiesDeclarationWithMultipleIndirection ) ;
2011-01-01 01:19:32 +01:00
TEST_CASE ( test_isVariableDeclarationIdentifiesArray ) ;
2015-08-28 23:06:39 +02:00
TEST_CASE ( test_isVariableDeclarationIdentifiesPointerArray ) ;
2011-01-01 01:19:32 +01:00
TEST_CASE ( test_isVariableDeclarationIdentifiesOfArrayPointers ) ;
2011-01-02 00:36:22 +01:00
TEST_CASE ( isVariableDeclarationIdentifiesTemplatedPointerVariable ) ;
2011-01-18 08:29:42 +01:00
TEST_CASE ( isVariableDeclarationIdentifiesTemplatedPointerToPointerVariable ) ;
2011-01-18 10:14:12 +01:00
TEST_CASE ( isVariableDeclarationIdentifiesTemplatedArrayVariable ) ;
2011-01-02 00:36:22 +01:00
TEST_CASE ( isVariableDeclarationIdentifiesTemplatedVariable ) ;
TEST_CASE ( isVariableDeclarationIdentifiesTemplatedVariableIterator ) ;
TEST_CASE ( isVariableDeclarationIdentifiesNestedTemplateVariable ) ;
2012-01-26 17:04:25 +01:00
TEST_CASE ( isVariableDeclarationIdentifiesReference ) ;
2011-01-02 00:36:22 +01:00
TEST_CASE ( isVariableDeclarationDoesNotIdentifyTemplateClass ) ;
2014-10-12 16:06:50 +02:00
TEST_CASE ( isVariableDeclarationDoesNotIdentifyCppCast ) ;
2012-03-24 15:10:06 +01:00
TEST_CASE ( isVariableDeclarationPointerConst ) ;
2013-04-04 18:47:44 +02:00
TEST_CASE ( isVariableDeclarationRValueRef ) ;
2014-01-28 15:44:56 +01:00
TEST_CASE ( isVariableStlType ) ;
2011-01-28 08:33:02 +01:00
2015-10-26 19:20:42 +01:00
TEST_CASE ( rangeBasedFor ) ;
2013-07-20 17:46:39 +02:00
TEST_CASE ( arrayMemberVar1 ) ;
TEST_CASE ( arrayMemberVar2 ) ;
TEST_CASE ( arrayMemberVar3 ) ;
2012-05-15 21:03:43 +02:00
TEST_CASE ( staticMemberVar ) ;
2015-01-14 22:59:01 +01:00
TEST_CASE ( getVariableFromVarIdBoundsCheck ) ;
2012-05-15 21:03:43 +02:00
2011-01-28 08:33:02 +01:00
TEST_CASE ( hasRegularFunction ) ;
TEST_CASE ( hasInlineClassFunction ) ;
TEST_CASE ( hasMissingInlineClassFunction ) ;
TEST_CASE ( hasClassFunction ) ;
TEST_CASE ( hasRegularFunctionReturningFunctionPointer ) ;
TEST_CASE ( hasInlineClassFunctionReturningFunctionPointer ) ;
TEST_CASE ( hasMissingInlineClassFunctionReturningFunctionPointer ) ;
TEST_CASE ( hasClassFunctionReturningFunctionPointer ) ;
2014-03-28 17:43:40 +01:00
TEST_CASE ( complexFunctionArrayPtr ) ;
2014-04-12 11:43:10 +02:00
TEST_CASE ( pointerToMemberFunction ) ;
2012-09-15 20:13:32 +02:00
TEST_CASE ( hasSubClassConstructor ) ;
2013-04-04 19:53:55 +02:00
TEST_CASE ( testConstructors ) ;
2012-08-22 12:37:50 +02:00
TEST_CASE ( functionDeclarationTemplate ) ;
2012-03-23 17:59:51 +01:00
TEST_CASE ( functionDeclarations ) ;
2014-09-29 13:05:51 +02:00
TEST_CASE ( constructorInitialization ) ;
2014-03-31 20:33:01 +02:00
TEST_CASE ( memberFunctionOfUnknownClassMacro1 ) ;
TEST_CASE ( memberFunctionOfUnknownClassMacro2 ) ;
2014-03-31 21:04:01 +02:00
TEST_CASE ( memberFunctionOfUnknownClassMacro3 ) ;
2015-01-08 05:45:31 +01:00
TEST_CASE ( functionLinkage ) ;
2011-02-25 13:17:55 +01:00
2012-02-24 20:45:56 +01:00
TEST_CASE ( classWithFriend ) ;
2011-11-05 12:23:05 +01:00
TEST_CASE ( parseFunctionCorrect ) ;
2012-05-22 21:30:10 +02:00
TEST_CASE ( parseFunctionDeclarationCorrect ) ;
2012-07-10 15:15:11 +02:00
TEST_CASE ( Cpp11InitInInitList ) ;
2011-11-05 12:23:05 +01:00
2011-02-25 13:17:55 +01:00
TEST_CASE ( hasGlobalVariables1 ) ;
TEST_CASE ( hasGlobalVariables2 ) ;
TEST_CASE ( hasGlobalVariables3 ) ;
2011-04-29 02:53:31 +02:00
2013-09-28 11:44:26 +02:00
TEST_CASE ( checkTypeStartEndToken1 ) ;
TEST_CASE ( checkTypeStartEndToken2 ) ; // handling for unknown macro: 'void f() MACRO {..'
2016-01-23 09:48:21 +01:00
TEST_CASE ( checkTypeStartEndToken3 ) ; // no variable name: void f(const char){}
2012-06-08 18:05:02 +02:00
2011-04-29 02:53:31 +02:00
TEST_CASE ( functionArgs1 ) ;
2011-08-28 19:32:42 +02:00
TEST_CASE ( functionArgs2 ) ;
2012-05-22 10:29:33 +02:00
TEST_CASE ( functionArgs3 ) ;
2012-12-29 08:32:43 +01:00
TEST_CASE ( functionArgs4 ) ;
2011-04-29 03:03:57 +02:00
2012-01-07 09:28:26 +01:00
TEST_CASE ( namespaces1 ) ;
TEST_CASE ( namespaces2 ) ;
2012-06-05 06:37:55 +02:00
TEST_CASE ( namespaces3 ) ; // #3854 - unknown macro
2016-01-30 14:04:48 +01:00
TEST_CASE ( namespaces4 ) ;
2012-01-07 09:28:26 +01:00
2012-01-26 04:48:18 +01:00
TEST_CASE ( tryCatch1 ) ;
2011-04-29 03:03:57 +02:00
TEST_CASE ( symboldatabase1 ) ;
TEST_CASE ( symboldatabase2 ) ;
TEST_CASE ( symboldatabase3 ) ; // ticket #2000
TEST_CASE ( symboldatabase4 ) ;
TEST_CASE ( symboldatabase5 ) ; // ticket #2178
TEST_CASE ( symboldatabase6 ) ; // ticket #2221
TEST_CASE ( symboldatabase7 ) ; // ticket #2230
TEST_CASE ( symboldatabase8 ) ; // ticket #2252
TEST_CASE ( symboldatabase9 ) ; // ticket #2525
TEST_CASE ( symboldatabase10 ) ; // ticket #2537
TEST_CASE ( symboldatabase11 ) ; // ticket #2539
TEST_CASE ( symboldatabase12 ) ; // ticket #2547
TEST_CASE ( symboldatabase13 ) ; // ticket #2577
TEST_CASE ( symboldatabase14 ) ; // ticket #2589
TEST_CASE ( symboldatabase15 ) ; // ticket #2591
TEST_CASE ( symboldatabase16 ) ; // ticket #2637
TEST_CASE ( symboldatabase17 ) ; // ticket #2657
2011-06-27 13:31:10 +02:00
TEST_CASE ( symboldatabase18 ) ; // ticket #2865
2011-08-11 23:57:54 +02:00
TEST_CASE ( symboldatabase19 ) ; // ticket #2991 (segmentation fault)
2011-08-17 01:16:58 +02:00
TEST_CASE ( symboldatabase20 ) ; // ticket #3013 (segmentation fault)
2011-09-29 04:05:26 +02:00
TEST_CASE ( symboldatabase21 ) ;
2011-12-22 09:20:37 +01:00
TEST_CASE ( symboldatabase22 ) ; // ticket #3437 (segmentation fault)
2011-12-25 11:05:06 +01:00
TEST_CASE ( symboldatabase23 ) ; // ticket #3435
2012-01-22 19:34:53 +01:00
TEST_CASE ( symboldatabase24 ) ; // ticket #3508 (constructor, destructor)
2012-01-28 01:24:01 +01:00
TEST_CASE ( symboldatabase25 ) ; // ticket #3561 (throw C++)
TEST_CASE ( symboldatabase26 ) ; // ticket #3561 (throw C)
2012-01-31 19:34:55 +01:00
TEST_CASE ( symboldatabase27 ) ; // ticket #3543 (segmentation fault)
2012-04-27 21:51:13 +02:00
TEST_CASE ( symboldatabase28 ) ;
2012-12-28 08:36:20 +01:00
TEST_CASE ( symboldatabase29 ) ; // ticket #4442 (segmentation fault)
2013-01-27 02:46:00 +01:00
TEST_CASE ( symboldatabase30 ) ;
2013-03-05 13:33:38 +01:00
TEST_CASE ( symboldatabase31 ) ;
2014-01-06 17:04:38 +01:00
TEST_CASE ( symboldatabase32 ) ;
2013-03-28 06:36:49 +01:00
TEST_CASE ( symboldatabase33 ) ; // ticket #4682 (false negatives)
2013-05-30 15:13:09 +02:00
TEST_CASE ( symboldatabase34 ) ; // ticket #4694 (segmentation fault)
2013-06-16 21:46:01 +02:00
TEST_CASE ( symboldatabase35 ) ; // ticket #4806 (segmentation fault)
2013-07-08 11:45:26 +02:00
TEST_CASE ( symboldatabase36 ) ; // ticket #4892 (segmentation fault)
2013-08-12 06:21:03 +02:00
TEST_CASE ( symboldatabase37 ) ;
2013-10-29 21:41:47 +01:00
TEST_CASE ( symboldatabase38 ) ; // ticket #5125 (infinite recursion)
2013-10-30 10:15:03 +01:00
TEST_CASE ( symboldatabase39 ) ; // ticket #5120 (infinite recursion)
2013-11-08 12:56:32 +01:00
TEST_CASE ( symboldatabase40 ) ; // ticket #5153
2013-11-25 03:43:39 +01:00
TEST_CASE ( symboldatabase41 ) ; // ticket #5197 (unknown macro)
2013-12-31 17:51:56 +01:00
TEST_CASE ( symboldatabase42 ) ; // only put variables in variable list
2014-05-25 12:19:19 +02:00
TEST_CASE ( symboldatabase43 ) ; // #4738
2014-08-05 15:33:57 +02:00
TEST_CASE ( symboldatabase44 ) ;
2014-09-03 11:15:05 +02:00
TEST_CASE ( symboldatabase45 ) ; // #6125
2014-10-15 21:41:15 +02:00
TEST_CASE ( symboldatabase46 ) ; // #6171 (anonymous namespace)
2014-12-09 21:36:09 +01:00
TEST_CASE ( symboldatabase47 ) ; // #6308
2015-01-12 06:11:22 +01:00
TEST_CASE ( symboldatabase48 ) ; // #6417
2015-01-19 06:38:54 +01:00
TEST_CASE ( symboldatabase49 ) ; // #6424
2015-01-19 16:15:11 +01:00
TEST_CASE ( symboldatabase50 ) ; // #6432
2015-02-24 06:11:31 +01:00
TEST_CASE ( symboldatabase51 ) ; // #6538
2015-11-06 10:16:44 +01:00
TEST_CASE ( symboldatabase52 ) ; // #6581
2015-11-15 17:51:27 +01:00
TEST_CASE ( symboldatabase53 ) ; // #7124 (library podtype)
2016-01-22 19:22:24 +01:00
TEST_CASE ( symboldatabase54 ) ; // #7257
2012-04-17 19:50:44 +02:00
2016-05-09 18:34:24 +02:00
TEST_CASE ( enum1 ) ;
TEST_CASE ( enum2 ) ;
TEST_CASE ( enum3 ) ;
2016-05-12 12:06:14 +02:00
TEST_CASE ( enum4 ) ;
2016-05-26 11:25:50 +02:00
TEST_CASE ( enum5 ) ;
2016-06-05 14:08:33 +02:00
TEST_CASE ( enum6 ) ;
2016-07-08 20:39:34 +02:00
TEST_CASE ( enum7 ) ;
2016-05-09 18:34:24 +02:00
2012-04-17 19:50:44 +02:00
TEST_CASE ( isImplicitlyVirtual ) ;
2015-11-07 22:21:50 +01:00
TEST_CASE ( isPure ) ;
2012-09-14 15:32:35 +02:00
2014-04-13 13:05:30 +02:00
TEST_CASE ( isFunction ) ; // UNKNOWN_MACRO(a,b) { .. }
2014-11-02 10:36:52 +01:00
TEST_CASE ( findFunction1 ) ;
2014-02-19 06:35:51 +01:00
TEST_CASE ( findFunction2 ) ; // mismatch: parameter passed by address => reference argument
2014-11-01 14:36:17 +01:00
TEST_CASE ( findFunction3 ) ;
2014-11-07 10:46:31 +01:00
TEST_CASE ( findFunction4 ) ;
2014-11-17 16:04:44 +01:00
TEST_CASE ( findFunction5 ) ; // #6230
2014-11-17 23:05:15 +01:00
TEST_CASE ( findFunction6 ) ;
2015-05-23 11:56:11 +02:00
TEST_CASE ( findFunction7 ) ; // #6700
2016-01-02 18:53:51 +01:00
TEST_CASE ( findFunction8 ) ;
2014-04-10 16:17:10 +02:00
TEST_CASE ( noexceptFunction1 ) ;
TEST_CASE ( noexceptFunction2 ) ;
TEST_CASE ( noexceptFunction3 ) ;
TEST_CASE ( noexceptFunction4 ) ;
2014-04-20 20:40:55 +02:00
2014-05-20 06:10:34 +02:00
TEST_CASE ( throwFunction1 ) ;
TEST_CASE ( throwFunction2 ) ;
2014-04-20 20:40:55 +02:00
TEST_CASE ( nothrowAttributeFunction ) ;
2014-05-04 20:47:20 +02:00
TEST_CASE ( nothrowDeclspecFunction ) ;
2014-05-24 18:35:49 +02:00
TEST_CASE ( varTypesIntegral ) ; // known integral
TEST_CASE ( varTypesFloating ) ; // known floating
TEST_CASE ( varTypesOther ) ; // (un)known
2014-06-02 06:18:32 +02:00
2016-05-04 14:10:09 +02:00
TEST_CASE ( functionPrototype ) ; // #5867
2014-08-31 10:21:10 +02:00
2016-05-04 14:10:09 +02:00
TEST_CASE ( lambda ) ; // #5867
TEST_CASE ( lambda2 ) ; // #7473
TEST_CASE ( circularDependencies ) ; // #6298
2015-10-04 19:42:58 +02:00
2016-03-22 14:10:20 +01:00
TEST_CASE ( executableScopeWithUnknownFunction ) ;
2015-10-04 19:42:58 +02:00
TEST_CASE ( valuetype ) ;
2010-12-30 09:46:44 +01:00
}
2016-05-26 11:25:50 +02:00
void array ( ) {
GET_SYMBOL_DB_C ( " int a[10+2]; " ) ;
ASSERT ( db ! = nullptr ) ;
if ( ! db )
return ;
ASSERT ( db - > getVariableListSize ( ) = = 2 ) ; // the first one is not used
const Variable * v = db - > getVariableFromVarId ( 1 ) ;
ASSERT ( v ! = nullptr ) ;
if ( ! v )
return ;
ASSERT ( v - > isArray ( ) ) ;
ASSERT_EQUALS ( 1U , v - > dimensions ( ) . size ( ) ) ;
ASSERT_EQUALS ( 12U , v - > dimension ( 0 ) ) ;
2012-08-10 11:01:12 +02:00
}
2015-01-30 21:56:27 +01:00
void stlarray ( ) const {
std : : istringstream code ( " std::array<int, 20> arr; " ) ;
TokenList list ( nullptr ) ;
list . createTokens ( code , " test.c " ) ;
list . front ( ) - > tokAt ( 3 ) - > link ( list . front ( ) - > tokAt ( 7 ) ) ;
Variable v ( list . front ( ) - > next ( ) , list . front ( ) , list . back ( ) , 0 , Public , nullptr , nullptr , & settings . library ) ;
ASSERT ( v . isArray ( ) ) ;
ASSERT_EQUALS ( 1U , v . dimensions ( ) . size ( ) ) ;
ASSERT_EQUALS ( 20U , v . dimension ( 0 ) ) ;
}
2014-11-20 14:20:09 +01:00
void test_isVariableDeclarationCanHandleNull ( ) {
2010-12-30 22:57:43 +01:00
reset ( ) ;
2014-02-16 10:32:10 +01:00
bool result = si . isVariableDeclaration ( nullptr , vartok , typetok ) ;
2010-12-30 09:46:44 +01:00
ASSERT_EQUALS ( false , result ) ;
2014-02-16 10:32:10 +01:00
ASSERT ( nullptr = = vartok ) ;
ASSERT ( nullptr = = typetok ) ;
2015-01-30 21:56:27 +01:00
Variable v ( nullptr , nullptr , nullptr , 0 , Public , 0 , 0 , & settings . library ) ;
2010-12-30 09:46:44 +01:00
}
2014-11-20 14:20:09 +01:00
void test_isVariableDeclarationIdentifiesSimpleDeclaration ( ) {
2010-12-30 22:57:43 +01:00
reset ( ) ;
2010-12-30 09:46:44 +01:00
givenACodeSampleToTokenize simpleDeclaration ( " int x; " ) ;
2012-05-11 17:56:47 +02:00
bool result = si . isVariableDeclaration ( simpleDeclaration . tokens ( ) , vartok , typetok ) ;
2010-12-30 09:46:44 +01:00
ASSERT_EQUALS ( true , result ) ;
ASSERT_EQUALS ( " x " , vartok - > str ( ) ) ;
2010-12-30 22:57:43 +01:00
ASSERT_EQUALS ( " int " , typetok - > str ( ) ) ;
2015-01-30 21:56:27 +01:00
Variable v ( vartok , typetok , vartok - > previous ( ) , 0 , Public , 0 , 0 , & settings . library ) ;
2012-05-11 17:56:47 +02:00
ASSERT ( false = = v . isArray ( ) ) ;
ASSERT ( false = = v . isPointer ( ) ) ;
ASSERT ( false = = v . isReference ( ) ) ;
2010-12-30 09:46:44 +01:00
}
2014-11-20 14:20:09 +01:00
void test_isVariableDeclarationIdentifiesInitialization ( ) {
2014-08-05 15:33:57 +02:00
reset ( ) ;
givenACodeSampleToTokenize simpleDeclaration ( " int x (1) ; " );
bool result = si . isVariableDeclaration ( simpleDeclaration . tokens ( ) , vartok , typetok ) ;
ASSERT_EQUALS ( true , result ) ;
ASSERT_EQUALS ( " x " , vartok - > str ( ) ) ;
ASSERT_EQUALS ( " int " , typetok - > str ( ) ) ;
2015-01-30 21:56:27 +01:00
Variable v ( vartok , typetok , vartok - > previous ( ) , 0 , Public , 0 , 0 , & settings . library ) ;
2014-08-05 15:33:57 +02:00
ASSERT ( false = = v . isArray ( ) ) ;
ASSERT ( false = = v . isPointer ( ) ) ;
ASSERT ( false = = v . isReference ( ) ) ;
}
2014-11-20 14:20:09 +01:00
void test_isVariableDeclarationIdentifiesCpp11Initialization ( ) {
2014-08-05 15:33:57 +02:00
reset ( ) ;
givenACodeSampleToTokenize simpleDeclaration ( " int x {1}; " ) ;
bool result = si . isVariableDeclaration ( simpleDeclaration . tokens ( ) , vartok , typetok ) ;
ASSERT_EQUALS ( true , result ) ;
ASSERT_EQUALS ( " x " , vartok - > str ( ) ) ;
ASSERT_EQUALS ( " int " , typetok - > str ( ) ) ;
2015-01-30 21:56:27 +01:00
Variable v ( vartok , typetok , vartok - > previous ( ) , 0 , Public , 0 , 0 , & settings . library ) ;
2014-08-05 15:33:57 +02:00
ASSERT ( false = = v . isArray ( ) ) ;
ASSERT ( false = = v . isPointer ( ) ) ;
ASSERT ( false = = v . isReference ( ) ) ;
}
2014-11-20 14:20:09 +01:00
void test_isVariableDeclarationIdentifiesScopedDeclaration ( ) {
2010-12-30 22:57:43 +01:00
reset ( ) ;
2010-12-30 09:46:44 +01:00
givenACodeSampleToTokenize ScopedDeclaration ( " ::int x; " ) ;
2012-05-11 17:56:47 +02:00
bool result = si . isVariableDeclaration ( ScopedDeclaration . tokens ( ) , vartok , typetok ) ;
2010-12-30 09:46:44 +01:00
ASSERT_EQUALS ( true , result ) ;
ASSERT_EQUALS ( " x " , vartok - > str ( ) ) ;
2010-12-30 22:57:43 +01:00
ASSERT_EQUALS ( " int " , typetok - > str ( ) ) ;
2015-01-30 21:56:27 +01:00
Variable v ( vartok , typetok , vartok - > previous ( ) , 0 , Public , 0 , 0 , & settings . library ) ;
2012-05-11 17:56:47 +02:00
ASSERT ( false = = v . isArray ( ) ) ;
ASSERT ( false = = v . isPointer ( ) ) ;
ASSERT ( false = = v . isReference ( ) ) ;
2010-12-30 09:46:44 +01:00
}
2014-11-20 14:20:09 +01:00
void test_isVariableDeclarationIdentifiesStdDeclaration ( ) {
2010-12-30 22:57:43 +01:00
reset ( ) ;
2010-12-30 09:46:44 +01:00
givenACodeSampleToTokenize StdDeclaration ( " std::string x; " ) ;
2012-05-11 17:56:47 +02:00
bool result = si . isVariableDeclaration ( StdDeclaration . tokens ( ) , vartok , typetok ) ;
2010-12-30 09:46:44 +01:00
ASSERT_EQUALS ( true , result ) ;
ASSERT_EQUALS ( " x " , vartok - > str ( ) ) ;
2010-12-30 22:57:43 +01:00
ASSERT_EQUALS ( " string " , typetok - > str ( ) ) ;
2015-01-30 21:56:27 +01:00
Variable v ( vartok , typetok , vartok - > previous ( ) , 0 , Public , 0 , 0 , & settings . library ) ;
2012-05-11 17:56:47 +02:00
ASSERT ( false = = v . isArray ( ) ) ;
ASSERT ( false = = v . isPointer ( ) ) ;
ASSERT ( false = = v . isReference ( ) ) ;
2010-12-30 09:46:44 +01:00
}
2014-11-20 14:20:09 +01:00
void test_isVariableDeclarationIdentifiesScopedStdDeclaration ( ) {
2010-12-30 22:57:43 +01:00
reset ( ) ;
2010-12-30 09:46:44 +01:00
givenACodeSampleToTokenize StdDeclaration ( " ::std::string x; " ) ;
2012-05-11 17:56:47 +02:00
bool result = si . isVariableDeclaration ( StdDeclaration . tokens ( ) , vartok , typetok ) ;
2010-12-30 09:46:44 +01:00
ASSERT_EQUALS ( true , result ) ;
ASSERT_EQUALS ( " x " , vartok - > str ( ) ) ;
2010-12-30 22:57:43 +01:00
ASSERT_EQUALS ( " string " , typetok - > str ( ) ) ;
2015-01-30 21:56:27 +01:00
Variable v ( vartok , typetok , vartok - > previous ( ) , 0 , Public , 0 , 0 , & settings . library ) ;
2012-05-11 17:56:47 +02:00
ASSERT ( false = = v . isArray ( ) ) ;
ASSERT ( false = = v . isPointer ( ) ) ;
ASSERT ( false = = v . isReference ( ) ) ;
2010-12-30 09:46:44 +01:00
}
2014-11-20 14:20:09 +01:00
void test_isVariableDeclarationIdentifiesManyScopes ( ) {
2010-12-30 22:57:43 +01:00
reset ( ) ;
2010-12-30 09:46:44 +01:00
givenACodeSampleToTokenize manyScopes ( " AA::BB::CC::DD::EE x; " ) ;
2012-05-11 17:56:47 +02:00
bool result = si . isVariableDeclaration ( manyScopes . tokens ( ) , vartok , typetok ) ;
2010-12-30 09:46:44 +01:00
ASSERT_EQUALS ( true , result ) ;
ASSERT_EQUALS ( " x " , vartok - > str ( ) ) ;
2010-12-30 22:57:43 +01:00
ASSERT_EQUALS ( " EE " , typetok - > str ( ) ) ;
2015-01-30 21:56:27 +01:00
Variable v ( vartok , typetok , vartok - > previous ( ) , 0 , Public , 0 , 0 , & settings . library ) ;
2012-05-11 17:56:47 +02:00
ASSERT ( false = = v . isArray ( ) ) ;
ASSERT ( false = = v . isPointer ( ) ) ;
ASSERT ( false = = v . isReference ( ) ) ;
2010-12-30 09:46:44 +01:00
}
2014-11-20 14:20:09 +01:00
void test_isVariableDeclarationIdentifiesPointers ( ) {
2010-12-30 22:57:43 +01:00
reset ( ) ;
2010-12-30 09:46:44 +01:00
givenACodeSampleToTokenize pointer ( " int* p; " ) ;
2012-05-14 21:47:02 +02:00
bool result1 = si . isVariableDeclaration ( pointer . tokens ( ) , vartok , typetok ) ;
ASSERT_EQUALS ( true , result1 ) ;
2010-12-30 22:57:43 +01:00
ASSERT_EQUALS ( " p " , vartok - > str ( ) ) ;
ASSERT_EQUALS ( " int " , typetok - > str ( ) ) ;
2015-01-30 21:56:27 +01:00
Variable v1 ( vartok , typetok , vartok - > previous ( ) , 0 , Public , 0 , 0 , & settings . library ) ;
2012-05-14 21:47:02 +02:00
ASSERT ( false = = v1 . isArray ( ) ) ;
ASSERT ( true = = v1 . isPointer ( ) ) ;
ASSERT ( false = = v1 . isReference ( ) ) ;
reset ( ) ;
givenACodeSampleToTokenize constpointer ( " const int* p; " ) ;
2015-01-30 21:56:27 +01:00
Variable v2 ( constpointer . tokens ( ) - > tokAt ( 3 ) , constpointer . tokens ( ) - > next ( ) , constpointer . tokens ( ) - > tokAt ( 2 ) , 0 , Public , 0 , 0 , & settings . library ) ;
2012-05-14 21:47:02 +02:00
ASSERT ( false = = v2 . isArray ( ) ) ;
ASSERT ( true = = v2 . isPointer ( ) ) ;
ASSERT ( false = = v2 . isConst ( ) ) ;
ASSERT ( false = = v2 . isReference ( ) ) ;
reset ( ) ;
givenACodeSampleToTokenize pointerconst ( " int* const p; " ) ;
bool result2 = si . isVariableDeclaration ( pointerconst . tokens ( ) , vartok , typetok ) ;
ASSERT_EQUALS ( true , result2 ) ;
ASSERT_EQUALS ( " p " , vartok - > str ( ) ) ;
ASSERT_EQUALS ( " int " , typetok - > str ( ) ) ;
2015-01-30 21:56:27 +01:00
Variable v3 ( vartok , typetok , vartok - > previous ( ) , 0 , Public , 0 , 0 , & settings . library ) ;
2012-05-14 21:47:02 +02:00
ASSERT ( false = = v3 . isArray ( ) ) ;
ASSERT ( true = = v3 . isPointer ( ) ) ;
ASSERT ( true = = v3 . isConst ( ) ) ;
ASSERT ( false = = v3 . isReference ( ) ) ;
2010-12-30 09:46:44 +01:00
}
2014-11-20 14:20:09 +01:00
void test_isVariableDeclarationDoesNotIdentifyConstness ( ) {
2010-12-30 22:57:43 +01:00
reset ( ) ;
2010-12-30 09:46:44 +01:00
givenACodeSampleToTokenize constness ( " const int* cp; " ) ;
2012-05-11 17:56:47 +02:00
bool result = si . isVariableDeclaration ( constness . tokens ( ) , vartok , typetok ) ;
2010-12-30 09:46:44 +01:00
ASSERT_EQUALS ( false , result ) ;
2014-02-16 10:32:10 +01:00
ASSERT ( nullptr = = vartok ) ;
ASSERT ( nullptr = = typetok ) ;
2010-12-30 09:46:44 +01:00
}
2014-11-20 14:20:09 +01:00
void test_isVariableDeclarationIdentifiesFirstOfManyVariables ( ) {
2010-12-30 22:57:43 +01:00
reset ( ) ;
2010-12-30 09:46:44 +01:00
givenACodeSampleToTokenize multipleDeclaration ( " int first, second; " ) ;
2012-05-11 17:56:47 +02:00
bool result = si . isVariableDeclaration ( multipleDeclaration . tokens ( ) , vartok , typetok ) ;
2010-12-30 09:46:44 +01:00
ASSERT_EQUALS ( true , result ) ;
ASSERT_EQUALS ( " first " , vartok - > str ( ) ) ;
2010-12-30 22:57:43 +01:00
ASSERT_EQUALS ( " int " , typetok - > str ( ) ) ;
2015-01-30 21:56:27 +01:00
Variable v ( vartok , typetok , vartok - > previous ( ) , 0 , Public , 0 , 0 , & settings . library ) ;
2012-05-11 17:56:47 +02:00
ASSERT ( false = = v . isArray ( ) ) ;
ASSERT ( false = = v . isPointer ( ) ) ;
ASSERT ( false = = v . isReference ( ) ) ;
2010-12-30 22:57:43 +01:00
}
2014-11-20 14:20:09 +01:00
void test_isVariableDeclarationIdentifiesScopedPointerDeclaration ( ) {
2010-12-30 22:57:43 +01:00
reset ( ) ;
givenACodeSampleToTokenize manyScopes ( " AA::BB::CC::DD::EE* p; " ) ;
2012-05-11 17:56:47 +02:00
bool result = si . isVariableDeclaration ( manyScopes . tokens ( ) , vartok , typetok ) ;
2010-12-30 22:57:43 +01:00
ASSERT_EQUALS ( true , result ) ;
ASSERT_EQUALS ( " p " , vartok - > str ( ) ) ;
ASSERT_EQUALS ( " EE " , typetok - > str ( ) ) ;
2015-01-30 21:56:27 +01:00
Variable v ( vartok , typetok , vartok - > previous ( ) , 0 , Public , 0 , 0 , & settings . library ) ;
2012-05-11 17:56:47 +02:00
ASSERT ( false = = v . isArray ( ) ) ;
ASSERT ( true = = v . isPointer ( ) ) ;
ASSERT ( false = = v . isReference ( ) ) ;
2010-12-30 22:57:43 +01:00
}
2014-11-20 14:20:09 +01:00
void test_isVariableDeclarationIdentifiesDeclarationWithIndirection ( ) {
2010-12-30 22:57:43 +01:00
reset ( ) ;
givenACodeSampleToTokenize pointerToPointer ( " int** pp; " ) ;
2012-05-11 17:56:47 +02:00
bool result = si . isVariableDeclaration ( pointerToPointer . tokens ( ) , vartok , typetok ) ;
2010-12-30 22:57:43 +01:00
ASSERT_EQUALS ( true , result ) ;
ASSERT_EQUALS ( " pp " , vartok - > str ( ) ) ;
ASSERT_EQUALS ( " int " , typetok - > str ( ) ) ;
2015-01-30 21:56:27 +01:00
Variable v ( vartok , typetok , vartok - > previous ( ) , 0 , Public , 0 , 0 , & settings . library ) ;
2012-05-11 17:56:47 +02:00
ASSERT ( false = = v . isArray ( ) ) ;
ASSERT ( true = = v . isPointer ( ) ) ;
ASSERT ( false = = v . isReference ( ) ) ;
2010-12-30 22:57:43 +01:00
}
2014-11-20 14:20:09 +01:00
void test_isVariableDeclarationIdentifiesDeclarationWithMultipleIndirection ( ) {
2010-12-30 22:57:43 +01:00
reset ( ) ;
givenACodeSampleToTokenize pointerToPointer ( " int***** p; " ) ;
2012-05-11 17:56:47 +02:00
bool result = si . isVariableDeclaration ( pointerToPointer . tokens ( ) , vartok , typetok ) ;
2010-12-30 22:57:43 +01:00
ASSERT_EQUALS ( true , result ) ;
ASSERT_EQUALS ( " p " , vartok - > str ( ) ) ;
ASSERT_EQUALS ( " int " , typetok - > str ( ) ) ;
2015-01-30 21:56:27 +01:00
Variable v ( vartok , typetok , vartok - > previous ( ) , 0 , Public , 0 , 0 , & settings . library ) ;
2012-05-11 17:56:47 +02:00
ASSERT ( false = = v . isArray ( ) ) ;
ASSERT ( true = = v . isPointer ( ) ) ;
ASSERT ( false = = v . isReference ( ) ) ;
2010-12-30 09:46:44 +01:00
}
2011-01-01 01:19:32 +01:00
2014-11-20 14:20:09 +01:00
void test_isVariableDeclarationIdentifiesArray ( ) {
2011-01-01 01:19:32 +01:00
reset ( ) ;
2012-08-12 17:04:37 +02:00
givenACodeSampleToTokenize arr ( " ::std::string v[3]; " ) ;
bool result = si . isVariableDeclaration ( arr . tokens ( ) , vartok , typetok ) ;
2011-01-01 01:19:32 +01:00
ASSERT_EQUALS ( true , result ) ;
ASSERT_EQUALS ( " v " , vartok - > str ( ) ) ;
ASSERT_EQUALS ( " string " , typetok - > str ( ) ) ;
2015-01-30 21:56:27 +01:00
Variable v ( vartok , typetok , vartok - > previous ( ) , 0 , Public , 0 , 0 , & settings . library ) ;
2012-05-11 17:56:47 +02:00
ASSERT ( true = = v . isArray ( ) ) ;
ASSERT ( false = = v . isPointer ( ) ) ;
2015-08-28 23:06:39 +02:00
ASSERT ( false = = v . isPointerArray ( ) ) ;
ASSERT ( false = = v . isReference ( ) ) ;
}
void test_isVariableDeclarationIdentifiesPointerArray ( ) {
reset ( ) ;
givenACodeSampleToTokenize arr ( " A *a[5]; " ) ;
bool result = si . isVariableDeclaration ( arr . tokens ( ) , vartok , typetok ) ;
ASSERT_EQUALS ( true , result ) ;
ASSERT_EQUALS ( " a " , vartok - > str ( ) ) ;
ASSERT_EQUALS ( " A " , typetok - > str ( ) ) ;
Variable v ( vartok , typetok , vartok - > previous ( ) , 0 , Public , 0 , 0 , & settings . library ) ;
ASSERT ( false = = v . isPointer ( ) ) ;
ASSERT ( true = = v . isArray ( ) ) ;
ASSERT ( false = = v . isPointerToArray ( ) ) ;
ASSERT ( true = = v . isPointerArray ( ) ) ;
2012-05-11 17:56:47 +02:00
ASSERT ( false = = v . isReference ( ) ) ;
2011-01-01 01:19:32 +01:00
}
2014-11-20 14:20:09 +01:00
void test_isVariableDeclarationIdentifiesOfArrayPointers ( ) {
2011-01-01 01:19:32 +01:00
reset ( ) ;
2015-08-25 21:19:19 +02:00
givenACodeSampleToTokenize arr ( " A (*a) [ 5 ] ; " );
2012-08-12 17:04:37 +02:00
bool result = si . isVariableDeclaration ( arr . tokens ( ) , vartok , typetok ) ;
2011-01-01 01:19:32 +01:00
ASSERT_EQUALS ( true , result ) ;
ASSERT_EQUALS ( " a " , vartok - > str ( ) ) ;
ASSERT_EQUALS ( " A " , typetok - > str ( ) ) ;
2015-01-30 21:56:27 +01:00
Variable v ( vartok , typetok , vartok - > previous ( ) , 0 , Public , 0 , 0 , & settings . library ) ;
2012-05-11 17:56:47 +02:00
ASSERT ( true = = v . isPointer ( ) ) ;
2015-08-25 21:19:19 +02:00
ASSERT ( false = = v . isArray ( ) ) ;
ASSERT ( true = = v . isPointerToArray ( ) ) ;
2015-08-28 23:06:39 +02:00
ASSERT ( false = = v . isPointerArray ( ) ) ;
2012-05-11 17:56:47 +02:00
ASSERT ( false = = v . isReference ( ) ) ;
2011-01-01 01:19:32 +01:00
}
2011-01-02 00:36:22 +01:00
2014-11-20 14:20:09 +01:00
void isVariableDeclarationIdentifiesTemplatedPointerVariable ( ) {
2011-01-02 00:36:22 +01:00
reset ( ) ;
givenACodeSampleToTokenize var ( " std::set<char>* chars; " ) ;
2012-05-11 17:56:47 +02:00
bool result = si . isVariableDeclaration ( var . tokens ( ) , vartok , typetok ) ;
2011-01-02 00:36:22 +01:00
ASSERT_EQUALS ( true , result ) ;
ASSERT_EQUALS ( " chars " , vartok - > str ( ) ) ;
ASSERT_EQUALS ( " set " , typetok - > str ( ) ) ;
2015-01-30 21:56:27 +01:00
Variable v ( vartok , typetok , vartok - > previous ( ) , 0 , Public , 0 , 0 , & settings . library ) ;
2012-05-11 17:56:47 +02:00
ASSERT ( false = = v . isArray ( ) ) ;
ASSERT ( true = = v . isPointer ( ) ) ;
ASSERT ( false = = v . isReference ( ) ) ;
2011-01-02 00:36:22 +01:00
}
2014-11-20 14:20:09 +01:00
void isVariableDeclarationIdentifiesTemplatedPointerToPointerVariable ( ) {
2011-01-18 08:29:42 +01:00
reset ( ) ;
givenACodeSampleToTokenize var ( " std::deque<int>*** ints; " ) ;
2012-05-11 17:56:47 +02:00
bool result = si . isVariableDeclaration ( var . tokens ( ) , vartok , typetok ) ;
2011-01-18 10:14:12 +01:00
ASSERT_EQUALS ( true , result ) ;
ASSERT_EQUALS ( " ints " , vartok - > str ( ) ) ;
ASSERT_EQUALS ( " deque " , typetok - > str ( ) ) ;
2015-01-30 21:56:27 +01:00
Variable v ( vartok , typetok , vartok - > previous ( ) , 0 , Public , 0 , 0 , & settings . library ) ;
2012-05-11 17:56:47 +02:00
ASSERT ( false = = v . isArray ( ) ) ;
ASSERT ( true = = v . isPointer ( ) ) ;
ASSERT ( false = = v . isReference ( ) ) ;
2011-01-18 10:14:12 +01:00
}
2014-11-20 14:20:09 +01:00
void isVariableDeclarationIdentifiesTemplatedArrayVariable ( ) {
2011-01-18 10:14:12 +01:00
reset ( ) ;
givenACodeSampleToTokenize var ( " std::deque<int> ints[3]; " ) ;
2012-05-11 17:56:47 +02:00
bool result = si . isVariableDeclaration ( var . tokens ( ) , vartok , typetok ) ;
2011-01-18 10:14:12 +01:00
ASSERT_EQUALS ( true , result ) ;
ASSERT_EQUALS ( " ints " , vartok - > str ( ) ) ;
ASSERT_EQUALS ( " deque " , typetok - > str ( ) ) ;
2015-01-30 21:56:27 +01:00
Variable v ( vartok , typetok , vartok - > previous ( ) , 0 , Public , 0 , 0 , & settings . library ) ;
2012-05-11 17:56:47 +02:00
ASSERT ( true = = v . isArray ( ) ) ;
ASSERT ( false = = v . isPointer ( ) ) ;
ASSERT ( false = = v . isReference ( ) ) ;
2011-01-18 08:29:42 +01:00
}
2014-11-20 14:20:09 +01:00
void isVariableDeclarationIdentifiesTemplatedVariable ( ) {
2011-01-02 00:36:22 +01:00
reset ( ) ;
givenACodeSampleToTokenize var ( " std::vector<int> ints; " ) ;
2012-05-11 17:56:47 +02:00
bool result = si . isVariableDeclaration ( var . tokens ( ) , vartok , typetok ) ;
2011-01-02 00:36:22 +01:00
ASSERT_EQUALS ( true , result ) ;
ASSERT_EQUALS ( " ints " , vartok - > str ( ) ) ;
ASSERT_EQUALS ( " vector " , typetok - > str ( ) ) ;
2015-01-30 21:56:27 +01:00
Variable v ( vartok , typetok , vartok - > previous ( ) , 0 , Public , 0 , 0 , & settings . library ) ;
2012-05-11 17:56:47 +02:00
ASSERT ( false = = v . isArray ( ) ) ;
ASSERT ( false = = v . isPointer ( ) ) ;
ASSERT ( false = = v . isReference ( ) ) ;
2011-01-02 00:36:22 +01:00
}
2014-11-20 14:20:09 +01:00
void isVariableDeclarationIdentifiesTemplatedVariableIterator ( ) {
2011-01-02 00:36:22 +01:00
reset ( ) ;
givenACodeSampleToTokenize var ( " std::list<int>::const_iterator floats; " ) ;
2012-05-11 17:56:47 +02:00
bool result = si . isVariableDeclaration ( var . tokens ( ) , vartok , typetok ) ;
2011-01-02 00:36:22 +01:00
ASSERT_EQUALS ( true , result ) ;
ASSERT_EQUALS ( " floats " , vartok - > str ( ) ) ;
ASSERT_EQUALS ( " const_iterator " , typetok - > str ( ) ) ;
2015-01-30 21:56:27 +01:00
Variable v ( vartok , typetok , vartok - > previous ( ) , 0 , Public , 0 , 0 , & settings . library ) ;
2012-05-11 17:56:47 +02:00
ASSERT ( false = = v . isArray ( ) ) ;
ASSERT ( false = = v . isPointer ( ) ) ;
ASSERT ( false = = v . isReference ( ) ) ;
2011-01-02 00:36:22 +01:00
}
2014-11-20 14:20:09 +01:00
void isVariableDeclarationIdentifiesNestedTemplateVariable ( ) {
2011-01-02 00:36:22 +01:00
reset ( ) ;
givenACodeSampleToTokenize var ( " std::deque<std::set<int> > intsets; " ) ;
2012-05-11 17:56:47 +02:00
bool result = si . isVariableDeclaration ( var . tokens ( ) , vartok , typetok ) ;
2011-01-02 00:36:22 +01:00
ASSERT_EQUALS ( true , result ) ;
ASSERT_EQUALS ( " intsets " , vartok - > str ( ) ) ;
ASSERT_EQUALS ( " deque " , typetok - > str ( ) ) ;
2015-01-30 21:56:27 +01:00
Variable v ( vartok , typetok , vartok - > previous ( ) , 0 , Public , 0 , 0 , & settings . library ) ;
2012-05-11 17:56:47 +02:00
ASSERT ( false = = v . isArray ( ) ) ;
ASSERT ( false = = v . isPointer ( ) ) ;
ASSERT ( false = = v . isReference ( ) ) ;
2012-01-26 17:04:25 +01:00
}
2014-11-20 14:20:09 +01:00
void isVariableDeclarationIdentifiesReference ( ) {
2012-01-26 17:04:25 +01:00
reset ( ) ;
givenACodeSampleToTokenize var1 ( " int& foo; " ) ;
2012-05-11 17:56:47 +02:00
bool result1 = si . isVariableDeclaration ( var1 . tokens ( ) , vartok , typetok ) ;
2012-01-26 17:04:25 +01:00
ASSERT_EQUALS ( true , result1 ) ;
2015-01-30 21:56:27 +01:00
Variable v1 ( vartok , typetok , vartok - > previous ( ) , 0 , Public , 0 , 0 , & settings . library ) ;
2012-05-11 17:56:47 +02:00
ASSERT ( false = = v1 . isArray ( ) ) ;
ASSERT ( false = = v1 . isPointer ( ) ) ;
ASSERT ( true = = v1 . isReference ( ) ) ;
2012-01-26 17:04:25 +01:00
reset ( ) ;
givenACodeSampleToTokenize var2 ( " foo*& bar; " ) ;
2012-05-11 17:56:47 +02:00
bool result2 = si . isVariableDeclaration ( var2 . tokens ( ) , vartok , typetok ) ;
2012-01-26 17:04:25 +01:00
ASSERT_EQUALS ( true , result2 ) ;
2015-01-30 21:56:27 +01:00
Variable v2 ( vartok , typetok , vartok - > previous ( ) , 0 , Public , 0 , 0 , & settings . library ) ;
2012-05-11 17:56:47 +02:00
ASSERT ( false = = v2 . isArray ( ) ) ;
ASSERT ( true = = v2 . isPointer ( ) ) ;
ASSERT ( true = = v2 . isReference ( ) ) ;
2012-01-26 17:04:25 +01:00
reset ( ) ;
givenACodeSampleToTokenize var3 ( " std::vector<int>& foo; " ) ;
2012-05-11 17:56:47 +02:00
bool result3 = si . isVariableDeclaration ( var3 . tokens ( ) , vartok , typetok ) ;
2012-01-26 17:04:25 +01:00
ASSERT_EQUALS ( true , result3 ) ;
2015-01-30 21:56:27 +01:00
Variable v3 ( vartok , typetok , vartok - > previous ( ) , 0 , Public , 0 , 0 , & settings . library ) ;
2012-05-11 17:56:47 +02:00
ASSERT ( false = = v3 . isArray ( ) ) ;
ASSERT ( false = = v3 . isPointer ( ) ) ;
ASSERT ( true = = v3 . isReference ( ) ) ;
2011-01-02 00:36:22 +01:00
}
2014-11-20 14:20:09 +01:00
void isVariableDeclarationDoesNotIdentifyTemplateClass ( ) {
2011-01-02 00:36:22 +01:00
reset ( ) ;
givenACodeSampleToTokenize var ( " template <class T> class SomeClass{}; " ) ;
2012-05-11 17:56:47 +02:00
bool result = si . isVariableDeclaration ( var . tokens ( ) , vartok , typetok ) ;
2011-01-02 00:36:22 +01:00
ASSERT_EQUALS ( false , result ) ;
}
2014-11-20 14:20:09 +01:00
void isVariableDeclarationDoesNotIdentifyCppCast ( ) {
2014-10-12 16:06:50 +02:00
reset ( ) ;
givenACodeSampleToTokenize var ( " reinterpret_cast <char *> (code) [ 0 ] = 0 ; " );
bool result = si . isVariableDeclaration ( var . tokens ( ) , vartok , typetok ) ;
ASSERT_EQUALS ( false , result ) ;
}
2014-11-20 14:20:09 +01:00
void isVariableDeclarationPointerConst ( ) {
2012-03-24 15:10:06 +01:00
reset ( ) ;
givenACodeSampleToTokenize var ( " std::string const* s; " ) ;
2016-05-04 12:33:19 +02:00
bool result = si . isVariableDeclaration ( var . tokens ( ) - > next ( ) , vartok , typetok ) ;
2012-03-24 15:10:06 +01:00
ASSERT_EQUALS ( true , result ) ;
2015-01-30 21:56:27 +01:00
Variable v ( vartok , typetok , vartok - > previous ( ) , 0 , Public , 0 , 0 , & settings . library ) ;
2012-05-11 17:56:47 +02:00
ASSERT ( false = = v . isArray ( ) ) ;
ASSERT ( true = = v . isPointer ( ) ) ;
ASSERT ( false = = v . isReference ( ) ) ;
2012-03-24 15:10:06 +01:00
}
2014-11-20 14:20:09 +01:00
void isVariableDeclarationRValueRef ( ) {
2013-04-04 18:47:44 +02:00
reset ( ) ;
givenACodeSampleToTokenize var ( " int&& i; " ) ;
bool result = si . isVariableDeclaration ( var . tokens ( ) , vartok , typetok ) ;
ASSERT_EQUALS ( true , result ) ;
2015-01-30 21:56:27 +01:00
Variable v ( vartok , typetok , vartok - > previous ( ) , 0 , Public , 0 , 0 , & settings . library ) ;
2013-04-04 18:47:44 +02:00
ASSERT ( false = = v . isArray ( ) ) ;
ASSERT ( false = = v . isPointer ( ) ) ;
ASSERT ( true = = v . isReference ( ) ) ;
ASSERT ( true = = v . isRValueReference ( ) ) ;
2013-05-14 11:06:16 +02:00
ASSERT ( var . tokens ( ) - > tokAt ( 2 ) - > scope ( ) ! = 0 ) ;
2013-04-04 18:47:44 +02:00
}
2015-10-26 19:20:42 +01:00
void rangeBasedFor ( ) {
GET_SYMBOL_DB ( " void reset() { \n "
" for(auto& e : array) \n "
" foo(e); \n "
" } " ) ;
ASSERT ( db ! = nullptr ) ;
if ( ! db )
return ;
ASSERT ( db - > scopeList . back ( ) . type = = Scope : : eFor ) ;
ASSERT_EQUALS ( 2 , db - > getVariableListSize ( ) ) ;
2015-10-26 21:24:53 +01:00
if ( db - > getVariableListSize ( ) < 2 )
return ;
2015-10-26 19:20:42 +01:00
const Variable * e = db - > getVariableFromVarId ( 1 ) ;
ASSERT ( e & & e - > isReference ( ) & & e - > isLocal ( ) ) ;
}
2014-11-20 14:20:09 +01:00
void isVariableStlType ( ) {
2014-01-28 15:44:56 +01:00
{
reset ( ) ;
std : : istringstream code ( " std::string s; " ) ;
2014-02-16 10:32:10 +01:00
TokenList list ( nullptr ) ;
2014-01-28 15:44:56 +01:00
list . createTokens ( code , " test.cpp " ) ;
bool result = si . isVariableDeclaration ( list . front ( ) , vartok , typetok ) ;
ASSERT_EQUALS ( true , result ) ;
2015-01-30 21:56:27 +01:00
Variable v ( vartok , list . front ( ) , list . back ( ) , 0 , Public , 0 , 0 , & settings . library ) ;
2015-05-17 20:02:41 +02:00
static const std : : set < std : : string > types = make_container < std : : set < std : : string > > ( ) < <
" string " < < " wstring " ;
static const std : : set < std : : string > no_types = make_container < std : : set < std : : string > > ( ) < <
" set " ;
2014-01-28 15:44:56 +01:00
ASSERT_EQUALS ( true , v . isStlType ( ) ) ;
ASSERT_EQUALS ( true , v . isStlType ( types ) ) ;
ASSERT_EQUALS ( false , v . isStlType ( no_types ) ) ;
2014-09-05 12:03:08 +02:00
ASSERT_EQUALS ( true , v . isStlStringType ( ) ) ;
2014-01-28 15:44:56 +01:00
}
{
reset ( ) ;
std : : istringstream code ( " std::vector<int> v; " ) ;
2014-02-16 10:32:10 +01:00
TokenList list ( nullptr ) ;
2014-01-28 15:44:56 +01:00
list . createTokens ( code , " test.cpp " ) ;
list . front ( ) - > tokAt ( 3 ) - > link ( list . front ( ) - > tokAt ( 5 ) ) ;
bool result = si . isVariableDeclaration ( list . front ( ) , vartok , typetok ) ;
ASSERT_EQUALS ( true , result ) ;
2015-01-30 21:56:27 +01:00
Variable v ( vartok , list . front ( ) , list . back ( ) , 0 , Public , 0 , 0 , & settings . library ) ;
2015-05-17 20:02:41 +02:00
static const std : : set < std : : string > types = make_container < std : : set < std : : string > > ( ) < <
" bitset " < < " set " < < " vector " < < " wstring " ;
static const std : : set < std : : string > no_types = make_container < std : : set < std : : string > > ( ) < <
" bitset " < < " map " < < " set " ;
2014-01-28 15:44:56 +01:00
ASSERT_EQUALS ( true , v . isStlType ( ) ) ;
ASSERT_EQUALS ( true , v . isStlType ( types ) ) ;
ASSERT_EQUALS ( false , v . isStlType ( no_types ) ) ;
2014-09-05 12:03:08 +02:00
ASSERT_EQUALS ( false , v . isStlStringType ( ) ) ;
2014-01-28 15:44:56 +01:00
}
{
reset ( ) ;
std : : istringstream code ( " SomeClass s; " ) ;
2014-02-16 10:32:10 +01:00
TokenList list ( nullptr ) ;
2014-01-28 15:44:56 +01:00
list . createTokens ( code , " test.cpp " ) ;
bool result = si . isVariableDeclaration ( list . front ( ) , vartok , typetok ) ;
ASSERT_EQUALS ( true , result ) ;
2015-01-30 21:56:27 +01:00
Variable v ( vartok , list . front ( ) , list . back ( ) , 0 , Public , 0 , 0 , & settings . library ) ;
2015-05-17 20:02:41 +02:00
static const std : : set < std : : string > types = make_container < std : : set < std : : string > > ( ) < <
" bitset " < < " set " < < " vector " ;
2014-01-28 15:44:56 +01:00
ASSERT_EQUALS ( false , v . isStlType ( ) ) ;
ASSERT_EQUALS ( false , v . isStlType ( types ) ) ;
2014-09-05 12:03:08 +02:00
ASSERT_EQUALS ( false , v . isStlStringType ( ) ) ;
2014-01-28 15:44:56 +01:00
}
}
2014-11-20 14:20:09 +01:00
void arrayMemberVar1 ( ) {
2015-10-08 12:53:56 +02:00
GET_SYMBOL_DB ( " struct Foo { \n "
" int x; \n "
" }; \n "
" void f() { \n "
" struct Foo foo[10]; \n "
" foo[1].x = 123; \n " // <- x should get a variable() pointer
" } " ) ;
2013-07-20 17:46:39 +02:00
2014-05-18 20:39:52 +02:00
const Token * tok = Token : : findsimplematch ( tokenizer . tokens ( ) , " . x " ) ;
2014-02-16 10:32:10 +01:00
tok = tok ? tok - > next ( ) : nullptr ;
2015-10-08 12:53:56 +02:00
ASSERT ( db ! = nullptr ) ;
2014-05-18 20:39:52 +02:00
ASSERT ( tok & & tok - > variable ( ) & & Token : : simpleMatch ( tok - > variable ( ) - > typeStartToken ( ) , " int x ; " ) ) ;
2013-07-20 17:46:39 +02:00
ASSERT ( tok & & tok - > varId ( ) = = 0U ) ; // It's possible to set a varId
}
2014-11-20 14:20:09 +01:00
void arrayMemberVar2 ( ) {
2015-10-08 12:53:56 +02:00
GET_SYMBOL_DB ( " struct Foo { \n "
" int x; \n "
" }; \n "
" void f() { \n "
" struct Foo foo[10][10]; \n "
" foo[1][2].x = 123; \n " // <- x should get a variable() pointer
" } " ) ;
2013-07-20 17:46:39 +02:00
2014-05-18 20:39:52 +02:00
const Token * tok = Token : : findsimplematch ( tokenizer . tokens ( ) , " . x " ) ;
2014-02-16 10:32:10 +01:00
tok = tok ? tok - > next ( ) : nullptr ;
2015-10-08 12:53:56 +02:00
ASSERT ( db ! = nullptr ) ;
2014-05-18 20:39:52 +02:00
ASSERT ( tok & & tok - > variable ( ) & & Token : : simpleMatch ( tok - > variable ( ) - > typeStartToken ( ) , " int x ; " ) ) ;
2013-07-20 17:46:39 +02:00
ASSERT ( tok & & tok - > varId ( ) = = 0U ) ; // It's possible to set a varId
}
2014-11-20 14:20:09 +01:00
void arrayMemberVar3 ( ) {
2015-10-08 12:53:56 +02:00
GET_SYMBOL_DB ( " struct Foo { \n "
" int x; \n "
" }; \n "
" void f() { \n "
" struct Foo foo[10]; \n "
" (foo[1]).x = 123; \n " // <- x should get a variable() pointer
" } " ) ;
2013-07-20 17:46:39 +02:00
2014-05-18 20:39:52 +02:00
const Token * tok = Token : : findsimplematch ( tokenizer . tokens ( ) , " . x " ) ;
2014-02-16 10:32:10 +01:00
tok = tok ? tok - > next ( ) : nullptr ;
2015-10-08 12:53:56 +02:00
ASSERT ( db ! = nullptr ) ;
2014-05-18 20:39:52 +02:00
ASSERT ( tok & & tok - > variable ( ) & & Token : : simpleMatch ( tok - > variable ( ) - > typeStartToken ( ) , " int x ; " ) ) ;
2013-07-20 17:46:39 +02:00
ASSERT ( tok & & tok - > varId ( ) = = 0U ) ; // It's possible to set a varId
}
2014-11-20 14:20:09 +01:00
void staticMemberVar ( ) {
2012-05-15 21:03:43 +02:00
GET_SYMBOL_DB ( " class Foo { \n "
" static const double d; \n "
" }; \n "
" const double Foo::d = 5.0; " ) ;
const Variable * v = db - > getVariableFromVarId ( 1 ) ;
ASSERT ( v & & db - > getVariableListSize ( ) = = 2 ) ;
ASSERT ( v & & v - > isStatic ( ) & & v - > isConst ( ) & & v - > isPrivate ( ) ) ;
}
2015-01-14 22:59:01 +01:00
void getVariableFromVarIdBoundsCheck ( ) {
GET_SYMBOL_DB ( " int x; \n "
" int y; \n " ) ;
const Variable * v = db - > getVariableFromVarId ( 2 ) ;
// three elements: varId 0 also counts via a fake-entry
ASSERT ( v & & db - > getVariableListSize ( ) = = 3 ) ;
2015-01-15 18:52:11 +01:00
ASSERT_THROW ( db - > getVariableFromVarId ( 3 ) , std : : out_of_range ) ;
2015-01-14 22:59:01 +01:00
}
2014-11-20 14:20:09 +01:00
void hasRegularFunction ( ) {
2011-01-28 08:33:02 +01:00
GET_SYMBOL_DB ( " void func() { } \n " )
// 2 scopes: Global and Function
2012-09-11 18:03:47 +02:00
ASSERT ( db & & db - > scopeList . size ( ) = = 2 ) ;
2011-01-28 08:33:02 +01:00
2011-10-13 20:53:06 +02:00
if ( db ) {
2013-01-28 06:47:48 +01:00
const Scope * scope = findFunctionScopeByToken ( db , tokenizer . tokens ( ) - > next ( ) ) ;
2011-01-28 08:33:02 +01:00
ASSERT ( scope & & scope - > className = = " func " ) ;
2012-05-11 17:56:47 +02:00
ASSERT ( scope & & scope - > functionOf = = 0 ) ;
2011-01-28 08:33:02 +01:00
2013-01-28 06:47:48 +01:00
const Function * function = findFunctionByName ( " func " , & db - > scopeList . front ( ) ) ;
2011-01-28 08:33:02 +01:00
ASSERT ( function & & function - > token - > str ( ) = = " func " ) ;
2011-11-20 15:09:57 +01:00
ASSERT ( function & & function - > token = = tokenizer . tokens ( ) - > next ( ) ) ;
2015-01-08 05:45:31 +01:00
ASSERT ( function & & function - > hasBody ( ) ) ;
2012-05-24 17:40:43 +02:00
ASSERT ( function & & function - > functionScope = = scope & & scope - > function = = function & & function - > nestedIn ! = scope ) ;
2013-09-03 10:48:01 +02:00
ASSERT ( function & & function - > retDef = = tokenizer . tokens ( ) ) ;
2011-01-28 08:33:02 +01:00
}
}
2014-11-20 14:20:09 +01:00
void hasInlineClassFunction ( ) {
2011-01-28 08:33:02 +01:00
GET_SYMBOL_DB ( " class Fred { void func() { } }; \n " )
// 3 scopes: Global, Class, and Function
2012-09-11 18:03:47 +02:00
ASSERT ( db & & db - > scopeList . size ( ) = = 3 ) ;
2011-01-28 08:33:02 +01:00
2011-10-13 20:53:06 +02:00
if ( db ) {
2014-05-18 20:39:52 +02:00
const Token * const functionToken = Token : : findsimplematch ( tokenizer . tokens ( ) , " func " ) ;
2014-04-12 16:06:31 +02:00
const Scope * scope = findFunctionScopeByToken ( db , functionToken ) ;
2011-01-28 08:33:02 +01:00
ASSERT ( scope & & scope - > className = = " func " ) ;
2012-05-11 17:56:47 +02:00
ASSERT ( scope & & scope - > functionOf & & scope - > functionOf = = db - > findScopeByName ( " Fred " ) ) ;
2011-01-28 08:33:02 +01:00
2013-01-28 06:47:48 +01:00
const Function * function = findFunctionByName ( " func " , & db - > scopeList . back ( ) ) ;
2011-01-28 08:33:02 +01:00
ASSERT ( function & & function - > token - > str ( ) = = " func " ) ;
2014-04-12 16:06:31 +02:00
ASSERT ( function & & function - > token = = functionToken ) ;
2015-01-08 05:45:31 +01:00
ASSERT ( function & & function - > hasBody ( ) & & function - > isInline ( ) ) ;
2012-05-24 17:40:43 +02:00
ASSERT ( function & & function - > functionScope = = scope & & scope - > function = = function & & function - > nestedIn = = db - > findScopeByName ( " Fred " ) ) ;
2014-04-12 16:06:31 +02:00
ASSERT ( function & & function - > retDef = = functionToken - > previous ( ) ) ;
2013-03-14 17:00:22 +01:00
ASSERT ( db & & db - > findScopeByName ( " Fred " ) & & db - > findScopeByName ( " Fred " ) - > definedType - > getFunction ( " func " ) = = function ) ;
2011-01-28 08:33:02 +01:00
}
}
2014-11-20 14:20:09 +01:00
void hasMissingInlineClassFunction ( ) {
2011-01-28 08:33:02 +01:00
GET_SYMBOL_DB ( " class Fred { void func(); }; \n " )
// 2 scopes: Global and Class (no Function scope because there is no function implementation)
2012-09-11 18:03:47 +02:00
ASSERT ( db & & db - > scopeList . size ( ) = = 2 ) ;
2011-01-28 08:33:02 +01:00
2011-10-13 20:53:06 +02:00
if ( db ) {
2014-05-18 20:39:52 +02:00
const Token * const functionToken = Token : : findsimplematch ( tokenizer . tokens ( ) , " func " ) ;
2014-04-12 16:06:31 +02:00
const Scope * scope = findFunctionScopeByToken ( db , functionToken ) ;
2011-01-28 08:33:02 +01:00
2014-02-16 10:32:10 +01:00
ASSERT ( scope = = nullptr ) ;
2011-01-28 08:33:02 +01:00
2013-01-28 06:47:48 +01:00
const Function * function = findFunctionByName ( " func " , & db - > scopeList . back ( ) ) ;
2011-01-28 08:33:02 +01:00
ASSERT ( function & & function - > token - > str ( ) = = " func " ) ;
2014-04-12 16:06:31 +02:00
ASSERT ( function & & function - > token = = functionToken ) ;
2015-01-08 05:45:31 +01:00
ASSERT ( function & & ! function - > hasBody ( ) ) ;
2011-01-28 08:33:02 +01:00
}
}
2014-11-20 14:20:09 +01:00
void hasClassFunction ( ) {
2014-09-20 14:51:58 +02:00
GET_SYMBOL_DB ( " class Fred { void func(); }; void Fred::func() { } \n " )
2011-01-28 08:33:02 +01:00
// 3 scopes: Global, Class, and Function
2012-09-11 18:03:47 +02:00
ASSERT ( db & & db - > scopeList . size ( ) = = 3 ) ;
2011-01-28 08:33:02 +01:00
2011-10-13 20:53:06 +02:00
if ( db ) {
2014-05-18 20:39:52 +02:00
const Token * const functionToken = Token : : findsimplematch ( tokenizer . tokens ( ) - > linkAt ( 2 ) , " func " ) ;
2014-04-12 16:06:31 +02:00
const Scope * scope = findFunctionScopeByToken ( db , functionToken ) ;
2011-01-28 08:33:02 +01:00
ASSERT ( scope & & scope - > className = = " func " ) ;
2012-05-11 17:56:47 +02:00
ASSERT ( scope & & scope - > functionOf & & scope - > functionOf = = db - > findScopeByName ( " Fred " ) ) ;
2011-01-28 08:33:02 +01:00
2013-01-28 06:47:48 +01:00
const Function * function = findFunctionByName ( " func " , & db - > scopeList . back ( ) ) ;
2011-01-28 08:33:02 +01:00
ASSERT ( function & & function - > token - > str ( ) = = " func " ) ;
2014-04-12 16:06:31 +02:00
ASSERT ( function & & function - > token = = functionToken ) ;
2015-01-08 05:45:31 +01:00
ASSERT ( function & & function - > hasBody ( ) & & ! function - > isInline ( ) ) ;
2012-05-24 17:40:43 +02:00
ASSERT ( function & & function - > functionScope = = scope & & scope - > function = = function & & function - > nestedIn = = db - > findScopeByName ( " Fred " ) ) ;
2011-01-28 08:33:02 +01:00
}
}
2014-11-20 14:20:09 +01:00
void hasRegularFunctionReturningFunctionPointer ( ) {
2011-01-28 08:33:02 +01:00
GET_SYMBOL_DB ( " void (*func(int f))(char) { } \n " )
// 2 scopes: Global and Function
2012-09-11 18:03:47 +02:00
ASSERT ( db & & db - > scopeList . size ( ) = = 2 ) ;
2011-01-28 08:33:02 +01:00
2011-10-13 20:53:06 +02:00
if ( db ) {
2014-05-18 20:39:52 +02:00
const Token * const functionToken = Token : : findsimplematch ( tokenizer . tokens ( ) , " func " ) ;
2014-04-12 16:06:31 +02:00
const Scope * scope = findFunctionScopeByToken ( db , functionToken ) ;
2011-01-28 08:33:02 +01:00
ASSERT ( scope & & scope - > className = = " func " ) ;
2013-01-28 06:47:48 +01:00
const Function * function = findFunctionByName ( " func " , & db - > scopeList . front ( ) ) ;
2011-01-28 08:33:02 +01:00
ASSERT ( function & & function - > token - > str ( ) = = " func " ) ;
2014-04-12 16:06:31 +02:00
ASSERT ( function & & function - > token = = functionToken ) ;
2015-01-08 05:45:31 +01:00
ASSERT ( function & & function - > hasBody ( ) ) ;
2011-01-28 08:33:02 +01:00
}
}
2014-11-20 14:20:09 +01:00
void hasInlineClassFunctionReturningFunctionPointer ( ) {
2011-01-28 08:33:02 +01:00
GET_SYMBOL_DB ( " class Fred { void (*func(int f))(char) { } }; \n " )
// 3 scopes: Global, Class, and Function
2012-09-11 18:03:47 +02:00
ASSERT ( db & & db - > scopeList . size ( ) = = 3 ) ;
2011-01-28 08:33:02 +01:00
2011-10-13 20:53:06 +02:00
if ( db ) {
2014-05-18 20:39:52 +02:00
const Token * const functionToken = Token : : findsimplematch ( tokenizer . tokens ( ) , " func " ) ;
2014-04-12 16:06:31 +02:00
const Scope * scope = findFunctionScopeByToken ( db , functionToken ) ;
2011-01-28 08:33:02 +01:00
ASSERT ( scope & & scope - > className = = " func " ) ;
2013-01-28 06:47:48 +01:00
const Function * function = findFunctionByName ( " func " , & db - > scopeList . back ( ) ) ;
2011-01-28 08:33:02 +01:00
ASSERT ( function & & function - > token - > str ( ) = = " func " ) ;
2014-04-12 16:06:31 +02:00
ASSERT ( function & & function - > token = = functionToken ) ;
2015-01-08 05:45:31 +01:00
ASSERT ( function & & function - > hasBody ( ) & & function - > isInline ( ) ) ;
2011-01-28 08:33:02 +01:00
}
}
2014-11-20 14:20:09 +01:00
void hasMissingInlineClassFunctionReturningFunctionPointer ( ) {
2011-01-28 08:33:02 +01:00
GET_SYMBOL_DB ( " class Fred { void (*func(int f))(char); }; \n " )
// 2 scopes: Global and Class (no Function scope because there is no function implementation)
2012-09-11 18:03:47 +02:00
ASSERT ( db & & db - > scopeList . size ( ) = = 2 ) ;
2011-01-28 08:33:02 +01:00
2011-10-13 20:53:06 +02:00
if ( db ) {
2014-05-18 20:39:52 +02:00
const Token * const functionToken = Token : : findsimplematch ( tokenizer . tokens ( ) , " func " ) ;
2014-04-12 16:06:31 +02:00
const Scope * scope = findFunctionScopeByToken ( db , functionToken ) ;
2011-01-28 08:33:02 +01:00
2014-02-16 10:32:10 +01:00
ASSERT ( scope = = nullptr ) ;
2011-01-28 08:33:02 +01:00
2013-01-28 06:47:48 +01:00
const Function * function = findFunctionByName ( " func " , & db - > scopeList . back ( ) ) ;
2011-01-28 08:33:02 +01:00
ASSERT ( function & & function - > token - > str ( ) = = " func " ) ;
2014-04-12 16:06:31 +02:00
ASSERT ( function & & function - > token = = functionToken ) ;
2015-01-08 05:45:31 +01:00
ASSERT ( function & & ! function - > hasBody ( ) ) ;
2011-01-28 08:33:02 +01:00
}
}
2014-11-20 14:20:09 +01:00
void hasClassFunctionReturningFunctionPointer ( ) {
2011-01-28 08:33:02 +01:00
GET_SYMBOL_DB ( " class Fred { void (*func(int f))(char); }; void (*Fred::func(int f))(char) { } \n " )
// 3 scopes: Global, Class, and Function
2012-09-11 18:03:47 +02:00
ASSERT ( db & & db - > scopeList . size ( ) = = 3 ) ;
2011-01-28 08:33:02 +01:00
2011-10-13 20:53:06 +02:00
if ( db ) {
2014-05-18 20:39:52 +02:00
const Token * const functionToken = Token : : findsimplematch ( tokenizer . tokens ( ) - > linkAt ( 2 ) , " func " ) ;
2014-04-12 16:06:31 +02:00
const Scope * scope = findFunctionScopeByToken ( db , functionToken ) ;
2011-01-28 08:33:02 +01:00
ASSERT ( scope & & scope - > className = = " func " ) ;
2013-01-28 06:47:48 +01:00
const Function * function = findFunctionByName ( " func " , & db - > scopeList . back ( ) ) ;
2011-01-28 08:33:02 +01:00
ASSERT ( function & & function - > token - > str ( ) = = " func " ) ;
2014-04-12 16:06:31 +02:00
ASSERT ( function & & function - > token = = functionToken ) ;
2015-01-08 05:45:31 +01:00
ASSERT ( function & & function - > hasBody ( ) & & ! function - > isInline ( ) ) ;
2011-01-28 08:33:02 +01:00
}
}
2011-02-25 13:17:55 +01:00
2014-11-20 14:20:09 +01:00
void complexFunctionArrayPtr ( ) {
2014-03-28 17:43:40 +01:00
GET_SYMBOL_DB ( " int(*p1)[10]; \n " // pointer to array 10 of int
" void(*p2)(char); \n " // pointer to function (char) returning void
" int(*(*p3)(char))[10]; \n " // pointer to function (char) returning pointer to array 10 of int
" float(*(*p4)(char))(long); \n " // pointer to function (char) returning pointer to function (long) returning float
" short(*(*(p5) (char))(long))(double); \n " // pointer to function (char) returning pointer to function (long) returning pointer to function (double) returning short
" int(*a1[10])(void); \n " // array 10 of pointer to function (void) returning int
" float(*(*a2[10])(char))(long); \n " // array 10 of pointer to func (char) returning pointer to func (long) returning float
" short(*(*(*a3[10])(char))(long))(double); \n " // array 10 of pointer to function (char) returning pointer to function (long) returning pointer to function (double) returning short
" ::boost::rational(&r_)[9]; \n " // reference to array of ::boost::rational
" ::boost::rational<T>(&r_)[9]; " ) ; // reference to array of ::boost::rational<T> (template!)
ASSERT ( db ! = nullptr ) ;
if ( db ) {
ASSERT_EQUALS ( 10 , db - > getVariableListSize ( ) - 1 ) ;
2015-01-31 13:12:06 +01:00
ASSERT_EQUALS ( true , db - > getVariableFromVarId ( 1 ) & & db - > getVariableFromVarId ( 1 ) - > dimensions ( ) . size ( ) = = 1 ) ;
2014-03-28 17:43:40 +01:00
ASSERT_EQUALS ( true , db - > getVariableFromVarId ( 2 ) ! = nullptr ) ;
2015-01-31 13:12:06 +01:00
ASSERT_EQUALS ( true , db - > getVariableFromVarId ( 3 ) & & db - > getVariableFromVarId ( 3 ) - > dimensions ( ) . size ( ) = = 0 ) ;
2014-03-28 17:43:40 +01:00
ASSERT_EQUALS ( true , db - > getVariableFromVarId ( 4 ) ! = nullptr ) ;
ASSERT_EQUALS ( true , db - > getVariableFromVarId ( 5 ) ! = nullptr ) ;
2015-01-31 13:12:06 +01:00
ASSERT_EQUALS ( true , db - > getVariableFromVarId ( 6 ) & & db - > getVariableFromVarId ( 6 ) - > dimensions ( ) . size ( ) = = 1 ) ;
ASSERT_EQUALS ( true , db - > getVariableFromVarId ( 7 ) & & db - > getVariableFromVarId ( 7 ) - > dimensions ( ) . size ( ) = = 1 ) ;
ASSERT_EQUALS ( true , db - > getVariableFromVarId ( 8 ) & & db - > getVariableFromVarId ( 8 ) - > dimensions ( ) . size ( ) = = 1 ) ;
ASSERT_EQUALS ( true , db - > getVariableFromVarId ( 9 ) & & db - > getVariableFromVarId ( 9 ) - > dimensions ( ) . size ( ) = = 1 ) ;
ASSERT_EQUALS ( true , db - > getVariableFromVarId ( 10 ) & & db - > getVariableFromVarId ( 10 ) - > dimensions ( ) . size ( ) = = 1 ) ;
2014-03-28 17:43:40 +01:00
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
}
}
2014-04-12 11:43:10 +02:00
2014-11-20 14:20:09 +01:00
void pointerToMemberFunction ( ) {
2014-04-12 11:43:10 +02:00
GET_SYMBOL_DB ( " bool (A::*pFun)(); " ) ; // Pointer to member function of A, returning bool and taking no parameters
ASSERT ( db ! = nullptr ) ;
if ( db ) {
ASSERT_EQUALS ( 1 , db - > getVariableListSize ( ) - 1 ) ;
ASSERT_EQUALS ( true , db - > getVariableFromVarId ( 1 ) ! = nullptr ) ;
if ( db - > getVariableFromVarId ( 1 ) )
ASSERT_EQUALS ( " pFun " , db - > getVariableFromVarId ( 1 ) - > name ( ) ) ;
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
}
}
2014-11-20 14:20:09 +01:00
void hasSubClassConstructor ( ) {
2012-09-15 20:13:32 +02:00
GET_SYMBOL_DB ( " class Foo { class Sub; }; class Foo::Sub { Sub() {} }; " ) ;
2014-02-16 11:47:52 +01:00
ASSERT ( db ! = nullptr ) ;
2012-09-15 20:13:32 +02:00
if ( db ) {
bool seen_something = false ;
for ( std : : list < Scope > : : const_iterator scope = db - > scopeList . begin ( ) ; scope ! = db - > scopeList . end ( ) ; + + scope ) {
for ( std : : list < Function > : : const_iterator func = scope - > functionList . begin ( ) ; func ! = scope - > functionList . end ( ) ; + + func ) {
ASSERT_EQUALS ( " Sub " , func - > token - > str ( ) ) ;
2015-01-08 05:45:31 +01:00
ASSERT_EQUALS ( true , func - > hasBody ( ) ) ;
2012-09-15 20:13:32 +02:00
ASSERT_EQUALS ( Function : : eConstructor , func - > type ) ;
seen_something = true ;
}
}
2012-11-30 06:03:58 +01:00
ASSERT_EQUALS ( true , seen_something ) ;
2012-09-15 20:13:32 +02:00
}
}
2014-11-20 14:20:09 +01:00
void testConstructors ( ) {
2013-04-04 19:53:55 +02:00
{
GET_SYMBOL_DB ( " class Foo { Foo(Foo f); }; " ) ;
const Function * ctor = tokenizer . tokens ( ) - > tokAt ( 3 ) - > function ( ) ;
2015-01-08 05:45:31 +01:00
ASSERT ( db & & ctor & & ctor - > type = = Function : : eConstructor & & ! ctor - > isExplicit ( ) ) ;
2013-09-03 10:48:01 +02:00
ASSERT ( ctor & & ctor - > retDef = = 0 ) ;
2013-04-04 19:53:55 +02:00
}
{
GET_SYMBOL_DB ( " class Foo { explicit Foo(Foo f); }; " ) ;
const Function * ctor = tokenizer . tokens ( ) - > tokAt ( 4 ) - > function ( ) ;
2015-01-08 05:45:31 +01:00
ASSERT ( db & & ctor & & ctor - > type = = Function : : eConstructor & & ctor - > isExplicit ( ) ) ;
2013-09-03 10:48:01 +02:00
ASSERT ( ctor & & ctor - > retDef = = 0 ) ;
2013-04-04 19:53:55 +02:00
}
{
GET_SYMBOL_DB ( " class Foo { Foo(Foo& f); }; " ) ;
const Function * ctor = tokenizer . tokens ( ) - > tokAt ( 3 ) - > function ( ) ;
ASSERT ( db & & ctor & & ctor - > type = = Function : : eCopyConstructor ) ;
2013-09-03 10:48:01 +02:00
ASSERT ( ctor & & ctor - > retDef = = 0 ) ;
2013-04-04 19:53:55 +02:00
}
{
GET_SYMBOL_DB ( " class Foo { Foo(Foo&& f); }; " ) ;
const Function * ctor = tokenizer . tokens ( ) - > tokAt ( 3 ) - > function ( ) ;
ASSERT ( db & & ctor & & ctor - > type = = Function : : eMoveConstructor ) ;
2013-09-03 10:48:01 +02:00
ASSERT ( ctor & & ctor - > retDef = = 0 ) ;
2013-04-04 19:53:55 +02:00
}
}
2014-11-20 14:20:09 +01:00
void functionDeclarationTemplate ( ) {
2012-08-22 12:37:50 +02:00
GET_SYMBOL_DB ( " std::map<int, string> foo() {} " )
// 2 scopes: Global and Function
2013-01-28 06:47:48 +01:00
ASSERT ( db & & db - > scopeList . size ( ) = = 2 & & findFunctionByName ( " foo " , & db - > scopeList . back ( ) ) ) ;
2012-08-22 12:37:50 +02:00
if ( db ) {
const Scope * scope = & db - > scopeList . front ( ) ;
ASSERT ( scope & & scope - > functionList . size ( ) = = 1 ) ;
const Function * foo = & scope - > functionList . front ( ) ;
ASSERT ( foo & & foo - > token - > str ( ) = = " foo " ) ;
2015-01-08 05:45:31 +01:00
ASSERT ( foo & & foo - > hasBody ( ) ) ;
2012-08-22 12:37:50 +02:00
}
}
2014-11-20 14:20:09 +01:00
void functionDeclarations ( ) {
2012-03-23 17:59:51 +01:00
GET_SYMBOL_DB ( " void foo(); \n void foo(); \n int foo(int i); \n void foo() {} " )
2012-08-22 12:37:50 +02:00
// 2 scopes: Global and Function
2013-01-28 06:47:48 +01:00
ASSERT ( db & & db - > scopeList . size ( ) = = 2 & & findFunctionByName ( " foo " , & db - > scopeList . back ( ) ) ) ;
2012-03-23 17:59:51 +01:00
if ( db ) {
const Scope * scope = & db - > scopeList . front ( ) ;
ASSERT ( scope & & scope - > functionList . size ( ) = = 2 ) ;
const Function * foo = & scope - > functionList . front ( ) ;
const Function * foo_int = & scope - > functionList . back ( ) ;
ASSERT ( foo & & foo - > token - > str ( ) = = " foo " ) ;
2015-01-08 05:45:31 +01:00
ASSERT ( foo & & foo - > hasBody ( ) ) ;
2012-03-23 17:59:51 +01:00
ASSERT ( foo & & foo - > token - > strAt ( 2 ) = = " ) " ) ;
ASSERT ( foo_int & & ! foo_int - > token ) ;
ASSERT ( foo_int & & foo_int - > tokenDef - > str ( ) = = " foo " ) ;
2015-01-08 05:45:31 +01:00
ASSERT ( foo_int & & ! foo_int - > hasBody ( ) ) ;
2012-03-23 17:59:51 +01:00
ASSERT ( foo_int & & foo_int - > tokenDef - > strAt ( 2 ) = = " int " ) ;
2013-04-04 18:47:44 +02:00
ASSERT ( & foo_int - > argumentList . front ( ) = = db - > getVariableFromVarId ( 1 ) ) ;
2012-03-23 17:59:51 +01:00
}
}
2014-11-20 14:20:09 +01:00
void constructorInitialization ( ) {
2014-09-29 13:05:51 +02:00
GET_SYMBOL_DB ( " std::string logfile; \n "
" std::ofstream log(logfile.c_str(), std::ios::out); " ) ;
// 1 scope: Global
ASSERT ( db & & db - > scopeList . size ( ) = = 1 ) ;
2014-09-29 14:36:03 +02:00
if ( db & & ! db - > scopeList . empty ( ) ) {
2014-09-29 13:05:51 +02:00
// No functions
ASSERT ( db - > scopeList . front ( ) . functionList . empty ( ) ) ;
}
}
2014-11-20 14:20:09 +01:00
void memberFunctionOfUnknownClassMacro1 ( ) {
2014-03-30 11:06:44 +02:00
GET_SYMBOL_DB ( " class ScVbaFormatCondition { OUString getServiceImplName() SAL_OVERRIDE; }; \n "
" void ScVbaValidation::getFormula1() { \n "
2014-03-31 20:33:01 +02:00
" sal_uInt16 nFlags = 0; \n "
" if (pDocSh && !getCellRangesForAddress(nFlags)) ; \n "
" } " ) ;
ASSERT ( db & & errout . str ( ) = = " " ) ;
if ( db ) {
const Scope * scope = db - > findScopeByName ( " getFormula1 " ) ;
ASSERT ( scope ! = nullptr ) ;
ASSERT ( scope & & scope - > nestedIn = = & db - > scopeList . front ( ) ) ;
}
}
2014-11-20 14:20:09 +01:00
void memberFunctionOfUnknownClassMacro2 ( ) {
2014-03-31 21:04:01 +02:00
GET_SYMBOL_DB ( " class ScVbaFormatCondition { OUString getServiceImplName() SAL_OVERRIDE {} }; \n "
" void getFormula1() { \n "
" sal_uInt16 nFlags = 0; \n "
" if (pDocSh && !getCellRangesForAddress(nFlags)) ; \n "
" } " ) ;
ASSERT ( db & & errout . str ( ) = = " " ) ;
if ( db ) {
const Scope * scope = db - > findScopeByName ( " getFormula1 " ) ;
ASSERT ( scope ! = nullptr ) ;
ASSERT ( scope & & scope - > nestedIn = = & db - > scopeList . front ( ) ) ;
scope = db - > findScopeByName ( " getServiceImplName " ) ;
ASSERT ( scope ! = nullptr ) ;
ASSERT ( scope & & scope - > nestedIn & & scope - > nestedIn - > className = = " ScVbaFormatCondition " ) ;
}
}
2014-11-20 14:20:09 +01:00
void memberFunctionOfUnknownClassMacro3 ( ) {
2014-03-31 20:33:01 +02:00
GET_SYMBOL_DB ( " class ScVbaFormatCondition { OUString getServiceImplName() THROW(whatever); }; \n "
" void ScVbaValidation::getFormula1() { \n "
2014-03-30 11:06:44 +02:00
" sal_uInt16 nFlags = 0; \n "
" if (pDocSh && !getCellRangesForAddress(nFlags)) ; \n "
" } " ) ;
ASSERT ( db & & errout . str ( ) = = " " ) ;
if ( db ) {
const Scope * scope = db - > findScopeByName ( " getFormula1 " ) ;
ASSERT ( scope ! = nullptr ) ;
ASSERT ( scope & & scope - > nestedIn = = & db - > scopeList . front ( ) ) ;
}
}
2015-01-08 05:45:31 +01:00
void functionLinkage ( ) {
GET_SYMBOL_DB ( " static void f1() { } \n "
" void f2(); \n "
" extern void f3(); \n "
" void f4(); \n "
" extern void f5() { }; \n "
" void f6() { } " ) ;
ASSERT ( db & & errout . str ( ) = = " " ) ;
if ( db ) {
const Token * f = Token : : findsimplematch ( tokenizer . tokens ( ) , " f1 " ) ;
ASSERT ( f & & f - > function ( ) & & f - > function ( ) - > isStaticLocal ( ) ) ;
f = Token : : findsimplematch ( tokenizer . tokens ( ) , " f2 " ) ;
ASSERT ( f & & f - > function ( ) & & ! f - > function ( ) - > isStaticLocal ( ) ) ;
f = Token : : findsimplematch ( tokenizer . tokens ( ) , " f3 " ) ;
ASSERT ( f & & f - > function ( ) & & f - > function ( ) - > isExtern ( ) ) ;
f = Token : : findsimplematch ( tokenizer . tokens ( ) , " f4 " ) ;
ASSERT ( f & & f - > function ( ) & & ! f - > function ( ) - > isExtern ( ) ) ;
f = Token : : findsimplematch ( tokenizer . tokens ( ) , " f5 " ) ;
ASSERT ( f & & f - > function ( ) & & f - > function ( ) - > isExtern ( ) ) ;
f = Token : : findsimplematch ( tokenizer . tokens ( ) , " f6 " ) ;
ASSERT ( f & & f - > function ( ) & & ! f - > function ( ) - > isExtern ( ) ) ;
}
}
2014-11-20 14:20:09 +01:00
void classWithFriend ( ) {
2012-02-24 20:45:56 +01:00
GET_SYMBOL_DB ( " class Foo {}; class Bar1 { friend class Foo; }; class Bar2 { friend Foo; }; " )
// 3 scopes: Global, 3 classes
ASSERT ( db & & db - > scopeList . size ( ) = = 4 ) ;
if ( db ) {
const Scope * foo = db - > findScopeByName ( " Foo " ) ;
2014-02-16 11:47:52 +01:00
ASSERT ( foo ! = nullptr ) ;
2012-02-24 20:45:56 +01:00
const Scope * bar1 = db - > findScopeByName ( " Bar1 " ) ;
2014-02-16 11:47:52 +01:00
ASSERT ( bar1 ! = nullptr ) ;
2012-02-24 20:45:56 +01:00
const Scope * bar2 = db - > findScopeByName ( " Bar2 " ) ;
2014-02-16 11:47:52 +01:00
ASSERT ( bar2 ! = nullptr ) ;
2012-02-24 20:45:56 +01:00
if ( foo & & bar1 & & bar2 ) {
2013-03-05 15:46:34 +01:00
ASSERT ( bar1 - > definedType - > friendList . size ( ) = = 1 & & bar1 - > definedType - > friendList . front ( ) . name = = " Foo " & & bar1 - > definedType - > friendList . front ( ) . type = = foo - > definedType ) ;
ASSERT ( bar2 - > definedType - > friendList . size ( ) = = 1 & & bar2 - > definedType - > friendList . front ( ) . name = = " Foo " & & bar2 - > definedType - > friendList . front ( ) . type = = foo - > definedType ) ;
2012-02-24 20:45:56 +01:00
}
}
}
2014-11-20 14:20:09 +01:00
void parseFunctionCorrect ( ) {
2011-11-05 12:23:05 +01:00
// ticket 3188 - "if" statement parsed as function
GET_SYMBOL_DB ( " void func(i) int i; { if (i == 1) return; } \n " )
2014-02-16 10:32:10 +01:00
ASSERT ( db ! = nullptr ) ;
2011-11-05 12:23:05 +01:00
// 3 scopes: Global, function, if
ASSERT_EQUALS ( 3 , db - > scopeList . size ( ) ) ;
2014-02-16 10:32:10 +01:00
ASSERT ( findFunctionByName ( " func " , & db - > scopeList . back ( ) ) ! = nullptr ) ;
ASSERT ( findFunctionByName ( " if " , & db - > scopeList . back ( ) ) = = nullptr ) ;
2011-11-05 12:23:05 +01:00
}
2014-11-20 14:20:09 +01:00
void parseFunctionDeclarationCorrect ( ) {
2012-05-22 21:30:10 +02:00
GET_SYMBOL_DB ( " void func(); \n "
" int bar() {} \n "
" void func() {} " )
2012-05-22 21:58:46 +02:00
ASSERT_EQUALS ( 3 , db - > findScopeByName ( " func " ) - > classStart - > linenr ( ) ) ;
2012-05-22 21:30:10 +02:00
}
2014-11-20 14:20:09 +01:00
void Cpp11InitInInitList ( ) {
2012-07-10 15:15:11 +02:00
GET_SYMBOL_DB ( " class Foo { \n "
" std::vector<std::string> bar; \n "
" Foo() : bar({ \" a \" , \" b \" }) \n "
" {} \n "
" }; " ) ;
ASSERT_EQUALS ( 4 , db - > scopeList . front ( ) . nestedList . front ( ) - > nestedList . front ( ) - > classStart - > linenr ( ) ) ;
}
2014-11-20 14:20:09 +01:00
void hasGlobalVariables1 ( ) {
2011-02-25 13:17:55 +01:00
GET_SYMBOL_DB ( " int i; \n " )
ASSERT ( db & & db - > scopeList . size ( ) = = 1 ) ;
2011-10-13 20:53:06 +02:00
if ( db & & db - > scopeList . size ( ) = = 1 ) {
2011-03-11 01:43:29 +01:00
std : : list < Scope > : : const_iterator it = db - > scopeList . begin ( ) ;
ASSERT ( it - > varlist . size ( ) = = 1 ) ;
2011-10-13 20:53:06 +02:00
if ( it - > varlist . size ( ) = = 1 ) {
2011-03-11 01:43:29 +01:00
std : : list < Variable > : : const_iterator var = it - > varlist . begin ( ) ;
2011-02-25 13:17:55 +01:00
ASSERT ( var - > name ( ) = = " i " ) ;
ASSERT ( var - > typeStartToken ( ) - > str ( ) = = " int " ) ;
}
}
}
2014-11-20 14:20:09 +01:00
void hasGlobalVariables2 ( ) {
2011-02-25 13:17:55 +01:00
GET_SYMBOL_DB ( " int array[2][2]; \n " )
ASSERT ( db & & db - > scopeList . size ( ) = = 1 ) ;
2011-10-13 20:53:06 +02:00
if ( db & & db - > scopeList . size ( ) = = 1 ) {
2011-03-11 01:43:29 +01:00
std : : list < Scope > : : const_iterator it = db - > scopeList . begin ( ) ;
ASSERT ( it - > varlist . size ( ) = = 1 ) ;
2011-10-13 20:53:06 +02:00
if ( it - > varlist . size ( ) = = 1 ) {
2011-03-11 01:43:29 +01:00
std : : list < Variable > : : const_iterator var = it - > varlist . begin ( ) ;
2011-02-25 13:17:55 +01:00
ASSERT ( var - > name ( ) = = " array " ) ;
ASSERT ( var - > typeStartToken ( ) - > str ( ) = = " int " ) ;
}
}
}
2014-11-20 14:20:09 +01:00
void hasGlobalVariables3 ( ) {
2011-02-25 13:17:55 +01:00
GET_SYMBOL_DB ( " int array[2][2] = { { 0, 0 }, { 0, 0 } }; \n " )
ASSERT ( db & & db - > scopeList . size ( ) = = 1 ) ;
2011-10-13 20:53:06 +02:00
if ( db & & db - > scopeList . size ( ) = = 1 ) {
2011-03-11 01:43:29 +01:00
std : : list < Scope > : : const_iterator it = db - > scopeList . begin ( ) ;
ASSERT ( it - > varlist . size ( ) = = 1 ) ;
2011-10-13 20:53:06 +02:00
if ( it - > varlist . size ( ) = = 1 ) {
2011-03-11 01:43:29 +01:00
std : : list < Variable > : : const_iterator var = it - > varlist . begin ( ) ;
2011-02-25 13:17:55 +01:00
ASSERT ( var - > name ( ) = = " array " ) ;
ASSERT ( var - > typeStartToken ( ) - > str ( ) = = " int " ) ;
}
}
}
2011-04-29 02:53:31 +02:00
2014-11-20 14:20:09 +01:00
void checkTypeStartEndToken1 ( ) {
2012-06-08 18:05:02 +02:00
GET_SYMBOL_DB ( " static std::string i; \n "
" static const std::string j; \n "
" const std::string* k; \n "
" const char m[]; \n "
" void f(const char* const l;) {} " ) ;
ASSERT ( db & & db - > getVariableListSize ( ) = = 6 & & db - > getVariableFromVarId ( 1 ) & & db - > getVariableFromVarId ( 2 ) & & db - > getVariableFromVarId ( 3 ) & & db - > getVariableFromVarId ( 4 ) & & db - > getVariableFromVarId ( 5 ) ) ;
if ( db & & db - > getVariableFromVarId ( 1 ) & & db - > getVariableFromVarId ( 2 ) & & db - > getVariableFromVarId ( 3 ) & & db - > getVariableFromVarId ( 4 ) & & db - > getVariableFromVarId ( 5 ) ) {
ASSERT_EQUALS ( " std " , db - > getVariableFromVarId ( 1 ) - > typeStartToken ( ) - > str ( ) ) ;
ASSERT_EQUALS ( " std " , db - > getVariableFromVarId ( 2 ) - > typeStartToken ( ) - > str ( ) ) ;
ASSERT_EQUALS ( " std " , db - > getVariableFromVarId ( 3 ) - > typeStartToken ( ) - > str ( ) ) ;
ASSERT_EQUALS ( " char " , db - > getVariableFromVarId ( 4 ) - > typeStartToken ( ) - > str ( ) ) ;
ASSERT_EQUALS ( " char " , db - > getVariableFromVarId ( 5 ) - > typeStartToken ( ) - > str ( ) ) ;
ASSERT_EQUALS ( " string " , db - > getVariableFromVarId ( 1 ) - > typeEndToken ( ) - > str ( ) ) ;
ASSERT_EQUALS ( " string " , db - > getVariableFromVarId ( 2 ) - > typeEndToken ( ) - > str ( ) ) ;
ASSERT_EQUALS ( " * " , db - > getVariableFromVarId ( 3 ) - > typeEndToken ( ) - > str ( ) ) ;
ASSERT_EQUALS ( " char " , db - > getVariableFromVarId ( 4 ) - > typeEndToken ( ) - > str ( ) ) ;
ASSERT_EQUALS ( " * " , db - > getVariableFromVarId ( 5 ) - > typeEndToken ( ) - > str ( ) ) ;
}
}
2014-11-20 14:20:09 +01:00
void checkTypeStartEndToken2 ( ) {
2013-09-28 11:44:26 +02:00
GET_SYMBOL_DB ( " class CodeGenerator { \n "
" DiagnosticsEngine Diags; \n "
" public: \n "
" void Initialize() { \n "
" Builder.reset(Diags); \n "
" } \n "
" \n "
" void HandleTagDeclRequiredDefinition() LLVM_OVERRIDE { \n "
" if (Diags.hasErrorOccurred()) \n "
" return; \n "
" } \n "
" }; " ) ;
ASSERT_EQUALS ( " DiagnosticsEngine " , db - > getVariableFromVarId ( 1 ) - > typeStartToken ( ) - > str ( ) ) ;
}
2016-01-23 09:48:21 +01:00
void checkTypeStartEndToken3 ( ) {
GET_SYMBOL_DB ( " void f(const char) {} " ) ;
ASSERT ( db & & db - > functionScopes . size ( ) = = 1U ) ;
if ( db & & db - > functionScopes . size ( ) = = 1U ) {
const Function * const f = db - > functionScopes . front ( ) - > function ;
ASSERT_EQUALS ( 1U , f - > argCount ( ) ) ;
const Variable * const arg1 = f - > getArgumentVar ( 0 ) ;
ASSERT_EQUALS ( " char " , arg1 - > typeStartToken ( ) - > str ( ) ) ;
ASSERT_EQUALS ( " char " , arg1 - > typeEndToken ( ) - > str ( ) ) ;
}
}
2014-11-20 14:20:09 +01:00
void check ( const char code [ ] , bool debug = true ) {
2011-04-29 02:53:31 +02:00
// Clear the error log
errout . str ( " " ) ;
// Check..
2015-10-07 18:33:57 +02:00
settings . debugwarnings = debug ;
2011-04-29 02:53:31 +02:00
// Tokenize..
2015-10-07 18:33:57 +02:00
Tokenizer tokenizer ( & settings , this ) ;
2011-04-29 02:53:31 +02:00
std : : istringstream istr ( code ) ;
tokenizer . tokenize ( istr , " test.cpp " ) ;
2013-12-30 17:45:28 +01:00
tokenizer . simplifyTokenList2 ( ) ;
2011-04-29 02:53:31 +02:00
// force symbol database creation
2015-01-23 15:53:39 +01:00
tokenizer . createSymbolDatabase ( ) ;
2015-10-07 18:33:57 +02:00
settings . debugwarnings = false ;
2011-04-29 02:53:31 +02:00
}
2014-11-20 14:20:09 +01:00
void functionArgs1 ( ) {
2012-05-11 17:56:47 +02:00
{
GET_SYMBOL_DB ( " void f(std::vector<std::string>, const std::vector<int> & v) { } " ) ;
2012-05-13 07:55:35 +02:00
ASSERT_EQUALS ( 1 + 1 , db - > getVariableListSize ( ) ) ;
const Variable * v = db - > getVariableFromVarId ( 1 ) ;
2012-05-11 17:56:47 +02:00
ASSERT ( v & & v - > isReference ( ) & & v - > isConst ( ) & & v - > isArgument ( ) ) ;
const Scope * f = db - > findScopeByName ( " f " ) ;
ASSERT ( f & & f - > type = = Scope : : eFunction & & f - > function ) ;
if ( f & & f - > function )
ASSERT ( f - > function - > argumentList . size ( ) = = 2 & & f - > function - > argumentList . front ( ) . index ( ) = = 0 & & f - > function - > argumentList . front ( ) . name ( ) = = " " & & f - > function - > argumentList . back ( ) . index ( ) = = 1 ) ;
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
}
{
GET_SYMBOL_DB ( " void g(std::map<std::string, std::vector<int> > m) { } " ) ;
ASSERT_EQUALS ( 1 + 1 , db - > getVariableListSize ( ) ) ;
const Variable * m = db - > getVariableFromVarId ( 1 ) ;
ASSERT ( m & & ! m - > isReference ( ) & & ! m - > isConst ( ) & & m - > isArgument ( ) & & m - > isClass ( ) ) ;
const Scope * g = db - > findScopeByName ( " g " ) ;
ASSERT ( g & & g - > type = = Scope : : eFunction & & g - > function & & g - > function - > argumentList . size ( ) = = 1 & & g - > function - > argumentList . front ( ) . index ( ) = = 0 ) ;
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
}
2012-09-06 20:02:53 +02:00
{
GET_SYMBOL_DB ( " void g(std::map<int, int> m = std::map<int, int>()) { } " ) ;
const Scope * g = db - > findScopeByName ( " g " ) ;
ASSERT ( g & & g - > type = = Scope : : eFunction & & g - > function & & g - > function - > argumentList . size ( ) = = 1 & & g - > function - > argumentList . front ( ) . index ( ) = = 0 & & g - > function - > initializedArgCount ( ) = = 1 ) ;
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
}
2012-09-06 20:50:46 +02:00
{
GET_SYMBOL_DB ( " void g(int = 0) { } " ) ;
const Scope * g = db - > findScopeByName ( " g " ) ;
ASSERT ( g & & g - > type = = Scope : : eFunction & & g - > function & & g - > function - > argumentList . size ( ) = = 1 & & g - > function - > argumentList . front ( ) . hasDefault ( ) ) ;
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
}
2014-06-26 09:16:55 +02:00
{
GET_SYMBOL_DB ( " void g(int* const) { } " ) ; // 'const' is not the name of the variable - #5882
const Scope * g = db - > findScopeByName ( " g " ) ;
ASSERT ( g & & g - > type = = Scope : : eFunction & & g - > function & & g - > function - > argumentList . size ( ) = = 1 & & g - > function - > argumentList . front ( ) . nameToken ( ) = = nullptr ) ;
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
}
2011-04-29 02:53:31 +02:00
}
2011-04-29 03:03:57 +02:00
2014-11-20 14:20:09 +01:00
void functionArgs2 ( ) {
2011-08-28 19:32:42 +02:00
GET_SYMBOL_DB ( " void f(int a[][4]) { } " ) ;
const Variable * a = db - > getVariableFromVarId ( 1 ) ;
ASSERT_EQUALS ( " a " , a - > nameToken ( ) - > str ( ) ) ;
ASSERT_EQUALS ( 2UL , a - > dimensions ( ) . size ( ) ) ;
ASSERT_EQUALS ( 0UL , a - > dimension ( 0 ) ) ;
2012-09-10 16:23:00 +02:00
ASSERT_EQUALS ( false , a - > dimensions ( ) [ 0 ] . known ) ;
2011-08-28 19:32:42 +02:00
ASSERT_EQUALS ( 4UL , a - > dimension ( 1 ) ) ;
2012-09-10 16:23:00 +02:00
ASSERT_EQUALS ( true , a - > dimensions ( ) [ 1 ] . known ) ;
2011-08-28 19:32:42 +02:00
}
2014-11-20 14:20:09 +01:00
void functionArgs3 ( ) {
2012-05-22 10:29:33 +02:00
GET_SYMBOL_DB ( " void f(int i,) { } " ) ; // Don't crash
const Variable * a = db - > getVariableFromVarId ( 1 ) ;
ASSERT_EQUALS ( " i " , a - > nameToken ( ) - > str ( ) ) ;
}
2014-11-20 14:20:09 +01:00
void functionArgs4 ( ) {
2012-12-29 08:32:43 +01:00
GET_SYMBOL_DB ( " void f1(char [10], struct foo [10]); " ) ;
ASSERT_EQUALS ( true , db - > scopeList . front ( ) . functionList . size ( ) = = 1UL ) ;
const Function * func = & db - > scopeList . front ( ) . functionList . front ( ) ;
ASSERT_EQUALS ( true , func & & func - > argumentList . size ( ) = = 2UL ) ;
if ( func & & func - > argumentList . size ( ) = = 2UL ) {
const Variable * first = & func - > argumentList . front ( ) ;
ASSERT_EQUALS ( 0UL , first - > name ( ) . size ( ) ) ;
ASSERT_EQUALS ( 1UL , first - > dimensions ( ) . size ( ) ) ;
ASSERT_EQUALS ( 10UL , first - > dimension ( 0 ) ) ;
const Variable * second = & func - > argumentList . back ( ) ;
ASSERT_EQUALS ( 0UL , second - > name ( ) . size ( ) ) ;
ASSERT_EQUALS ( 1UL , second - > dimensions ( ) . size ( ) ) ;
ASSERT_EQUALS ( 10UL , second - > dimension ( 0 ) ) ;
}
}
2014-11-20 14:20:09 +01:00
void namespaces1 ( ) {
2012-01-07 09:28:26 +01:00
GET_SYMBOL_DB ( " namespace fred { \n "
" namespace barney { \n "
" class X { X(int); }; \n "
" } \n "
" } \n "
2013-03-20 15:36:16 +01:00
" namespace barney { X::X(int) { } } " ) ;
2012-01-07 09:28:26 +01:00
// Locate the scope for the class..
2014-02-16 10:32:10 +01:00
const Scope * scope = nullptr ;
2012-01-07 09:28:26 +01:00
for ( std : : list < Scope > : : const_iterator it = db - > scopeList . begin ( ) ; it ! = db - > scopeList . end ( ) ; + + it ) {
if ( it - > isClassOrStruct ( ) ) {
scope = & ( * it ) ;
break ;
}
}
2014-02-16 11:47:52 +01:00
ASSERT ( scope ! = nullptr ) ;
2012-01-21 10:08:09 +01:00
if ( ! scope )
return ;
2012-01-07 09:28:26 +01:00
ASSERT_EQUALS ( " X " , scope - > className ) ;
2012-01-07 09:37:38 +01:00
// The class has a constructor but the implementation _is not_ seen
2012-01-07 09:28:26 +01:00
ASSERT_EQUALS ( 1U , scope - > functionList . size ( ) ) ;
const Function * function = & ( scope - > functionList . front ( ) ) ;
2015-01-08 05:45:31 +01:00
ASSERT_EQUALS ( false , function - > hasBody ( ) ) ;
2012-01-07 09:28:26 +01:00
}
// based on namespaces1 but here the namespaces match
2014-11-20 14:20:09 +01:00
void namespaces2 ( ) {
2012-01-07 09:28:26 +01:00
GET_SYMBOL_DB ( " namespace fred { \n "
" namespace barney { \n "
" class X { X(int); }; \n "
" } \n "
" } \n "
" namespace fred { \n "
" namespace barney { \n "
" X::X(int) { } \n "
" } \n "
2013-03-20 15:36:16 +01:00
" } " ) ;
2012-01-07 09:28:26 +01:00
// Locate the scope for the class..
2014-02-16 10:32:10 +01:00
const Scope * scope = nullptr ;
2012-01-07 09:28:26 +01:00
for ( std : : list < Scope > : : const_iterator it = db - > scopeList . begin ( ) ; it ! = db - > scopeList . end ( ) ; + + it ) {
if ( it - > isClassOrStruct ( ) ) {
scope = & ( * it ) ;
break ;
}
}
2014-02-16 11:47:52 +01:00
ASSERT ( scope ! = nullptr ) ;
2012-01-21 10:08:09 +01:00
if ( ! scope )
return ;
2012-01-07 09:28:26 +01:00
ASSERT_EQUALS ( " X " , scope - > className ) ;
2012-01-07 09:37:38 +01:00
// The class has a constructor and the implementation _is_ seen
2012-01-07 09:28:26 +01:00
ASSERT_EQUALS ( 1U , scope - > functionList . size ( ) ) ;
const Function * function = & ( scope - > functionList . front ( ) ) ;
ASSERT_EQUALS ( " X " , function - > tokenDef - > str ( ) ) ;
2015-01-08 05:45:31 +01:00
ASSERT_EQUALS ( true , function - > hasBody ( ) ) ;
2012-01-07 09:28:26 +01:00
}
2014-11-20 14:20:09 +01:00
void namespaces3 ( ) { // #3854 - namespace with unknown macro
2012-06-05 06:37:55 +02:00
GET_SYMBOL_DB ( " namespace fred UNKNOWN_MACRO(default) { \n "
2013-03-20 15:36:16 +01:00
" } " ) ;
2012-06-05 06:37:55 +02:00
ASSERT_EQUALS ( 2U , db - > scopeList . size ( ) ) ;
ASSERT_EQUALS ( Scope : : eGlobal , db - > scopeList . front ( ) . type ) ;
ASSERT_EQUALS ( Scope : : eNamespace , db - > scopeList . back ( ) . type ) ;
}
2012-01-07 09:28:26 +01:00
2016-01-30 14:04:48 +01:00
void namespaces4 ( ) { // #4698 - type lookup
GET_SYMBOL_DB ( " struct A { int a; }; \n "
" namespace fred { struct A {}; } \n "
" fred::A fredA; " ) ;
const Variable * fredA = db - > getVariableFromVarId ( 2U ) ;
ASSERT_EQUALS ( " fredA " , fredA - > name ( ) ) ;
const Type * fredAType = fredA - > type ( ) ;
ASSERT_EQUALS ( 2U , fredAType - > classDef - > linenr ( ) ) ;
}
2014-11-20 14:20:09 +01:00
void tryCatch1 ( ) {
2014-04-02 13:56:34 +02:00
const char str [ ] = " void foo() { \n "
" try { } \n "
" catch (const Error1 & x) { } \n "
" catch (const X::Error2 & x) { } \n "
" catch (Error3 x) { } \n "
" catch (X::Error4 x) { } \n "
" } " ;
GET_SYMBOL_DB ( str ) ;
2012-01-26 04:48:18 +01:00
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
ASSERT ( db & & db - > getVariableListSize ( ) = = 5 ) ; // index 0 + 4 variables
ASSERT ( db & & db - > scopeList . size ( ) = = 7 ) ; // global + function + try + 4 catch
}
2014-11-20 14:20:09 +01:00
void symboldatabase1 ( ) {
2011-04-29 03:03:57 +02:00
check ( " namespace foo { \n "
" class bar; \n "
" }; " ) ;
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
check ( " class foo : public bar < int, int> { \n "
" }; " ) ;
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
}
2014-11-20 14:20:09 +01:00
void symboldatabase2 ( ) {
2011-04-29 03:03:57 +02:00
check ( " class foo { \n "
" public slots : \n "
" foo() { } \n "
" }; " ) ;
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
check ( " class foo { \n "
" class bar; \n "
" foo() { } \n "
" }; " ) ;
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
}
2014-11-20 14:20:09 +01:00
void symboldatabase3 ( ) {
2011-04-29 03:03:57 +02:00
check ( " typedef void (func_type)(); \n "
" struct A { \n "
" friend func_type f : 2; \n "
2013-03-20 15:36:16 +01:00
" }; " ) ;
2011-04-29 03:03:57 +02:00
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
}
2014-11-20 14:20:09 +01:00
void symboldatabase4 ( ) {
2011-04-29 03:03:57 +02:00
check ( " static void function_declaration_before(void) __attribute__((__used__)); \n "
" static void function_declaration_before(void) {} \n "
" static void function_declaration_after(void) {} \n "
" static void function_declaration_after(void) __attribute__((__used__)); \n " ) ;
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
2013-03-20 15:36:16 +01:00
check ( " main(int argc, char *argv[]) { } " ) ;
2011-04-29 03:03:57 +02:00
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
check ( " namespace boost { \n "
" std::locale generate_locale() \n "
" { \n "
" return std::locale(); \n "
" } \n "
2013-03-20 15:36:16 +01:00
" } " ) ;
2011-04-29 03:03:57 +02:00
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
check ( " namespace X { \n "
" static void function_declaration_before(void) __attribute__((__used__)); \n "
" static void function_declaration_before(void) {} \n "
" static void function_declaration_after(void) {} \n "
" static void function_declaration_after(void) __attribute__((__used__)); \n "
2013-03-20 15:36:16 +01:00
" } " ) ;
2011-04-29 03:03:57 +02:00
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
check ( " testing::testing() \n "
" { \n "
2013-03-20 15:36:16 +01:00
" } " ) ;
2015-12-06 10:40:22 +01:00
ASSERT_EQUALS ( " [test.cpp:1]: (debug) Executable scope 'testing' with unknown function. \n " , errout . str ( ) ) ;
2011-04-29 03:03:57 +02:00
}
2014-11-20 14:20:09 +01:00
void symboldatabase5 ( ) {
2011-04-29 03:03:57 +02:00
// ticket #2178 - segmentation fault
check ( " int CL_INLINE_DECL(integer_decode_float) (int x) { \n "
" return (sign ? cl_I() : 0); \n "
2013-03-20 15:36:16 +01:00
" } " ) ;
2011-04-29 03:03:57 +02:00
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
}
2014-11-20 14:20:09 +01:00
void symboldatabase6 ( ) {
2011-04-29 03:03:57 +02:00
// ticket #2221 - segmentation fault
check ( " template<int i> class X { }; \n "
" X< 1>2 > x1; \n "
" X<(1>2)> x2; \n "
" template<class T> class Y { }; \n "
" Y<X<1>> x3; \n "
" Y<X<6>>1>> x4; \n "
2011-09-29 04:05:26 +02:00
" Y<X<(6>>1)>> x5; \n " , false ) ;
2011-04-29 03:03:57 +02:00
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
}
2014-11-20 14:20:09 +01:00
void symboldatabase7 ( ) {
2011-04-29 03:03:57 +02:00
// ticket #2230 - segmentation fault
check ( " template<template<class> class E,class D> class C : E<D> \n "
" { \n "
" public: \n "
" int f(); \n "
" }; \n "
" class E : C<D,int> \n "
" { \n "
" public: \n "
" int f() { return C< ::D,int>::f(); } \n "
2013-03-20 15:36:16 +01:00
" }; " ) ;
2013-11-19 06:07:25 +01:00
ASSERT_EQUALS ( " [test.cpp:1]: (debug) simplifyTemplates: bailing out \n " , errout . str ( ) ) ;
2011-04-29 03:03:57 +02:00
}
2014-11-20 14:20:09 +01:00
void symboldatabase8 ( ) {
2011-04-29 03:03:57 +02:00
// ticket #2252 - segmentation fault
check ( " struct PaletteColorSpaceHolder: public rtl::StaticWithInit<uno::Reference<rendering::XColorSpace>, \n "
" PaletteColorSpaceHolder> \n "
" { \n "
" uno::Reference<rendering::XColorSpace> operator()() \n "
" { \n "
" return vcl::unotools::createStandardColorSpace(); \n "
" } \n "
2013-03-20 15:36:16 +01:00
" }; " ) ;
2011-04-29 03:03:57 +02:00
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
}
2014-11-20 14:20:09 +01:00
void symboldatabase9 ( ) {
2011-04-29 03:03:57 +02:00
// ticket #2425 - segmentation fault
check ( " class CHyperlink : public CString \n "
" { \n "
" public: \n "
" const CHyperlink& operator=(LPCTSTR lpsz) { \n "
" CString::operator=(lpsz); \n "
" return *this; \n "
" } \n "
2011-09-29 04:05:26 +02:00
" }; \n " , false ) ;
2011-04-29 03:03:57 +02:00
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
}
2014-11-20 14:20:09 +01:00
void symboldatabase10 ( ) {
2011-04-29 03:03:57 +02:00
// ticket #2537 - segmentation fault
check ( " class A { \n "
" private: \n "
" void f(); \n "
" }; \n "
" class B { \n "
" friend void A::f(); \n "
2013-03-20 15:36:16 +01:00
" }; " ) ;
2011-04-29 03:03:57 +02:00
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
}
2014-11-20 14:20:09 +01:00
void symboldatabase11 ( ) {
2011-04-29 03:03:57 +02:00
// ticket #2539 - segmentation fault
check ( " int g (); \n "
" struct S { \n "
" int i : (false ? g () : 1); \n "
2013-03-20 15:36:16 +01:00
" }; " ) ;
2011-04-29 03:03:57 +02:00
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
}
2014-11-20 14:20:09 +01:00
void symboldatabase12 ( ) {
2011-04-29 03:03:57 +02:00
// ticket #2547 - segmentation fault
check ( " class foo { \n "
" void bar2 () = __null; \n "
2013-03-20 15:36:16 +01:00
" }; " ) ;
2011-04-29 03:03:57 +02:00
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
}
2014-11-20 14:20:09 +01:00
void symboldatabase13 ( ) {
2011-04-29 03:03:57 +02:00
// ticket #2577 - segmentation fault
check ( " class foo { \n "
" void bar2 () = A::f; \n "
2013-03-20 15:36:16 +01:00
" }; " ) ;
2011-04-29 03:03:57 +02:00
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
}
2014-11-20 14:20:09 +01:00
void symboldatabase14 ( ) {
2011-04-29 03:03:57 +02:00
// ticket #2589 - segmentation fault
2014-03-27 19:06:13 +01:00
ASSERT_THROW ( check ( " struct B : A \n " ) , InternalError ) ;
2011-04-29 03:03:57 +02:00
}
2014-11-20 14:20:09 +01:00
void symboldatabase15 ( ) {
2011-04-29 03:03:57 +02:00
// ticket #2591 - segmentation fault
2014-03-27 19:06:13 +01:00
ASSERT_THROW ( check ( " struct A : \n " ) , InternalError ) ;
2011-04-29 03:03:57 +02:00
}
2014-11-20 14:20:09 +01:00
void symboldatabase16 ( ) {
2011-04-29 03:03:57 +02:00
// ticket #2637 - segmentation fault
check ( " {} const const \n " ) ;
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
}
2014-11-20 14:20:09 +01:00
void symboldatabase17 ( ) {
2011-04-29 03:03:57 +02:00
// ticket #2657 - segmentation fault
2013-03-20 15:36:16 +01:00
check ( " return f(){} " ) ;
2011-04-29 03:03:57 +02:00
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
}
2014-11-20 14:20:09 +01:00
void symboldatabase18 ( ) {
2011-06-27 13:31:10 +02:00
// ticket #2865 - segmentation fault
check ( " char a[1] \n " ) ;
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
}
2014-11-20 14:20:09 +01:00
void symboldatabase19 ( ) {
2011-08-11 23:57:54 +02:00
// ticket #2991 - segmentation fault
2013-03-20 15:36:16 +01:00
check ( " ::y(){x} " ) ;
2011-08-11 23:57:54 +02:00
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
}
2014-11-20 14:20:09 +01:00
void symboldatabase20 ( ) {
2011-08-17 01:16:58 +02:00
// ticket #3013 - segmentation fault
2014-03-27 19:06:13 +01:00
ASSERT_THROW ( check ( " struct x : virtual y \n " ) , InternalError ) ;
2011-08-17 01:16:58 +02:00
}
2014-11-20 14:20:09 +01:00
void symboldatabase21 ( ) {
2011-09-29 04:05:26 +02:00
check ( " class Fred { \n "
" class Foo { }; \n "
" void func() const; \n "
" }; \n "
" Fred::func() const { \n "
" Foo foo; \n "
2013-03-20 15:36:16 +01:00
" } " ) ;
2011-09-29 04:05:26 +02:00
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
}
2015-10-08 12:53:56 +02:00
// ticket 3437 (segmentation fault)
2014-11-20 14:20:09 +01:00
void symboldatabase22 ( ) {
2011-12-22 09:20:37 +01:00
check ( " template <class C> struct A {}; \n "
" A<int> a; \n " ) ;
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
}
2015-10-08 12:53:56 +02:00
// ticket 3435 (std::vector)
2014-11-20 14:20:09 +01:00
void symboldatabase23 ( ) {
2013-03-20 15:36:16 +01:00
GET_SYMBOL_DB ( " class A { std::vector<int*> ints; }; " ) ;
2011-12-25 11:05:06 +01:00
ASSERT_EQUALS ( 2U , db - > scopeList . size ( ) ) ;
const Scope & scope = db - > scopeList . back ( ) ;
ASSERT_EQUALS ( 1U , scope . varlist . size ( ) ) ;
const Variable & var = scope . varlist . front ( ) ;
ASSERT_EQUALS ( std : : string ( " ints " ) , var . name ( ) ) ;
ASSERT_EQUALS ( true , var . isClass ( ) ) ;
}
2015-10-08 12:53:56 +02:00
// ticket 3508 (constructor, destructor)
2014-11-20 14:20:09 +01:00
void symboldatabase24 ( ) {
2012-01-22 19:34:53 +01:00
GET_SYMBOL_DB ( " struct Fred { \n "
" ~Fred(); \n "
" Fred(); \n "
" }; \n "
" Fred::Fred() { } \n "
" Fred::~Fred() { } " ) ;
// Global scope, Fred, Fred::Fred, Fred::~Fred
ASSERT_EQUALS ( 4U , db - > scopeList . size ( ) ) ;
// Find the scope for the Fred struct..
2014-02-16 10:32:10 +01:00
const Scope * fredScope = nullptr ;
2012-01-22 19:34:53 +01:00
for ( std : : list < Scope > : : const_iterator scope = db - > scopeList . begin ( ) ; scope ! = db - > scopeList . end ( ) ; + + scope ) {
if ( scope - > isClassOrStruct ( ) & & scope - > className = = " Fred " )
fredScope = & ( * scope ) ;
}
2014-02-16 10:32:10 +01:00
ASSERT ( fredScope ! = nullptr ) ;
if ( fredScope = = nullptr )
2012-01-22 19:34:53 +01:00
return ;
// The struct Fred has two functions, a constructor and a destructor
ASSERT_EQUALS ( 2U , fredScope - > functionList . size ( ) ) ;
// Get linenumbers where the bodies for the constructor and destructor are..
unsigned int constructor = 0 ;
unsigned int destructor = 0 ;
for ( std : : list < Function > : : const_iterator it = fredScope - > functionList . begin ( ) ; it ! = fredScope - > functionList . end ( ) ; + + it ) {
if ( it - > type = = Function : : eConstructor )
constructor = it - > token - > linenr ( ) ; // line number for constructor body
if ( it - > type = = Function : : eDestructor )
destructor = it - > token - > linenr ( ) ; // line number for destructor body
}
// The body for the constructor is located at line 5..
ASSERT_EQUALS ( 5U , constructor ) ;
// The body for the destructor is located at line 6..
ASSERT_EQUALS ( 6U , destructor ) ;
}
2015-10-08 12:53:56 +02:00
// ticket #3561 (throw C++)
2014-11-20 14:20:09 +01:00
void symboldatabase25 ( ) {
2014-04-02 13:56:34 +02:00
const char str [ ] = " int main() { \n "
" foo bar; \n "
" throw bar; \n "
" } " ;
GET_SYMBOL_DB ( str ) ;
2012-01-28 01:24:01 +01:00
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
ASSERT ( db & & db - > getVariableListSize ( ) = = 2 ) ; // index 0 + 1 variable
}
2015-10-08 12:53:56 +02:00
// ticket #3561 (throw C)
2014-11-20 14:20:09 +01:00
void symboldatabase26 ( ) {
2014-04-02 13:56:34 +02:00
const char str [ ] = " int main() { \n "
" throw bar; \n "
" } " ;
GET_SYMBOL_DB_C ( str ) ;
2012-01-28 01:24:01 +01:00
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
ASSERT ( db & & db - > getVariableListSize ( ) = = 2 ) ; // index 0 + 1 variable
}
2011-12-25 11:05:06 +01:00
2015-10-08 12:53:56 +02:00
// ticket #3543 (segmentation fault)
2014-11-20 14:20:09 +01:00
void symboldatabase27 ( ) {
2012-01-31 19:34:55 +01:00
check ( " class C : public B1 \n "
" { \n "
" B1() \n "
" {} C(int) : B1() class \n "
2013-03-20 15:36:16 +01:00
" }; " ) ;
2012-01-31 19:34:55 +01:00
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
}
2014-11-20 14:20:09 +01:00
void symboldatabase28 ( ) {
2012-04-27 21:51:13 +02:00
GET_SYMBOL_DB ( " struct S {}; \n "
" void foo(struct S s) {} " ) ;
2013-03-05 13:33:38 +01:00
ASSERT ( db & & db - > getVariableFromVarId ( 1 ) & & db - > getVariableFromVarId ( 1 ) - > typeScope ( ) & & db - > getVariableFromVarId ( 1 ) - > typeScope ( ) - > className = = " S " ) ;
2012-04-27 21:51:13 +02:00
}
2015-10-08 12:53:56 +02:00
// ticket #4442 (segmentation fault)
2014-11-20 14:20:09 +01:00
void symboldatabase29 ( ) {
2012-12-28 08:36:20 +01:00
check ( " struct B : A { \n "
" B() : A {} \n "
" }; " ) ;
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
}
2014-11-20 14:20:09 +01:00
void symboldatabase30 ( ) {
2013-01-27 02:46:00 +01:00
GET_SYMBOL_DB ( " struct A { void foo(const int a); }; \n "
" void A::foo(int a) { } " ) ;
ASSERT ( db & & db - > functionScopes . size ( ) = = 1 & & db - > functionScopes [ 0 ] - > functionOf ) ;
}
2014-11-20 14:20:09 +01:00
void symboldatabase31 ( ) {
2013-03-05 13:33:38 +01:00
GET_SYMBOL_DB ( " class Foo; \n "
" class Bar; \n "
" class Sub; \n "
" class Foo { class Sub; }; \n "
" class Bar { class Sub; }; \n "
" class Bar::Sub { \n "
" int b; \n "
" public: \n "
" Sub() { } \n "
" Sub(int); \n "
" }; \n "
" Bar::Sub::Sub(int) { }; \n "
" class ::Foo::Sub { \n "
" int f; \n "
" public: \n "
" ~Sub(); \n "
" Sub(); \n "
" }; \n "
" ::Foo::Sub::~Sub() { } \n "
" ::Foo::Sub::Sub() { } \n "
" class Foo; \n "
" class Bar; \n "
" class Sub; \n " ) ;
ASSERT ( db & & db - > typeList . size ( ) = = 5 ) ;
if ( ! db | | db - > typeList . size ( ) < 5 )
return ;
std : : list < Type > : : const_iterator i = db - > typeList . begin ( ) ;
const Type * Foo = & ( * i + + ) ;
const Type * Bar = & ( * i + + ) ;
const Type * Sub = & ( * i + + ) ;
const Type * Foo_Sub = & ( * i + + ) ;
const Type * Bar_Sub = & ( * i ) ;
ASSERT ( Foo & & Foo - > classDef & & Foo - > classScope & & Foo - > enclosingScope & & Foo - > name ( ) = = " Foo " ) ;
ASSERT ( Bar & & Bar - > classDef & & Bar - > classScope & & Bar - > enclosingScope & & Bar - > name ( ) = = " Bar " ) ;
ASSERT ( Sub & & Sub - > classDef & & ! Sub - > classScope & & Sub - > enclosingScope & & Sub - > name ( ) = = " Sub " ) ;
ASSERT ( Foo_Sub & & Foo_Sub - > classDef & & Foo_Sub - > classScope & & Foo_Sub - > enclosingScope = = Foo - > classScope & & Foo_Sub - > name ( ) = = " Sub " ) ;
ASSERT ( Bar_Sub & & Bar_Sub - > classDef & & Bar_Sub - > classScope & & Bar_Sub - > enclosingScope = = Bar - > classScope & & Bar_Sub - > name ( ) = = " Sub " ) ;
ASSERT ( Foo_Sub & & Foo_Sub - > classScope & & Foo_Sub - > classScope - > numConstructors = = 1 & & Foo_Sub - > classScope - > className = = " Sub " ) ;
ASSERT ( Bar_Sub & & Bar_Sub - > classScope & & Bar_Sub - > classScope - > numConstructors = = 2 & & Bar_Sub - > classScope - > className = = " Sub " ) ;
}
2014-11-20 14:20:09 +01:00
void symboldatabase32 ( ) {
2013-03-14 17:00:22 +01:00
GET_SYMBOL_DB ( " struct Base { \n "
" void foo() {} \n "
" }; \n "
" class Deri : Base { \n "
" }; " ) ;
ASSERT ( db & & db - > findScopeByName ( " Deri " ) & & db - > findScopeByName ( " Deri " ) - > definedType - > getFunction ( " foo " ) ) ;
}
2014-11-20 14:20:09 +01:00
void symboldatabase33 ( ) { // ticket #4682
2013-03-28 06:36:49 +01:00
GET_SYMBOL_DB ( " static struct A::B s; \n "
" static struct A::B t = { 0 }; \n "
" static struct A::B u(0); \n "
" static struct A::B v{0}; \n "
" static struct A::B w({0}); \n "
" void foo() { } " ) ;
ASSERT ( db & & db - > functionScopes . size ( ) = = 1 ) ;
}
2014-11-20 14:20:09 +01:00
void symboldatabase34 ( ) { // ticket #4694
2013-05-30 15:13:09 +02:00
check ( " typedef _Atomic(int(A::*)) atomic_mem_ptr_to_int; \n "
2013-06-09 16:04:59 +02:00
" typedef _Atomic(int)&atomic_int_ref; \n "
" struct S { \n "
" _Atomic union { int n; }; \n "
" }; " ) ;
2013-05-30 15:13:09 +02:00
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
}
2014-11-20 14:20:09 +01:00
void symboldatabase35 ( ) { // ticket #4806 and #4841
2013-06-16 21:46:01 +02:00
check ( " class FragmentQueue : public CL_NS(util)::PriorityQueue<CL_NS(util)::Deletor::Object<TextFragment> > \n "
" {}; " ) ;
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
}
2014-11-20 14:20:09 +01:00
void symboldatabase36 ( ) { // ticket #4892
2015-05-26 00:28:08 +02:00
check ( " void struct ( ) { if ( 1 ) } int main ( ) { } " ) ;
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
2013-07-08 11:45:26 +02:00
}
2014-11-20 14:20:09 +01:00
void symboldatabase37 ( ) {
2013-08-12 06:21:03 +02:00
GET_SYMBOL_DB ( " class Fred { \n "
" public: \n "
2013-08-16 05:42:12 +02:00
" struct Wilma { }; \n "
2013-08-12 06:21:03 +02:00
" struct Barney { \n "
" bool operator == (const struct Barney & b) const { return true; } \n "
2013-08-16 05:42:12 +02:00
" bool operator == (const struct Wilma & w) const { return true; } \n "
2013-08-12 06:21:03 +02:00
" }; \n "
" Fred(const struct Barney & b) { barney = b; } \n "
" private: \n "
" struct Barney barney; \n "
" }; \n " ) ;
2013-08-16 05:42:12 +02:00
ASSERT ( db & & db - > typeList . size ( ) = = 3 ) ;
if ( ! db | | db - > typeList . size ( ) ! = 3 )
2013-08-12 06:21:03 +02:00
return ;
std : : list < Type > : : const_iterator i = db - > typeList . begin ( ) ;
const Type * Fred = & ( * i + + ) ;
2013-08-16 05:42:12 +02:00
const Type * Wilma = & ( * i + + ) ;
2013-08-12 06:21:03 +02:00
const Type * Barney = & ( * i + + ) ;
ASSERT ( Fred & & Fred - > classDef & & Fred - > classScope & & Fred - > enclosingScope & & Fred - > name ( ) = = " Fred " ) ;
2013-08-16 05:42:12 +02:00
ASSERT ( Wilma & & Wilma - > classDef & & Wilma - > classScope & & Wilma - > enclosingScope & & Wilma - > name ( ) = = " Wilma " ) ;
2013-08-12 06:21:03 +02:00
ASSERT ( Barney & & Barney - > classDef & & Barney - > classScope & & Barney - > enclosingScope & & Barney - > name ( ) = = " Barney " ) ;
2014-01-17 18:10:10 +01:00
ASSERT ( db - > getVariableListSize ( ) = = 5 ) ;
if ( db - > getVariableListSize ( ) ! = 5 )
2013-08-12 06:21:03 +02:00
return ;
2014-01-17 18:10:10 +01:00
ASSERT ( db - > getVariableFromVarId ( 1 ) & & db - > getVariableFromVarId ( 1 ) - > type ( ) & & db - > getVariableFromVarId ( 1 ) - > type ( ) - > name ( ) = = " Barney " ) ;
ASSERT ( db - > getVariableFromVarId ( 2 ) & & db - > getVariableFromVarId ( 2 ) - > type ( ) & & db - > getVariableFromVarId ( 2 ) - > type ( ) - > name ( ) = = " Wilma " ) ;
ASSERT ( db - > getVariableFromVarId ( 3 ) & & db - > getVariableFromVarId ( 3 ) - > type ( ) & & db - > getVariableFromVarId ( 3 ) - > type ( ) - > name ( ) = = " Barney " ) ;
2013-08-12 06:21:03 +02:00
}
2014-11-20 14:20:09 +01:00
void symboldatabase38 ( ) { // ticket #5125
2013-10-29 21:41:47 +01:00
check ( " template <typename T = class service> struct scoped_service; \n "
" struct service {}; \n "
" template <> struct scoped_service<service> {}; \n "
" template <typename T> \n "
" struct scoped_service : scoped_service<service> \n "
" { \n "
" scoped_service( T* ptr ) : scoped_service<service>(ptr), m_ptr(ptr) {} \n "
" T* const m_ptr; \n "
" }; " ) ;
}
2014-11-20 14:20:09 +01:00
void symboldatabase39 ( ) { // ticket #5120
2013-10-30 10:15:03 +01:00
check ( " struct V : { public case {} ; struct U : U void { V *f (int x) (x) } } " ) ;
}
2014-11-20 14:20:09 +01:00
void symboldatabase40 ( ) { // ticket #5153
2013-11-08 12:56:32 +01:00
check ( " void f() { \n "
" try { } \n "
" catch (std::bad_alloc) { } \n "
" } \n " ) ;
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
}
2014-11-20 14:20:09 +01:00
void symboldatabase41 ( ) { // ticket #5197 (unknown macro)
2013-11-25 03:43:39 +01:00
GET_SYMBOL_DB ( " struct X1 { MACRO1 f(int spd) MACRO2; }; \n " ) ;
2015-01-08 05:45:31 +01:00
ASSERT ( db & & db - > findScopeByName ( " X1 " ) & & db - > findScopeByName ( " X1 " ) - > functionList . size ( ) = = 1 & & ! db - > findScopeByName ( " X1 " ) - > functionList . front ( ) . hasBody ( ) ) ;
2013-11-25 03:43:39 +01:00
}
2014-11-20 14:20:09 +01:00
void symboldatabase42 ( ) { // only put variables in variable list
2013-12-31 17:51:56 +01:00
GET_SYMBOL_DB ( " void f() { extern int x(); } \n " ) ;
2014-01-08 12:26:48 +01:00
ASSERT ( ! ! db ) ;
2014-02-16 10:32:10 +01:00
const Scope * const fscope = db ? db - > findScopeByName ( " f " ) : nullptr ;
2014-01-08 12:26:48 +01:00
ASSERT ( ! ! fscope ) ;
2013-12-31 17:51:56 +01:00
ASSERT_EQUALS ( 0U , fscope ? fscope - > varlist . size ( ) : ~ 0U ) ; // "x" is not a variable
}
2014-11-20 14:20:09 +01:00
void symboldatabase43 ( ) { // ticket #4738
2014-05-25 12:19:19 +02:00
check ( " void f() { \n "
" new int; \n "
" } \n " ) ;
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
}
2014-11-20 14:20:09 +01:00
void symboldatabase44 ( ) {
2014-08-05 15:33:57 +02:00
GET_SYMBOL_DB ( " int i { 1 }; \n "
" int j ( i ); \n "
" void foo() { \n "
" int k { 1 }; \n "
" int l ( 1 ); \n "
" } " ) ;
ASSERT ( db ! = nullptr ) ;
ASSERT_EQUALS ( 4U , db - > getVariableListSize ( ) - 1 ) ;
ASSERT_EQUALS ( 2U , db - > scopeList . size ( ) ) ;
for ( std : : size_t i = 1U ; i < db - > getVariableListSize ( ) ; i + + )
ASSERT ( db - > getVariableFromVarId ( i ) ! = nullptr ) ;
}
2014-11-20 14:20:09 +01:00
void symboldatabase45 ( ) {
2014-09-03 11:15:05 +02:00
GET_SYMBOL_DB ( " typedef struct { \n "
" unsigned long bits; \n "
" } S; \n "
" struct T { \n "
" S span; \n "
" int flags; \n "
" }; \n "
" struct T f(int x) { \n "
" return (struct T) { \n "
" .span = (S) { 0UL }, \n "
" .flags = (x ? 256 : 0), \n "
" }; \n "
" } " ) ;
ASSERT ( db ! = nullptr ) ;
ASSERT_EQUALS ( 4U , db - > getVariableListSize ( ) - 1 ) ;
for ( std : : size_t i = 1U ; i < db - > getVariableListSize ( ) ; i + + )
ASSERT ( db - > getVariableFromVarId ( i ) ! = nullptr ) ;
ASSERT_EQUALS ( 4U , db - > scopeList . size ( ) ) ;
std : : list < Scope > : : const_iterator scope = db - > scopeList . begin ( ) ;
ASSERT_EQUALS ( Scope : : eGlobal , scope - > type ) ;
+ + scope ;
ASSERT_EQUALS ( Scope : : eStruct , scope - > type ) ;
+ + scope ;
ASSERT_EQUALS ( Scope : : eStruct , scope - > type ) ;
+ + scope ;
ASSERT_EQUALS ( Scope : : eFunction , scope - > type ) ;
}
2014-11-20 14:20:09 +01:00
void symboldatabase46 ( ) { // #6171 (anonymous namespace)
2014-10-15 21:41:15 +02:00
GET_SYMBOL_DB ( " struct S { }; \n "
" namespace { \n "
" struct S { }; \n "
" } " ) ;
ASSERT ( db ! = nullptr ) ;
ASSERT_EQUALS ( 4U , db - > scopeList . size ( ) ) ;
std : : list < Scope > : : const_iterator scope = db - > scopeList . begin ( ) ;
ASSERT_EQUALS ( Scope : : eGlobal , scope - > type ) ;
+ + scope ;
ASSERT_EQUALS ( Scope : : eStruct , scope - > type ) ;
ASSERT_EQUALS ( scope - > className , " S " ) ;
+ + scope ;
ASSERT_EQUALS ( Scope : : eNamespace , scope - > type ) ;
ASSERT_EQUALS ( scope - > className , " " ) ;
+ + scope ;
ASSERT_EQUALS ( Scope : : eStruct , scope - > type ) ;
ASSERT_EQUALS ( scope - > className , " S " ) ;
}
2014-12-09 21:36:09 +01:00
void symboldatabase47 ( ) { // #6308 - associate Function and Scope for destructors
GET_SYMBOL_DB ( " namespace NS { \n "
" class MyClass { \n "
" ~MyClass(); \n "
" }; \n "
" } \n "
" using namespace NS; \n "
" MyClass::~MyClass() { \n "
" delete Example; \n "
" } " ) ;
ASSERT ( db & & ! db - > functionScopes . empty ( ) & & db - > functionScopes . front ( ) - > function & & db - > functionScopes . front ( ) - > function - > functionScope = = db - > functionScopes . front ( ) ) ;
}
2015-01-12 06:11:22 +01:00
void symboldatabase48 ( ) { // #6417
GET_SYMBOL_DB ( " namespace NS { \n "
" class MyClass { \n "
" MyClass(); \n "
" ~MyClass(); \n "
" }; \n "
" } \n "
" using namespace NS; \n "
" MyClass::~MyClass() { } \n "
" MyClass::MyClass() { } \n " ) ;
ASSERT ( db & & ! db - > functionScopes . empty ( ) & & db - > functionScopes . front ( ) - > function & & db - > functionScopes . front ( ) - > function - > functionScope = = db - > functionScopes . front ( ) ) ;
const Token * f = Token : : findsimplematch ( tokenizer . tokens ( ) , " MyClass ( ) ; " ) ;
ASSERT_EQUALS ( true , db & & f & & f - > function ( ) & & f - > function ( ) - > tokenDef - > linenr ( ) = = 3 & & f - > function ( ) - > token - > linenr ( ) = = 9 ) ;
f = Token : : findsimplematch ( tokenizer . tokens ( ) , " ~ MyClass ( ) ; " ) ;
f = f - > next ( ) ;
ASSERT_EQUALS ( true , db & & f & & f - > function ( ) & & f - > function ( ) - > tokenDef - > linenr ( ) = = 4 & & f - > function ( ) - > token - > linenr ( ) = = 8 ) ;
}
2015-01-19 06:38:54 +01:00
void symboldatabase49 ( ) { // #6424
GET_SYMBOL_DB ( " namespace Ns { class C; } \n "
" void f1() { char *p; *p = 0; } \n "
" class Ns::C* p; \n "
" void f2() { char *p; *p = 0; } \n " ) ;
ASSERT ( db ! = nullptr ) ;
const Token * f = Token : : findsimplematch ( tokenizer . tokens ( ) , " p ; void f2 " ) ;
ASSERT_EQUALS ( true , db & & f & & f - > variable ( ) ) ;
f = Token : : findsimplematch ( tokenizer . tokens ( ) , " f2 " ) ;
ASSERT_EQUALS ( true , db & & f & & f - > function ( ) ) ;
}
2015-01-19 16:15:11 +01:00
void symboldatabase50 ( ) { // #6432
GET_SYMBOL_DB ( " template <bool del, class T> \n "
" class _ConstTessMemberResultCallback_0_0<del, void, T> \n "
" { \n "
" public: \n "
" typedef void (T::*MemberSignature)() const; \n "
" \n "
" private: \n "
" const T* object_; \n "
" MemberSignature member_; \n "
" \n "
" public: \n "
" inline _ConstTessMemberResultCallback_0_0( \n "
" const T* object, MemberSignature member) \n "
" : object_(object), \n "
" member_(member) { \n "
" } \n "
" }; " ) ;
ASSERT ( db ! = nullptr ) ;
const Token * f = Token : : findsimplematch ( tokenizer . tokens ( ) , " _ConstTessMemberResultCallback_0_0 ( " ) ;
ASSERT_EQUALS ( true , db & & f & & f - > function ( ) & & f - > function ( ) - > isConstructor ( ) ) ;
}
2015-02-24 06:11:31 +01:00
void symboldatabase51 ( ) { // #6538
GET_SYMBOL_DB ( " static const float f1 = 2 * foo1(a, b); \n "
" static const float f2 = 2 * ::foo2(a, b); \n "
" static const float f3 = 2 * std::foo3(a, b); \n "
" static const float f4 = c * foo4(a, b); \n "
" static const int i1 = 2 & foo5(a, b); \n "
" static const bool b1 = 2 > foo6(a, b); \n " ) ;
ASSERT ( db ! = nullptr ) ;
if ( db ) {
ASSERT ( findFunctionByName ( " foo1 " , & db - > scopeList . front ( ) ) = = nullptr ) ;
ASSERT ( findFunctionByName ( " foo2 " , & db - > scopeList . front ( ) ) = = nullptr ) ;
ASSERT ( findFunctionByName ( " foo3 " , & db - > scopeList . front ( ) ) = = nullptr ) ;
ASSERT ( findFunctionByName ( " foo4 " , & db - > scopeList . front ( ) ) = = nullptr ) ;
ASSERT ( findFunctionByName ( " foo5 " , & db - > scopeList . front ( ) ) = = nullptr ) ;
ASSERT ( findFunctionByName ( " foo6 " , & db - > scopeList . front ( ) ) = = nullptr ) ;
}
}
2015-11-06 10:16:44 +01:00
void symboldatabase52 ( ) { // #6581
GET_SYMBOL_DB ( " void foo() { \n "
" int i = 0; \n "
" S s{ { i }, 0 }; \n "
" } " ) ;
ASSERT ( db ! = nullptr ) ;
if ( db ) {
ASSERT_EQUALS ( 2 , db - > scopeList . size ( ) ) ;
ASSERT_EQUALS ( 2 , db - > getVariableListSize ( ) - 1 ) ;
2015-11-28 10:49:08 +01:00
ASSERT ( db - > getVariableFromVarId ( 1 ) ! = nullptr ) ;
ASSERT ( db - > getVariableFromVarId ( 2 ) ! = nullptr ) ;
2015-11-06 10:16:44 +01:00
}
}
2015-11-15 17:51:27 +01:00
void symboldatabase53 ( ) { // #7124
GET_SYMBOL_DB ( " int32_t x; "
" std::int32_t y; " ) ;
ASSERT ( db ! = nullptr ) ;
if ( db ) {
2015-11-28 10:49:08 +01:00
ASSERT ( db - > getVariableFromVarId ( 1 ) ! = nullptr ) ;
ASSERT ( db - > getVariableFromVarId ( 2 ) ! = nullptr ) ;
2015-11-15 17:51:27 +01:00
ASSERT_EQUALS ( false , db - > getVariableFromVarId ( 1 ) - > isClass ( ) ) ;
ASSERT_EQUALS ( false , db - > getVariableFromVarId ( 2 ) - > isClass ( ) ) ;
}
}
2016-01-22 19:22:24 +01:00
void symboldatabase54 ( ) { // #7343
GET_SYMBOL_DB ( " class A { \n "
" void getReg() const override { \n "
" assert(Kind == k_ShiftExtend); \n "
" } \n "
" }; " ) ;
ASSERT ( db ! = nullptr ) ;
if ( db ) {
ASSERT_EQUALS ( 1U , db - > functionScopes . size ( ) ) ;
ASSERT_EQUALS ( " getReg " , db - > functionScopes . front ( ) - > className ) ;
}
}
2016-05-09 18:34:24 +02:00
void enum1 ( ) {
GET_SYMBOL_DB ( " enum BOOL { FALSE, TRUE }; enum BOOL b; " ) ;
/* there is a enum scope with the name BOOL */
ASSERT ( db & & db - > scopeList . back ( ) . type = = Scope : : eEnum & & db - > scopeList . back ( ) . className = = " BOOL " ) ;
/* b is a enum variable, type is BOOL */
ASSERT ( db & & db - > getVariableFromVarId ( 1 ) - > isEnumType ( ) ) ;
}
void enum2 ( ) {
GET_SYMBOL_DB ( " enum BOOL { FALSE, TRUE } b; " ) ;
/* there is a enum scope with the name BOOL */
ASSERT ( db & & db - > scopeList . back ( ) . type = = Scope : : eEnum & & db - > scopeList . back ( ) . className = = " BOOL " ) ;
/* b is a enum variable, type is BOOL */
ASSERT ( db & & db - > getVariableFromVarId ( 1 ) - > isEnumType ( ) ) ;
}
void enum3 ( ) {
GET_SYMBOL_DB ( " enum ABC { A=11,B,C=A+B }; " ) ;
ASSERT ( db & & db - > scopeList . back ( ) . type = = Scope : : eEnum ) ;
if ( db ) {
/* There is an enum A with value 11 */
const Enumerator * A = db - > scopeList . back ( ) . findEnumerator ( " A " ) ;
ASSERT ( A & & A - > value = = 11 & & A - > value_known ) ;
/* There is an enum B with value 12 */
const Enumerator * B = db - > scopeList . back ( ) . findEnumerator ( " B " ) ;
ASSERT ( B & & B - > value = = 12 & & B - > value_known ) ;
/* There is an enum C with value 23 */
const Enumerator * C = db - > scopeList . back ( ) . findEnumerator ( " C " ) ;
ASSERT ( C & & C - > value = = 23 & & C - > value_known ) ;
}
}
2016-05-12 12:06:14 +02:00
void enum4 ( ) { // #7493
2016-05-29 14:45:45 +02:00
GET_SYMBOL_DB ( " enum Offsets { O1, O2, O3=5, O4 }; \n "
" enum MyEnums { E1=O1+1, E2, E3=O3+1 }; " ) ;
2016-05-25 15:30:49 +02:00
ASSERT ( db ! = nullptr ) ;
2016-05-12 12:06:14 +02:00
if ( ! db )
return ;
ASSERT_EQUALS ( 3U , db - > scopeList . size ( ) ) ;
// Assert that all enum values are known
std : : list < Scope > : : const_iterator scope = db - > scopeList . begin ( ) ;
// Offsets
+ + scope ;
ASSERT_EQUALS ( ( unsigned int ) Scope : : eEnum , ( unsigned int ) scope - > type ) ;
2016-05-29 14:45:45 +02:00
ASSERT_EQUALS ( 4U , scope - > enumeratorList . size ( ) ) ;
ASSERT ( scope - > enumeratorList [ 0 ] . name - > enumerator ( ) = = & scope - > enumeratorList [ 0 ] ) ;
ASSERT_EQUALS ( ( unsigned int ) Token : : eEnumerator , ( unsigned int ) scope - > enumeratorList [ 0 ] . name - > tokType ( ) ) ;
ASSERT ( scope - > enumeratorList [ 0 ] . scope = = & * scope ) ;
ASSERT_EQUALS ( " O1 " , scope - > enumeratorList [ 0 ] . name - > str ( ) ) ;
ASSERT ( scope - > enumeratorList [ 0 ] . start = = nullptr ) ;
ASSERT ( scope - > enumeratorList [ 0 ] . end = = nullptr ) ;
2016-05-12 12:06:14 +02:00
ASSERT_EQUALS ( true , scope - > enumeratorList [ 0 ] . value_known ) ;
2016-05-29 14:45:45 +02:00
ASSERT_EQUALS ( 0 , scope - > enumeratorList [ 0 ] . value ) ;
ASSERT ( scope - > enumeratorList [ 1 ] . name - > enumerator ( ) = = & scope - > enumeratorList [ 1 ] ) ;
ASSERT_EQUALS ( ( unsigned int ) Token : : eEnumerator , ( unsigned int ) scope - > enumeratorList [ 1 ] . name - > tokType ( ) ) ;
ASSERT ( scope - > enumeratorList [ 1 ] . scope = = & * scope ) ;
ASSERT_EQUALS ( " O2 " , scope - > enumeratorList [ 1 ] . name - > str ( ) ) ;
ASSERT ( scope - > enumeratorList [ 1 ] . start = = nullptr ) ;
ASSERT ( scope - > enumeratorList [ 1 ] . end = = nullptr ) ;
2016-05-12 12:06:14 +02:00
ASSERT_EQUALS ( true , scope - > enumeratorList [ 1 ] . value_known ) ;
2016-05-29 14:45:45 +02:00
ASSERT_EQUALS ( 1 , scope - > enumeratorList [ 1 ] . value ) ;
ASSERT ( scope - > enumeratorList [ 2 ] . name - > enumerator ( ) = = & scope - > enumeratorList [ 2 ] ) ;
ASSERT_EQUALS ( ( unsigned int ) Token : : eEnumerator , ( unsigned int ) scope - > enumeratorList [ 2 ] . name - > tokType ( ) ) ;
ASSERT ( scope - > enumeratorList [ 2 ] . scope = = & * scope ) ;
ASSERT_EQUALS ( " O3 " , scope - > enumeratorList [ 2 ] . name - > str ( ) ) ;
ASSERT ( scope - > enumeratorList [ 2 ] . start ! = nullptr ) ;
ASSERT ( scope - > enumeratorList [ 2 ] . end ! = nullptr ) ;
2016-05-12 12:06:14 +02:00
ASSERT_EQUALS ( true , scope - > enumeratorList [ 2 ] . value_known ) ;
2016-05-29 14:45:45 +02:00
ASSERT_EQUALS ( 5 , scope - > enumeratorList [ 2 ] . value ) ;
ASSERT ( scope - > enumeratorList [ 3 ] . name - > enumerator ( ) = = & scope - > enumeratorList [ 3 ] ) ;
ASSERT_EQUALS ( ( unsigned int ) Token : : eEnumerator , ( unsigned int ) scope - > enumeratorList [ 3 ] . name - > tokType ( ) ) ;
ASSERT ( scope - > enumeratorList [ 3 ] . scope = = & * scope ) ;
ASSERT_EQUALS ( " O4 " , scope - > enumeratorList [ 3 ] . name - > str ( ) ) ;
ASSERT ( scope - > enumeratorList [ 3 ] . start = = nullptr ) ;
ASSERT ( scope - > enumeratorList [ 3 ] . end = = nullptr ) ;
ASSERT_EQUALS ( true , scope - > enumeratorList [ 3 ] . value_known ) ;
ASSERT_EQUALS ( 6 , scope - > enumeratorList [ 3 ] . value ) ;
2016-05-12 12:06:14 +02:00
// MyEnums
+ + scope ;
ASSERT_EQUALS ( ( unsigned int ) Scope : : eEnum , ( unsigned int ) scope - > type ) ;
ASSERT_EQUALS ( 3U , scope - > enumeratorList . size ( ) ) ;
2016-05-29 14:45:45 +02:00
ASSERT ( scope - > enumeratorList [ 0 ] . name - > enumerator ( ) = = & scope - > enumeratorList [ 0 ] ) ;
ASSERT_EQUALS ( ( unsigned int ) Token : : eEnumerator , ( unsigned int ) scope - > enumeratorList [ 0 ] . name - > tokType ( ) ) ;
ASSERT ( scope - > enumeratorList [ 0 ] . scope = = & * scope ) ;
ASSERT_EQUALS ( " E1 " , scope - > enumeratorList [ 0 ] . name - > str ( ) ) ;
ASSERT ( scope - > enumeratorList [ 0 ] . start ! = nullptr ) ;
ASSERT ( scope - > enumeratorList [ 0 ] . end ! = nullptr ) ;
ASSERT_EQUALS ( true , scope - > enumeratorList [ 0 ] . value_known ) ;
ASSERT_EQUALS ( 1 , scope - > enumeratorList [ 0 ] . value ) ;
ASSERT ( scope - > enumeratorList [ 1 ] . name - > enumerator ( ) = = & scope - > enumeratorList [ 1 ] ) ;
ASSERT_EQUALS ( ( unsigned int ) Token : : eEnumerator , ( unsigned int ) scope - > enumeratorList [ 1 ] . name - > tokType ( ) ) ;
ASSERT ( scope - > enumeratorList [ 1 ] . scope = = & * scope ) ;
ASSERT_EQUALS ( " E2 " , scope - > enumeratorList [ 1 ] . name - > str ( ) ) ;
ASSERT ( scope - > enumeratorList [ 1 ] . start = = nullptr ) ;
ASSERT ( scope - > enumeratorList [ 1 ] . end = = nullptr ) ;
ASSERT_EQUALS ( true , scope - > enumeratorList [ 1 ] . value_known ) ;
ASSERT_EQUALS ( 2 , scope - > enumeratorList [ 1 ] . value ) ;
ASSERT ( scope - > enumeratorList [ 2 ] . name - > enumerator ( ) = = & scope - > enumeratorList [ 2 ] ) ;
ASSERT_EQUALS ( ( unsigned int ) Token : : eEnumerator , ( unsigned int ) scope - > enumeratorList [ 2 ] . name - > tokType ( ) ) ;
ASSERT ( scope - > enumeratorList [ 2 ] . scope = = & * scope ) ;
ASSERT_EQUALS ( " E3 " , scope - > enumeratorList [ 2 ] . name - > str ( ) ) ;
ASSERT ( scope - > enumeratorList [ 2 ] . start ! = nullptr ) ;
ASSERT ( scope - > enumeratorList [ 2 ] . end ! = nullptr ) ;
ASSERT_EQUALS ( true , scope - > enumeratorList [ 2 ] . value_known ) ;
ASSERT_EQUALS ( 6 , scope - > enumeratorList [ 2 ] . value ) ;
2016-05-12 12:06:14 +02:00
}
2016-05-26 11:25:50 +02:00
void enum5 ( ) {
GET_SYMBOL_DB ( " enum { A = 10, B = 2 }; \n "
" int a[10 + 2]; \n "
" int b[A]; \n "
" int c[A + 2]; \n "
" int d[10 + B]; \n "
" int e[A + B]; \n " ) ;
ASSERT ( db ) ;
if ( ! db )
return ;
ASSERT_EQUALS ( 2U , db - > scopeList . size ( ) ) ;
// Assert that all enum values are known
std : : list < Scope > : : const_iterator scope = db - > scopeList . begin ( ) ;
+ + scope ;
ASSERT_EQUALS ( ( unsigned int ) Scope : : eEnum , ( unsigned int ) scope - > type ) ;
ASSERT_EQUALS ( 2U , scope - > enumeratorList . size ( ) ) ;
ASSERT_EQUALS ( true , scope - > enumeratorList [ 0 ] . value_known ) ;
ASSERT_EQUALS ( 10 , scope - > enumeratorList [ 0 ] . value ) ;
ASSERT_EQUALS ( true , scope - > enumeratorList [ 1 ] . value_known ) ;
ASSERT_EQUALS ( 2 , scope - > enumeratorList [ 1 ] . value ) ;
ASSERT ( db - > getVariableListSize ( ) = = 6 ) ; // the first one is not used
const Variable * v = db - > getVariableFromVarId ( 1 ) ;
ASSERT ( v ! = nullptr ) ;
if ( ! v )
return ;
ASSERT ( v - > isArray ( ) ) ;
ASSERT_EQUALS ( 1U , v - > dimensions ( ) . size ( ) ) ;
ASSERT_EQUALS ( 12U , v - > dimension ( 0 ) ) ;
v = db - > getVariableFromVarId ( 2 ) ;
ASSERT ( v ! = nullptr ) ;
if ( ! v )
return ;
ASSERT ( v - > isArray ( ) ) ;
ASSERT_EQUALS ( 1U , v - > dimensions ( ) . size ( ) ) ;
ASSERT_EQUALS ( 10U , v - > dimension ( 0 ) ) ;
v = db - > getVariableFromVarId ( 3 ) ;
ASSERT ( v ! = nullptr ) ;
if ( ! v )
return ;
ASSERT ( v - > isArray ( ) ) ;
ASSERT_EQUALS ( 1U , v - > dimensions ( ) . size ( ) ) ;
ASSERT_EQUALS ( 12U , v - > dimension ( 0 ) ) ;
v = db - > getVariableFromVarId ( 4 ) ;
ASSERT ( v ! = nullptr ) ;
if ( ! v )
return ;
ASSERT ( v - > isArray ( ) ) ;
ASSERT_EQUALS ( 1U , v - > dimensions ( ) . size ( ) ) ;
ASSERT_EQUALS ( 12U , v - > dimension ( 0 ) ) ;
v = db - > getVariableFromVarId ( 5 ) ;
ASSERT ( v ! = nullptr ) ;
if ( ! v )
return ;
ASSERT ( v - > isArray ( ) ) ;
ASSERT_EQUALS ( 1U , v - > dimensions ( ) . size ( ) ) ;
ASSERT_EQUALS ( 12U , v - > dimension ( 0 ) ) ;
}
2016-06-05 14:08:33 +02:00
void enum6 ( ) {
GET_SYMBOL_DB ( " struct Fred { \n "
" enum Enum { E0, E1 }; \n "
" }; \n "
" struct Barney : public Fred { \n "
" Enum func(Enum e) { return e; } \n "
" }; " ) ;
ASSERT ( db ) ;
if ( ! db )
return ;
const Token * const functionToken = Token : : findsimplematch ( tokenizer . tokens ( ) , " func " ) ;
ASSERT ( functionToken ) ;
if ( ! functionToken )
return ;
const Function * function = functionToken - > function ( ) ;
ASSERT ( function ) ;
if ( ! function )
return ;
ASSERT ( function - > token - > str ( ) = = " func " ) ;
ASSERT ( function - > retDef & & function - > retDef - > str ( ) = = " Enum " ) ;
ASSERT ( function - > retType & & function - > retType - > name ( ) = = " Enum " ) ;
}
2016-07-08 20:39:34 +02:00
# define TEST(S) \
v = db - > getVariableFromVarId ( id + + ) ; \
ASSERT ( v ! = nullptr ) ; \
if ( ! v ) \
return ; \
ASSERT ( v - > isArray ( ) ) ; \
ASSERT_EQUALS ( 1U , v - > dimensions ( ) . size ( ) ) ; \
ASSERT_EQUALS ( S , v - > dimension ( 0 ) )
void enum7 ( ) {
GET_SYMBOL_DB ( " enum E { X }; \n "
" enum EC : char { C }; \n "
" enum ES : short { S }; \n "
" enum EI : int { I }; \n "
" enum EL : long { L }; \n "
" enum ELL : long long { LL }; \n "
" char array1[sizeof(E)]; \n "
" char array2[sizeof(X)]; \n "
" char array3[sizeof(EC)]; \n "
" char array4[sizeof(C)]; \n "
" char array5[sizeof(ES)]; \n "
" char array6[sizeof(S)]; \n "
" char array7[sizeof(EI)]; \n "
" char array8[sizeof(I)]; \n "
" char array9[sizeof(EL)]; \n "
" char array10[sizeof(L)]; \n "
" char array11[sizeof(ELL)]; \n "
" char array12[sizeof(LL)]; \n " ) ;
ASSERT ( db ) ;
if ( ! db )
return ;
ASSERT ( db - > getVariableListSize ( ) = = 13 ) ; // the first one is not used
const Variable * v ;
unsigned int id = 1 ;
TEST ( settings . sizeof_int ) ;
TEST ( settings . sizeof_int ) ;
TEST ( 1 ) ;
TEST ( 1 ) ;
TEST ( settings . sizeof_short ) ;
TEST ( settings . sizeof_short ) ;
TEST ( settings . sizeof_int ) ;
TEST ( settings . sizeof_int ) ;
TEST ( settings . sizeof_long ) ;
TEST ( settings . sizeof_long ) ;
TEST ( settings . sizeof_long_long ) ;
TEST ( settings . sizeof_long_long ) ;
}
2014-11-20 14:20:09 +01:00
void isImplicitlyVirtual ( ) {
2012-04-17 19:50:44 +02:00
{
GET_SYMBOL_DB ( " class Base { \n "
" virtual void foo() {} \n "
" }; \n "
" class Deri : Base { \n "
" void foo() {} \n "
" }; " ) ;
ASSERT ( db & & db - > findScopeByName ( " Deri " ) & & db - > findScopeByName ( " Deri " ) - > functionList . front ( ) . isImplicitlyVirtual ( ) ) ;
}
{
GET_SYMBOL_DB ( " class Base { \n "
" virtual void foo() {} \n "
" }; \n "
" class Deri1 : Base { \n "
" void foo() {} \n "
" }; \n "
" class Deri2 : Deri1 { \n "
" void foo() {} \n "
" }; " ) ;
ASSERT ( db & & db - > findScopeByName ( " Deri2 " ) & & db - > findScopeByName ( " Deri2 " ) - > functionList . front ( ) . isImplicitlyVirtual ( ) ) ;
}
{
GET_SYMBOL_DB ( " class Base { \n "
" void foo() {} \n "
" }; \n "
" class Deri : Base { \n "
" void foo() {} \n "
" }; " ) ;
ASSERT ( db & & db - > findScopeByName ( " Deri " ) & & ! db - > findScopeByName ( " Deri " ) - > functionList . front ( ) . isImplicitlyVirtual ( true ) ) ;
}
{
GET_SYMBOL_DB ( " class Base { \n "
" virtual void foo() {} \n "
" }; \n "
" class Deri : Base { \n "
" void foo(std::string& s) {} \n "
" }; " ) ;
ASSERT ( db & & db - > findScopeByName ( " Deri " ) & & ! db - > findScopeByName ( " Deri " ) - > functionList . front ( ) . isImplicitlyVirtual ( true ) ) ;
}
{
GET_SYMBOL_DB ( " class Base { \n "
" virtual void foo() {} \n "
" }; \n "
" class Deri1 : Base { \n "
" void foo(int i) {} \n "
" }; \n "
" class Deri2 : Deri1 { \n "
" void foo() {} \n "
" }; " ) ;
ASSERT ( db & & db - > findScopeByName ( " Deri2 " ) & & db - > findScopeByName ( " Deri2 " ) - > functionList . front ( ) . isImplicitlyVirtual ( ) ) ;
}
{
GET_SYMBOL_DB ( " class Base : Base2 { \n " // We don't know Base2
" void foo() {} \n "
" }; \n "
" class Deri : Base { \n "
" void foo() {} \n "
" }; " ) ;
ASSERT ( db & & db - > findScopeByName ( " Deri " ) & & db - > findScopeByName ( " Deri " ) - > functionList . front ( ) . isImplicitlyVirtual ( true ) ) ; // Default true -> true
}
{
GET_SYMBOL_DB ( " class Base : Base2 { \n " // We don't know Base2
" void foo() {} \n "
" }; \n "
" class Deri : Base { \n "
" void foo() {} \n "
" }; " ) ;
ASSERT ( db & & db - > findScopeByName ( " Deri " ) & & ! db - > findScopeByName ( " Deri " ) - > functionList . front ( ) . isImplicitlyVirtual ( false ) ) ; // Default false -> false
}
{
GET_SYMBOL_DB ( " class Base : Base2 { \n " // We don't know Base2
" virtual void foo() {} \n "
" }; \n "
" class Deri : Base { \n "
" void foo() {} \n "
" }; " ) ;
ASSERT ( db & & db - > findScopeByName ( " Deri " ) & & db - > findScopeByName ( " Deri " ) - > functionList . front ( ) . isImplicitlyVirtual ( false ) ) ; // Default false, but we saw "virtual" -> true
}
2014-01-05 19:10:16 +01:00
// #5289
{
GET_SYMBOL_DB ( " template<> \n "
" class Bar<void, void> { \n "
" }; \n "
" template<typename K, typename V, int KeySize> \n "
" class Bar : private Bar<void, void> { \n "
" void foo() { \n "
" } \n "
" }; " ) ;
ASSERT ( db & & db - > findScopeByName ( " Bar " ) & & ! db - > findScopeByName ( " Bar " ) - > functionList . front ( ) . isImplicitlyVirtual ( false ) ) ;
2015-03-15 10:06:56 +01:00
if ( db )
ASSERT_EQUALS ( 1 , db - > findScopeByName ( " Bar " ) - > functionList . size ( ) ) ;
2014-03-22 08:49:28 +01:00
}
// #5590
{
GET_SYMBOL_DB ( " class InfiniteB : InfiniteA { \n "
" class D { \n "
" }; \n "
" }; \n "
" namespace N { \n "
" class InfiniteA : InfiniteB { \n "
" }; \n "
" } \n "
" class InfiniteA : InfiniteB { \n "
" void foo(); \n "
" }; \n "
" void InfiniteA::foo() { \n "
" C a; \n "
" } " ) ;
//ASSERT(db && db->findScopeByName("InfiniteA") && !db->findScopeByName("InfiniteA")->functionList.front().isImplicitlyVirtual());
TODO_ASSERT_EQUALS ( 1 , 0 , db - > findScopeByName ( " InfiniteA " ) - > functionList . size ( ) ) ;
2014-01-05 19:10:16 +01:00
}
2012-04-17 19:50:44 +02:00
}
2012-09-14 15:32:35 +02:00
2015-11-07 22:21:50 +01:00
void isPure ( ) {
GET_SYMBOL_DB ( " class C { \n "
" void f() = 0; \n "
" C(B b) = 0; \n "
" C(C& c) = default; "
" void g(); \n "
" }; " ) ;
ASSERT ( db & & db - > scopeList . back ( ) . functionList . size ( ) = = 4 ) ;
if ( db & & db - > scopeList . back ( ) . functionList . size ( ) = = 4 ) {
std : : list < Function > : : const_iterator it = db - > scopeList . back ( ) . functionList . begin ( ) ;
ASSERT ( ( it + + ) - > isPure ( ) ) ;
ASSERT ( ( it + + ) - > isPure ( ) ) ;
ASSERT ( ! ( it + + ) - > isPure ( ) ) ;
ASSERT ( ! ( it + + ) - > isPure ( ) ) ;
}
}
2014-11-20 14:20:09 +01:00
void isFunction ( ) { // #5602 - UNKNOWN_MACRO(a,b) { .. }
2014-04-13 13:05:30 +02:00
GET_SYMBOL_DB ( " TEST(a,b) { \n "
" std::vector<int> messages; \n "
" foo(messages[2].size()); \n "
" } " ) ;
const Variable * const var = db ? db - > getVariableFromVarId ( 1U ) : nullptr ;
ASSERT ( db & &
db - > findScopeByName ( " TEST " ) & &
var & &
var - > typeStartToken ( ) & &
var - > typeStartToken ( ) - > str ( ) = = " std " ) ;
}
2014-11-20 14:20:09 +01:00
void findFunction1 ( ) {
2012-10-30 15:48:06 +01:00
GET_SYMBOL_DB ( " int foo(int x); \n " /* 1 */
" void foo(); \n " /* 2 */
" void bar() { \n " /* 3 */
" foo(); \n " /* 4 */
" foo(1); \n " /* 5 */
" } " ) ; /* 6 */
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
if ( db ) {
const Scope * bar = db - > findScopeByName ( " bar " ) ;
2014-02-16 11:47:52 +01:00
ASSERT ( bar ! = nullptr ) ;
2012-10-30 15:48:06 +01:00
if ( bar ) {
unsigned int linenrs [ ] = { 2 , 1 } ;
unsigned int index = 0 ;
for ( const Token * tok = bar - > classStart - > next ( ) ; tok ! = bar - > classEnd ; tok = tok - > next ( ) ) {
2015-01-31 10:50:39 +01:00
if ( Token : : Match ( tok , " %name% ( " ) & & ! tok - > varId ( ) & & Token : : simpleMatch ( tok - > linkAt ( 1 ) , " ) ; " ) ) {
2013-01-28 06:47:48 +01:00
const Function * function = db - > findFunction ( tok ) ;
2014-02-16 11:47:52 +01:00
ASSERT ( function ! = nullptr ) ;
2012-10-30 15:48:06 +01:00
if ( function ) {
std : : stringstream expected ;
expected < < " Function call on line " < < tok - > linenr ( ) < < " calls function on line " < < linenrs [ index ] < < std : : endl ;
std : : stringstream actual ;
actual < < " Function call on line " < < tok - > linenr ( ) < < " calls function on line " < < function - > tokenDef - > linenr ( ) < < std : : endl ;
2014-04-02 13:56:34 +02:00
ASSERT_EQUALS ( expected . str ( ) , actual . str ( ) ) ;
2012-10-30 15:48:06 +01:00
}
index + + ;
}
}
}
}
}
2014-02-19 06:35:51 +01:00
2014-11-20 14:20:09 +01:00
void findFunction2 ( ) {
2014-02-19 06:35:51 +01:00
// The function does not match the function call.
GET_SYMBOL_DB ( " void func(const int x, const Fred &fred); \n "
" void otherfunc() { \n "
" float t; \n "
" func(x, &t); \n "
" } " ) ;
2014-05-18 20:39:52 +02:00
const Token * callfunc = Token : : findsimplematch ( tokenizer . tokens ( ) , " func ( x , & t ) ; " ) ;
2014-02-19 06:35:51 +01:00
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
ASSERT_EQUALS ( true , db ! = nullptr ) ; // not null
ASSERT_EQUALS ( true , callfunc ! = nullptr ) ; // not null
ASSERT_EQUALS ( false , ( callfunc & & callfunc - > function ( ) ) ) ; // callfunc->function() should be null
}
2014-04-10 16:17:10 +02:00
2014-11-20 14:20:09 +01:00
void findFunction3 ( ) {
2014-11-01 14:36:17 +01:00
GET_SYMBOL_DB ( " struct base { void foo() { } }; \n "
" struct derived : public base { void foo() { } }; \n "
" void foo() { \n "
" derived d; \n "
" d.foo(); \n "
" } " ) ;
const Token * callfunc = Token : : findsimplematch ( tokenizer . tokens ( ) , " d . foo ( ) ; " ) ;
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
ASSERT_EQUALS ( true , db ! = nullptr ) ; // not null
ASSERT_EQUALS ( true , callfunc ! = nullptr ) ; // not null
ASSERT_EQUALS ( true , callfunc & & callfunc - > tokAt ( 2 ) - > function ( ) & & callfunc - > tokAt ( 2 ) - > function ( ) - > tokenDef - > linenr ( ) = = 2 ) ; // should find function on line 2
}
2014-11-20 14:20:09 +01:00
void findFunction4 ( ) {
2014-11-07 10:46:31 +01:00
GET_SYMBOL_DB ( " void foo(UNKNOWN) { } \n "
" void foo(int a) { } \n "
" void foo(unsigned int a) { } \n "
" void foo(unsigned long a) { } \n "
" void foo(unsigned long long a) { } \n "
" void foo(float a) { } \n "
" void foo(double a) { } \n "
" void foo(long double a) { } \n "
" int i; \n "
" unsigned int ui; \n "
" unsigned long ul; \n "
" unsigned long long ull; \n "
" float f; \n "
" double d; \n "
" long double ld; \n "
" int & ri = i; \n "
" unsigned int & rui = ui; \n "
" unsigned long & rul = ul; \n "
" unsigned long long & rull = ull; \n "
" float & rf = f; \n "
" double & rd = d; \n "
" long double & rld = ld; \n "
" const int & cri = i; \n "
" const unsigned int & crui = ui; \n "
" const unsigned long & crul = ul; \n "
" const unsigned long long & crull = ull; \n "
" const float & crf = f; \n "
" const double & crd = d; \n "
" const long double & crld = ld; \n "
" void foo() { \n "
" foo(1); \n "
" foo(1U); \n "
" foo(1UL); \n "
" foo(1ULL); \n "
" foo(1.0F); \n "
" foo(1.0); \n "
" foo(1.0L); \n "
" foo(i); \n "
" foo(ui); \n "
" foo(ul); \n "
" foo(ull); \n "
" foo(f); \n "
" foo(d); \n "
" foo(ld); \n "
" foo(ri); \n "
" foo(rui); \n "
" foo(rul); \n "
" foo(rull); \n "
" foo(rf); \n "
" foo(rd); \n "
" foo(rld); \n "
" foo(cri); \n "
" foo(crui); \n "
" foo(crul); \n "
" foo(crull); \n "
" foo(crf); \n "
" foo(crd); \n "
" foo(crld); \n "
" } " ) ;
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
const Token * f = Token : : findsimplematch ( tokenizer . tokens ( ) , " foo ( 1 ) ; " ) ;
2014-11-17 16:04:44 +01:00
ASSERT_EQUALS ( true , db & & f & & f - > function ( ) & & f - > function ( ) - > tokenDef - > linenr ( ) = = 2 ) ;
2014-11-07 10:46:31 +01:00
f = Token : : findsimplematch ( tokenizer . tokens ( ) , " foo ( 1U ) ; " ) ;
2014-11-17 16:04:44 +01:00
ASSERT_EQUALS ( true , db & & f & & f - > function ( ) & & f - > function ( ) - > tokenDef - > linenr ( ) = = 3 ) ;
2014-11-07 10:46:31 +01:00
f = Token : : findsimplematch ( tokenizer . tokens ( ) , " foo ( 1UL ) ; " ) ;
2014-11-17 16:04:44 +01:00
ASSERT_EQUALS ( true , db & & f & & f - > function ( ) & & f - > function ( ) - > tokenDef - > linenr ( ) = = 4 ) ;
2014-11-07 10:46:31 +01:00
f = Token : : findsimplematch ( tokenizer . tokens ( ) , " foo ( 1ULL ) ; " ) ;
2014-11-17 16:04:44 +01:00
ASSERT_EQUALS ( true , db & & f & & f - > function ( ) & & f - > function ( ) - > tokenDef - > linenr ( ) = = 5 ) ;
2014-11-07 10:46:31 +01:00
f = Token : : findsimplematch ( tokenizer . tokens ( ) , " foo ( 1.0F ) ; " ) ;
2014-11-17 16:04:44 +01:00
ASSERT_EQUALS ( true , db & & f & & f - > function ( ) & & f - > function ( ) - > tokenDef - > linenr ( ) = = 6 ) ;
2014-11-07 10:46:31 +01:00
f = Token : : findsimplematch ( tokenizer . tokens ( ) , " foo ( 1.0 ) ; " ) ;
2014-11-17 16:04:44 +01:00
ASSERT_EQUALS ( true , db & & f & & f - > function ( ) & & f - > function ( ) - > tokenDef - > linenr ( ) = = 7 ) ;
2014-11-07 10:46:31 +01:00
f = Token : : findsimplematch ( tokenizer . tokens ( ) , " foo ( 1.0L ) ; " ) ;
2014-11-17 16:04:44 +01:00
ASSERT_EQUALS ( true , db & & f & & f - > function ( ) & & f - > function ( ) - > tokenDef - > linenr ( ) = = 8 ) ;
2014-11-07 10:46:31 +01:00
f = Token : : findsimplematch ( tokenizer . tokens ( ) , " foo ( i ) ; " ) ;
2014-11-17 16:04:44 +01:00
ASSERT_EQUALS ( true , db & & f & & f - > function ( ) & & f - > function ( ) - > tokenDef - > linenr ( ) = = 2 ) ;
2014-11-07 10:46:31 +01:00
f = Token : : findsimplematch ( tokenizer . tokens ( ) , " foo ( ui ) ; " ) ;
2014-11-17 16:04:44 +01:00
ASSERT_EQUALS ( true , db & & f & & f - > function ( ) & & f - > function ( ) - > tokenDef - > linenr ( ) = = 3 ) ;
2014-11-07 10:46:31 +01:00
f = Token : : findsimplematch ( tokenizer . tokens ( ) , " foo ( ul ) ; " ) ;
2014-11-17 16:04:44 +01:00
ASSERT_EQUALS ( true , db & & f & & f - > function ( ) & & f - > function ( ) - > tokenDef - > linenr ( ) = = 4 ) ;
2014-11-07 10:46:31 +01:00
f = Token : : findsimplematch ( tokenizer . tokens ( ) , " foo ( ull ) ; " ) ;
2014-11-17 16:04:44 +01:00
ASSERT_EQUALS ( true , db & & f & & f - > function ( ) & & f - > function ( ) - > tokenDef - > linenr ( ) = = 5 ) ;
2014-11-07 10:46:31 +01:00
f = Token : : findsimplematch ( tokenizer . tokens ( ) , " foo ( f ) ; " ) ;
2014-11-17 16:04:44 +01:00
ASSERT_EQUALS ( true , db & & f & & f - > function ( ) & & f - > function ( ) - > tokenDef - > linenr ( ) = = 6 ) ;
2014-11-07 10:46:31 +01:00
f = Token : : findsimplematch ( tokenizer . tokens ( ) , " foo ( d ) ; " ) ;
2014-11-17 16:04:44 +01:00
ASSERT_EQUALS ( true , db & & f & & f - > function ( ) & & f - > function ( ) - > tokenDef - > linenr ( ) = = 7 ) ;
2014-11-07 10:46:31 +01:00
f = Token : : findsimplematch ( tokenizer . tokens ( ) , " foo ( ld ) ; " ) ;
2014-11-17 16:04:44 +01:00
ASSERT_EQUALS ( true , db & & f & & f - > function ( ) & & f - > function ( ) - > tokenDef - > linenr ( ) = = 8 ) ;
2014-11-07 10:46:31 +01:00
f = Token : : findsimplematch ( tokenizer . tokens ( ) , " foo ( ri ) ; " ) ;
2014-11-17 16:04:44 +01:00
ASSERT_EQUALS ( true , db & & f & & f - > function ( ) & & f - > function ( ) - > tokenDef - > linenr ( ) = = 2 ) ;
2014-11-07 10:46:31 +01:00
f = Token : : findsimplematch ( tokenizer . tokens ( ) , " foo ( rui ) ; " ) ;
2014-11-17 16:04:44 +01:00
ASSERT_EQUALS ( true , db & & f & & f - > function ( ) & & f - > function ( ) - > tokenDef - > linenr ( ) = = 3 ) ;
2014-11-07 10:46:31 +01:00
f = Token : : findsimplematch ( tokenizer . tokens ( ) , " foo ( rul ) ; " ) ;
2014-11-17 16:04:44 +01:00
ASSERT_EQUALS ( true , db & & f & & f - > function ( ) & & f - > function ( ) - > tokenDef - > linenr ( ) = = 4 ) ;
2014-11-07 10:46:31 +01:00
f = Token : : findsimplematch ( tokenizer . tokens ( ) , " foo ( rull ) ; " ) ;
2014-11-17 16:04:44 +01:00
ASSERT_EQUALS ( true , db & & f & & f - > function ( ) & & f - > function ( ) - > tokenDef - > linenr ( ) = = 5 ) ;
2014-11-07 10:46:31 +01:00
f = Token : : findsimplematch ( tokenizer . tokens ( ) , " foo ( rf ) ; " ) ;
2014-11-17 16:04:44 +01:00
ASSERT_EQUALS ( true , db & & f & & f - > function ( ) & & f - > function ( ) - > tokenDef - > linenr ( ) = = 6 ) ;
2014-11-07 10:46:31 +01:00
f = Token : : findsimplematch ( tokenizer . tokens ( ) , " foo ( rd ) ; " ) ;
2014-11-17 16:04:44 +01:00
ASSERT_EQUALS ( true , db & & f & & f - > function ( ) & & f - > function ( ) - > tokenDef - > linenr ( ) = = 7 ) ;
2014-11-07 10:46:31 +01:00
f = Token : : findsimplematch ( tokenizer . tokens ( ) , " foo ( rld ) ; " ) ;
2014-11-17 16:04:44 +01:00
ASSERT_EQUALS ( true , db & & f & & f - > function ( ) & & f - > function ( ) - > tokenDef - > linenr ( ) = = 8 ) ;
2014-11-07 10:46:31 +01:00
f = Token : : findsimplematch ( tokenizer . tokens ( ) , " foo ( cri ) ; " ) ;
2014-11-17 16:04:44 +01:00
ASSERT_EQUALS ( true , db & & f & & f - > function ( ) & & f - > function ( ) - > tokenDef - > linenr ( ) = = 2 ) ;
2014-11-07 10:46:31 +01:00
f = Token : : findsimplematch ( tokenizer . tokens ( ) , " foo ( crui ) ; " ) ;
2014-11-17 16:04:44 +01:00
ASSERT_EQUALS ( true , db & & f & & f - > function ( ) & & f - > function ( ) - > tokenDef - > linenr ( ) = = 3 ) ;
2014-11-07 10:46:31 +01:00
f = Token : : findsimplematch ( tokenizer . tokens ( ) , " foo ( crul ) ; " ) ;
2014-11-17 16:04:44 +01:00
ASSERT_EQUALS ( true , db & & f & & f - > function ( ) & & f - > function ( ) - > tokenDef - > linenr ( ) = = 4 ) ;
2014-11-07 10:46:31 +01:00
f = Token : : findsimplematch ( tokenizer . tokens ( ) , " foo ( crull ) ; " ) ;
2014-11-17 16:04:44 +01:00
ASSERT_EQUALS ( true , db & & f & & f - > function ( ) & & f - > function ( ) - > tokenDef - > linenr ( ) = = 5 ) ;
2014-11-07 10:46:31 +01:00
f = Token : : findsimplematch ( tokenizer . tokens ( ) , " foo ( crf ) ; " ) ;
2014-11-17 16:04:44 +01:00
ASSERT_EQUALS ( true , db & & f & & f - > function ( ) & & f - > function ( ) - > tokenDef - > linenr ( ) = = 6 ) ;
2014-11-07 10:46:31 +01:00
f = Token : : findsimplematch ( tokenizer . tokens ( ) , " foo ( crd ) ; " ) ;
2014-11-17 16:04:44 +01:00
ASSERT_EQUALS ( true , db & & f & & f - > function ( ) & & f - > function ( ) - > tokenDef - > linenr ( ) = = 7 ) ;
2014-11-07 10:46:31 +01:00
f = Token : : findsimplematch ( tokenizer . tokens ( ) , " foo ( crld ) ; " ) ;
2014-11-17 16:04:44 +01:00
ASSERT_EQUALS ( true , db & & f & & f - > function ( ) & & f - > function ( ) - > tokenDef - > linenr ( ) = = 8 ) ;
}
2014-11-20 14:20:09 +01:00
void findFunction5 ( ) {
2014-11-17 16:04:44 +01:00
GET_SYMBOL_DB ( " struct Fred { \n "
" void Sync(dsmp_t& type, int& len, int limit = 123); \n "
" void Sync(int& syncpos, dsmp_t& type, int& len, int limit = 123); \n "
" void FindSyncPoint(); \n "
" }; \n "
" void Fred::FindSyncPoint() { \n "
" dsmp_t type; \n "
" int syncpos, len; \n "
" Sync(syncpos, type, len); \n "
" Sync(type, len); \n "
" } " ) ;
const Token * f = Token : : findsimplematch ( tokenizer . tokens ( ) , " Sync ( syncpos " ) ;
ASSERT_EQUALS ( true , db & & f & & f - > function ( ) & & f - > function ( ) - > tokenDef - > linenr ( ) = = 3 ) ;
f = Token : : findsimplematch ( tokenizer . tokens ( ) , " Sync ( type " ) ;
ASSERT_EQUALS ( true , db & & f & & f - > function ( ) & & f - > function ( ) - > tokenDef - > linenr ( ) = = 2 ) ;
2014-11-07 10:46:31 +01:00
}
2014-11-20 14:20:09 +01:00
void findFunction6 ( ) { // avoid null pointer access
2014-11-17 23:05:15 +01:00
GET_SYMBOL_DB ( " void addtoken(Token** rettail, const Token *tok); \n "
" void CheckMemoryLeakInFunction::getcode(const Token *tok ) { \n "
" addtoken(&rettail, tok); \n "
" } " ) ;
2014-11-18 19:36:47 +01:00
const Token * f = Token : : findsimplematch ( tokenizer . tokens ( ) , " void addtoken ( Token * * " ) ;
2014-11-18 19:52:06 +01:00
ASSERT_EQUALS ( true , db & & f & & ! f - > function ( ) ) ; // regression value only
2014-11-17 23:05:15 +01:00
}
2015-05-23 11:56:11 +02:00
void findFunction7 ( ) {
GET_SYMBOL_DB ( " class ResultEnsemble { \n "
" public: \n "
" std::vector<int> &nodeResults() const; \n "
" std::vector<int> &nodeResults(); \n "
" }; \n "
" class Simulator { \n "
" int generatePinchResultEnsemble(const ResultEnsemble &power, const ResultEnsemble &ground) { \n "
" power.nodeResults().size(); \n "
" assert(power.nodeResults().size()==ground.nodeResults().size()); \n "
" } \n "
" }; " )
const Token * callfunc = Token : : findsimplematch ( tokenizer . tokens ( ) , " power . nodeResults ( ) . size ( ) ; " ) ;
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
ASSERT_EQUALS ( true , db ! = nullptr ) ; // not null
ASSERT_EQUALS ( true , callfunc ! = nullptr ) ; // not null
ASSERT_EQUALS ( true , callfunc & & callfunc - > tokAt ( 2 ) - > function ( ) & & callfunc - > tokAt ( 2 ) - > function ( ) - > tokenDef - > linenr ( ) = = 3 ) ;
}
2016-01-02 18:53:51 +01:00
void findFunction8 ( ) {
GET_SYMBOL_DB ( " struct S { \n "
" void f() { } \n "
" void f() & { } \n "
" void f() &&{ } \n "
" void f() const { } \n "
" void f() const & { } \n "
" void f() const &&{ } \n "
" void g() ; \n "
" void g() & ; \n "
" void g() &&; \n "
" void g() const ; \n "
" void g() const & ; \n "
" void g() const &&; \n "
" }; \n "
" void S::g() { } \n "
" void S::g() & { } \n "
" void S::g() &&{ } \n "
" void S::g() const { } \n "
" void S::g() const & { } \n "
" void S::g() const &&{ } \n " ) ;
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
const Token * f = Token : : findsimplematch ( tokenizer . tokens ( ) , " f ( ) { " ) ;
ASSERT_EQUALS ( true , db & & f & & f - > function ( ) & & f - > function ( ) - > tokenDef - > linenr ( ) = = 2 ) ;
f = Token : : findsimplematch ( tokenizer . tokens ( ) , " f ( ) & { " ) ;
ASSERT_EQUALS ( true , db & & f & & f - > function ( ) & & f - > function ( ) - > tokenDef - > linenr ( ) = = 3 ) ;
f = Token : : findsimplematch ( tokenizer . tokens ( ) , " f ( ) && { " ) ;
ASSERT_EQUALS ( true , db & & f & & f - > function ( ) & & f - > function ( ) - > tokenDef - > linenr ( ) = = 4 ) ;
f = Token : : findsimplematch ( tokenizer . tokens ( ) , " f ( ) const { " ) ;
ASSERT_EQUALS ( true , db & & f & & f - > function ( ) & & f - > function ( ) - > tokenDef - > linenr ( ) = = 5 ) ;
f = Token : : findsimplematch ( tokenizer . tokens ( ) , " f ( ) const & { " ) ;
ASSERT_EQUALS ( true , db & & f & & f - > function ( ) & & f - > function ( ) - > tokenDef - > linenr ( ) = = 6 ) ;
f = Token : : findsimplematch ( tokenizer . tokens ( ) , " f ( ) const && { " ) ;
ASSERT_EQUALS ( true , db & & f & & f - > function ( ) & & f - > function ( ) - > tokenDef - > linenr ( ) = = 7 ) ;
f = Token : : findsimplematch ( tokenizer . tokens ( ) , " g ( ) { " ) ;
ASSERT_EQUALS ( true , db & & f & & f - > function ( ) & & f - > function ( ) - > tokenDef - > linenr ( ) = = 8 & & f - > function ( ) - > token - > linenr ( ) = = 15 ) ;
f = Token : : findsimplematch ( tokenizer . tokens ( ) , " g ( ) & { " ) ;
ASSERT_EQUALS ( true , db & & f & & f - > function ( ) & & f - > function ( ) - > tokenDef - > linenr ( ) = = 9 & & f - > function ( ) - > token - > linenr ( ) = = 16 ) ;
f = Token : : findsimplematch ( tokenizer . tokens ( ) , " g ( ) && { " ) ;
ASSERT_EQUALS ( true , db & & f & & f - > function ( ) & & f - > function ( ) - > tokenDef - > linenr ( ) = = 10 & & f - > function ( ) - > token - > linenr ( ) = = 17 ) ;
f = Token : : findsimplematch ( tokenizer . tokens ( ) , " g ( ) const { " ) ;
ASSERT_EQUALS ( true , db & & f & & f - > function ( ) & & f - > function ( ) - > tokenDef - > linenr ( ) = = 11 & & f - > function ( ) - > token - > linenr ( ) = = 18 ) ;
f = Token : : findsimplematch ( tokenizer . tokens ( ) , " g ( ) const & { " ) ;
ASSERT_EQUALS ( true , db & & f & & f - > function ( ) & & f - > function ( ) - > tokenDef - > linenr ( ) = = 12 & & f - > function ( ) - > token - > linenr ( ) = = 19 ) ;
f = Token : : findsimplematch ( tokenizer . tokens ( ) , " g ( ) const && { " ) ;
ASSERT_EQUALS ( true , db & & f & & f - > function ( ) & & f - > function ( ) - > tokenDef - > linenr ( ) = = 13 & & f - > function ( ) - > token - > linenr ( ) = = 20 ) ;
f = Token : : findsimplematch ( tokenizer . tokens ( ) , " S :: g ( ) { " ) ;
ASSERT_EQUALS ( true , db & & f & & f - > tokAt ( 2 ) - > function ( ) & & f - > tokAt ( 2 ) - > function ( ) - > tokenDef - > linenr ( ) = = 8 & & f - > tokAt ( 2 ) - > function ( ) - > token - > linenr ( ) = = 15 ) ;
f = Token : : findsimplematch ( tokenizer . tokens ( ) , " S :: g ( ) & { " ) ;
ASSERT_EQUALS ( true , db & & f & & f - > tokAt ( 2 ) - > function ( ) & & f - > tokAt ( 2 ) - > function ( ) - > tokenDef - > linenr ( ) = = 9 & & f - > tokAt ( 2 ) - > function ( ) - > token - > linenr ( ) = = 16 ) ;
f = Token : : findsimplematch ( tokenizer . tokens ( ) , " S :: g ( ) && { " ) ;
ASSERT_EQUALS ( true , db & & f & & f - > tokAt ( 2 ) - > function ( ) & & f - > tokAt ( 2 ) - > function ( ) - > tokenDef - > linenr ( ) = = 10 & & f - > tokAt ( 2 ) - > function ( ) - > token - > linenr ( ) = = 17 ) ;
f = Token : : findsimplematch ( tokenizer . tokens ( ) , " S :: g ( ) const { " ) ;
ASSERT_EQUALS ( true , db & & f & & f - > tokAt ( 2 ) - > function ( ) & & f - > tokAt ( 2 ) - > function ( ) - > tokenDef - > linenr ( ) = = 11 & & f - > tokAt ( 2 ) - > function ( ) - > token - > linenr ( ) = = 18 ) ;
f = Token : : findsimplematch ( tokenizer . tokens ( ) , " S :: g ( ) const & { " ) ;
ASSERT_EQUALS ( true , db & & f & & f - > tokAt ( 2 ) - > function ( ) & & f - > tokAt ( 2 ) - > function ( ) - > tokenDef - > linenr ( ) = = 12 & & f - > tokAt ( 2 ) - > function ( ) - > token - > linenr ( ) = = 19 ) ;
f = Token : : findsimplematch ( tokenizer . tokens ( ) , " S :: g ( ) const && { " ) ;
ASSERT_EQUALS ( true , db & & f & & f - > tokAt ( 2 ) - > function ( ) & & f - > tokAt ( 2 ) - > function ( ) - > tokenDef - > linenr ( ) = = 13 & & f - > tokAt ( 2 ) - > function ( ) - > token - > linenr ( ) = = 20 ) ;
}
2015-05-23 11:56:11 +02:00
2014-11-17 23:05:15 +01:00
2014-04-10 16:17:10 +02:00
# define FUNC(x) const Function *x = findFunctionByName(#x, &db->scopeList.front()); \
2014-05-20 06:10:34 +02:00
ASSERT_EQUALS ( true , x ! = nullptr ) ; \
2015-01-08 05:45:31 +01:00
if ( x ) ASSERT_EQUALS ( true , x - > isNoExcept ( ) ) ;
2014-04-10 16:17:10 +02:00
2014-11-20 14:20:09 +01:00
void noexceptFunction1 ( ) {
2014-04-10 16:17:10 +02:00
GET_SYMBOL_DB ( " void func1() noexcept; \n "
" void func2() noexcept { } \n "
" void func3() noexcept(true); \n "
" void func4() noexcept(true) { } \n " ) ;
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
ASSERT_EQUALS ( true , db ! = nullptr ) ; // not null
if ( db ) {
FUNC ( func1 ) ;
FUNC ( func2 ) ;
FUNC ( func3 ) ;
FUNC ( func4 ) ;
}
}
2014-11-20 14:20:09 +01:00
void noexceptFunction2 ( ) {
2014-04-10 16:17:10 +02:00
GET_SYMBOL_DB ( " template <class T> void self_assign(T& t) noexcept(noexcept(t = t)) {t = t; } \n " ) ;
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
ASSERT_EQUALS ( true , db ! = nullptr ) ; // not null
if ( db ) {
FUNC ( self_assign ) ;
}
}
2014-12-09 23:53:50 +01:00
# define CLASS_FUNC(x, y, z) const Function *x = findFunctionByName(#x, y); \
2014-04-10 16:17:10 +02:00
ASSERT_EQUALS ( true , x ! = nullptr ) ; \
2015-01-08 05:45:31 +01:00
if ( x ) ASSERT_EQUALS ( z , x - > isNoExcept ( ) ) ;
2014-04-10 16:17:10 +02:00
2014-11-20 14:20:09 +01:00
void noexceptFunction3 ( ) {
2014-04-10 16:17:10 +02:00
GET_SYMBOL_DB ( " struct Fred { \n "
" void func1() noexcept; \n "
" void func2() noexcept { } \n "
" void func3() noexcept(true); \n "
" void func4() noexcept(true) { } \n "
" void func5() const noexcept; \n "
" void func6() const noexcept { } \n "
" void func7() const noexcept(true); \n "
" void func8() const noexcept(true) { } \n "
2014-05-20 06:10:34 +02:00
" void func9() noexcept = 0; \n "
" void func10() noexcept = 0; \n "
" void func11() const noexcept(true) = 0; \n "
" void func12() const noexcept(true) = 0; \n "
2014-12-09 23:53:50 +01:00
" void func13() const noexcept(false) = 0; \n "
2014-04-10 16:17:10 +02:00
" }; " ) ;
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
ASSERT_EQUALS ( true , db ! = nullptr ) ; // not null
if ( db ) {
const Scope * fred = db - > findScopeByName ( " Fred " ) ;
ASSERT_EQUALS ( true , fred ! = nullptr ) ;
if ( fred ) {
2014-12-09 23:53:50 +01:00
CLASS_FUNC ( func1 , fred , true ) ;
CLASS_FUNC ( func2 , fred , true ) ;
CLASS_FUNC ( func3 , fred , true ) ;
CLASS_FUNC ( func4 , fred , true ) ;
CLASS_FUNC ( func5 , fred , true ) ;
CLASS_FUNC ( func6 , fred , true ) ;
CLASS_FUNC ( func7 , fred , true ) ;
CLASS_FUNC ( func8 , fred , true ) ;
CLASS_FUNC ( func9 , fred , true ) ;
CLASS_FUNC ( func10 , fred , true ) ;
CLASS_FUNC ( func11 , fred , true ) ;
CLASS_FUNC ( func12 , fred , true ) ;
CLASS_FUNC ( func13 , fred , false ) ;
2014-04-10 16:17:10 +02:00
}
}
}
2014-11-20 14:20:09 +01:00
void noexceptFunction4 ( ) {
2014-04-10 16:17:10 +02:00
GET_SYMBOL_DB ( " class A { \n "
" public: \n "
" A(A&& a) { \n "
" throw std::runtime_error( \" err \" ); \n "
" } \n "
" }; \n "
" class B { \n "
" A a; \n "
" B(B&& b) noexcept \n "
" :a(std::move(b.a)) { } \n "
" }; \n " ) ;
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
ASSERT_EQUALS ( true , db ! = nullptr ) ; // not null
if ( db ) {
const Scope * b = db - > findScopeByName ( " B " ) ;
ASSERT_EQUALS ( true , b ! = nullptr ) ;
if ( b ) {
2014-12-09 23:53:50 +01:00
CLASS_FUNC ( B , b , true ) ;
2014-04-10 16:17:10 +02:00
}
2014-05-20 06:10:34 +02:00
}
}
# define FUNC_THROW(x) const Function *x = findFunctionByName(#x, &db->scopeList.front()); \
ASSERT_EQUALS ( true , x ! = nullptr ) ; \
2015-01-08 05:45:31 +01:00
if ( x ) ASSERT_EQUALS ( true , x - > isThrow ( ) ) ;
2014-05-20 06:10:34 +02:00
2014-11-20 14:20:09 +01:00
void throwFunction1 ( ) {
2014-05-20 06:10:34 +02:00
GET_SYMBOL_DB ( " void func1() throw(); \n "
" void func2() throw() { } \n "
" void func3() throw(int); \n "
" void func4() throw(int) { } \n " ) ;
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
ASSERT_EQUALS ( true , db ! = nullptr ) ; // not null
if ( db ) {
FUNC_THROW ( func1 ) ;
FUNC_THROW ( func2 ) ;
FUNC_THROW ( func3 ) ;
FUNC_THROW ( func4 ) ;
}
}
# define CLASS_FUNC_THROW(x, y) const Function *x = findFunctionByName(#x, y); \
ASSERT_EQUALS ( true , x ! = nullptr ) ; \
2015-01-08 05:45:31 +01:00
if ( x ) ASSERT_EQUALS ( true , x - > isThrow ( ) ) ;
2014-11-20 14:20:09 +01:00
void throwFunction2 ( ) {
2014-05-20 06:10:34 +02:00
GET_SYMBOL_DB ( " struct Fred { \n "
" void func1() throw(); \n "
" void func2() throw() { } \n "
" void func3() throw(int); \n "
" void func4() throw(int) { } \n "
" void func5() const throw(); \n "
" void func6() const throw() { } \n "
" void func7() const throw(int); \n "
" void func8() const throw(int) { } \n "
" void func9() throw() = 0; \n "
" void func10() throw(int) = 0; \n "
" void func11() const throw() = 0; \n "
" void func12() const throw(int) = 0; \n "
" }; " ) ;
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
ASSERT_EQUALS ( true , db ! = nullptr ) ; // not null
if ( db ) {
const Scope * fred = db - > findScopeByName ( " Fred " ) ;
ASSERT_EQUALS ( true , fred ! = nullptr ) ;
if ( fred ) {
CLASS_FUNC_THROW ( func1 , fred ) ;
CLASS_FUNC_THROW ( func2 , fred ) ;
CLASS_FUNC_THROW ( func3 , fred ) ;
CLASS_FUNC_THROW ( func4 , fred ) ;
CLASS_FUNC_THROW ( func5 , fred ) ;
CLASS_FUNC_THROW ( func6 , fred ) ;
CLASS_FUNC_THROW ( func7 , fred ) ;
CLASS_FUNC_THROW ( func8 , fred ) ;
CLASS_FUNC_THROW ( func9 , fred ) ;
CLASS_FUNC_THROW ( func10 , fred ) ;
CLASS_FUNC_THROW ( func11 , fred ) ;
CLASS_FUNC_THROW ( func12 , fred ) ;
}
2014-04-10 16:17:10 +02:00
}
}
2014-11-20 14:20:09 +01:00
void nothrowAttributeFunction ( ) {
2014-04-20 20:40:55 +02:00
GET_SYMBOL_DB ( " void func() __attribute__((nothrow)); \n "
" void func() { } \n " ) ;
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
ASSERT_EQUALS ( true , db ! = nullptr ) ; // not null
if ( db ) {
const Function * func = findFunctionByName ( " func " , & db - > scopeList . front ( ) ) ;
ASSERT_EQUALS ( true , func ! = nullptr ) ;
if ( func )
ASSERT_EQUALS ( true , func - > isAttributeNothrow ( ) ) ;
}
}
2014-11-20 14:20:09 +01:00
void nothrowDeclspecFunction ( ) {
2014-05-04 20:47:20 +02:00
GET_SYMBOL_DB ( " void __declspec(nothrow) func() { } \n " ) ;
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
ASSERT_EQUALS ( true , db ! = nullptr ) ; // not null
if ( db ) {
const Function * func = findFunctionByName ( " func " , & db - > scopeList . front ( ) ) ;
ASSERT_EQUALS ( true , func ! = nullptr ) ;
if ( func )
2015-01-09 20:18:09 +01:00
ASSERT_EQUALS ( true , func - > isAttributeNothrow ( ) ) ;
2014-05-04 20:47:20 +02:00
}
}
2014-11-20 14:20:09 +01:00
void varTypesIntegral ( ) {
2014-05-24 18:35:49 +02:00
GET_SYMBOL_DB ( " void f() { bool b; char c; unsigned char uc; short s; unsigned short us; int i; unsigned u; unsigned int ui; long l; unsigned long ul; long long ll; } " ) ;
const Variable * b = db - > getVariableFromVarId ( 1 ) ;
2014-05-25 09:52:54 +02:00
ASSERT ( b ! = nullptr ) ;
if ( b ) {
ASSERT_EQUALS ( " b " , b - > nameToken ( ) - > str ( ) ) ;
ASSERT_EQUALS ( false , b - > isFloatingType ( ) ) ;
}
2014-05-24 18:35:49 +02:00
const Variable * c = db - > getVariableFromVarId ( 2 ) ;
2014-05-25 09:52:54 +02:00
ASSERT ( c ! = nullptr ) ;
if ( c ) {
ASSERT_EQUALS ( " c " , c - > nameToken ( ) - > str ( ) ) ;
ASSERT_EQUALS ( false , c - > isFloatingType ( ) ) ;
}
2014-05-24 18:35:49 +02:00
const Variable * uc = db - > getVariableFromVarId ( 3 ) ;
2014-05-25 09:52:54 +02:00
ASSERT ( uc ! = nullptr ) ;
if ( uc ) {
ASSERT_EQUALS ( " uc " , uc - > nameToken ( ) - > str ( ) ) ;
ASSERT_EQUALS ( false , uc - > isFloatingType ( ) ) ;
}
2014-05-24 18:35:49 +02:00
const Variable * s = db - > getVariableFromVarId ( 4 ) ;
2014-05-25 09:52:54 +02:00
ASSERT ( s ! = nullptr ) ;
if ( s ) {
ASSERT_EQUALS ( " s " , s - > nameToken ( ) - > str ( ) ) ;
ASSERT_EQUALS ( false , s - > isFloatingType ( ) ) ;
}
2014-05-24 18:35:49 +02:00
const Variable * us = db - > getVariableFromVarId ( 5 ) ;
2014-05-25 09:52:54 +02:00
ASSERT ( us ! = nullptr ) ;
if ( us ) {
ASSERT_EQUALS ( " us " , us - > nameToken ( ) - > str ( ) ) ;
ASSERT_EQUALS ( false , us - > isFloatingType ( ) ) ;
}
2014-05-24 18:35:49 +02:00
const Variable * i = db - > getVariableFromVarId ( 6 ) ;
2014-05-25 09:52:54 +02:00
ASSERT ( i ! = nullptr ) ;
if ( i ) {
ASSERT_EQUALS ( " i " , i - > nameToken ( ) - > str ( ) ) ;
ASSERT_EQUALS ( false , i - > isFloatingType ( ) ) ;
}
2014-05-24 18:35:49 +02:00
const Variable * u = db - > getVariableFromVarId ( 7 ) ;
2014-05-25 09:52:54 +02:00
ASSERT ( u ! = nullptr ) ;
if ( u ) {
ASSERT_EQUALS ( " u " , u - > nameToken ( ) - > str ( ) ) ;
ASSERT_EQUALS ( false , u - > isFloatingType ( ) ) ;
}
2014-05-24 18:35:49 +02:00
const Variable * ui = db - > getVariableFromVarId ( 8 ) ;
2014-05-25 09:52:54 +02:00
ASSERT ( ui ! = nullptr ) ;
if ( ui ) {
ASSERT_EQUALS ( " ui " , ui - > nameToken ( ) - > str ( ) ) ;
ASSERT_EQUALS ( false , ui - > isFloatingType ( ) ) ;
}
2014-05-24 18:35:49 +02:00
const Variable * l = db - > getVariableFromVarId ( 9 ) ;
2014-05-25 09:52:54 +02:00
ASSERT ( l ! = nullptr ) ;
if ( l ) {
ASSERT_EQUALS ( " l " , l - > nameToken ( ) - > str ( ) ) ;
ASSERT_EQUALS ( false , l - > isFloatingType ( ) ) ;
}
2014-05-24 18:35:49 +02:00
const Variable * ul = db - > getVariableFromVarId ( 10 ) ;
2014-05-25 09:52:54 +02:00
ASSERT ( ul ! = nullptr ) ;
if ( ul ) {
ASSERT_EQUALS ( " ul " , ul - > nameToken ( ) - > str ( ) ) ;
ASSERT_EQUALS ( false , ul - > isFloatingType ( ) ) ;
}
2014-05-24 18:35:49 +02:00
const Variable * ll = db - > getVariableFromVarId ( 11 ) ;
2014-05-28 17:05:42 +02:00
ASSERT ( ll ! = nullptr ) ;
if ( ll ) {
2014-05-25 09:52:54 +02:00
ASSERT_EQUALS ( " ll " , ll - > nameToken ( ) - > str ( ) ) ;
ASSERT_EQUALS ( false , ll - > isFloatingType ( ) ) ;
}
2014-05-24 18:35:49 +02:00
}
2014-11-20 14:20:09 +01:00
void varTypesFloating ( ) {
2014-05-24 18:35:49 +02:00
{
GET_SYMBOL_DB ( " void f() { float f; double d; long double ld; } " ) ;
const Variable * f = db - > getVariableFromVarId ( 1 ) ;
2014-05-25 09:52:54 +02:00
ASSERT ( f ! = nullptr ) ;
if ( f ) {
ASSERT_EQUALS ( " f " , f - > nameToken ( ) - > str ( ) ) ;
ASSERT_EQUALS ( true , f - > isFloatingType ( ) ) ;
}
2014-05-24 18:35:49 +02:00
const Variable * d = db - > getVariableFromVarId ( 2 ) ;
2014-05-25 09:52:54 +02:00
ASSERT ( d ! = nullptr ) ;
if ( d ) {
ASSERT_EQUALS ( " d " , d - > nameToken ( ) - > str ( ) ) ;
ASSERT_EQUALS ( true , d - > isFloatingType ( ) ) ;
}
2014-05-24 18:35:49 +02:00
const Variable * ld = db - > getVariableFromVarId ( 3 ) ;
2014-05-25 09:52:54 +02:00
ASSERT ( ld ! = nullptr ) ;
if ( ld ) {
ASSERT_EQUALS ( " ld " , ld - > nameToken ( ) - > str ( ) ) ;
ASSERT_EQUALS ( true , ld - > isFloatingType ( ) ) ;
}
2014-05-24 18:35:49 +02:00
}
{
GET_SYMBOL_DB ( " void f() { float * f; static const float * scf; } " ) ;
const Variable * f = db - > getVariableFromVarId ( 1 ) ;
2014-05-25 09:52:54 +02:00
ASSERT ( f ! = nullptr ) ;
if ( f ) {
ASSERT_EQUALS ( " f " , f - > nameToken ( ) - > str ( ) ) ;
2014-08-09 11:44:55 +02:00
ASSERT_EQUALS ( true , f - > isFloatingType ( ) ) ;
ASSERT_EQUALS ( true , f - > isArrayOrPointer ( ) ) ;
2014-05-25 09:52:54 +02:00
}
2014-05-24 18:35:49 +02:00
const Variable * scf = db - > getVariableFromVarId ( 2 ) ;
2014-05-25 09:52:54 +02:00
ASSERT ( scf ! = nullptr ) ;
if ( scf ) {
ASSERT_EQUALS ( " scf " , scf - > nameToken ( ) - > str ( ) ) ;
2014-08-09 11:44:55 +02:00
ASSERT_EQUALS ( true , scf - > isFloatingType ( ) ) ;
ASSERT_EQUALS ( true , scf - > isArrayOrPointer ( ) ) ;
2014-05-25 09:52:54 +02:00
}
2014-05-24 18:35:49 +02:00
}
{
GET_SYMBOL_DB ( " void f() { float fa[42]; } " ) ;
const Variable * fa = db - > getVariableFromVarId ( 1 ) ;
2014-05-25 09:52:54 +02:00
ASSERT ( fa ! = nullptr ) ;
if ( fa ) {
ASSERT_EQUALS ( " fa " , fa - > nameToken ( ) - > str ( ) ) ;
2014-08-09 11:44:55 +02:00
ASSERT_EQUALS ( true , fa - > isFloatingType ( ) ) ;
ASSERT_EQUALS ( true , fa - > isArrayOrPointer ( ) ) ;
2014-05-25 09:52:54 +02:00
}
2014-05-24 18:35:49 +02:00
}
}
2014-11-20 14:20:09 +01:00
void varTypesOther ( ) {
2014-05-24 18:35:49 +02:00
GET_SYMBOL_DB ( " void f() { class A {} a; void *b; } " ) ;
const Variable * a = db - > getVariableFromVarId ( 1 ) ;
2014-05-25 09:52:54 +02:00
ASSERT ( a ! = nullptr ) ;
if ( a ) {
ASSERT_EQUALS ( " a " , a - > nameToken ( ) - > str ( ) ) ;
ASSERT_EQUALS ( false , a - > isFloatingType ( ) ) ;
}
2014-05-24 18:35:49 +02:00
const Variable * b = db - > getVariableFromVarId ( 2 ) ;
2014-05-25 09:52:54 +02:00
ASSERT ( b ! = nullptr ) ;
if ( b ) {
ASSERT_EQUALS ( " b " , b - > nameToken ( ) - > str ( ) ) ;
ASSERT_EQUALS ( false , b - > isFloatingType ( ) ) ;
}
2014-05-24 18:35:49 +02:00
}
2014-06-02 06:18:32 +02:00
2014-11-20 14:20:09 +01:00
void functionPrototype ( ) {
2014-06-02 06:18:32 +02:00
check ( " int foo(int x) { \n "
" extern int func1(); \n "
" extern int func2(int); \n "
" int func3(); \n "
" int func4(int); \n "
" return func4(x); \n "
" } \n " , true ) ;
ASSERT_EQUALS ( " " , errout . str ( ) ) ;
}
2014-08-31 10:21:10 +02:00
2014-11-20 14:20:09 +01:00
void lambda ( ) {
2014-08-31 10:21:10 +02:00
GET_SYMBOL_DB ( " void func() { \n "
" float y = 0.0f; \n "
" auto lambda = [&]() \n "
" { \n "
" float x = 1.0f; \n "
" y += 10.0f - x; \n "
" } \n "
" lambda(); \n "
" } " ) ;
ASSERT ( db & & db - > scopeList . size ( ) = = 3 ) ;
if ( db & & db - > scopeList . size ( ) = = 3 ) {
std : : list < Scope > : : const_iterator scope = db - > scopeList . begin ( ) ;
ASSERT_EQUALS ( Scope : : eGlobal , scope - > type ) ;
+ + scope ;
ASSERT_EQUALS ( Scope : : eFunction , scope - > type ) ;
+ + scope ;
ASSERT_EQUALS ( Scope : : eLambda , scope - > type ) ;
}
}
2016-05-04 14:10:09 +02:00
void lambda2 ( ) {
GET_SYMBOL_DB ( " void func() { \n "
" float y = 0.0f; \n "
" auto lambda = [&]() -> bool \n "
" { \n "
" float x = 1.0f; \n "
" } \n "
" lambda(); \n "
" } " ) ;
ASSERT ( db & & db - > scopeList . size ( ) = = 3 ) ;
if ( db & & db - > scopeList . size ( ) = = 3 ) {
std : : list < Scope > : : const_iterator scope = db - > scopeList . begin ( ) ;
ASSERT_EQUALS ( Scope : : eGlobal , scope - > type ) ;
+ + scope ;
ASSERT_EQUALS ( Scope : : eFunction , scope - > type ) ;
+ + scope ;
ASSERT_EQUALS ( Scope : : eLambda , scope - > type ) ;
}
}
2015-07-01 07:50:13 +02:00
// #6298 "stack overflow in Scope::findFunctionInBase (endless recursion)"
void circularDependencies ( ) {
check ( " template<template<class> class E,class D> class C : E<D> { \n "
" public: \n "
" int f(); \n "
" }; \n "
" class E : C<D,int> { \n "
" public: \n "
" int f() { return C< ::D,int>::f(); } \n "
" }; \n "
" int main() { \n "
" E c; \n "
" c.f(); \n "
" } " ) ;
}
2015-10-04 19:42:58 +02:00
2016-03-22 14:10:20 +01:00
void executableScopeWithUnknownFunction ( ) {
GET_SYMBOL_DB ( " class Fred { \n "
" void foo(const std::string & a = " " ); \n "
" }; \n "
" Fred::foo(const std::string & b) { } \n " ) ;
ASSERT ( db & & db - > scopeList . size ( ) = = 3 ) ;
if ( db & & db - > scopeList . size ( ) = = 3 ) {
std : : list < Scope > : : const_iterator scope = db - > scopeList . begin ( ) ;
ASSERT_EQUALS ( Scope : : eGlobal , scope - > type ) ;
+ + scope ;
ASSERT_EQUALS ( Scope : : eClass , scope - > type ) ;
const Scope * class_scope = & * scope ;
+ + scope ;
ASSERT ( class_scope - > functionList . size ( ) = = 1 ) ;
if ( class_scope - > functionList . size ( ) = = 1 ) {
ASSERT ( class_scope - > functionList . begin ( ) - > hasBody ( ) ) ;
ASSERT ( class_scope - > functionList . begin ( ) - > functionScope = = & * scope ) ;
}
}
}
2016-02-05 13:31:31 +01:00
std : : string typeOf ( const char code [ ] , const char pattern [ ] , const char filename [ ] = " test.cpp " ) {
2016-02-04 20:49:13 +01:00
Tokenizer tokenizer ( & settings2 , this ) ;
2015-10-04 19:42:58 +02:00
std : : istringstream istr ( code ) ;
2016-01-07 10:46:19 +01:00
tokenizer . tokenize ( istr , filename ) ;
2016-02-05 13:31:31 +01:00
const Token * tok ;
for ( tok = tokenizer . list . back ( ) ; tok ; tok = tok - > previous ( ) )
if ( Token : : simpleMatch ( tok , pattern ) )
break ;
2016-01-05 19:47:11 +01:00
return tok - > valueType ( ) ? tok - > valueType ( ) - > str ( ) : std : : string ( ) ;
2015-10-04 19:42:58 +02:00
}
void valuetype ( ) {
2016-01-01 15:13:50 +01:00
// stringification
ASSERT_EQUALS ( " " , ValueType ( ) . str ( ) ) ;
2015-10-07 18:10:48 +02:00
// numbers
ASSERT_EQUALS ( " signed int " , typeOf ( " 1 " , " 1 " ) ) ;
ASSERT_EQUALS ( " unsigned int " , typeOf ( " 1U " , " 1U " ) ) ;
ASSERT_EQUALS ( " signed long " , typeOf ( " 1L " , " 1L " ) ) ;
ASSERT_EQUALS ( " unsigned long " , typeOf ( " 1UL " , " 1UL " ) ) ;
ASSERT_EQUALS ( " signed long long " , typeOf ( " 1LL " , " 1LL " ) ) ;
ASSERT_EQUALS ( " unsigned long long " , typeOf ( " 1ULL " , " 1ULL " ) ) ;
2016-01-03 13:34:47 +01:00
ASSERT_EQUALS ( " unsigned int " , typeOf ( " 1u " , " 1u " ) ) ;
ASSERT_EQUALS ( " signed long " , typeOf ( " 1l " , " 1l " ) ) ;
ASSERT_EQUALS ( " unsigned long " , typeOf ( " 1ul " , " 1ul " ) ) ;
ASSERT_EQUALS ( " signed long long " , typeOf ( " 1ll " , " 1ll " ) ) ;
ASSERT_EQUALS ( " unsigned long long " , typeOf ( " 1ull " , " 1ull " ) ) ;
ASSERT_EQUALS ( " float " , typeOf ( " 1.0F " , " 1.0F " ) ) ;
2015-10-07 18:10:48 +02:00
ASSERT_EQUALS ( " float " , typeOf ( " 1.0f " , " 1.0f " ) ) ;
ASSERT_EQUALS ( " double " , typeOf ( " 1.0 " , " 1.0 " ) ) ;
2015-10-04 19:42:58 +02:00
// Constant calculations
2015-10-07 18:10:48 +02:00
ASSERT_EQUALS ( " signed int " , typeOf ( " 1 + 2 " , " + " ) ) ;
ASSERT_EQUALS ( " signed long " , typeOf ( " 1L + 2 " , " + " ) ) ;
ASSERT_EQUALS ( " signed long long " , typeOf ( " 1LL + 2 " , " + " ) ) ;
2015-10-04 19:42:58 +02:00
ASSERT_EQUALS ( " float " , typeOf ( " 1.2f + 3 " , " + " ) ) ;
ASSERT_EQUALS ( " float " , typeOf ( " 1 + 2.3f " , " + " ) ) ;
2015-10-07 19:50:33 +02:00
// promotions
ASSERT_EQUALS ( " signed int " , typeOf ( " (char)1 + (char)2 " , " + " ) ) ;
ASSERT_EQUALS ( " signed int " , typeOf ( " (short)1 + (short)2 " , " + " ) ) ;
ASSERT_EQUALS ( " signed int " , typeOf ( " (signed int)1 + (signed char)2 " , " + " ) ) ;
ASSERT_EQUALS ( " signed int " , typeOf ( " (signed int)1 + (unsigned char)2 " , " + " ) ) ;
ASSERT_EQUALS ( " unsigned int " , typeOf ( " (unsigned int)1 + (signed char)2 " , " + " ) ) ;
ASSERT_EQUALS ( " unsigned int " , typeOf ( " (unsigned int)1 + (unsigned char)2 " , " + " ) ) ;
ASSERT_EQUALS ( " unsigned int " , typeOf ( " (unsigned int)1 + (signed int)2 " , " + " ) ) ;
ASSERT_EQUALS ( " unsigned int " , typeOf ( " (unsigned int)1 + (unsigned int)2 " , " + " ) ) ;
ASSERT_EQUALS ( " signed long " , typeOf ( " (signed long)1 + (unsigned int)2 " , " + " ) ) ;
ASSERT_EQUALS ( " unsigned long " , typeOf ( " (unsigned long)1 + (signed int)2 " , " + " ) ) ;
2015-10-04 19:42:58 +02:00
// char *
2015-10-07 19:08:26 +02:00
ASSERT_EQUALS ( " const char * " , typeOf ( " \" hello \" + 1 " , " + " ) ) ;
2016-02-05 13:31:31 +01:00
ASSERT_EQUALS ( " const char " , typeOf ( " \" hello \" [1] " , " [ " ) ) ;
ASSERT_EQUALS ( " const char " , typeOf ( " * \" hello \" " , " * " ) ) ;
2015-10-11 08:13:30 +02:00
ASSERT_EQUALS ( " const short * " , typeOf ( " L \" hello \" + 1 " , " + " ) ) ;
2015-10-04 19:42:58 +02:00
// Variable calculations
2015-12-29 19:58:51 +01:00
ASSERT_EQUALS ( " void * " , typeOf ( " void *p; a = p + 1; " , " + " ) ) ;
2016-01-31 14:34:26 +01:00
ASSERT_EQUALS ( " signed int " , typeOf ( " int x; a = x + 1; " , " + " ) ) ;
ASSERT_EQUALS ( " signed int " , typeOf ( " int x; a = x | 1; " , " | " ) ) ;
2015-10-04 19:42:58 +02:00
ASSERT_EQUALS ( " float " , typeOf ( " float x; a = x + 1; " , " + " ) ) ;
2015-10-04 23:27:58 +02:00
ASSERT_EQUALS ( " signed int " , typeOf ( " signed x; a = x + 1; " , " x + " ) ) ;
ASSERT_EQUALS ( " unsigned int " , typeOf ( " unsigned x; a = x + 1; " , " x + " ) ) ;
2015-10-07 18:10:48 +02:00
ASSERT_EQUALS ( " unsigned int " , typeOf ( " unsigned int u1, u2; a = u1 + 1; " , " u1 + " ) ) ;
ASSERT_EQUALS ( " unsigned int " , typeOf ( " unsigned int u1, u2; a = u1 + 1U; " , " u1 + " ) ) ;
ASSERT_EQUALS ( " unsigned int " , typeOf ( " unsigned int u1, u2; a = u1 + u2; " , " u1 + " ) ) ;
ASSERT_EQUALS ( " unsigned int " , typeOf ( " unsigned int u1, u2; a = u1 * 2; " , " u1 * " ) ) ;
ASSERT_EQUALS ( " unsigned int " , typeOf ( " unsigned int u1, u2; a = u1 * u2; " , " u1 * " ) ) ;
2016-01-31 14:34:26 +01:00
ASSERT_EQUALS ( " signed int * " , typeOf ( " int x; a = &x; " , " & " ) ) ;
ASSERT_EQUALS ( " signed int * " , typeOf ( " int x; a = &x; " , " & " ) ) ;
2015-10-08 19:50:10 +02:00
ASSERT_EQUALS ( " long double " , typeOf ( " long double x; dostuff(x,1); " , " x , " ) ) ;
ASSERT_EQUALS ( " long double * " , typeOf ( " long double x; dostuff(&x,1); " , " & x , " ) ) ;
2016-01-31 14:34:26 +01:00
ASSERT_EQUALS ( " signed int " , typeOf ( " struct X {int i;}; void f(struct X x) { x.i } " , " . " ) ) ;
2016-02-05 12:06:44 +01:00
ASSERT_EQUALS ( " signed int * " , typeOf ( " int *p; a = p++; " , " ++ " ) ) ;
ASSERT_EQUALS ( " signed int " , typeOf ( " int x; a = x++; " , " ++ " ) ) ;
2016-05-09 11:11:13 +02:00
ASSERT_EQUALS ( " signed int * " , typeOf ( " enum AB {A,B}; AB *ab; x=ab+2; " , " + " ) ) ;
ASSERT_EQUALS ( " signed int * " , typeOf ( " enum AB {A,B}; enum AB *ab; x=ab+2; " , " + " ) ) ;
2016-05-08 13:15:20 +02:00
ASSERT_EQUALS ( " AB * " , typeOf ( " struct AB {int a; int b;}; AB ab; x=&ab; " , " & " ) ) ;
ASSERT_EQUALS ( " AB * " , typeOf ( " struct AB {int a; int b;}; struct AB ab; x=&ab; " , " & " ) ) ;
ASSERT_EQUALS ( " A::BC * " , typeOf ( " namespace A { struct BC { int b; int c; }; }; struct A::BC abc; x=&abc; " , " & " ) ) ;
2016-05-08 14:55:10 +02:00
ASSERT_EQUALS ( " A::BC * " , typeOf ( " namespace A { struct BC { int b; int c; }; }; struct A::BC *abc; x=abc+1; " , " + " ) ) ;
2015-10-04 19:42:58 +02:00
2016-02-04 21:03:54 +01:00
// Unary arithmetic/bit operators
ASSERT_EQUALS ( " signed int " , typeOf ( " int x; a = -x; " , " - " ) ) ;
ASSERT_EQUALS ( " signed int " , typeOf ( " int x; a = ~x; " , " ~ " ) ) ;
ASSERT_EQUALS ( " double " , typeOf ( " double x; a = -x; " , " - " ) ) ;
2016-02-04 21:20:05 +01:00
// Ternary operator
ASSERT_EQUALS ( " signed int " , typeOf ( " int x; a = (b ? x : x) " , " ? " ) ) ;
ASSERT_EQUALS ( " " , typeOf ( " int x; a = (b ? x : y) " , " ? " ) ) ;
ASSERT_EQUALS ( " double " , typeOf ( " int x; double y; a = (b ? x : y) " , " ? " ) ) ;
2016-02-05 09:59:27 +01:00
ASSERT_EQUALS ( " const char * " , typeOf ( " int x; double y; a = (b ? \" a \" : \" b \" ) " , " ? " ) ) ;
ASSERT_EQUALS ( " " , typeOf ( " int x; double y; a = (b ? \" a \" : std::string( \" b \" )) " , " ? " ) ) ;
2016-02-04 21:20:05 +01:00
2016-02-05 15:15:13 +01:00
// Boolean operators
ASSERT_EQUALS ( " bool " , typeOf ( " a > b; " , " > " ) ) ;
ASSERT_EQUALS ( " bool " , typeOf ( " !b; " , " ! " ) ) ;
ASSERT_EQUALS ( " bool " , typeOf ( " c = a && b; " , " && " ) ) ;
2015-12-31 20:18:35 +01:00
// shift => result has same type as lhs
2016-01-31 14:34:26 +01:00
ASSERT_EQUALS ( " signed int " , typeOf ( " int x; a = x << 1U; " , " << " ) ) ;
ASSERT_EQUALS ( " signed int " , typeOf ( " int x; a = x >> 1U; " , " >> " ) ) ;
2016-01-07 10:46:19 +01:00
ASSERT_EQUALS ( " " , typeOf ( " a = 12 >> x; " , " >> " , " test.cpp " ) ) ; // >> might be overloaded
ASSERT_EQUALS ( " signed int " , typeOf ( " a = 12 >> x; " , " >> " , " test.c " ) ) ;
ASSERT_EQUALS ( " " , typeOf ( " a = 12 << x; " , " << " , " test.cpp " ) ) ; // << might be overloaded
ASSERT_EQUALS ( " signed int " , typeOf ( " a = 12 << x; " , " << " , " test.c " ) ) ;
2015-12-31 20:18:35 +01:00
2016-03-21 19:51:09 +01:00
// assignment => result has same type as lhs
ASSERT_EQUALS ( " unsigned short " , typeOf ( " unsigned short x; x = 3; " , " = " ) ) ;
2015-10-04 19:42:58 +02:00
// array..
2015-12-29 19:58:51 +01:00
ASSERT_EQUALS ( " void * * " , typeOf ( " void * x[10]; a = x + 0; " , " + " ) ) ;
2016-01-31 14:34:26 +01:00
ASSERT_EQUALS ( " signed int * " , typeOf ( " int x[10]; a = x + 1; " , " + " ) ) ;
ASSERT_EQUALS ( " signed int " , typeOf ( " int x[10]; a = x[0] + 1; " , " + " ) ) ;
2016-05-23 18:53:59 +02:00
ASSERT_EQUALS ( " " , typeOf ( " a = x[ \" hello \" ]; " , " [ " , " test.cpp " ) ) ;
ASSERT_EQUALS ( " const char " , typeOf ( " a = x[ \" hello \" ]; " , " [ " , " test.c " ) ) ;
2015-10-04 23:27:58 +02:00
// cast..
2015-12-29 19:58:51 +01:00
ASSERT_EQUALS ( " void * " , typeOf ( " a = (void *)0; " , " ( " ) ) ;
2015-10-04 23:27:58 +02:00
ASSERT_EQUALS ( " char " , typeOf ( " a = (char)32; " , " ( " ) ) ;
2016-01-31 14:34:26 +01:00
ASSERT_EQUALS ( " signed long " , typeOf ( " a = (long)32; " , " ( " ) ) ;
ASSERT_EQUALS ( " signed long " , typeOf ( " a = (long int)32; " , " ( " ) ) ;
ASSERT_EQUALS ( " signed long long " , typeOf ( " a = (long long)32; " , " ( " ) ) ;
2015-10-08 19:50:10 +02:00
ASSERT_EQUALS ( " long double " , typeOf ( " a = (long double)32; " , " ( " ) ) ;
2015-12-26 15:20:17 +01:00
ASSERT_EQUALS ( " char " , typeOf ( " a = static_cast<char>(32); " , " ( " ) ) ;
2016-01-05 19:47:11 +01:00
ASSERT_EQUALS ( " " , typeOf ( " a = (unsigned x)0; " , " ( " ) ) ;
2015-10-07 19:08:26 +02:00
// const..
ASSERT_EQUALS ( " const char * " , typeOf ( " a = \" 123 \" ; " , " \" 123 \" " ) ) ;
2016-01-31 14:34:26 +01:00
ASSERT_EQUALS ( " const signed int * " , typeOf ( " const int *a; x = a + 1; " , " a + " ) ) ;
ASSERT_EQUALS ( " signed int * const " , typeOf ( " int * const a; x = a + 1; " , " + " ) ) ;
ASSERT_EQUALS ( " const signed int * " , typeOf ( " const int a[20]; x = a + 1; " , " + " ) ) ;
2016-02-05 13:31:31 +01:00
ASSERT_EQUALS ( " const signed int * " , typeOf ( " const int x; a = &x; " , " & " ) ) ;
ASSERT_EQUALS ( " signed int " , typeOf ( " int * const a; x = *a; " , " * " ) ) ;
ASSERT_EQUALS ( " const signed int " , typeOf ( " const int * const a; x = *a; " , " * " ) ) ;
2015-10-11 08:42:31 +02:00
// function call..
2016-01-31 14:34:26 +01:00
ASSERT_EQUALS ( " signed int " , typeOf ( " int a(int); a(5); " , " ( 5 " ) ) ;
2015-10-11 12:20:40 +02:00
ASSERT_EQUALS ( " unsigned long " , typeOf ( " sizeof(x); " , " ( " ) ) ;
2015-12-30 11:36:46 +01:00
// struct member..
2016-01-31 14:34:26 +01:00
ASSERT_EQUALS ( " signed int " , typeOf ( " struct AB { int a; int b; } ab; x = ab.a; " , " . " ) ) ;
ASSERT_EQUALS ( " signed int " , typeOf ( " struct AB { int a; int b; } *ab; x = ab[1].a; " , " . " ) ) ;
2016-02-04 20:49:13 +01:00
2016-05-25 13:56:36 +02:00
// Overloaded operators
ASSERT_EQUALS ( " Fred " , typeOf ( " class Fred { Fred& operator<(int); }; void f() { Fred fred; x=fred<123; } " , " < " ) ) ;
2016-02-04 20:49:13 +01:00
// Static members
ASSERT_EQUALS ( " signed int " , typeOf ( " struct AB { static int a; }; x = AB::a; " , " :: " ) ) ;
2016-02-05 20:22:30 +01:00
// Pointer to unknown type
ASSERT_EQUALS ( " * " , typeOf ( " Bar* b; " , " b " ) ) ;
2015-10-04 19:42:58 +02:00
}
2010-12-30 09:46:44 +01:00
} ;
REGISTER_TEST ( TestSymbolDatabase )