diff options
author | Christian Kandeler <christian.kandeler@qt.io> | 2021-08-30 10:58:08 +0200 |
---|---|---|
committer | Christian Kandeler <christian.kandeler@qt.io> | 2021-09-01 14:53:58 +0000 |
commit | 284817fae6514701902ccdb834c2faa46462f2e8 (patch) | |
tree | 44a8c7d9813dc110b61c4639036366c7696bd7e9 /src/plugins/cppeditor/cpppointerdeclarationformatter.h | |
parent | 3e1fa0f170d523971d2c3c12da15a6e291f56511 (diff) |
Merge CppTools into CppEditor
There was no proper separation of responsibilities between these
plugins. In particular, CppTools had lots of editor-related
functionality, so it's not clear why it was separated out in the first
place.
In fact, for a lot of code, it seemed quite arbitrary where it was put
(just one example: switchHeaderSource() was in CppTools, wheras
switchDeclarationDefinition() was in CppEditor).
Merging the plugins will enable us to get rid of various convoluted
pseudo-abstractions that were only introduced to keep up the artificial
separation.
Change-Id: Iafc3bce625b4794f6d4aa03df6cddc7f2d26716a
Reviewed-by: Christian Stenger <christian.stenger@qt.io>
Diffstat (limited to 'src/plugins/cppeditor/cpppointerdeclarationformatter.h')
-rw-r--r-- | src/plugins/cppeditor/cpppointerdeclarationformatter.h | 120 |
1 files changed, 120 insertions, 0 deletions
diff --git a/src/plugins/cppeditor/cpppointerdeclarationformatter.h b/src/plugins/cppeditor/cpppointerdeclarationformatter.h new file mode 100644 index 0000000000..8e5069ed8f --- /dev/null +++ b/src/plugins/cppeditor/cpppointerdeclarationformatter.h @@ -0,0 +1,120 @@ +/**************************************************************************** +** +** 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. +** +****************************************************************************/ + +#pragma once + +#include "cppeditor_global.h" +#include "cpprefactoringchanges.h" + +#include <cplusplus/ASTVisitor.h> + +#include <utils/changeset.h> + +namespace CPlusPlus { class Overview; } + +namespace CppEditor { + +using namespace CPlusPlus; + +/*! + \class CppEditor::PointerDeclarationFormatter + + \brief The PointerDeclarationFormatter class rewrites pointer or reference + declarations to an Overview. + + The following constructs are supported: + \list + \li Simple declarations + \li Parameters and return types of function declarations and definitions + \li Control flow statements like if, while, for, foreach + \endlist +*/ + +class CPPEDITOR_EXPORT PointerDeclarationFormatter: protected ASTVisitor +{ +public: + /*! + \enum PointerDeclarationFormatter::CursorHandling + + This enum type simplifies the QuickFix implementation. + + \value RespectCursor + Consider the cursor position or selection of the CppRefactoringFile + for rejecting edit operation candidates for the resulting ChangeSet. + If there is a selection, the range of the edit operation candidate + should be inside the selection. If there is no selection, the cursor + position should be within the range of the edit operation candidate. + \value IgnoreCursor + Cursor position or selection of the CppRefactoringFile will + _not_ be considered for aborting. + */ + enum CursorHandling { RespectCursor, IgnoreCursor }; + + explicit PointerDeclarationFormatter(const CppRefactoringFilePtr &refactoringFile, + Overview &overview, + CursorHandling cursorHandling = IgnoreCursor); + + /*! + Returns a ChangeSet for applying the formatting changes. + The ChangeSet is empty if it was not possible to rewrite anything. + */ + Utils::ChangeSet format(AST *ast) + { + if (ast) + accept(ast); + return m_changeSet; + } + +protected: + bool visit(SimpleDeclarationAST *ast) override; + bool visit(FunctionDefinitionAST *ast) override; + bool visit(ParameterDeclarationAST *ast) override; + bool visit(IfStatementAST *ast) override; + bool visit(WhileStatementAST *ast) override; + bool visit(ForStatementAST *ast) override; + bool visit(ForeachStatementAST *ast) override; + +private: + class TokenRange { + public: + TokenRange() = default; + TokenRange(int start, int end) : start(start), end(end) {} + int start = 0; + int end = 0; + }; + + void processIfWhileForStatement(ExpressionAST *expression, Symbol *symbol); + void checkAndRewrite(DeclaratorAST *declarator, Symbol *symbol, TokenRange range, + unsigned charactersToRemove = 0); + void printCandidate(AST *ast); + + const CppRefactoringFilePtr m_cppRefactoringFile; + Overview &m_overview; + const CursorHandling m_cursorHandling; + + Utils::ChangeSet m_changeSet; +}; + +} // namespace CppEditor |