/*************************************************************************** ** ** This file is part of Qt Creator ** ** Copyright (c) 2008-2009 Nokia Corporation and/or its subsidiary(-ies). ** ** Contact: Qt Software Information (qt-info@nokia.com) ** ** ** Non-Open Source Usage ** ** Licensees may use this file in accordance with the Qt Beta Version ** License Agreement, Agreement version 2.2 provided with the Software or, ** alternatively, in accordance with the terms contained in a written ** agreement between you and Nokia. ** ** GNU General Public License Usage ** ** Alternatively, this file may be used under the terms of the GNU General ** Public License versions 2.0 or 3.0 as published by the Free Software ** Foundation and appearing in the file LICENSE.GPL included in the packaging ** of this file. Please review the following information to ensure GNU ** General Public Licensing requirements will be met: ** ** http://www.fsf.org/licensing/licenses/info/GPLv2.html and ** http://www.gnu.org/copyleft/gpl.html. ** ** In addition, as a special exception, Nokia gives you certain additional ** rights. These rights are described in the Nokia Qt GPL Exception ** version 1.3, included in the file GPL_EXCEPTION.txt in this package. ** ***************************************************************************/ // Copyright (c) 2008 Roberto Raggi // // Permission is hereby granted, free of charge, to any person obtaining a copy // of this software and associated documentation files (the "Software"), to deal // in the Software without restriction, including without limitation the rights // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell // copies of the Software, and to permit persons to whom the Software is // furnished to do so, subject to the following conditions: // // The above copyright notice and this permission notice shall be included in // all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN // THE SOFTWARE. #ifndef CPLUSPLUS_CONTROL_H #define CPLUSPLUS_CONTROL_H #include "CPlusPlusForwardDeclarations.h" #include CPLUSPLUS_BEGIN_HEADER CPLUSPLUS_BEGIN_NAMESPACE class CPLUSPLUS_EXPORT Control { public: Control(); ~Control(); TranslationUnit *translationUnit() const; TranslationUnit *switchTranslationUnit(TranslationUnit *unit); DiagnosticClient *diagnosticClient() const; void setDiagnosticClient(DiagnosticClient *diagnosticClient); /// Returns the canonical name id. NameId *nameId(Identifier *id); /// Returns the canonical template name id. TemplateNameId *templateNameId(Identifier *id, FullySpecifiedType *const args = 0, unsigned argc = 0); /// Returns the canonical destructor name id. DestructorNameId *destructorNameId(Identifier *id); /// Returns the canonical operator name id. OperatorNameId *operatorNameId(int operatorId); /// Returns the canonical conversion name id. ConversionNameId *conversionNameId(FullySpecifiedType type); /// Returns the canonical qualified name id. QualifiedNameId *qualifiedNameId(Name *const *names, unsigned nameCount, bool isGlobal = false); /// Returns a Type object of type VoidType. VoidType *voidType(); /// Returns a Type object of type IntegerType. IntegerType *integerType(int integerId); /// Returns a Type object of type FloatType. FloatType *floatType(int floatId); /// Returns a Type object of type PointertoMemberType. PointerToMemberType *pointerToMemberType(Name *memberName, FullySpecifiedType elementType); /// Returns a Type object of type PointerType. PointerType *pointerType(FullySpecifiedType elementType); /// Returns a Type object of type ReferenceType. ReferenceType *referenceType(FullySpecifiedType elementType); /// Retruns a Type object of type ArrayType. ArrayType *arrayType(FullySpecifiedType elementType, size_t size = 0); /// Returns a Type object of type NamedType. NamedType *namedType(Name *name); /// Creates a new Declaration symbol. Declaration *newDeclaration(unsigned sourceLocation, Name *name = 0); /// Creates a new Argument symbol. Argument *newArgument(unsigned sourceLocation, Name *name = 0); /// Creates a new Function symbol. Function *newFunction(unsigned sourceLocation, Name *name = 0); /// Creates a new Namespace symbol. Namespace *newNamespace(unsigned sourceLocation, Name *name = 0); /// Creates a new BaseClass symbol. BaseClass *newBaseClass(unsigned sourceLocation, Name *name = 0); /// Creates a new Class symbol. Class *newClass(unsigned sourceLocation, Name *name = 0); /// Creates a new Enum symbol. Enum *newEnum(unsigned sourceLocation, Name *name = 0); /// Creates a new Block symbol. Block *newBlock(unsigned sourceLocation); /// Creates a new UsingNamespaceDirective symbol. UsingNamespaceDirective *newUsingNamespaceDirective(unsigned sourceLocation, Name *name = 0); /// Creates a new UsingDeclaration symbol. UsingDeclaration *newUsingDeclaration(unsigned sourceLocation, Name *name = 0); /// Creates a new ForwardClassDeclaration symbol. ForwardClassDeclaration *newForwardClassDeclaration(unsigned sourceLocation, Name *name = 0); Identifier *findOrInsertIdentifier(const char *chars, unsigned size); Identifier *findOrInsertIdentifier(const char *chars); typedef const Identifier *const *IdentifierIterator; IdentifierIterator firstIdentifier() const; IdentifierIterator lastIdentifier() const; StringLiteral *findOrInsertStringLiteral(const char *chars, unsigned size); StringLiteral *findOrInsertStringLiteral(const char *chars); NumericLiteral *findOrInsertNumericLiteral(const char *chars, unsigned size); NumericLiteral *findOrInsertNumericLiteral(const char *chars); StringLiteral *findOrInsertFileName(const char *chars, unsigned size); StringLiteral *findOrInsertFileName(const char *chars); unsigned fileNameCount() const; StringLiteral *fileNameAt(unsigned index) const; private: class Data; friend class Data; Data *d; }; CPLUSPLUS_END_NAMESPACE CPLUSPLUS_END_HEADER #endif // CPLUSPLUS_CONTROL_H