forked from qt-creator/qt-creator
Fixes: QTCREATORBUG-24550 Change-Id: Iac4f3b133a632d7272bfe4253f8a0740e51b0952 Reviewed-by: Christian Stenger <christian.stenger@qt.io>
942 lines
24 KiB
C++
942 lines
24 KiB
C++
/****************************************************************************
|
|
**
|
|
** Copyright (C) 2016 The Qt Company Ltd.
|
|
** Contact: https://www.qt.io/licensing/
|
|
**
|
|
** This file is part of Qt Creator.
|
|
**
|
|
** Commercial License Usage
|
|
** Licensees holding valid commercial Qt licenses may use this file in
|
|
** accordance with the commercial license agreement provided with the
|
|
** Software or, alternatively, in accordance with the terms contained in
|
|
** a written agreement between you and The Qt Company. For licensing terms
|
|
** and conditions see https://www.qt.io/terms-conditions. For further
|
|
** information use the contact form at https://www.qt.io/contact-us.
|
|
**
|
|
** GNU General Public License Usage
|
|
** Alternatively, this file may be used under the terms of the GNU
|
|
** General Public License version 3 as published by the Free Software
|
|
** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT
|
|
** included in the packaging of this file. Please review the following
|
|
** information to ensure the GNU General Public License requirements will
|
|
** be met: https://www.gnu.org/licenses/gpl-3.0.html.
|
|
**
|
|
****************************************************************************/
|
|
|
|
#include "googletest.h"
|
|
|
|
#include "clangcompareoperators.h"
|
|
#include "unittest-utility-functions.h"
|
|
|
|
#include <clangdocument.h>
|
|
#include <clangdocuments.h>
|
|
#include <clangstring.h>
|
|
#include <cursor.h>
|
|
#include <sourcelocation.h>
|
|
#include <sourcerange.h>
|
|
#include <clangtranslationunit.h>
|
|
#include <unsavedfiles.h>
|
|
|
|
using ClangBackEnd::Cursor;
|
|
using ClangBackEnd::Document;
|
|
using ClangBackEnd::TranslationUnit;
|
|
using ClangBackEnd::UnsavedFiles;
|
|
using ClangBackEnd::Documents;
|
|
using ClangBackEnd::ClangString;
|
|
using ClangBackEnd::SourceRange;
|
|
|
|
using testing::IsNull;
|
|
using testing::NotNull;
|
|
using testing::Gt;
|
|
using testing::Contains;
|
|
using testing::EndsWith;
|
|
using testing::AllOf;
|
|
using testing::Not;
|
|
using testing::IsEmpty;
|
|
using testing::StrEq;
|
|
using testing::Eq;
|
|
|
|
namespace {
|
|
|
|
struct Data {
|
|
ClangBackEnd::UnsavedFiles unsavedFiles;
|
|
ClangBackEnd::Documents documents{unsavedFiles};
|
|
Utf8String filePath{Utf8StringLiteral(TESTDATA_DIR"/cursor.cpp")};
|
|
Document document{filePath,
|
|
UnitTest::addPlatformArguments({Utf8StringLiteral("-std=c++11")}),
|
|
{},
|
|
documents};
|
|
TranslationUnit translationUnit{filePath,
|
|
filePath,
|
|
document.translationUnit().cxIndex(),
|
|
document.translationUnit().cxTranslationUnit()};
|
|
};
|
|
|
|
class Cursor : public ::testing::Test
|
|
{
|
|
public:
|
|
static void SetUpTestCase();
|
|
static void TearDownTestCase();
|
|
|
|
protected:
|
|
static Data *d;
|
|
const Document &document = d->document;
|
|
const TranslationUnit &translationUnit = d->translationUnit;
|
|
};
|
|
|
|
|
|
|
|
TEST_F(Cursor, CreateNullCursor)
|
|
{
|
|
::Cursor cursor;
|
|
|
|
ASSERT_TRUE(cursor.isNull());
|
|
}
|
|
|
|
TEST_F(Cursor, CompareNullCursors)
|
|
{
|
|
::Cursor cursor;
|
|
::Cursor cursor2;
|
|
|
|
ASSERT_THAT(cursor, cursor2);
|
|
}
|
|
|
|
TEST_F(Cursor, IsNotValid)
|
|
{
|
|
::Cursor cursor;
|
|
|
|
ASSERT_FALSE(cursor.isValid());
|
|
}
|
|
|
|
TEST_F(Cursor, IsValid)
|
|
{
|
|
auto cursor = translationUnit.cursor();
|
|
|
|
ASSERT_TRUE(cursor.isValid());
|
|
}
|
|
|
|
TEST_F(Cursor, IsTranslationUnit)
|
|
{
|
|
auto cursor = translationUnit.cursor();
|
|
|
|
ASSERT_TRUE(cursor.isTranslationUnit());
|
|
}
|
|
|
|
TEST_F(Cursor, NullCursorIsNotTranslationUnit)
|
|
{
|
|
::Cursor cursor;
|
|
|
|
ASSERT_FALSE(cursor.isTranslationUnit());
|
|
}
|
|
|
|
TEST_F(Cursor, UnifiedSymbolResolution)
|
|
{
|
|
::Cursor cursor;
|
|
|
|
ASSERT_FALSE(cursor.unifiedSymbolResolution().hasContent());
|
|
}
|
|
|
|
TEST_F(Cursor, GetCursorAtLocation)
|
|
{
|
|
auto cursor = translationUnit.cursorAt(3, 6);
|
|
|
|
ASSERT_THAT(cursor.unifiedSymbolResolution(), Eq("c:@F@function#I#"));
|
|
}
|
|
|
|
TEST_F(Cursor, GetCursoSourceLocation)
|
|
{
|
|
auto cursor = translationUnit.cursorAt(3, 6);
|
|
|
|
ASSERT_THAT(cursor.sourceLocation(), translationUnit.sourceLocationAt(3, 6));
|
|
}
|
|
|
|
TEST_F(Cursor, GetCursoSourceRange)
|
|
{
|
|
auto cursor = translationUnit.cursorAt(3, 6);
|
|
|
|
ASSERT_THAT(cursor.sourceRange(), SourceRange(translationUnit.sourceLocationAt(3, 1),
|
|
translationUnit.sourceLocationAt(6, 2)));
|
|
}
|
|
|
|
TEST_F(Cursor, Mangling)
|
|
{
|
|
auto cursor = translationUnit.cursorAt(3, 6);
|
|
|
|
ASSERT_TRUE(cursor.mangling().hasContent());
|
|
}
|
|
|
|
TEST_F(Cursor, Spelling)
|
|
{
|
|
auto cursor = translationUnit.cursorAt(3, 6);
|
|
|
|
ASSERT_THAT(cursor.spelling().cString(), StrEq("function"));
|
|
}
|
|
|
|
TEST_F(Cursor, DisplayName)
|
|
{
|
|
auto cursor = translationUnit.cursorAt(3, 6);
|
|
|
|
ASSERT_THAT(cursor.displayName(), Eq("function(int)"));
|
|
}
|
|
|
|
TEST_F(Cursor, BriefComment)
|
|
{
|
|
auto cursor = translationUnit.cursorAt(Utf8StringLiteral(TESTDATA_DIR"/cursor.h"), 10, 7);
|
|
|
|
ASSERT_THAT(cursor.briefComment(), Eq("A brief comment"));
|
|
}
|
|
|
|
TEST_F(Cursor, RawComment)
|
|
{
|
|
auto cursor = translationUnit.cursorAt(Utf8StringLiteral(TESTDATA_DIR"/cursor.h"), 10, 7);
|
|
|
|
ASSERT_THAT(cursor.rawComment(), Eq("/**\n * A brief comment\n */"));
|
|
}
|
|
|
|
TEST_F(Cursor, CommentRange)
|
|
{
|
|
auto cursor = translationUnit.cursorAt(Utf8StringLiteral(TESTDATA_DIR"/cursor.h"), 10, 7);
|
|
|
|
|
|
ASSERT_THAT(cursor.commentRange(),
|
|
SourceRange(translationUnit.sourceLocationAt(Utf8StringLiteral(TESTDATA_DIR"/cursor.h"), 7, 1),
|
|
translationUnit.sourceLocationAt(Utf8StringLiteral(TESTDATA_DIR"/cursor.h"), 9, 4)));
|
|
}
|
|
|
|
TEST_F(Cursor, IsDefinition)
|
|
{
|
|
auto cursor = translationUnit.cursorAt(Utf8StringLiteral(TESTDATA_DIR"/cursor.h"), 10, 7);
|
|
|
|
ASSERT_TRUE(cursor.isDefinition());
|
|
}
|
|
|
|
TEST_F(Cursor, ForwardDeclarationIsNotDefinition)
|
|
{
|
|
auto cursor = translationUnit.cursorAt(Utf8StringLiteral(TESTDATA_DIR"/cursor.h"), 6, 7);
|
|
|
|
ASSERT_FALSE(cursor.isDefinition());
|
|
}
|
|
|
|
TEST_F(Cursor, GetDefinitionOfFowardDeclaration)
|
|
{
|
|
auto forwardDeclarationcursor = translationUnit.cursorAt(Utf8StringLiteral(TESTDATA_DIR"/cursor.h"), 6, 7);
|
|
auto definitionCursor = translationUnit.cursorAt(Utf8StringLiteral(TESTDATA_DIR"/cursor.h"), 10, 7);
|
|
|
|
ASSERT_THAT(forwardDeclarationcursor.definition(), definitionCursor);
|
|
}
|
|
|
|
TEST_F(Cursor, CallToMethodeIsNotDynamic)
|
|
{
|
|
auto cursor = translationUnit.cursorAt(18, 5);
|
|
|
|
ASSERT_FALSE(cursor.isDynamicCall());
|
|
}
|
|
|
|
TEST_F(Cursor, CallToAbstractVirtualMethodeIsDynamic)
|
|
{
|
|
auto cursor = translationUnit.cursorAt(19, 5);
|
|
|
|
ASSERT_TRUE(cursor.isDynamicCall());
|
|
}
|
|
|
|
TEST_F(Cursor, CanonicalCursor)
|
|
{
|
|
auto forwardDeclarationcursor = translationUnit.cursorAt(Utf8StringLiteral(TESTDATA_DIR"/cursor.h"), 6, 7);
|
|
auto definitionCursor = translationUnit.cursorAt(Utf8StringLiteral(TESTDATA_DIR"/cursor.h"), 10, 7);
|
|
|
|
ASSERT_THAT(definitionCursor.canonical(), forwardDeclarationcursor);
|
|
}
|
|
|
|
TEST_F(Cursor, ReferencedCursor)
|
|
{
|
|
auto functionCallCursor = translationUnit.cursorAt(18, 5);
|
|
auto functionCursor = translationUnit.cursorAt(16, 17);
|
|
|
|
ASSERT_THAT(functionCallCursor.referenced(), functionCursor);
|
|
}
|
|
|
|
TEST_F(Cursor, IsVirtual)
|
|
{
|
|
auto cursor = translationUnit.cursorAt(Utf8StringLiteral(TESTDATA_DIR"/cursor.h"), 15, 17);
|
|
|
|
ASSERT_TRUE(cursor.isVirtualMethod());
|
|
}
|
|
|
|
TEST_F(Cursor, IsNotPureVirtualOnlyVirtual)
|
|
{
|
|
auto cursor = translationUnit.cursorAt(Utf8StringLiteral(TESTDATA_DIR"/cursor.h"), 15, 17);
|
|
|
|
ASSERT_FALSE(cursor.isPureVirtualMethod());
|
|
}
|
|
|
|
TEST_F(Cursor, IsPureVirtual)
|
|
{
|
|
auto cursor = translationUnit.cursorAt(Utf8StringLiteral(TESTDATA_DIR"/cursor.h"), 16, 17);
|
|
|
|
ASSERT_TRUE(cursor.isPureVirtualMethod());
|
|
}
|
|
|
|
TEST_F(Cursor, ConstantMethod)
|
|
{
|
|
auto cursor = translationUnit.cursorAt(31, 18);
|
|
|
|
ASSERT_TRUE(cursor.isConstantMethod());
|
|
}
|
|
|
|
TEST_F(Cursor, IsStaticMethod)
|
|
{
|
|
auto cursor = translationUnit.cursorAt(36, 18);
|
|
|
|
ASSERT_TRUE(cursor.isStaticMethod());
|
|
}
|
|
|
|
TEST_F(Cursor, TypeSpelling)
|
|
{
|
|
auto cursor = translationUnit.cursorAt(43, 5);
|
|
|
|
ASSERT_THAT(cursor.type().utf8Spelling(), Utf8StringLiteral("lint"));
|
|
}
|
|
|
|
TEST_F(Cursor, CanonicalTypeSpelling)
|
|
{
|
|
auto cursor = translationUnit.cursorAt(43, 5);
|
|
|
|
ASSERT_THAT(cursor.type().canonical().utf8Spelling(), Utf8StringLiteral("long long"));
|
|
}
|
|
|
|
TEST_F(Cursor, CanonicalTypeCStringSpelling)
|
|
{
|
|
auto cursor = translationUnit.cursorAt(43, 5);
|
|
|
|
auto spelling = cursor.type().canonical().spelling();
|
|
|
|
ASSERT_THAT(spelling.cString(), StrEq("long long"));
|
|
}
|
|
|
|
TEST_F(Cursor, CanonicalTypeIsNotType)
|
|
{
|
|
auto cursor = translationUnit.cursorAt(43, 5);
|
|
|
|
ASSERT_THAT(cursor.type().canonical(), Not(cursor.type()));
|
|
}
|
|
|
|
TEST_F(Cursor, TypeDeclartionIsAlias)
|
|
{
|
|
auto declarationCursor = translationUnit.cursorAt(41, 5);
|
|
auto lintCursor = translationUnit.cursorAt(39, 11);
|
|
|
|
ASSERT_THAT(declarationCursor.type().declaration().type(), lintCursor.type());
|
|
}
|
|
|
|
TEST_F(Cursor, TypeIsConstantWithoutAliasLookup)
|
|
{
|
|
auto cursor = translationUnit.cursorAt(45, 16);
|
|
|
|
ASSERT_TRUE(cursor.type().isConstant());
|
|
}
|
|
|
|
TEST_F(Cursor, ClassIsCompoundType)
|
|
{
|
|
auto cursor = translationUnit.cursorAt(Utf8StringLiteral(TESTDATA_DIR"/cursor.h"), 10, 7);
|
|
|
|
ASSERT_TRUE(cursor.isCompoundType());
|
|
}
|
|
|
|
TEST_F(Cursor, StructIsCompoundType)
|
|
{
|
|
auto cursor = translationUnit.cursorAt(Utf8StringLiteral(TESTDATA_DIR"/cursor.h"), 28, 8);
|
|
|
|
ASSERT_TRUE(cursor.isCompoundType());
|
|
}
|
|
|
|
TEST_F(Cursor, UnionIsCompoundType)
|
|
{
|
|
auto cursor = translationUnit.cursorAt(Utf8StringLiteral(TESTDATA_DIR"/cursor.h"), 33, 7);
|
|
|
|
ASSERT_TRUE(cursor.isCompoundType());
|
|
}
|
|
|
|
TEST_F(Cursor, IsDeclaration)
|
|
{
|
|
auto cursor = translationUnit.cursorAt(41, 10);
|
|
|
|
ASSERT_TRUE(cursor.isDeclaration());
|
|
}
|
|
|
|
TEST_F(Cursor, SemanticParent)
|
|
{
|
|
auto cursor = translationUnit.cursorAt(43, 6);
|
|
auto expectedSemanticParent = translationUnit.cursorAt(36, 18);
|
|
|
|
auto semanticParent = cursor.semanticParent();
|
|
|
|
ASSERT_THAT(semanticParent, expectedSemanticParent);
|
|
}
|
|
|
|
TEST_F(Cursor, IsLocalVariableInMethod)
|
|
{
|
|
auto cursor = translationUnit.cursorAt(20, 9);
|
|
|
|
ASSERT_TRUE(cursor.isLocalVariable());
|
|
}
|
|
|
|
TEST_F(Cursor, IsLocalVariableInStaticFunction)
|
|
{
|
|
auto cursor = translationUnit.cursorAt(43, 5);
|
|
|
|
ASSERT_TRUE(cursor.isLocalVariable());
|
|
}
|
|
|
|
TEST_F(Cursor, IsLocalVariableInTemplateFunction)
|
|
{
|
|
auto cursor = translationUnit.cursorAt(52, 7);
|
|
|
|
ASSERT_TRUE(cursor.isLocalVariable());
|
|
}
|
|
|
|
TEST_F(Cursor, IsLocalVariableInConversionOperator)
|
|
{
|
|
auto cursor = translationUnit.cursorAt(57, 9);
|
|
|
|
ASSERT_TRUE(cursor.isLocalVariable());
|
|
}
|
|
|
|
TEST_F(Cursor, IsLocalVariableInOperator)
|
|
{
|
|
auto cursor = translationUnit.cursorAt(62, 9);
|
|
|
|
ASSERT_TRUE(cursor.isLocalVariable());
|
|
}
|
|
|
|
TEST_F(Cursor, IsLocalVariableInConstructor)
|
|
{
|
|
auto cursor = translationUnit.cursorAt(13, 9);
|
|
|
|
ASSERT_TRUE(cursor.isLocalVariable());
|
|
}
|
|
|
|
TEST_F(Cursor, IsLocalVariableInDestructor)
|
|
{
|
|
auto cursor = translationUnit.cursorAt(69, 9);
|
|
|
|
ASSERT_TRUE(cursor.isLocalVariable());
|
|
}
|
|
|
|
TEST_F(Cursor, FindFunctionCaller)
|
|
{
|
|
auto functionCursor = translationUnit.cursorAt(92, 24);
|
|
auto structCursor = translationUnit.cursorAt(Utf8StringLiteral(TESTDATA_DIR"/cursor.h"), 28, 8);
|
|
|
|
ASSERT_THAT(functionCursor.functionBaseDeclaration(), structCursor);
|
|
}
|
|
|
|
TEST_F(Cursor, FindFunctionCallerPointer)
|
|
{
|
|
auto functionCursor = translationUnit.cursorAt(79, 25);
|
|
auto structCursor = translationUnit.cursorAt(Utf8StringLiteral(TESTDATA_DIR"/cursor.h"), 28, 8);
|
|
|
|
ASSERT_THAT(functionCursor.functionBaseDeclaration(), structCursor);
|
|
}
|
|
|
|
TEST_F(Cursor, FindFunctionCallerThis)
|
|
{
|
|
auto functionCursor = translationUnit.cursorAt(106, 5);
|
|
auto structCursor = translationUnit.cursorAt(Utf8StringLiteral(TESTDATA_DIR"/cursor.h"), 38, 8);
|
|
|
|
ASSERT_THAT(functionCursor.functionBaseDeclaration(), structCursor);
|
|
}
|
|
|
|
TEST_F(Cursor, NonPointerTypeForValue)
|
|
{
|
|
auto variableCursor = translationUnit.cursorAt(101, 10);
|
|
auto variablePointerCursor = translationUnit.cursorAt(100, 11);
|
|
|
|
ASSERT_THAT(variableCursor.nonPointerTupe(), variablePointerCursor.nonPointerTupe());
|
|
}
|
|
|
|
TEST_F(Cursor, HasFinalAttributeInFunction)
|
|
{
|
|
auto cursor = translationUnit.cursorAt(Utf8StringLiteral(TESTDATA_DIR"/cursor.h"), 30, 18);
|
|
|
|
ASSERT_TRUE(cursor.hasFinalFunctionAttribute());
|
|
}
|
|
|
|
TEST_F(Cursor, HasNotFinalAttributeInFunction)
|
|
{
|
|
auto cursor = translationUnit.cursorAt(Utf8StringLiteral(TESTDATA_DIR"/cursor.h"), 15, 17);
|
|
|
|
ASSERT_FALSE(cursor.hasFinalFunctionAttribute());
|
|
}
|
|
|
|
TEST_F(Cursor, HasFinalAttributeInClass)
|
|
{
|
|
auto cursor = translationUnit.cursorAt(Utf8StringLiteral(TESTDATA_DIR"/cursor.h"), 28, 8);
|
|
|
|
ASSERT_TRUE(cursor.hasFinalClassAttribute());
|
|
}
|
|
|
|
TEST_F(Cursor, HasNotFinaAttributeInClass)
|
|
{
|
|
auto cursor = translationUnit.cursorAt(Utf8StringLiteral(TESTDATA_DIR"/cursor.h"), 38, 8);
|
|
|
|
ASSERT_FALSE(cursor.hasFinalClassAttribute());
|
|
}
|
|
|
|
TEST_F(Cursor, HasOutputValues)
|
|
{
|
|
auto callExpressionCursor = translationUnit.cursorAt(117, 19);
|
|
auto outputArgumentExpectedSourceLocation = translationUnit.cursorAt(117, 20).cxSourceRange();
|
|
|
|
auto outputArgumentLocations = callExpressionCursor.outputArgumentRanges();
|
|
|
|
ASSERT_THAT(outputArgumentLocations.size(), 2);
|
|
ASSERT_THAT(outputArgumentLocations[0], outputArgumentExpectedSourceLocation);
|
|
}
|
|
|
|
TEST_F(Cursor, HasOnlyInputValues)
|
|
{
|
|
auto callExpressionCursor = translationUnit.cursorAt(118, 18);
|
|
|
|
auto outputArgumentLocations = callExpressionCursor.outputArgumentRanges();
|
|
|
|
ASSERT_THAT(outputArgumentLocations, IsEmpty());
|
|
}
|
|
|
|
TEST_F(Cursor, ArgumentCountIsZero)
|
|
{
|
|
auto cursor = translationUnit.cursorAt(121, 23);
|
|
|
|
auto count = cursor.type().argumentCount();
|
|
|
|
ASSERT_THAT(count, 0);
|
|
}
|
|
|
|
TEST_F(Cursor, ArgumentCountIsTwo)
|
|
{
|
|
auto cursor = translationUnit.cursorAt(122, 22);
|
|
|
|
auto count = cursor.type().argumentCount();
|
|
|
|
ASSERT_THAT(count, 2);
|
|
}
|
|
|
|
TEST_F(Cursor, ArgumentOneIsValue)
|
|
{
|
|
auto callExpressionCursor = translationUnit.cursorAt(122, 22);
|
|
|
|
auto argument = callExpressionCursor.type().argument(0);
|
|
|
|
ASSERT_FALSE(argument.isConstant());
|
|
ASSERT_THAT(argument.kind(), CXType_Int);
|
|
}
|
|
|
|
TEST_F(Cursor, ArgumentTwoIsLValueReference)
|
|
{
|
|
auto callExpressionCursor = translationUnit.cursorAt(122, 22);
|
|
|
|
auto argument = callExpressionCursor.type().argument(1);
|
|
|
|
ASSERT_THAT(argument.kind(), CXType_LValueReference);
|
|
}
|
|
|
|
TEST_F(Cursor, ArgumentTwoIsConstantReference)
|
|
{
|
|
auto callExpressionCursor = translationUnit.cursorAt(122, 22);
|
|
|
|
auto argumentPointee = callExpressionCursor.type().argument(1);
|
|
|
|
ASSERT_TRUE(argumentPointee.isConstantReference());
|
|
}
|
|
|
|
TEST_F(Cursor, CursorArgumentCount)
|
|
{
|
|
auto cursor = translationUnit.cursorAt(117, 19);
|
|
|
|
ASSERT_THAT(cursor.kind(), CXCursor_CallExpr);
|
|
ASSERT_THAT(cursor.argumentCount(), 4);
|
|
}
|
|
|
|
TEST_F(Cursor, CursorArgumentInputValue)
|
|
{
|
|
auto callExpressionCursor = translationUnit.cursorAt(117, 19);
|
|
auto declarationReferenceExpressionCursor = translationUnit.cursorAt(117, 20);
|
|
|
|
ASSERT_THAT(callExpressionCursor.argument(0), declarationReferenceExpressionCursor);
|
|
}
|
|
|
|
TEST_F(Cursor, IsConstantLValueReference)
|
|
{
|
|
auto callExpressionCursor = translationUnit.cursorAt(125, 26);
|
|
|
|
auto argument = callExpressionCursor.type().argument(0);
|
|
|
|
ASSERT_TRUE(argument.isConstantReference());
|
|
}
|
|
|
|
TEST_F(Cursor, LValueReferenceIsNotConstantLValueReference)
|
|
{
|
|
auto callExpressionCursor = translationUnit.cursorAt(124, 21);
|
|
|
|
auto argument = callExpressionCursor.type().argument(0);
|
|
|
|
ASSERT_FALSE(argument.isConstantReference());
|
|
}
|
|
|
|
TEST_F(Cursor, ValueIsNotConstantLValueReference)
|
|
{
|
|
auto callExpressionCursor = translationUnit.cursorAt(123, 18);
|
|
|
|
auto argument = callExpressionCursor.type().argument(0);
|
|
|
|
ASSERT_FALSE(argument.isConstantReference());
|
|
}
|
|
|
|
TEST_F(Cursor, PointerToConstantNotConstantLValueReference)
|
|
{
|
|
auto callExpressionCursor = translationUnit.cursorAt(126, 20);
|
|
|
|
auto argument = callExpressionCursor.type().argument(0);
|
|
|
|
ASSERT_FALSE(argument.isConstantReference());
|
|
}
|
|
|
|
TEST_F(Cursor, IsLValueReference)
|
|
{
|
|
auto callExpressionCursor = translationUnit.cursorAt(124, 21);
|
|
|
|
auto argument = callExpressionCursor.type().argument(0);
|
|
|
|
ASSERT_TRUE(argument.isLValueReference());
|
|
}
|
|
|
|
TEST_F(Cursor, ConstantLValueReferenceIsLValueReference)
|
|
{
|
|
auto callExpressionCursor = translationUnit.cursorAt(125, 26);
|
|
|
|
auto argument = callExpressionCursor.type().argument(0);
|
|
|
|
ASSERT_TRUE(argument.isLValueReference());
|
|
}
|
|
|
|
TEST_F(Cursor, ValueIsNotLValueReference)
|
|
{
|
|
auto callExpressionCursor = translationUnit.cursorAt(123, 18);
|
|
|
|
auto argument = callExpressionCursor.type().argument(0);
|
|
|
|
ASSERT_FALSE(argument.isLValueReference());
|
|
}
|
|
|
|
TEST_F(Cursor, PointerIsNotLValueReference)
|
|
{
|
|
auto callExpressionCursor = translationUnit.cursorAt(126, 20);
|
|
|
|
auto argument = callExpressionCursor.type().argument(0);
|
|
|
|
ASSERT_FALSE(argument.isLValueReference());
|
|
}
|
|
|
|
TEST_F(Cursor, PointerToConstant)
|
|
{
|
|
auto callExpressionCursor = translationUnit.cursorAt(126, 20);
|
|
|
|
auto argument = callExpressionCursor.type().argument(0);
|
|
|
|
ASSERT_TRUE(argument.isPointerToConstant());
|
|
}
|
|
|
|
TEST_F(Cursor, ValueIsNotPointerToConstant)
|
|
{
|
|
auto callExpressionCursor = translationUnit.cursorAt(123, 18);
|
|
|
|
auto argument = callExpressionCursor.type().argument(0);
|
|
|
|
ASSERT_FALSE(argument.isPointerToConstant());
|
|
}
|
|
|
|
TEST_F(Cursor, PointerNotPointerToConstant)
|
|
{
|
|
auto callExpressionCursor = translationUnit.cursorAt(127, 13);
|
|
|
|
auto argument = callExpressionCursor.type().argument(0);
|
|
|
|
ASSERT_FALSE(argument.isPointerToConstant());
|
|
}
|
|
|
|
TEST_F(Cursor, ConstantLValueReferenceIsNotPointerToConstant)
|
|
{
|
|
auto callExpressionCursor = translationUnit.cursorAt(125, 26);
|
|
|
|
auto argument = callExpressionCursor.type().argument(0);
|
|
|
|
ASSERT_FALSE(argument.isPointerToConstant());
|
|
}
|
|
|
|
TEST_F(Cursor, IsConstantPointer)
|
|
{
|
|
auto callExpressionCursor = translationUnit.cursorAt(128, 21);
|
|
|
|
auto argument = callExpressionCursor.type().argument(0);
|
|
|
|
ASSERT_TRUE(argument.isConstantPointer());
|
|
}
|
|
|
|
TEST_F(Cursor, PointerToConstantIsNotConstantPointer)
|
|
{
|
|
auto callExpressionCursor = translationUnit.cursorAt(126, 20);
|
|
|
|
auto argument = callExpressionCursor.type().argument(0);
|
|
|
|
ASSERT_FALSE(argument.isConstantPointer());
|
|
}
|
|
|
|
TEST_F(Cursor, ConstValueIsNotConstantPointer)
|
|
{
|
|
auto callExpressionCursor = translationUnit.cursorAt(129, 23);
|
|
|
|
auto argument = callExpressionCursor.type().argument(0);
|
|
|
|
ASSERT_FALSE(argument.isConstantPointer());
|
|
}
|
|
|
|
TEST_F(Cursor, PointerToConstantIsReferencingConstant)
|
|
{
|
|
auto callExpressionCursor = translationUnit.cursorAt(126, 20);
|
|
|
|
auto argument = callExpressionCursor.type().argument(0);
|
|
|
|
ASSERT_TRUE(argument.isReferencingConstant());
|
|
}
|
|
|
|
TEST_F(Cursor, ConstantReferenceIsReferencingConstant)
|
|
{
|
|
auto callExpressionCursor = translationUnit.cursorAt(125, 26);
|
|
|
|
auto argument = callExpressionCursor.type().argument(0);
|
|
|
|
ASSERT_TRUE(argument.isReferencingConstant());
|
|
}
|
|
|
|
TEST_F(Cursor, LValueReferenceIsNotReferencingConstant)
|
|
{
|
|
auto callExpressionCursor = translationUnit.cursorAt(124, 21);
|
|
|
|
auto argument = callExpressionCursor.type().argument(0);
|
|
|
|
ASSERT_FALSE(argument.isReferencingConstant());
|
|
}
|
|
|
|
TEST_F(Cursor, ValueIsNotReferencingConstant)
|
|
{
|
|
auto callExpressionCursor = translationUnit.cursorAt(123, 18);
|
|
|
|
auto argument = callExpressionCursor.type().argument(0);
|
|
|
|
ASSERT_FALSE(argument.isReferencingConstant());
|
|
}
|
|
|
|
TEST_F(Cursor, PointerIsNotRefencingConstant)
|
|
{
|
|
auto callExpressionCursor = translationUnit.cursorAt(127, 13);
|
|
|
|
auto argument = callExpressionCursor.type().argument(0);
|
|
|
|
ASSERT_FALSE(argument.isReferencingConstant());
|
|
}
|
|
|
|
TEST_F(Cursor, PointerIsOutputArgument)
|
|
{
|
|
auto callExpressionCursor = translationUnit.cursorAt(127, 13);
|
|
|
|
auto argument = callExpressionCursor.type().argument(0);
|
|
|
|
ASSERT_TRUE(argument.isOutputArgument());
|
|
}
|
|
|
|
TEST_F(Cursor, ConstantReferenceIsNotOutputArgument)
|
|
{
|
|
auto callExpressionCursor = translationUnit.cursorAt(125, 26);
|
|
|
|
auto argument = callExpressionCursor.type().argument(0);
|
|
|
|
ASSERT_FALSE(argument.isOutputArgument());
|
|
}
|
|
|
|
TEST_F(Cursor, PointerToConstantIsNotOutputArgument)
|
|
{
|
|
auto callExpressionCursor = translationUnit.cursorAt(126, 20);
|
|
|
|
auto argument = callExpressionCursor.type().argument(0);
|
|
|
|
ASSERT_FALSE(argument.isOutputArgument()) << argument.isConstant() << argument.pointeeType().isConstant();
|
|
}
|
|
|
|
TEST_F(Cursor, ConstantPointerIsOutputArgument)
|
|
{
|
|
auto callExpressionCursor = translationUnit.cursorAt(128, 21);
|
|
|
|
auto argument = callExpressionCursor.type().argument(0);
|
|
|
|
ASSERT_TRUE(argument.isOutputArgument());
|
|
}
|
|
|
|
TEST_F(Cursor, ReferenceIsOutputArgument)
|
|
{
|
|
auto callExpressionCursor = translationUnit.cursorAt(124, 21);
|
|
|
|
auto argument = callExpressionCursor.type().argument(0);
|
|
|
|
ASSERT_TRUE(argument.isOutputArgument());
|
|
}
|
|
|
|
TEST_F(Cursor, ConstReferenceIsNotOutputArgument)
|
|
{
|
|
auto callExpressionCursor = translationUnit.cursorAt(125, 26);
|
|
|
|
auto argument = callExpressionCursor.type().argument(0);
|
|
|
|
ASSERT_FALSE(argument.isOutputArgument());
|
|
}
|
|
|
|
TEST_F(Cursor, ResultType)
|
|
{
|
|
auto methodCursor = translationUnit.cursorAt(31, 18);
|
|
|
|
Utf8String resultType = methodCursor.type().resultType().spelling();
|
|
|
|
ASSERT_THAT(resultType, Utf8String("bool", 4));
|
|
}
|
|
|
|
TEST_F(Cursor, PrivateMethodAccessSpecifier)
|
|
{
|
|
auto methodCursor = translationUnit.cursorAt(16, 17);
|
|
|
|
auto accessSpecifier = methodCursor.accessSpecifier();
|
|
|
|
ASSERT_THAT(accessSpecifier, ClangBackEnd::AccessSpecifier::Private);
|
|
}
|
|
|
|
TEST_F(Cursor, PublicMethodAccessSpecifier)
|
|
{
|
|
auto methodCursor = translationUnit.cursorAt(79, 25);
|
|
|
|
auto accessSpecifier = methodCursor.accessSpecifier();
|
|
|
|
ASSERT_THAT(accessSpecifier, ClangBackEnd::AccessSpecifier::Public);
|
|
}
|
|
|
|
TEST_F(Cursor, ProtectedMethodAccessSpecifier)
|
|
{
|
|
auto methodCursor = translationUnit.cursorAt(131, 22);
|
|
|
|
auto accessSpecifier = methodCursor.accessSpecifier();
|
|
|
|
ASSERT_THAT(accessSpecifier, ClangBackEnd::AccessSpecifier::Protected);
|
|
}
|
|
|
|
TEST_F(Cursor, PrivateFieldAccessSpecifier)
|
|
{
|
|
auto fieldCursor = translationUnit.cursorAt(21, 12);
|
|
|
|
auto accessSpecifier = fieldCursor.accessSpecifier();
|
|
|
|
ASSERT_THAT(accessSpecifier, ClangBackEnd::AccessSpecifier::Private);
|
|
}
|
|
|
|
TEST_F(Cursor, InvalidAccessSpecifier)
|
|
{
|
|
auto localVarCursor = translationUnit.cursorAt(62, 9);
|
|
|
|
auto accessSpecifier = localVarCursor.accessSpecifier();
|
|
|
|
ASSERT_THAT(accessSpecifier, ClangBackEnd::AccessSpecifier::Invalid);
|
|
}
|
|
|
|
TEST_F(Cursor, NoStorageClass)
|
|
{
|
|
auto localVarCursor = translationUnit.cursorAt(62, 9);
|
|
|
|
auto storageClass = localVarCursor.storageClass();
|
|
|
|
ASSERT_THAT(storageClass, ClangBackEnd::StorageClass::None);
|
|
}
|
|
|
|
TEST_F(Cursor, ExternVarStorageClass)
|
|
{
|
|
auto externalVarCursor = translationUnit.cursorAt(133, 12);
|
|
|
|
auto storageClass = externalVarCursor.storageClass();
|
|
|
|
ASSERT_THAT(storageClass, ClangBackEnd::StorageClass::Extern);
|
|
}
|
|
|
|
TEST_F(Cursor, StaticMethodStorageClass)
|
|
{
|
|
auto methodCursor = translationUnit.cursorAt(135, 13);
|
|
|
|
auto storageClass = methodCursor.storageClass();
|
|
|
|
ASSERT_THAT(storageClass, ClangBackEnd::StorageClass::Static);
|
|
}
|
|
|
|
TEST_F(Cursor, InvalidStorageClass)
|
|
{
|
|
auto functionTemplateCursor = translationUnit.cursorAt(137, 28);
|
|
|
|
auto storageClass = functionTemplateCursor.storageClass();
|
|
|
|
ASSERT_THAT(storageClass, ClangBackEnd::StorageClass::Invalid);
|
|
}
|
|
|
|
TEST_F(Cursor, IsAnonymousNamespace)
|
|
{
|
|
auto anonymousCursor = translationUnit.cursorAt(140, 1);
|
|
|
|
bool anonymous = anonymousCursor.isAnonymous();
|
|
|
|
ASSERT_THAT(anonymous, true);
|
|
}
|
|
|
|
TEST_F(Cursor, IsNotAnonymousNamespace)
|
|
{
|
|
auto anonymousCursor = translationUnit.cursorAt(139, 1);
|
|
|
|
bool anonymous = anonymousCursor.isAnonymous();
|
|
|
|
ASSERT_THAT(anonymous, false);
|
|
}
|
|
|
|
TEST_F(Cursor, AnonymousNamespaceDisplayName)
|
|
{
|
|
auto anonymousCursor = translationUnit.cursorAt(140, 1);
|
|
|
|
auto name = anonymousCursor.displayName();
|
|
|
|
ASSERT_THAT(name, Utf8String("(anonymous)"));
|
|
}
|
|
|
|
TEST_F(Cursor, AnonymousEnumDisplayName)
|
|
{
|
|
auto anonymousCursor = translationUnit.cursorAt(144, 1);
|
|
|
|
auto name = anonymousCursor.displayName();
|
|
|
|
ASSERT_THAT(name, Utf8String("(anonymous)"));
|
|
}
|
|
|
|
Data *Cursor::d;
|
|
|
|
void Cursor::SetUpTestCase()
|
|
{
|
|
d = new Data;
|
|
d->document.parse();
|
|
}
|
|
|
|
void Cursor::TearDownTestCase()
|
|
{
|
|
delete d;
|
|
d = nullptr;
|
|
}
|
|
|
|
}
|