mirror of
https://github.com/gentoo-mirror/gentoo.git
synced 2025-12-21 21:17:37 -08:00
app-text/doxygen: fix emitting duplicate type names
... breaking wxpython. Closes: https://bugs.gentoo.org/966843 Thanks-to: Blake Batson <bbatson101@gmail.com> Signed-off-by: Sam James <sam@gentoo.org>
This commit is contained in:
parent
475ebc8395
commit
be8ff84c44
141
app-text/doxygen/doxygen-1.15.0-r1.ebuild
Normal file
141
app-text/doxygen/doxygen-1.15.0-r1.ebuild
Normal file
@ -0,0 +1,141 @@
|
||||
# Copyright 1999-2025 Gentoo Authors
|
||||
# Distributed under the terms of the GNU General Public License v2
|
||||
|
||||
EAPI=8
|
||||
|
||||
LLVM_COMPAT=( 18 19 20 21 )
|
||||
LLVM_OPTIONAL=1
|
||||
PYTHON_COMPAT=( python3_{11..14} )
|
||||
PYTHON_REQ_USE="xml(+)"
|
||||
|
||||
inherit cmake flag-o-matic llvm-r1 python-any-r1
|
||||
|
||||
DESCRIPTION="Documentation system for most programming languages"
|
||||
HOMEPAGE="https://www.doxygen.nl/"
|
||||
|
||||
if [[ ${PV} == *9999* ]]; then
|
||||
inherit git-r3
|
||||
EGIT_REPO_URI="https://github.com/doxygen/doxygen.git"
|
||||
else
|
||||
SRC_URI="https://doxygen.nl/files/${P}.src.tar.gz"
|
||||
SRC_URI+=" https://downloads.sourceforge.net/doxygen/rel-${PV}/${P}.src.tar.gz"
|
||||
KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~hppa ~loong ~m68k ~mips ~ppc ~ppc64 ~riscv ~s390 ~sparc ~x86 ~amd64-linux ~x86-linux ~ppc-macos ~x64-macos ~x64-solaris"
|
||||
fi
|
||||
|
||||
# GPL-2 also for bundled libmscgen
|
||||
LICENSE="GPL-2"
|
||||
SLOT="0"
|
||||
IUSE="clang debug doc dot doxysearch gui test"
|
||||
# - We need TeX for tests, bug #765472
|
||||
# - We keep the odd construct of noop USE=test because of
|
||||
# the special relationship b/t RESTRICT & USE for tests.
|
||||
# Also, it's a hint which avoids tests being silently skipped during arch testing.
|
||||
REQUIRED_USE="clang? ( ${LLVM_REQUIRED_USE} ) test? ( doc )"
|
||||
RESTRICT="!test? ( test )"
|
||||
|
||||
BDEPEND="
|
||||
app-alternatives/yacc
|
||||
app-alternatives/lex
|
||||
${PYTHON_DEPS}
|
||||
"
|
||||
RDEPEND="
|
||||
app-text/ghostscript-gpl
|
||||
dev-db/sqlite:3
|
||||
dev-lang/perl
|
||||
dev-libs/libfmt:=
|
||||
dev-libs/spdlog:=
|
||||
virtual/libiconv
|
||||
clang? (
|
||||
$(llvm_gen_dep '
|
||||
llvm-core/clang:${LLVM_SLOT}=
|
||||
llvm-core/llvm:${LLVM_SLOT}=
|
||||
')
|
||||
)
|
||||
dot? (
|
||||
media-gfx/graphviz[freetype(+)]
|
||||
)
|
||||
doc? (
|
||||
dev-texlive/texlive-bibtexextra
|
||||
dev-texlive/texlive-fontsextra
|
||||
dev-texlive/texlive-fontutils
|
||||
dev-texlive/texlive-latex
|
||||
dev-texlive/texlive-latexextra
|
||||
dev-texlive/texlive-plaingeneric
|
||||
)
|
||||
doxysearch? ( dev-libs/xapian:= )
|
||||
gui? ( dev-qt/qtbase:6[gui,widgets,xml] )
|
||||
"
|
||||
DEPEND="${RDEPEND}"
|
||||
|
||||
PATCHES=(
|
||||
"${FILESDIR}/${PN}-1.15.0-link_with_pthread.patch"
|
||||
"${FILESDIR}/${PN}-1.14.0-suppress-unused-option-libcxx.patch"
|
||||
"${FILESDIR}/${PN}-1.15.0-duplicate-type-names.patch"
|
||||
)
|
||||
|
||||
DOCS=( LANGUAGE.HOWTO README.md )
|
||||
|
||||
pkg_setup() {
|
||||
use clang && llvm-r1_pkg_setup
|
||||
python-any-r1_pkg_setup
|
||||
}
|
||||
|
||||
src_prepare() {
|
||||
cmake_src_prepare
|
||||
|
||||
# Call dot with -Teps instead of -Tps for EPS generation - bug #282150
|
||||
sed -i -e '/addJob("ps"/ s/"ps"/"eps"/g' src/dot.cpp || die
|
||||
|
||||
# fix pdf doc
|
||||
sed -i.orig -e "s:g_kowal:g kowal:" \
|
||||
doc/maintainers.txt || die
|
||||
|
||||
if is-flagq "-O3" ; then
|
||||
# TODO: Investigate this and report a bug accordingly...
|
||||
ewarn "Compiling with -O3 is known to produce incorrectly"
|
||||
ewarn "optimized code which breaks doxygen. Using -O2 instead."
|
||||
replace-flags "-O3" "-O2"
|
||||
fi
|
||||
}
|
||||
|
||||
src_configure() {
|
||||
# Very slow to compile, bug #920092
|
||||
filter-flags -fipa-pta
|
||||
# -Wodr warnings, see bug #854357 and https://github.com/doxygen/doxygen/issues/9287
|
||||
filter-lto
|
||||
|
||||
local mycmakeargs=(
|
||||
-Duse_libclang=$(usex clang)
|
||||
# Let the user choose instead, see also bug #822615
|
||||
-Duse_libc++=OFF
|
||||
-Dbuild_doc=$(usex doc)
|
||||
-Dbuild_search=$(usex doxysearch)
|
||||
-Dbuild_wizard=$(usex gui)
|
||||
-Dforce_qt=Qt6
|
||||
-Duse_sys_fmt=ON
|
||||
-Duse_sys_spdlog=ON
|
||||
-Duse_sys_sqlite3=ON
|
||||
-DBUILD_SHARED_LIBS=OFF
|
||||
-DGIT_EXECUTABLE="false"
|
||||
|
||||
# Noisy and irrelevant downstream
|
||||
-Wno-dev
|
||||
)
|
||||
|
||||
use doc && mycmakeargs+=(
|
||||
-DDOC_INSTALL_DIR="share/doc/${P}"
|
||||
)
|
||||
|
||||
cmake_src_configure
|
||||
}
|
||||
|
||||
src_compile() {
|
||||
cmake_src_compile
|
||||
|
||||
if use doc; then
|
||||
export VARTEXFONTS="${T}/fonts" # bug #564944
|
||||
|
||||
# -j1 for bug #770070
|
||||
cmake_src_compile docs -j1
|
||||
fi
|
||||
}
|
||||
@ -0,0 +1,50 @@
|
||||
https://bugs.gentoo.org/966843
|
||||
https://github.com/wxWidgets/Phoenix/issues/2820
|
||||
https://github.com/doxygen/doxygen/issues/11889
|
||||
https://github.com/doxygen/doxygen/commit/148e93969da016a8d8ecf1fcdb9fcf045471d688
|
||||
|
||||
From 148e93969da016a8d8ecf1fcdb9fcf045471d688 Mon Sep 17 00:00:00 2001
|
||||
From: Blake Batson <bbatson101@gmail.com>
|
||||
Date: Wed, 10 Dec 2025 20:43:32 -0500
|
||||
Subject: [PATCH] Fix duplicate type names
|
||||
|
||||
---
|
||||
src/util.cpp | 10 ++++++++--
|
||||
1 file changed, 8 insertions(+), 2 deletions(-)
|
||||
|
||||
diff --git a/src/util.cpp b/src/util.cpp
|
||||
index 89e49d9aff1..ddb4829117c 100644
|
||||
--- a/src/util.cpp
|
||||
+++ b/src/util.cpp
|
||||
@@ -979,6 +979,7 @@ void linkifyText(const TextGeneratorIntf &out, const Definition *scope,
|
||||
{
|
||||
const ClassDef *cd=nullptr;
|
||||
const ConceptDef *cnd=nullptr;
|
||||
+ const Definition *d=nullptr;
|
||||
//printf("** Match word '%s'\n",qPrint(matchWord));
|
||||
|
||||
SymbolResolver resolver(fileScope);
|
||||
@@ -1010,7 +1011,12 @@ void linkifyText(const TextGeneratorIntf &out, const Definition *scope,
|
||||
}
|
||||
}
|
||||
};
|
||||
- if ((cd=getClass(matchWord)))
|
||||
+
|
||||
+ if (found)
|
||||
+ {
|
||||
+ //printf(" -> skip\n");
|
||||
+ }
|
||||
+ else if ((cd=getClass(matchWord)))
|
||||
{
|
||||
writeCompoundName(cd);
|
||||
}
|
||||
@@ -1022,7 +1028,7 @@ void linkifyText(const TextGeneratorIntf &out, const Definition *scope,
|
||||
{
|
||||
writeCompoundName(cnd);
|
||||
}
|
||||
- else if (const Definition *d=nullptr; cd==nullptr && !found && (d=resolver.resolveSymbol(scope,matchWord)))
|
||||
+ else if ((d=resolver.resolveSymbol(scope,matchWord)))
|
||||
{
|
||||
writeCompoundName(d);
|
||||
}
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user