diff options
Diffstat (limited to 'dev-util/cppcheck')
-rw-r--r-- | dev-util/cppcheck/Manifest | 2 | ||||
-rw-r--r-- | dev-util/cppcheck/cppcheck-2.17.1.ebuild | 133 |
2 files changed, 135 insertions, 0 deletions
diff --git a/dev-util/cppcheck/Manifest b/dev-util/cppcheck/Manifest index 95db06f92fc3..7e55986ce80c 100644 --- a/dev-util/cppcheck/Manifest +++ b/dev-util/cppcheck/Manifest @@ -1,5 +1,7 @@ DIST cppcheck-2.14.2.tar.gz 3723248 BLAKE2B 551c783e13202f496b705602566799848b611bcc706f7a803c9ff530b3405db9e0b5294d2ce51ef5a4889e08c5b9d54c15d40a7ec6f4dc59333a7b6ed24b1f02 SHA512 8e90fa87845a083a4de66ec86edf707184a2293eb346fd79bfcafb73f93db049216472fcb2ab802ce529680f9708261ba3c26675c6fd9637e1dc83903bc44c4b DIST cppcheck-2.16.0.tar.gz 3845764 BLAKE2B f1945ec48774c6f2ebb566f649d3f931202b0270e133130ce8da6894be6cf1c8454f35fdc394fcbc2513206a8f899ce266cc1bd809455171050fe979117da2c3 SHA512 b224d4d62be1802c322f57a0674a01caecf3d034d36396d8375c302a518a6d5f0ca9160a2a94eaa33b498ff0bbd092785f0489abef30de8af446b5d381f44922 +DIST cppcheck-2.17.1.tar.gz 3872633 BLAKE2B 8a2404b2610386166c1e8d3bfe8b3405834bde8534974678043a658721a43a6a627c6d2793febe4c6c70856e823907e04ce46674acbca8354c5a452236f289cc SHA512 ffd1caeba22493e45ad24c61af19c71adc25ba8eb2c3070152d150921024d68b4892d4e01575c9960e0b0aa1df9deae3514612b184afcf48e377022ca3bb0d85 EBUILD cppcheck-2.14.2-r1.ebuild 2859 BLAKE2B 8ce5603c20534d73a2ae5134e9dcba0239332e20f0fa0fa23ad803ebefc1251eff2d8eb663b1090942104fc2d94cb7419f86732d26407aefbd5cd0e15ff097f7 SHA512 3e52198c062f802f0962921e2a8fd42c62778898a5d131702dbcc8dd9df5199200d8962cd600d93e13e82af657ee7f169bfeb191ab93c61501e5a07068435e06 EBUILD cppcheck-2.16.0.ebuild 2874 BLAKE2B 9fd1bb84726f155864dc2121183500615e4bdcf7ced2932a1c3ccea8df815107802313535c42439aefa6f3ab576f34786e564328fdacfee8ebf94e8d174bc318 SHA512 41c86d2cbd63de6871ddfd9a8a05843fb6ef8c1c32f0d38702314579abe13a1e37fe7f30092f7af7a4b1673bfa5e7cb8747f9d21c21cfef86a52350f612ecd10 +EBUILD cppcheck-2.17.1.ebuild 2964 BLAKE2B cb3150d899164b88f0f5de35c00f5902fdc66ab554e7004105085de2bc73c1b068420c31899a1a214efbfb7daaf4b5d136cbf1c9ba8a6c09d2f3c1bff2693cb4 SHA512 40b17f539e86a5c23150533b3807bb16281dfa3f6d9f029b2d82db89506e2b123fac5ed8ca75ef45c23d76042d6575f124420309576f5a75b54c78e5ebf10b77 MISC metadata.xml 668 BLAKE2B da81419239f465fa6c33d05b660b99e2fbcd6c5ede59dc6ea6360a479a95732e41b49d67698e3b1e471a516e12627e004c3a7675e2811e862e17e2e1f66024d3 SHA512 d88d2d9cd484a5f9c0c146cab114349980587036e28693c5a825354c8b246dbb85aa1fd27303007ba7c425ae38db8a14f1ce5e7403f4b4710088d6aeefdbb26f diff --git a/dev-util/cppcheck/cppcheck-2.17.1.ebuild b/dev-util/cppcheck/cppcheck-2.17.1.ebuild new file mode 100644 index 000000000000..7243d2f436a5 --- /dev/null +++ b/dev-util/cppcheck/cppcheck-2.17.1.ebuild @@ -0,0 +1,133 @@ +# Copyright 1999-2025 Gentoo Authors +# Distributed under the terms of the GNU General Public License v2 + +EAPI=8 + +PYTHON_COMPAT=( python3_{11..13} ) +inherit cmake python-single-r1 xdg + +DESCRIPTION="Static analyzer of C/C++ code" +HOMEPAGE="https://github.com/danmar/cppcheck" +SRC_URI="https://github.com/danmar/cppcheck/archive/refs/tags/${PV}.tar.gz -> ${P}.tar.gz" + +LICENSE="GPL-3+" +SLOT="0" +KEYWORDS="~amd64 ~arm ~arm64 ~loong ~ppc64 ~riscv ~x86" +IUSE="charts gui htmlreport pcre test" +REQUIRED_USE=" + ${PYTHON_REQUIRED_USE} + charts? ( gui ) +" +RESTRICT="!test? ( test )" + +COMMON_DEPEND=" + dev-libs/tinyxml2:= + gui? ( + dev-qt/qtbase:6[gui,widgets,network] + charts? ( dev-qt/qtcharts:6 ) + ) + pcre? ( dev-libs/libpcre ) +" +DEPEND="${COMMON_DEPEND} + gui? ( dev-qt/qttools:6[assistant,linguist] ) +" +RDEPEND="${COMMON_DEPEND} + ${PYTHON_DEPS} + htmlreport? ( + $(python_gen_cond_dep ' + dev-python/pygments[${PYTHON_USEDEP}] + ') + ) +" +BDEPEND=" + ${PYTHON_DEPS} + app-text/docbook-xsl-stylesheets + dev-libs/libxslt + virtual/pkgconfig + gui? ( dev-qt/qttools:6[assistant,linguist] ) + test? ( + htmlreport? ( + $(python_gen_cond_dep ' + dev-python/pytest[${PYTHON_USEDEP}] + dev-python/pytest-timeout[${PYTHON_USEDEP}] + dev-python/pygments[${PYTHON_USEDEP}] + ') + ) + ) +" + +src_prepare() { + cmake_src_prepare + + # Modify to an existing docbook location + sed -i \ + -e "s|set(DB2MAN .*|set(DB2MAN \"${EPREFIX}/usr/share/sgml/docbook/xsl-stylesheets/manpages/docbook.xsl\")|" \ + man/CMakeLists.txt || die + + # Make tests use cppcheck built in build dir. + sed -i -e "s|CPPCHECK_BIN = .*|CPPCHECK_BIN = '${BUILD_DIR}/bin/cppcheck'|" test/tools/htmlreport/test_htmlreport.py || die +} + +src_configure() { + local mycmakeargs=( + -DFILESDIR="${EPREFIX}"/usr/share/${PF}/ + -DBUILD_MANPAGE=ON + + -DHAVE_RULES=$(usex pcre) + + -DBUILD_GUI=$(usex gui) + -DUSE_QT6=$(usex gui) + -DWITH_QCHART=$(usex charts) + + -DBUILD_TESTS=$(usex test) + -DREGISTER_TESTS=$(usex test) + -DREGISTER_GUI_TESTS=$(usex test) + + -DUSE_MATCHCOMPILER=ON + + -DDISABLE_DMAKE=ON + -DUSE_BUNDLED_TINYXML2=OFF + + # Yes, this is necessary to use the correct python version. + # bug #826602 + -DPython_EXECUTABLE=${PYTHON} + ) + + cmake_src_configure +} + +src_compile() { + cmake_src_compile + cmake_build man +} + +src_test() { + local CMAKE_SKIP_TESTS=( + # Out of source builds breaks test TestFileLister + # https://github.com/danmar/cppcheck/pull/5462 + TestFileLister + ) + cmake_src_test + + rm test/cli/other_test.py || die + use htmlreport && TEST_CPPCHECK_EXE_LOOKUP_PATH="${BUILD_DIR}/bin/" epytest test +} + +src_install() { + cmake_src_install + + insinto /usr/share/${PF}/cfg + doins cfg/*.cfg + + if use gui ; then + dobin "${WORKDIR}/${P}_build/bin/${PN}-gui" + dodoc gui/{projectfile.txt,gui.${PN}} + fi + + use htmlreport && python_doscript htmlreport/cppcheck-htmlreport + python_fix_shebang "${ED}"/usr/share/${PF} + python_optimize "${ED}"/usr/share/${PF} + + dodoc -r tools/triage + doman "${BUILD_DIR}"/man/cppcheck.1 +} |