File: abstractfunctiondeclaration.cpp

package info (click to toggle)
kdevelop 4%3A24.12.3-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 71,888 kB
  • sloc: cpp: 290,869; python: 3,626; javascript: 3,518; sh: 1,316; ansic: 703; xml: 401; php: 95; lisp: 66; makefile: 31; sed: 12
file content (78 lines) | stat: -rw-r--r-- 2,131 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
/*
    SPDX-FileCopyrightText: 2007 Hamish Rodda <rodda@kde.org>
    SPDX-FileCopyrightText: 2007-2008 David Nolden <david.nolden.kdevelop@art-master.de>

    SPDX-License-Identifier: LGPL-2.0-only
*/

#include "abstractfunctiondeclaration.h"

#include "types/functiontype.h"
#include "declaration.h"
#include "ducontext.h"
#include <serialization/indexedstring.h>

namespace KDevelop {
AbstractFunctionDeclaration::~AbstractFunctionDeclaration()
{
}

bool AbstractFunctionDeclaration::isVirtual() const
{
    return data()->m_isVirtual;
}

void AbstractFunctionDeclaration::setVirtual(bool isVirtual)
{
    dynamicData()->m_isVirtual = isVirtual;
}

bool AbstractFunctionDeclaration::isInline() const
{
    return data()->m_isInline;
}

void AbstractFunctionDeclaration::setInline(bool isInline)
{
    dynamicData()->m_isInline = isInline;
}

bool AbstractFunctionDeclaration::isExplicit() const
{
    return data()->m_isExplicit;
}

void AbstractFunctionDeclaration::setExplicit(bool isExplicit)
{
    dynamicData()->m_isExplicit = isExplicit;
}

void AbstractFunctionDeclaration::setFunctionSpecifiers(FunctionSpecifiers specifiers)
{
    dynamicData()->m_isInline = specifiers & InlineSpecifier;
    dynamicData()->m_isExplicit = specifiers & ExplicitSpecifier;
    dynamicData()->m_isVirtual = specifiers & VirtualSpecifier;
}

IndexedString AbstractFunctionDeclaration::defaultParameterForArgument(int index) const
{
    FunctionType::Ptr fType = dynamic_cast<const Declaration*>(this)->type<FunctionType>();
    if (fType && index >= 0 && index < fType->arguments().size()) {
        index -= (fType->arguments().size() - defaultParametersSize());
        if (index >= 0 && index < ( int )defaultParametersSize())
            return defaultParameters()[index];
    }

    return IndexedString();
}

void AbstractFunctionDeclaration::setInternalFunctionContext(DUContext* context)
{
    Q_ASSERT(!context || context->type() == DUContext::Function);
    dynamicData()->m_functionContext = context;
}
DUContext* AbstractFunctionDeclaration::internalFunctionContext() const
{
    return data()->m_functionContext.context();
}
}