aboutsummaryrefslogtreecommitdiffstats
path: root/src/plugins/cppeditor/cpppointerdeclarationformatter.h
diff options
context:
space:
mode:
authorChristian Kandeler <christian.kandeler@qt.io>2021-08-30 10:58:08 +0200
committerChristian Kandeler <christian.kandeler@qt.io>2021-09-01 14:53:58 +0000
commit284817fae6514701902ccdb834c2faa46462f2e8 (patch)
tree44a8c7d9813dc110b61c4639036366c7696bd7e9 /src/plugins/cppeditor/cpppointerdeclarationformatter.h
parent3e1fa0f170d523971d2c3c12da15a6e291f56511 (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.h120
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