commit:     b46bf0e8d4bac2fa871c1a1ee351599760e06c6d
Author:     Peter Levine <plevine457 <AT> gmail <DOT> com>
AuthorDate: Mon Oct 31 00:56:49 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Nov  5 06:32:44 2022 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=b46bf0e8

dev-qt/qt-creator: add 8.0.2

Signed-off-by: Peter Levine <plevine457 <AT> gmail.com>
Signed-off-by: Sam James <sam <AT> gentoo.org>

 dev-qt/qt-creator/Manifest                |   1 +
 dev-qt/qt-creator/qt-creator-8.0.2.ebuild | 444 ++++++++++++++++++++++++++++++
 2 files changed, 445 insertions(+)

diff --git a/dev-qt/qt-creator/Manifest b/dev-qt/qt-creator/Manifest
index 45540d8edfe6..3512b8464ddb 100644
--- a/dev-qt/qt-creator/Manifest
+++ b/dev-qt/qt-creator/Manifest
@@ -1 +1,2 @@
 DIST qt-creator-opensource-src-8.0.1.tar.xz 46918596 BLAKE2B 
07ab50ae9ee77372c2d79a472da8cb3c65b269b8def670f66426daf9875ca44f2a66bb2ab0c01d8591420d6c43b7ca57f6ac2a6b8443cc8a5af7c89599e3966d
 SHA512 
ffef39e8d0694b38549f301a143dec6e2fe026a1e6098acc41bd8f9c80c93d1dbb60616042901093bdaa13380034b9dd8234d82300b1fa89ab9bce81bd3f1672
+DIST qt-creator-opensource-src-8.0.2.tar.xz 48874868 BLAKE2B 
53f491441ba28f9420c76cd4adfdcb7c7ef432d756fc5bf64a507c2cd1022b35700418a7b35b7119d97f9947b5dac2a8acc56b600c3e75001f80565f1619c072
 SHA512 
59ff62e6592fd33ff74aeab13dd33f3817ba132fb98f8a87ea818e1e52b4af0dc292e362085733665f0867d67ff867794755b2f02067897a9fb1c14023c6fb23

