Gentoo Archives: gentoo-commits

From: "Miroslav Šulc" <fordfrog@g.o>
To: gentoo-commits@l.g.o
Subject: [gentoo-commits] repo/gentoo:master commit in: dev-java/swt/, dev-java/swt/files/
Date: Sun, 19 Mar 2023 06:38:20
Message-Id: 1679207439.f827629c3b99735e623babe93c76624251cd2fd2.fordfrog@gentoo
1 commit: f827629c3b99735e623babe93c76624251cd2fd2
2 Author: Volkmar W. Pogatzki <gentoo <AT> pogatzki <DOT> net>
3 AuthorDate: Mon Jan 2 18:38:42 2023 +0000
4 Commit: Miroslav Šulc <fordfrog <AT> gentoo <DOT> org>
5 CommitDate: Sun Mar 19 06:30:39 2023 +0000
6 URL: https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=f827629c
7
8 dev-java/swt: add 4.27
9
10 - adds arm64 to conditional sources, to be keyworded
11 - switches to java-pkg-simple.eclass
12 - drops osgi stuff, not used upstream
13 - reworks swt-4.27-as-needed-and-flag-fixes.patch from 4.10
14 - re-uses src_compile() from 4.10 except "eant compile"
15 Signed-off-by: Volkmar W. Pogatzki <gentoo <AT> pogatzki.net>
16 Closes: https://github.com/gentoo/gentoo/pull/29142/commits/0cace839b2d3e8c310b1371dcd12f9626c90a147
17 Signed-off-by: Miroslav Šulc <fordfrog <AT> gentoo.org>
18
19 dev-java/swt/Manifest | 3 +
20 .../files/swt-4.27-as-needed-and-flag-fixes.patch | 82 ++++++++++++
21 dev-java/swt/swt-4.27.ebuild | 142 +++++++++++++++++++++
22 3 files changed, 227 insertions(+)
23
24 diff --git a/dev-java/swt/Manifest b/dev-java/swt/Manifest
25 index a1e00f9e4f9c..296f28fcfb56 100644
26 --- a/dev-java/swt/Manifest
27 +++ b/dev-java/swt/Manifest
28 @@ -3,3 +3,6 @@ DIST swt-3.7.2-gtk-linux-x86.zip 5374609 BLAKE2B 04d44b9fffcedc6ce255e2651377ac6
29 DIST swt-3.7.2-gtk-linux-x86_64.zip 5671443 BLAKE2B 953fc9eab6d1f2750b1a1345cddf4aa6969567cb75977f87ee50668d367e55dda8be2ff836d87b780005c22132fa783b475f422c093617fd02f478eadd96076d SHA512 d60ae1d3f3b0577f7e3018139f93069c89d021064fec2f3f4074f95cfae56abdc0c7d531cb904ad3911482543cddcc3f6646ff47192073f4bde97c79e13612b7
30 DIST swt-4.10-gtk-linux-ppc64le.zip 3848264 BLAKE2B 214861fde6987906fb24f3187936f3bcb49aebed54fe242427c3737bf6761e8f77d049c376f30ca0fc33e74a1e8a48b6aff6d9863775ee9c33fea7cb2edd1309 SHA512 1b3ede58c2b41abae76f58a303bd3fbf1849ba8be3fd6518325bc22400e960c3ab542e7351b1bc08053e2746ea3e28812e04c2d1789cb1e19ea28745c8a5f39a
31 DIST swt-4.10-gtk-linux-x86_64.zip 3844306 BLAKE2B 0e0ed21708acce347fd025920ee635f586c460f8a9c05a7067fd70eed9da999b4a62a5febd17f0c5546ab15198336038e4ab49a1bd588d49ffb39450353a1911 SHA512 9dd946cb7c11446f553f06b8af516167519bab00d4a89f626cd612be6d18e50023fc537aa3d844a8f7a56a767df00410efe4dd20e2bfd930639330a1e279a7a0
32 +DIST swt-4.27-gtk-linux-aarch64.zip 3849438 BLAKE2B b07daa4942c450d5cca5a323b0649a645fe9a283b272a73a9675f3bd07fbae859c41f451521231a93f4fb56ae4093d57474545611c4789c076abad2e9e1c911f SHA512 a3ba011258e5906beb15ffd5deaa73fc9a5ed5f7bce78a4a683ad8ad12a5cca1fa3a0d89fed6da9f4ade530ea3bda09093ad43202993b522a060a9dcd98746d3
33 +DIST swt-4.27-gtk-linux-ppc64le.zip 3872996 BLAKE2B 58ae779b7103da932719fe702674e211f8f0068c3b6094172b4c58e939de96d8d43ef80d40740c29f6fcd802a252a87ba850e9e6320d881c958b0161700e4e8c SHA512 6f8f1fce502e0980ced3f201dcdeb3397a583a9ba9ebe76d82c713c440d614c4ff38efe5f596a9da25940f931e3c651c36b18211faea4fab31872d25566b060a
34 +DIST swt-4.27-gtk-linux-x86_64.zip 3869518 BLAKE2B d0eb7d1be59944cbffe5556c258043d084f7f1a8fa1d9ad9c3738896adc12aa015f85b675ba72af31de566ae451280bb83d82082b3f589c8da643631bf1f7bfb SHA512 efa89c1752340978e1aa1d2343a07df001fa952092aef959bdeedf53a31270d24ebe34ccb50e72ef2221da810ed08c53b188a80aab8a37e5932f85f6771ea1ef
35
36 diff --git a/dev-java/swt/files/swt-4.27-as-needed-and-flag-fixes.patch b/dev-java/swt/files/swt-4.27-as-needed-and-flag-fixes.patch
37 new file mode 100644
38 index 000000000000..fffbc910c521
39 --- /dev/null
40 +++ b/dev-java/swt/files/swt-4.27-as-needed-and-flag-fixes.patch
41 @@ -0,0 +1,82 @@
42 +diff -Naur a/make_linux.mak b/make_linux.mak
43 +--- a/make_linux.mak 2019-01-07 14:08:00.269147198 +0100
44 ++++ b/make_linux.mak 2019-01-07 14:10:28.645155241 +0100
45 +@@ -98,7 +98,7 @@
46 + WEBKIT_OBJECTS = swt.o webkitgtk.o webkitgtk_structs.o webkitgtk_stats.o webkitgtk_custom.o
47 + GLX_OBJECTS = swt.o glx.o glx_structs.o glx_stats.o
48 +
49 +-CFLAGS := $(CFLAGS) \
50 ++CFLAGS += -fPIC \
51 + -DSWT_VERSION=$(SWT_VERSION) \
52 + $(NATIVE_STATS) \
53 + $(SWT_DEBUG) \
54 +@@ -130,13 +130,13 @@
55 + make_swt: $(SWT_LIB) $(SWTPI_LIB)
56 +
57 + $(SWT_LIB): $(SWT_OBJECTS)
58 +- $(CC) $(LFLAGS) -o $(SWT_LIB) $(SWT_OBJECTS)
59 ++ $(CC) $(LDFLAGS) $(LFLAGS) -o $(SWT_LIB) $(SWT_OBJECTS)
60 +
61 + callback.o: callback.c callback.h
62 + $(CC) $(CFLAGS) $(GTKCFLAGS) -DUSE_ASSEMBLER -c callback.c
63 +
64 + $(SWTPI_LIB): $(SWTPI_OBJECTS)
65 +- $(CC) $(LFLAGS) -o $(SWTPI_LIB) $(SWTPI_OBJECTS) $(GTKLIBS)
66 ++ $(CC) $(LDFLAGS) $(LFLAGS) -o $(SWTPI_LIB) $(SWTPI_OBJECTS) $(GTKLIBS)
67 +
68 + swt.o: swt.c swt.h
69 + $(CC) $(CFLAGS) -c swt.c
70 +@@ -169,7 +169,7 @@
71 + make_cairo: $(CAIRO_LIB)
72 +
73 + $(CAIRO_LIB): $(CAIRO_OBJECTS)
74 +- $(CC) $(LFLAGS) -o $(CAIRO_LIB) $(CAIRO_OBJECTS) $(CAIROLIBS)
75 ++ $(CC) $(LDFLAGS) $(LFLAGS) -o $(CAIRO_LIB) $(CAIRO_OBJECTS) $(CAIROLIBS)
76 +
77 + cairo.o: cairo.c cairo.h swt.h
78 + $(CC) $(CFLAGS) $(CAIROCFLAGS) -c cairo.c
79 +@@ -184,7 +184,7 @@
80 + make_awt:$(AWT_LIB)
81 +
82 + $(AWT_LIB): $(AWT_OBJECTS)
83 +- $(CC) $(AWT_LFLAGS) -o $(AWT_LIB) $(AWT_OBJECTS) $(AWT_LIBS)
84 ++ $(CC) -fPIC $(LDFLAGS) $(AWT_LFLAGS) -o $(AWT_LIB) $(AWT_OBJECTS) $(AWT_LIBS)
85 +
86 + #
87 + # Atk lib
88 +@@ -192,7 +192,7 @@
89 + make_atk: $(ATK_LIB)
90 +
91 + $(ATK_LIB): $(ATK_OBJECTS)
92 +- $(CC) $(LFLAGS) -o $(ATK_LIB) $(ATK_OBJECTS) $(ATKLIBS)
93 ++ $(CC) $(LDFLAGS) $(LFLAGS) -o $(ATK_LIB) $(ATK_OBJECTS) $(ATKLIBS)
94 +
95 + atk.o: atk.c atk.h
96 + $(CC) $(CFLAGS) $(ATKCFLAGS) -c atk.c
97 +@@ -209,7 +209,7 @@
98 + make_webkit: $(WEBKIT_LIB)
99 +
100 + $(WEBKIT_LIB): $(WEBKIT_OBJECTS)
101 +- $(CC) $(LFLAGS) -o $(WEBKIT_LIB) $(WEBKIT_OBJECTS) $(WEBKITLIBS)
102 ++ $(CC) $(LDFLAGS) $(LFLAGS) -o $(WEBKIT_LIB) $(WEBKIT_OBJECTS) $(WEBKITLIBS)
103 +
104 + webkitgtk.o: webkitgtk.c webkitgtk_custom.h
105 + $(CC) $(CFLAGS) $(WEBKITCFLAGS) -c webkitgtk.c
106 +# @@ -217,7 +217,7 @@
107 +# make_webkit2extension: $(WEBKIT_EXTENSION_LIB)
108 +#
109 +# $(WEBKIT_EXTENSION_LIB) : webkitgtk_extension.o
110 +# - $(CC) $(LFLAGS) -o $@ $^ $(WEBKIT_EXTENSION_LFLAGS)
111 +# + $(CC) $(LDFLAGS) $(LFLAGS) -o $@ $^ $(WEBKIT_EXTENSION_LFLAGS)
112 +#
113 +# webkitgtk_extension.o : webkitgtk_extension.c
114 +# $(CC) $(CFLAGS) $(WEBKIT_EXTENSION_CFLAGS) ${SWT_PTR_CFLAGS} -fPIC -c $^
115 +@@ -229,7 +229,7 @@
116 + make_glx: $(GLX_LIB)
117 +
118 + $(GLX_LIB): $(GLX_OBJECTS)
119 +- $(CC) $(LFLAGS) -o $(GLX_LIB) $(GLX_OBJECTS) $(GLXLIBS)
120 ++ $(CC) $(LDFLAGS) $(LFLAGS) -o $(GLX_LIB) $(GLX_OBJECTS) $(GLXLIBS)
121 +
122 + glx.o: glx.c
123 + $(CC) $(CFLAGS) $(GLXCFLAGS) -c glx.c
124
125 diff --git a/dev-java/swt/swt-4.27.ebuild b/dev-java/swt/swt-4.27.ebuild
126 new file mode 100644
127 index 000000000000..e21194ce71dd
128 --- /dev/null
129 +++ b/dev-java/swt/swt-4.27.ebuild
130 @@ -0,0 +1,142 @@
131 +# Copyright 1999-2023 Gentoo Authors
132 +# Distributed under the terms of the GNU General Public License v2
133 +
134 +EAPI=8
135 +
136 +JAVA_PKG_IUSE="doc source"
137 +
138 +inherit flag-o-matic java-pkg-2 java-pkg-simple toolchain-funcs
139 +
140 +MY_PV="${PV/_rc/RC}"
141 +MY_DMF="https://download.eclipse.org/eclipse/downloads/drops4/R-${MY_PV}-202303020300"
142 +MY_P="${PN}-${MY_PV}"
143 +
144 +DESCRIPTION="GTK based SWT Library"
145 +HOMEPAGE="https://www.eclipse.org/swt/"
146 +SRC_URI="
147 + amd64? ( ${MY_DMF}/${MY_P}-gtk-linux-x86_64.zip )
148 + arm64? ( ${MY_DMF}/${MY_P}-gtk-linux-aarch64.zip )
149 + ppc64? ( ${MY_DMF}/${MY_P}-gtk-linux-ppc64le.zip )"
150 +
151 +LICENSE="CPL-1.0 LGPL-2.1 MPL-1.1"
152 +SLOT="4.27"
153 +KEYWORDS="~amd64 ~ppc64"
154 +IUSE="cairo opengl webkit"
155 +
156 +COMMON_DEP="
157 + app-accessibility/at-spi2-core:2
158 + dev-libs/glib
159 + x11-libs/gtk+:2
160 + x11-libs/libXtst
161 + cairo? ( x11-libs/cairo )
162 + opengl? (
163 + virtual/glu
164 + virtual/opengl
165 + )
166 + webkit? (
167 + net-libs/webkit-gtk:4.1
168 + )"
169 +DEPEND="${COMMON_DEP}
170 + >=virtual/jdk-11:*[-headless-awt]
171 + x11-base/xorg-proto
172 + x11-libs/libX11
173 + x11-libs/libXrender
174 + x11-libs/libXt
175 + x11-libs/libXtst"
176 +RDEPEND="${COMMON_DEP}
177 + >=virtual/jre-1.8:*"
178 +BDEPEND="
179 + app-arch/unzip
180 + virtual/pkgconfig
181 +"
182 +
183 +HTML_DOCS=( about.html )
184 +
185 +JAVA_RESOURCE_DIRS="resources"
186 +JAVA_SRC_DIR="src"
187 +
188 +PATCHES=(
189 + "${FILESDIR}/${P}-as-needed-and-flag-fixes.patch"
190 +)
191 +
192 +src_unpack() {
193 + default
194 + unpack "./src.zip"
195 +}
196 +
197 +src_prepare() {
198 + default
199 + java-pkg-2_src_prepare
200 + # .css stuff is essential at least for running net-p2p/biglybt
201 + unzip swt.jar 'org/eclipse/swt/internal/gtk/*.css' -d resources || die
202 + java-pkg_clean
203 + mkdir src || die "mkdir failed"
204 + mv org src || die "moving java sources failed"
205 + find src -type f ! -name '*.java' | xargs \
206 + cp --parent -t resources -v || die "copying resources failed"
207 + cp version.txt resources || die "adding version.txt failed"
208 +}
209 +
210 +src_compile() {
211 + append-cflags -fcommon # https://bugs.gentoo.org/707838
212 +
213 + local JAWTSO="libjawt.so"
214 + IFS=":" read -r -a ldpaths <<< $(java-config -g LDPATH)
215 +
216 + for libpath in "${ldpaths[@]}"; do
217 + if [[ -f "${libpath}/${JAWTSO}" ]]; then
218 + export AWT_LIB_PATH="${libpath}"
219 + break
220 + # this is a workaround for broken LDPATH in <=openjdk-8.292_p10 and <=dev-java/openjdk-bin-8.292_p10
221 + elif [[ -f "${libpath}/$(tc-arch)/${JAWTSO}" ]]; then
222 + export AWT_LIB_PATH="${libpath}/$(tc-arch)"
223 + break
224 + fi
225 + done
226 +
227 + if [[ -z "${AWT_LIB_PATH}" ]]; then
228 + eerror "${JAWTSO} not found in the JDK being used for compilation!"
229 + die "cannot build AWT library"
230 + fi
231 +
232 + # Fix the pointer size for AMD64
233 + export SWT_PTR_CFLAGS=-DJNI64
234 +
235 + # Bug #461784, g_thread_init is deprecated since glib-2.32.
236 + append-cflags -DNO__1g_1thread_1init
237 +
238 + local make="emake -f make_linux.mak NO_STRIP=y CC=$(tc-getCC) CXX=$(tc-getCXX)"
239 +
240 + einfo "Building AWT library"
241 + ${make} make_awt AWT_LIBS="-L\$(AWT_LIB_PATH) -Wl,-rpath,\$(AWT_LIB_PATH) -ljawt \`pkg-config --libs x11\`"
242 +
243 + einfo "Building SWT library"
244 + ${make} make_swt
245 +
246 + einfo "Building JAVA-AT-SPI bridge"
247 + ${make} make_atk
248 +
249 + if use cairo ; then
250 + einfo "Building CAIRO support"
251 + ${make} make_cairo
252 + fi
253 +
254 + if use opengl ; then
255 + einfo "Building OpenGL component"
256 + ${make} make_glx
257 + fi
258 +
259 + if use webkit ; then
260 + einfo "Building WebKit component"
261 + ${make} make_webkit
262 + fi
263 +
264 + java-pkg-simple_src_compile
265 +}
266 +
267 +src_install() {
268 + java-pkg-simple_src_install
269 +
270 + java-pkg_sointo "/usr/$(get_libdir)/swt"
271 + java-pkg_doso *.so
272 +}