aboutsummaryrefslogtreecommitdiffstats
path: root/scripts
diff options
context:
space:
mode:
authorArtem Sokolovskii <artem.sokolovskii@qt.io>2022-11-23 12:25:40 +0100
committerArtem Sokolovskii <artem.sokolovskii@qt.io>2022-12-07 08:39:48 +0000
commit76568d82328b1b2acfb3db7cb21679cce3d9b665 (patch)
treef929b23086783bbf70d2188568a7b86f334bf50b /scripts
parent89b81b6046d1a78694a71fa3fbfcaffef17d7784 (diff)
ClangFormat: Create new generateclangformatchecks file
- new generateclangformatcheckslayout file generates two clangformatchecks files .cpp and .h, which contain UI Layout based on utils/layoutbuilder Change-Id: I4a83e542f089618d0cbd552dc99485b9428b4106 Reviewed-by: <github-actions-qt-creator@cristianadam.eu> Reviewed-by: Jarek Kobus <jaroslaw.kobus@qt.io>
Diffstat (limited to 'scripts')
-rwxr-xr-xscripts/generateClangFormatChecksLayout.py231
-rwxr-xr-xscripts/generateClangFormatChecksUI.py190
2 files changed, 231 insertions, 190 deletions
diff --git a/scripts/generateClangFormatChecksLayout.py b/scripts/generateClangFormatChecksLayout.py
new file mode 100755
index 0000000000..b431485ca0
--- /dev/null
+++ b/scripts/generateClangFormatChecksLayout.py
@@ -0,0 +1,231 @@
+#!/usr/bin/env python3.10
+# Copyright (C) 2022 The Qt Company Ltd.
+# SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0 WITH Qt-GPL-exception-1.0
+
+import argparse
+import os
+# for installing use pip3 install robotpy-cppheaderparse
+import CppHeaderParser
+
+def parse_arguments():
+ parser = argparse.ArgumentParser(description='Clazy checks header file \
+ generator')
+ parser.add_argument('--clang-format-header-file', help='path to \
+ Format.h usually /usr/lib/llvm-x/include/clang/Format/Format.h',
+ default=None, dest='options_header', required=True)
+ return parser.parse_args()
+
+
+def full_header_content(header_code):
+ return '''// Copyright (C) 2022 The Qt Company Ltd.
+// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0+ OR GPL-3.0 WITH Qt-GPL-exception-1.0
+
+// THIS FILE IS AUTOMATICALLY GENERATED. DO NOT EDIT!
+
+#pragma once
+
+#include <QWidget>
+
+QT_BEGIN_NAMESPACE
+class QCheckBox;
+class QComboBox;
+class QLabel;
+class QLineEdit;
+class QPlainTextEdit;
+class QPushButton;
+class QWidget;
+QT_END_NAMESPACE
+
+namespace ClangFormat {
+
+class ClangFormatChecks : public QWidget
+{
+ Q_OBJECT
+public:
+ ClangFormatChecks(QWidget *parent = nullptr);
+
+private:
+''' + header_code + '''
+};
+
+} //ClangFormat
+'''
+
+
+def full_source_content(source_code, layout_code):
+ return '''// Copyright (C) 2022 The Qt Company Ltd.
+// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0+ OR GPL-3.0 WITH Qt-GPL-exception-1.0
+
+// THIS FILE IS AUTOMATICALLY GENERATED. DO NOT EDIT!
+
+#include "clangformatchecks.h"
+
+#include <utils/layoutbuilder.h>
+
+#include <QCheckBox>
+#include <QComboBox>
+#include <QLabel>
+#include <QLineEdit>
+#include <QPlainTextEdit>
+#include <QPushButton>
+#include <QWidget>
+
+using namespace Utils;
+
+using namespace ClangFormat;
+
+ClangFormatChecks::ClangFormatChecks(QWidget *parent)
+ : QWidget(parent)
+{
+''' + source_code + '''
+ using namespace Layouting;
+
+ Form {
+''' + layout_code + ''' }.attachTo(this, Layouting::WithoutMargins);
+}
+'''
+
+# Combobox UI
+def combobox_header(name):
+ header = " QComboBox *m_" + name + " = nullptr;\n"
+ return header
+
+def combobox_source(name, values, offset):
+ source = ""
+ source += " m_" + name + " = new QComboBox(this);\n"
+
+ list = ""
+ for value in values:
+ list += "\"" + value + "\","
+
+ source += " m_" + name + "->addItems({" + list + "});\n"
+ source += " m_" + name + "->setObjectName(\"" + name + "\");\n\n"
+ return source
+
+def combobox_source_bool(name, offset):
+ return combobox_source(name, ["Default", "true", "false"], offset)
+
+def combobox_layout(name, offset):
+ layout = " new QLabel(\"" + offset + name + "\"), m_" + name + ", br,\n"
+ return layout
+
+# String UI
+def string_header(name):
+ header = " QLineEdit *m_" + name + " = nullptr;\n"
+ header += " QPushButton *m_set" + name + " = nullptr;\n"
+ return header
+
+def string_source(name, offset):
+ source = ""
+ source += " m_" + name + " = new QLineEdit(this);\n"
+ source += " m_" + name + "->setObjectName(\"" + name + "\");\n"
+ source += " m_set" + name + " = new QPushButton(\"Set\", this);\n\n"
+ source += " m_set" + name + "->setObjectName(\"set" + name + "\");\n"
+# source += "m_" + name + "->setObjectName(\"" + offset + name + "\");\n\n"
+ return source
+
+def string_layout(name, offset):
+ layout = " new QLabel(\"" + offset + name + "\"), Row {m_" + name + ", m_set" + name + "}, br,\n"
+ return layout
+
+# Vector UI
+def vector_header(name):
+ header = " QPlainTextEdit *m_" + name + " = nullptr;\n"
+ header += " QPushButton *m_set" + name + " = nullptr;\n"
+ return header
+
+def vector_source(name, offset):
+ source = ""
+ source += " m_" + name + " = new QPlainTextEdit(this);\n"
+ source += " m_" + name + "->setObjectName(\"" + name + "\");\n"
+ source += " m_" + name + "->setFixedHeight(100);\n"
+ source += " m_set" + name + " = new QPushButton(\"Set\", this);\n\n"
+ source += " m_set" + name + "->setObjectName(\"set" + name + "\");\n"
+# source += "m_" + name + "->setObjectName(\"" + offset + name + "\");\n\n"
+ return source
+
+def vector_layout(name, offset):
+ layout = " new QLabel(\"" + offset + name + "\"), Row {m_" + name + ", m_set" + name + "}, br,\n"
+ return layout
+
+# Struct Layout
+def struct_layout(name, offset):
+ layout = " new QLabel(\"" + offset + name + "\"), br,\n"
+ return layout
+
+
+def in_list(list, type):
+ for element in list:
+ if element["name"] == type:
+ return element;
+ return
+
+def create_private_variables(variables, enums, structs, offset = ""):
+ header = ""
+ source = ""
+ layout = ""
+
+ # create BasedOnStyle combobox ussually not presented in FormatStyle struct
+ if offset == "":
+ header += combobox_header("BasedOnStyle")
+ source += combobox_source("BasedOnStyle", ["LLVM", "Google", "Chromium", "Mozilla", "WebKit", "Microsoft", "GNU"], offset)
+ layout += combobox_layout("BasedOnStyle", offset)
+
+ for variable in variables:
+ if "doxygen" in variable.keys():
+ if ("**deprecated**" in variable['doxygen']):
+ continue;
+
+ type = variable["type"]
+ name = variable["name"]
+ enum = in_list(enums, type)
+ struct = in_list(structs, type)
+ if enum:
+ header += combobox_header(name)
+ source += combobox_source(name, [value["name"].split("_")[1] for value in enum["values"]], offset)
+ layout += combobox_layout(name, offset)
+ elif struct:
+ layout += struct_layout(name, offset)
+ header_tmp, source_tmp, layout_tmp = create_private_variables(struct["properties"]["public"], enums, structs, " ")
+ header += header_tmp
+ source += source_tmp
+ layout += layout_tmp
+ elif "std::string" == type or "unsigned" == type or "int" == type:
+ header += string_header(name)
+ source += string_source(name, offset)
+ layout += string_layout(name, offset)
+ elif "std::vector<std::string >" == type:
+ header += vector_header(name)
+ source += vector_source(name, offset)
+ layout += vector_layout(name, offset)
+ elif "bool" == type:
+ header += combobox_header(name)
+ source += combobox_source_bool(name, offset)
+ layout += combobox_layout(name, offset);
+ return header, source, layout
+
+
+def main():
+ arguments = parse_arguments()
+ header = CppHeaderParser.CppHeader(arguments.options_header)
+
+ enums = header.classes["FormatStyle"]["enums"]["public"]
+ structs = header.classes["FormatStyle"]["nested_classes"]
+ variables = header.classes["FormatStyle"]["properties"]["public"]
+
+ current_path = os.path.dirname(os.path.abspath(__file__))
+ source_path = os.path.abspath(os.path.join(current_path, '..', 'src',
+ 'plugins', 'clangformat', 'clangformatchecks.cpp'))
+ header_path = os.path.abspath(os.path.join(current_path, '..', 'src',
+ 'plugins', 'clangformat', 'clangformatchecks.h'))
+
+ header, source, layout = create_private_variables(variables, enums, structs)
+ with open(source_path, 'w') as f:
+ f.write(full_source_content(source, layout))
+
+ with open(header_path, 'w') as f:
+ f.write(full_header_content(header))
+
+
+if __name__ == "__main__":
+ main()
diff --git a/scripts/generateClangFormatChecksUI.py b/scripts/generateClangFormatChecksUI.py
deleted file mode 100755
index a0a9f37e1a..0000000000
--- a/scripts/generateClangFormatChecksUI.py
+++ /dev/null
@@ -1,190 +0,0 @@
-#!/usr/bin/env python3.10
-# Copyright (C) 2019 The Qt Company Ltd.
-# SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0 WITH Qt-GPL-exception-1.0
-
-import argparse
-import os
-# for installing use pip3 install robotpy-cppheaderparse
-import CppHeaderParser
-
-def parse_arguments():
- parser = argparse.ArgumentParser(description='Clazy checks header file \
- generator')
- parser.add_argument('--clang-format-header-file', help='path to \
- Format.h usually /usr/lib/llvm-x/include/clang/Format/Format.h',
- default=None, dest='options_header', required=True)
- return parser.parse_args()
-
-def full_ui_content(checks):
- return '''<?xml version="1.0" encoding="UTF-8"?>
-<ui version="4.0">
- <class>ClangFormat::ClangFormatChecksWidget</class>
- <widget class="QWidget" name="ClangFormat::ClangFormatChecksWidget">
- <property name="maximumSize">
- <size>
- <width>580</width>
- <height>16777215</height>
- </size>
- </property>
- <layout class="QGridLayout" name="checksLayout">
-''' + checks + ''' </layout>
- </widget>
- <resources/>
- <connections/>
-</ui>
-'''
-
-def lable_ui(name, index, offset = ""):
- return ''' <item row="''' + str(index) + '''" column="0">
- <widget class="QLabel" name="label''' + name + '''">
- <property name="text">
- <string notr="true">''' + offset + name + '''</string>
- </property>
- </widget>
- </item>
-'''
-
-def combobox_ui(name, values, index):
- combobox = ''' <item row="''' + str(index) + '''" column="1">
- <widget class="QComboBox" name="''' + name + '''">
- <property name="focusPolicy">
- <enum>Qt::StrongFocus</enum>
- </property>
-'''
- for value in values:
- combobox += ''' <item>
- <property name="text">
- <string notr="true">''' + value + '''</string>
- </property>
- </item>
-'''
- # for
- combobox += ''' </widget>
- </item>
-'''
- return combobox
-
-def string_ui(name, index):
- return ''' <item row="''' + str(index) + '''" column="1">
- <layout class="QHBoxLayout">
- <item>
- <widget class="QLineEdit" name="''' + name + '''">
- </widget>
- </item>
- <item>
- <widget class="QPushButton" name="set''' + name + '''">
- <property name="maximumSize">
- <size>
- <width>40</width>
- <height>16777215</height>
- </size>
- </property>
- <property name="text">
- <string notr="true">Set</string>
- </property>
- </widget>
- </item>
- </layout>
- </item>
-'''
-
-def vector_ui(name, index):
- return ''' <item row="''' + str(index) + '''" column="1">
- <layout class="QHBoxLayout">
- <item>
- <widget class="QPlainTextEdit" name="''' + name + '''">
- <property name="sizePolicy">
- <sizepolicy hsizetype="Expanding" vsizetype="Fixed"/>
- </property>
- <property name="maximumSize">
- <size>
- <width>16777215</width>
- <height>50</height>
- </size>
- </property>
- </widget>
- </item>
- <item>
- <widget class="QPushButton" name="set''' + name + '''">
- <property name="maximumSize">
- <size>
- <width>40</width>
- <height>16777215</height>
- </size>
- </property>
- <property name="text">
- <string notr="true">Set</string>
- </property>
- </widget>
- </item>
- </layout>
- </item>
-'''
-
-def combobox_ui_bool(name, index):
- return combobox_ui(name, ["Default", "true", "false"], index)
-
-def in_list(list, type):
- for element in list:
- if element["name"] == type:
- return element;
- return
-
-create_checks_index = 0
-def create_checks(variables, enums, structs, offset = ""):
- checks = ""
- global create_checks_index
- # create BasedOnStyle combobox ussually not presented in FormatStyle struct
- if 0 == create_checks_index:
- create_checks_index += 1
- checks = lable_ui("BasedOnStyle", create_checks_index)
- checks += combobox_ui("BasedOnStyle", ["LLVM", "Google", "Chromium", "Mozilla", "WebKit", "Microsoft", "GNU"], create_checks_index)
-
- for variable in variables:
- if "doxygen" in variable.keys():
- if ("**deprecated**" in variable['doxygen']):
- continue;
-
- create_checks_index += 1
- type = variable["type"]
- name = variable["name"]
- enum = in_list(enums, type)
- struct = in_list(structs, type)
- if enum:
- checks += lable_ui(name, create_checks_index, offset)
- checks += combobox_ui(name, [value["name"].split("_")[1] for value in enum["values"]], create_checks_index)
- elif struct:
- checks += lable_ui(name, create_checks_index, offset)
- check = create_checks(struct["properties"]["public"], enums, structs, " ")
- checks += check
- elif "std::string" == type or "unsigned" == type or "int" == type:
- checks += lable_ui(name, create_checks_index, offset)
- checks += string_ui(name, create_checks_index)
- elif "std::vector<std::string >" == type:
- checks += lable_ui(name, create_checks_index, offset)
- checks += vector_ui(name, create_checks_index)
- elif "bool" == type:
- checks += lable_ui(name, create_checks_index, offset)
- checks += combobox_ui_bool(name, create_checks_index)
- return checks
-
-
-def main():
- arguments = parse_arguments()
- header = CppHeaderParser.CppHeader(arguments.options_header)
-
- enums = header.classes["FormatStyle"]["enums"]["public"]
- structs = header.classes["FormatStyle"]["nested_classes"]
- variables = header.classes["FormatStyle"]["properties"]["public"]
-
- checks = create_checks(variables, enums, structs)
-
- current_path = os.path.dirname(os.path.abspath(__file__))
- ui_path = os.path.abspath(os.path.join(current_path, '..', 'src',
- 'plugins', 'clangformat', 'clangformatchecks.ui'))
- with open(ui_path, 'w') as f:
- f.write(full_ui_content(checks))
-
-
-if __name__ == "__main__":
- main()