kde-extraapps/kdevplatform/language/duchain/abstractfunctiondeclaration.cpp
2015-07-26 14:23:17 +03:00

92 lines
2.8 KiB
C++

/* This file is part of KDevelop
Copyright 2007 Hamish Rodda <rodda@kde.org>
Copyright 2007-2008 David Nolden <david.nolden.kdevelop@art-master.de>
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Library General Public
License version 2 as published by the Free Software Foundation.
This library 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
Library General Public License for more details.
You should have received a copy of the GNU Library General Public License
along with this library; see the file COPYING.LIB. If not, write to
the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
Boston, MA 02110-1301, USA.
*/
#include "abstractfunctiondeclaration.h"
#include "types/functiontype.h"
#include "declaration.h"
#include "ducontext.h"
#include "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();
}
}
// kate: space-indent on; indent-width 2; tab-width 4; replace-tabs on; auto-insert-doxygen on