diff --git a/dev-qt/qt-creator/qt-creator-8.0.2.ebuild 
b/dev-qt/qt-creator/qt-creator-8.0.2.ebuild
new file mode 100644
index 000000000000..138e0e37a74e
--- /dev/null
+++ b/dev-qt/qt-creator/qt-creator-8.0.2.ebuild
@@ -0,0 +1,444 @@
+# Copyright 1999-2022 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=8
+LLVM_MAX_SLOT=14
+PLOCALES="cs da de fr hr ja pl ru sl uk zh-CN zh-TW"
+
+inherit cmake llvm optfeature virtualx xdg
+
+DESCRIPTION="Lightweight IDE for C++/QML development centering around Qt"
+HOMEPAGE="https://doc.qt.io/qtcreator/";
+
+if [[ ${PV} == *9999 ]]; then
+       inherit git-r3
+       EGIT_REPO_URI="https://code.qt.io/${PN}/${PN}.git";
+       EGIT_SUBMODULES=(
+               perfparser
+               qtscript # Need the dev branch
+               src/libs/qlitehtml
+               src/libs/qlitehtml/src/3rdparty/litehtml
+       )
+else
+       MY_PV=${PV/_/-}
+       MY_P=${PN}-opensource-src-${MY_PV}
+       [[ ${MY_PV} == ${PV} ]] && MY_REL=official || MY_REL=development
+       SRC_URI="https://download.qt.io/${MY_REL}_releases/${PN/-}/$(ver_cut 
1-2)/${MY_PV}/${MY_P}.tar.xz"
+       S="${WORKDIR}"/${MY_P}
+       KEYWORDS="~amd64 ~arm ~x86"
+fi
+
+LICENSE="GPL-3"
+SLOT="0"
+
+QTCREATOR_PLUGINS=(
+       # Misc
+       +autotest beautifier coco conan cppcheck ctfvisualizer +designer docker
+       +help imageviewer modeling perfprofiler qmlprofiler scxml serialterminal
+       silversearcher valgrind
+
+       # Buildsystems
+       autotools +cmake incredibuild meson qbs +qmake
+
+       # Languages
+       glsl +lsp nim python
+
+       # Platforms
+       android baremetal boot2qt mcu qnx remotelinux webassembly
+
+       # VCS
+       bazaar clearcase cvs +git mercurial perforce subversion
+)
+
+IUSE="+clang debug doc +qml systemd test wayland webengine
+       ${QTCREATOR_PLUGINS[@]}"
+
+REQUIRED_USE="
+       android? ( lsp )
+       boot2qt? ( remotelinux )
+       clang? ( lsp )
+       coco? ( lsp )
+       mcu? ( baremetal cmake )
+       python? ( lsp )
+       qml? ( qmake )
+       qnx? ( remotelinux )
+       test? ( qbs qmake )
+"
+
+# minimum Qt version required
+QT_PV="5.15.2:5"
+
+BDEPEND="
+       >=dev-qt/linguist-tools-${QT_PV}
+       doc? ( >=dev-qt/qdoc-${QT_PV} )
+       help? ( !webengine? ( virtual/pkgconfig ) )
+"
+CDEPEND="
+       clang? (
+               >=dev-cpp/yaml-cpp-0.6.2:=
+               sys-devel/clang:14=
+       )
+       >=dev-qt/qtconcurrent-${QT_PV}
+       >=dev-qt/qtcore-${QT_PV}
+       >=dev-qt/qtdeclarative-${QT_PV}[widgets]
+       >=dev-qt/qtgui-${QT_PV}
+       >=dev-qt/qtnetwork-${QT_PV}[ssl]
+       >=dev-qt/qtprintsupport-${QT_PV}
+       >=dev-qt/qtquickcontrols-${QT_PV}
+       >=dev-qt/qtsql-${QT_PV}[sqlite]
+       >=dev-qt/qtwidgets-${QT_PV}
+       >=dev-qt/qtxml-${QT_PV}
+       >=kde-frameworks/syntax-highlighting-5.87:5
+
+       designer? ( >=dev-qt/designer-${QT_PV} )
+       help? (
+               >=dev-qt/qthelp-${QT_PV}
+               webengine? ( >=dev-qt/qtwebengine-${QT_PV}[widgets] )
+               !webengine? ( dev-libs/gumbo )
+       )
+       imageviewer? ( >=dev-qt/qtsvg-${QT_PV} )
+       perfprofiler? (
+               app-arch/zstd
+               dev-libs/elfutils
+       )
+       serialterminal? ( >=dev-qt/qtserialport-${QT_PV} )
+       systemd? ( sys-apps/systemd:= )
+       test? ( mcu? ( dev-cpp/gtest:= ) )
+"
+DEPEND="
+       ${CDEPEND}
+       test? (
+               dev-cpp/benchmark
+               dev-cpp/eigen
+               dev-cpp/gtest
+               dev-libs/boost
+               >=dev-qt/qttest-${QT_PV}
+       )
+"
+RDEPEND="
+       ${CDEPEND}
+       qml? ( >=dev-qt/qtquicktimeline-${QT_PV} )
+       wayland? ( >=dev-qt/qtgui-${QT_PV}[wayland] )
+"
+
+# qt translations must also be installed or qt-creator translations won't be 
loaded
+for x in ${PLOCALES}; do
+       IUSE+=" l10n_${x}"
+       RDEPEND+=" l10n_${x}? ( >=dev-qt/qttranslations-${QT_PV} )"
+done
+unset x
+
+# FUNCTION: cmake_use_remove_addsubdirectory
+# USAGE: <flag> <subdir> <files...>
+# DESCRIPTION:
+# <flag> is the name of a flag in IUSE.
+# <subdir> is the  name of a directory called with add_subdirectory().
+# <files...> is a list of one or more qmake project files.
+#
+# This function patches <files> to remove add_subdirectory(<subdir>) from cmake
+# when <flag> is disabled, otherwise it does nothing. This can be useful to
+# avoid an automagic dependency when a subdirectory is added in cmake but the
+# corresponding feature USE flag is disabled. Similar to 
qt_use_disable_config()
+# from /qt5-build.eclass
+cmake_use_remove_addsubdirectory() {
+       [[ $# -ge 3 ]] || die "${FUNCNAME}() requires at least three arguments"
+       local flag=$1
+       local subdir=$2
+       shift 2
+
+       if ! use "${flag}"; then
+               echo "$@" | xargs sed -i -e "/add_subdirectory(${subdir})/d" || 
die
+       fi
+}
+
+llvm_check_deps() {
+       has_version -d "sys-devel/clang:${LLVM_SLOT}"
+}
+
+pkg_setup() {
+       if use clang; then
+               llvm_pkg_setup
+               export CLANG_PREFIX="$(get_llvm_prefix ${LLVM_MAX_SLOT})"
+       fi
+}
+
+src_prepare() {
+       cmake_src_prepare
+
+       # Remove automagic dep for qt5/qt6
+       sed -e "/^find_package(Qt6/,/else()/ s|if (NOT Qt6_FOUND)|if (1)|" \
+               -i cmake/FindQt5.cmake || die
+
+       # PLUGIN_RECOMMENDS is treated like a hard-dependency
+       sed -i -e '/PLUGIN_RECOMMENDS /d' \
+               src/plugins/*/CMakeLists.txt || die
+
+       cmake_use_remove_addsubdirectory glsl glsl src/libs/CMakeLists.txt
+       cmake_use_remove_addsubdirectory lsp languageserverprotocol \
+               src/libs/CMakeLists.txt tests/auto/CMakeLists.txt
+       cmake_use_remove_addsubdirectory modeling modelinglib \
+               src/libs/CMakeLists.txt
+       cmake_use_remove_addsubdirectory qml advanceddockingsystem \
+               src/libs/CMakeLists.txt
+       cmake_use_remove_addsubdirectory clang clangtools \
+               src/plugins/CMakeLists.txt
+       cmake_use_remove_addsubdirectory test test \
+               src/plugins/mcusupport/CMakeLists.txt
+
+       # fix translations
+       local languages=()
+       for lang in ${PLOCALES}; do
+               use l10n_${lang} && languages+=( "${lang/-/_}" )
+       done
+       sed -i -e "s|^set(languages.*|set(languages ${languages[*]})|" \
+               share/qtcreator/translations/CMakeLists.txt || die
+
+       # remove bundled yaml-cpp
+       rm -r src/libs/3rdparty/yaml-cpp || die
+
+       # remove bundled qbs
+       rm -r src/shared/qbs || die
+
+       # qt-creator hardcodes the CLANG_INCLUDE_DIR to the default.
+       # However, in sys-devel/clang, the directory changes with respect to
+       # -DCLANG_RESOURCE_DIR.  We sed in the correct include dir.
+       if use clang; then
+               local res_dir="$(${CLANG_PREFIX}/bin/clang -print-resource-dir 
|| die)"
+               sed -i -e 
"/\w*CLANG_INCLUDE_DIR=/s|=.*|=\"${res_dir}/include\"|" \
+                       src/plugins/clangtools/CMakeLists.txt || die
+       fi
+
+       if use doc; then
+               # Fix doc install path
+               sed -i -e "/set(_IDE_DOC_PATH/s|qtcreator|${PF}|" \
+                       cmake/QtCreatorAPIInternal.cmake || die
+       fi
+
+       if use help && ! use webengine; then
+               # unbundled gumbo doesn't use cmake
+               local gumbo_dep='find_package(PkgConfig REQUIRED)\n'
+               gumbo_dep+='pkg_check_modules(gumbo REQUIRED IMPORTED_TARGET 
gumbo)\n'
+               sed -i -e '/^\s*gumbo/s|gumbo|PkgConfig::gumbo|' \
+                       -e "/^find_package(litehtml/s|^|${gumbo_dep}|" \
+                       src/libs/qlitehtml/src/CMakeLists.txt || die
+       fi
+
+       if use test; then
+               # Find "GoogleBenchmark" as "benchmark" and change bundled 
"Googletest"
+               # to external "GTest"
+               find "${S}" -type f -name CMakeLists.txt -exec \
+                       xargs sed -i -e 's|TARGET 
GoogleBenchmark|benchmark_FOUND|g' \
+                               -e 's|GoogleBenchmark\( MODULE\)\?|benchmark|g' 
\
+                               -e 's|Googletest\( MODULE\)\?|GTest|g' {} \; || 
die
+               # For mcu, also link to gmock to prevent an unknown symbol
+               # error at runtime.
+               sed -i -e  's|if(TARGET GTest)|if(GTest_FOUND)|' \
+                       -e 's|DEPENDS GTest|DEPENDS gtest gmock|' \
+                       src/plugins/mcusupport/test/CMakeLists.txt || die
+       fi
+}
+
+src_configure() {
+       mycmakeargs+=(
+               -DWITH_TESTS=$(usex test)
+               -DWITH_DEBUG_CMAKE=$(usex debug)
+
+               # Don't use SANITIZE_FLAGS to pass extra CXXFLAGS
+               -DWITH_SANITIZE=NO
+
+               # Don't build bundled ksyntaxhighlighting
+               -DBUILD_LIBRARY_KSYNTAXHIGHLIGHTING=NO
+
+               -DWITH_DOCS=$(usex doc)
+               -DBUILD_DEVELOPER_DOCS=$(usex doc)
+
+               # Install failure.  Disable for now
+               -DWITH_ONLINE_DOCS=NO
+
+               # Force enable plugins that pride basic, neccessary IDE 
functionality
+               # and small, simple plugins
+               -DBUILD_PLUGIN_BINEDITOR=YES
+               -DBUILD_PLUGIN_BOOKMARKS=YES
+               -DBUILD_PLUGIN_CLASSVIEW=YES
+               -DBUILD_PLUGIN_CODEPASTER=YES
+               -DBUILD_PLUGIN_COMPILATIONDATABASEPROJECTMANAGER=YES
+               -DBUILD_PLUGIN_CORE=YES
+               -DBUILD_PLUGIN_CPPEDITOR=YES
+               -DBUILD_PLUGIN_DEBUGGER=YES
+               -DBUILD_PLUGIN_DIFFEDITOR=YES
+               -DBUILD_PLUGIN_EMACSKEYS=YES
+               -DBUILD_PLUGIN_FAKEVIM=YES
+               -DBUILD_PLUGIN_GENERICPROJECTMANAGER=YES
+               -DBUILD_PLUGIN_MACROS=YES
+               -DBUILD_PLUGIN_MARKETPLACE=YES
+               -DBUILD_PLUGIN_PROJECTEXPLORER=YES
+               -DBUILD_PLUGIN_QMLJSTOOLS=YES
+               -DBUILD_PLUGIN_QTSUPPORT=YES
+               -DBUILD_PLUGIN_RESOURCEEDITOR=YES
+               -DBUILD_PLUGIN_TASKLIST=YES
+               -DBUILD_PLUGIN_TEXTEDITOR=YES
+               -DBUILD_PLUGIN_TODO=YES
+               -DBUILD_PLUGIN_VCSBASE=YES
+               -DBUILD_PLUGIN_WELCOME=YES
+
+               # Misc
+               -DBUILD_PLUGIN_AUTOTEST=$(usex autotest)
+               -DBUILD_PLUGIN_BEAUTIFIER=$(usex beautifier)
+               -DBUILD_PLUGIN_COCO=$(usex coco)
+               -DBUILD_PLUGIN_CONAN=$(usex conan)
+               -DBUILD_PLUGIN_CPPCHECK=$(usex cppcheck)
+               -DBUILD_PLUGIN_CTFVISUALIZER=$(usex ctfvisualizer)
+               -DBUILD_PLUGIN_DESIGNER=$(usex designer)
+               -DBUILD_PLUGIN_DOCKER=$(usex docker)
+               -DBUILD_PLUGIN_HELP=$(usex help)
+               -DBUILD_PLUGIN_IMAGEVIEWER=$(usex imageviewer)
+               -DBUILD_PLUGIN_MODELEDITOR=$(usex modeling)
+               -DBUILD_PLUGIN_PERFPROFILER=$(usex perfprofiler)
+               -DBUILD_PLUGIN_QMLPROFILER=$(usex qmlprofiler)
+               -DBUILD_PLUGIN_SCXMLEDITOR=$(usex scxml)
+               -DBUILD_PLUGIN_SERIALTERMINAL=$(usex serialterminal)
+               -DBUILD_PLUGIN_SILVERSEARCHER=$(usex silversearcher)
+               -DBUILD_PLUGIN_VALGRIND=$(usex valgrind)
+
+               # Buildsystems
+               -DBUILD_PLUGIN_AUTOTOOLSPROJECTMANAGER=$(usex autotools)
+               -DBUILD_PLUGIN_CMAKEPROJECTMANAGER=$(usex cmake)
+               -DBUILD_PLUGIN_MESONPROJECTMANAGER=$(usex meson)
+               -DBUILD_PLUGIN_QBSPROJECTMANAGER=$(usex qbs)
+               -DBUILD_PLUGIN_QMAKEPROJECTMANAGER=$(usex qmake)
+
+               # Languages
+               -DBUILD_PLUGIN_GLSLEDITOR=$(usex glsl)
+               -DBUILD_PLUGIN_LANGUAGECLIENT=$(usex lsp)
+               -DBUILD_PLUGIN_NIM=$(usex nim)
+               -DBUILD_PLUGIN_PYTHON=$(usex python)
+
+               # Platforms
+               -DBUILD_PLUGIN_ANDROID=$(usex android)
+               -DBUILD_PLUGIN_BAREMETAL=$(usex baremetal)
+               -DBUILD_PLUGIN_BOOT2QT=$(usex boot2qt)
+               -DBUILD_PLUGIN_MCUSUPPORT=$(usex mcu)
+               -DBUILD_PLUGIN_QNX=$(usex qnx)
+               -DBUILD_PLUGIN_REMOTELINUX=$(usex remotelinux)
+               -DBUILD_PLUGIN_WEBASSEMBLY=$(usex webassembly)
+
+               # VCS
+               -DBUILD_PLUGIN_BAZAAR=$(usex bazaar)
+               -DBUILD_PLUGIN_CLEARCASE=$(usex clearcase)
+               -DBUILD_PLUGIN_CVS=$(usex cvs)
+               -DBUILD_PLUGIN_GIT=$(usex git)
+               -DBUILD_PLUGIN_GITLAB=$(usex git)
+               -DBUILD_PLUGIN_MERCURIAL=$(usex mercurial)
+               -DBUILD_PLUGIN_PERFORCE=$(usex perforce)
+               -DBUILD_PLUGIN_SUBVERSION=$(usex subversion)
+
+               # Executables
+               -DBUILD_EXECUTABLE_BUILDOUTPUTPARSER=$(usex qmake)
+               -DBUILD_EXECUTABLE_PERFPARSER=$(usex perfprofiler)
+               -DBUILD_EXECUTABLE_QML2PUPPET=$(usex qml)
+
+               # Clang stuff
+               -DBUILD_PLUGIN_CLANGCODEMODEL=$(usex clang)
+               -DBUILD_PLUGIN_CLANGFORMAT=$(usex clang)
+
+               # QML stuff
+               # -DBUILD_PLUGIN_QMLDESIGNER=$(usex qml) #Qt6 only
+               -DBUILD_PLUGIN_QMLJSEDITOR=$(usex qml)
+               -DBUILD_PLUGIN_QMLPREVIEW=$(usex qml)
+               -DBUILD_PLUGIN_QMLPROJECTMANAGER=$(usex qml)
+               # -DBUILD_PLUGIN_STUDIOWELCOME=$(usex qml) #Qt6 only
+
+               # Don't spam "created by a different GCC executable 
[-Winvalid-pch]"
+               -DBUILD_WITH_PCH=NO
+               # An entire mode devoted to a giant "Hello World!" button that 
does nothing.
+               -DBUILD_PLUGIN_HELLOWORLD=NO
+               # Not usable in linux environment
+               -DBUILD_PLUGIN_IOS=NO
+               # Use portage to update
+               -DBUILD_PLUGIN_UPDATEINFO=NO
+       )
+
+       if use clang; then
+               mycmakeargs+=(
+                       -DClang_DIR="${CLANG_PREFIX}/$(get_libdir)/cmake/clang"
+                       -DLLVM_DIR="${CLANG_PREFIX}/$(get_libdir)/cmake/llvm"
+                       -DCLANGTOOLING_LINK_CLANG_DYLIB=YES
+                       -DBUILD_PLUGIN_CLANGTOOLS=YES
+               )
+       fi
+       if use help; then
+               mycmakeargs+=(
+                       -DBUILD_HELPVIEWERBACKEND_QTWEBENGINE=$(usex webengine)
+                       -DBUILD_LIBRARY_QLITEHTML=$(usex webengine NO YES)
+                       -DHELPVIEWER_DEFAULT_BACKEND=$(usex webengine 
qtwebengine litehtml)
+               )
+               if ! use webengine; then
+                       mycmakeargs+=(
+                               -DEXTERNAL_GUMBO=YES
+                               -DEXTERNAL_XXD=NO
+                               -DLITEHTML_UTF8=YES
+                       )
+               fi
+       fi
+       if use test; then
+               mycmakeargs+=(
+                       # Don't test pretty printing in gdb/lldb. Tests like
+                       # tst_debugger_dumpers fail and it's "not officially 
supported"
+                       # See share/qtcreator/debugger/README.txt
+                       -DWITH_DEBUGGER_DUMPERS=NO
+
+                       # Disable broken tests
+                       -DBUILD_TEST_TST_PERFDATA=NO
+                       -DBUILD_TEST_TST_QML_CHECK=NO
+                       -DBUILD_TEST_TST_QML_TESTCORE=NO
+               )
+       fi
+       cmake_src_configure
+}
+
+src_test() {
+       virtx cmake_src_test
+}
+
+src_install() {
+       cmake_src_install
+
+       if use doc; then
+               cmake_src_install doc/{qch,html}_docs
+               dodoc "${BUILD_DIR}"/share/doc/${PF}/qtcreator{,-dev}.qch
+               docompress -x /usr/share/doc/${PF}/qtcreator{,-dev}.qch
+               docinto html
+               dodoc -r "${BUILD_DIR}"/doc/html/.
+       fi
+}
+
+pkg_postinst() {
+       optfeature_header \
+               "Some enabled plugins require optional dependencies for 
functionality:"
+       use android && optfeature "android device support" \
+               dev-util/android-sdk-update-manager
+       if use autotest; then
+               optfeature "catch testing framework support" dev-cpp/catch
+               optfeature "gtest testing framework support" dev-cpp/gtest
+               optfeature "boost testing framework support" dev-libs/boost
+               optfeature "qt testing framework support" dev-qt/qttest
+       fi
+       if use beautifier; then
+               optfeature "astyle auto-formatting support" dev-util/astyle
+               optfeature "uncrustify auto-formatting support" 
dev-util/uncrustify
+       fi
+       use clang && optfeature "clazy QT static code analysis" dev-util/clazy
+       use conan && optfeature "conan package manager integration" 
dev-util/conan
+       use cvs && optfeature "cvs vcs integration" dev-vcs/cvs
+       use docker && optfeature "using a docker image as a device" \
+               app-containers/docker
+       use git && optfeature "git vcs integration" dev-vcs/git
+       use mercurial && optfeature "mercurial vcs integration" 
dev-vcs/mercurial
+       use meson && optfeature "meson buildsystem support" dev-util/meson
+       use nim && optfeature "nim language support" dev-lang/nim
+       use qbs && optfeature "QBS buildsystem support" dev-util/qbs
+       use silversearcher && optfeature "code searching with silversearcher" \
+               sys-apps/the_silver_searcher
+       use subversion && optfeature "subversion vcs integration" 
dev-vcs/subversion
+       use valgrind && optfeature "valgrind code analysis" dev-util/valgrind
+}

Reply via email to