Gentoo Archives: gentoo-commits

From: Mart Raudsepp <leio@g.o>
To: gentoo-commits@l.g.o
Subject: [gentoo-commits] repo/gentoo:master commit in: dev-util/gnome-builder/files/, dev-util/gnome-builder/
Date: Wed, 29 Aug 2018 21:57:31
Message-Id: 1535579805.72eade86bac797c6161cd3ad36a0fcfc6436b688.leio@gentoo
1 commit: 72eade86bac797c6161cd3ad36a0fcfc6436b688
2 Author: Mart Raudsepp <leio <AT> gentoo <DOT> org>
3 AuthorDate: Wed Aug 29 06:48:06 2018 +0000
4 Commit: Mart Raudsepp <leio <AT> gentoo <DOT> org>
5 CommitDate: Wed Aug 29 21:56:45 2018 +0000
6 URL: https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=72eade86
7
8 dev-util/gnome-builder: bump to 3.28.4
9
10 Package-Manager: Portage-2.3.48, Repoman-2.3.10
11
12 dev-util/gnome-builder/Manifest | 1 +
13 .../files/3.28.4-fix-docs-option.patch | 42 +++++
14 .../files/3.28.4-fix-tests-schemadir.patch | 26 +++
15 .../files/3.28.4-jedi-0.12-compat.patch | 93 +++++++++++
16 .../gnome-builder/files/3.28.4-python37-fix.patch | 57 +++++++
17 dev-util/gnome-builder/files/3.28.4-valac.patch | 15 ++
18 dev-util/gnome-builder/gnome-builder-3.28.4.ebuild | 185 +++++++++++++++++++++
19 dev-util/gnome-builder/metadata.xml | 1 +
20 8 files changed, 420 insertions(+)
21
22 diff --git a/dev-util/gnome-builder/Manifest b/dev-util/gnome-builder/Manifest
23 index 555f60511b2..46650bd57a9 100644
24 --- a/dev-util/gnome-builder/Manifest
25 +++ b/dev-util/gnome-builder/Manifest
26 @@ -1 +1,2 @@
27 DIST gnome-builder-3.24.2.tar.xz 4342908 BLAKE2B 5dca80d2e948041bc096fa9a2a5d39322c6fedb0560e3e4f3c60c7b0657c7c62e89387a63f7d050c3df90d8c129485bc5495039802548b22ae268d94c14a37ae SHA512 dec133ad3c5ef96a036598ebbe684667dc44f73d8643e700f1e776cf8eb860b99c1d333f1fed5bc896cb7bdcf607eb51fedb7bb1f5b0cc662e4b2703d74140bf
28 +DIST gnome-builder-3.28.4.tar.xz 9309060 BLAKE2B a4402452ffaf64cc767edb9cba65b74a88cb77d04ca2ffecd3b01c53382930891c2c03e2528861f4d28ca3643465b6767235e945f44cc37d2d716bcbb3ab25c8 SHA512 ef83b909f295d83478aa7d5deb8b5d8291ddf6134e147e88452cdba8ff449a2415d0381d63d3f82cf28942b1096a704de64540c8cdf5f06c21c8278c93fbbc03
29
30 diff --git a/dev-util/gnome-builder/files/3.28.4-fix-docs-option.patch b/dev-util/gnome-builder/files/3.28.4-fix-docs-option.patch
31 new file mode 100644
32 index 00000000000..ca2323f314a
33 --- /dev/null
34 +++ b/dev-util/gnome-builder/files/3.28.4-fix-docs-option.patch
35 @@ -0,0 +1,42 @@
36 +From 054ef6d2e47da9f41e7c24908b251d074e11a03b Mon Sep 17 00:00:00 2001
37 +From: Christian Hergert <chergert@××××××.com>
38 +Date: Wed, 8 Aug 2018 13:03:50 -0700
39 +Subject: [PATCH] help: fix get_option() to check for proper value
40 +
41 +We want to check for help docs, not sdk docs. Also, if enabled, don't be
42 +automatic about it. Fail hard so the caller knows there is an issue.
43 +---
44 + doc/help/meson.build | 18 ++++++++----------
45 + 1 file changed, 8 insertions(+), 10 deletions(-)
46 +
47 +diff --git a/doc/help/meson.build b/doc/help/meson.build
48 +index 1336e6a26..e684f078c 100644
49 +--- a/doc/help/meson.build
50 ++++ b/doc/help/meson.build
51 +@@ -1,15 +1,13 @@
52 +-if get_option('with_docs')
53 ++if get_option('with_help')
54 +
55 +-sphinx = find_program(['sphinx-build-3', 'sphinx-build'], required: false)
56 ++sphinx = find_program(['sphinx-build-3', 'sphinx-build'], required: true)
57 +
58 +-if sphinx.found()
59 +- custom_target('en user documentation',
60 +- command: [sphinx, '-b', 'html', '-c', meson.current_source_dir(), meson.current_source_dir(), '@OUTPUT@'],
61 +- output: 'en',
62 +- build_by_default: true)
63 ++custom_target('en user documentation',
64 ++ command: [sphinx, '-b', 'html', '-c', meson.current_source_dir(), meson.current_source_dir(), '@OUTPUT@'],
65 ++ output: 'en',
66 ++ build_by_default: true
67 ++)
68 +
69 +-
70 +- install_subdir(meson.current_build_dir() + '/en', install_dir: pkgdocdir_abs)
71 +-endif
72 ++install_subdir(meson.current_build_dir() + '/en', install_dir: pkgdocdir_abs)
73 +
74 + endif
75 +--
76 +2.17.0
77 +
78
79 diff --git a/dev-util/gnome-builder/files/3.28.4-fix-tests-schemadir.patch b/dev-util/gnome-builder/files/3.28.4-fix-tests-schemadir.patch
80 new file mode 100644
81 index 00000000000..3c427c41584
82 --- /dev/null
83 +++ b/dev-util/gnome-builder/files/3.28.4-fix-tests-schemadir.patch
84 @@ -0,0 +1,26 @@
85 +From a66b2d99f21bff6986b0dda5b7cc9ee393be934a Mon Sep 17 00:00:00 2001
86 +From: Mart Raudsepp <leio@g.o>
87 +Date: Wed, 29 Aug 2018 12:30:14 +0300
88 +Subject: [PATCH] build: Fix GSETTINGS_SCHEMA_DIR envvar handling in tests
89 +
90 +GSETTINGS_SCHEMA_DIR does not support multiple colon-separated paths.
91 +---
92 + src/tests/meson.build | 2 +-
93 + 1 file changed, 1 insertion(+), 1 deletion(-)
94 +
95 +diff --git a/src/tests/meson.build b/src/tests/meson.build
96 +index 646f6f875..42c0e6d28 100644
97 +--- a/src/tests/meson.build
98 ++++ b/src/tests/meson.build
99 +@@ -16,7 +16,7 @@ ide_test_env = [
100 + 'G_TEST_BUILDDIR=@0@'.format(meson.current_build_dir()),
101 + 'G_DEBUG=gc-friendly',
102 + 'GSETTINGS_BACKEND=memory',
103 +- 'GSETTINGS_SCHEMA_DIR=@0@/data/gsettings:$(GSETTINGS_SCHEMA_DIR)'.format(meson.build_root()),
104 ++ 'GSETTINGS_SCHEMA_DIR=@0@/data/gsettings'.format(meson.build_root()),
105 + 'PYTHONDONTWRITEBYTECODE=yes',
106 + 'MALLOC_CHECK_=2',
107 + # 'MALLOC_PERTURB_=$((${RANDOM:-256} % 256))',
108 +--
109 +2.17.0
110 +
111
112 diff --git a/dev-util/gnome-builder/files/3.28.4-jedi-0.12-compat.patch b/dev-util/gnome-builder/files/3.28.4-jedi-0.12-compat.patch
113 new file mode 100644
114 index 00000000000..4132e2d1bfe
115 --- /dev/null
116 +++ b/dev-util/gnome-builder/files/3.28.4-jedi-0.12-compat.patch
117 @@ -0,0 +1,93 @@
118 +From 799a378b96cad5dc9b1093604e76ed362d22f4cc Mon Sep 17 00:00:00 2001
119 +From: Christian Hergert <chergert@××××××.com>
120 +Date: Sun, 27 May 2018 20:19:34 -0700
121 +Subject: [PATCH] jedi: minimal attempt to get things working again
122 +
123 +This tries to get some of our jedi code working with recent API changes
124 +in the jedi project.
125 +
126 +This is just a minimal fix, and I'd expect some others may be needed for
127 +improved functionality.
128 +
129 +Fixes #403
130 +---
131 + src/plugins/jedi/jedi_plugin.py | 44 ++++++++++++++++++++++-----------
132 + 1 file changed, 29 insertions(+), 15 deletions(-)
133 +
134 +diff --git a/src/plugins/jedi/jedi_plugin.py b/src/plugins/jedi/jedi_plugin.py
135 +index fd8e15d68..052500da1 100644
136 +--- a/src/plugins/jedi/jedi_plugin.py
137 ++++ b/src/plugins/jedi/jedi_plugin.py
138 +@@ -91,8 +91,14 @@ try:
139 + import jedi
140 + from jedi.evaluate.compiled import CompiledObject
141 + from jedi.evaluate.compiled import get_special_object
142 +- from jedi.evaluate.compiled import _create_from_name
143 +- from jedi.evaluate.context import Context
144 ++ try:
145 ++ # 0.12
146 ++ from jedi.evaluate.compiled import create_from_name
147 ++ from jedi.evaluate.base_context import Context
148 ++ except ImportError:
149 ++ # Pre 0.12
150 ++ from jedi.evaluate.compiled import _create_from_name as create_from_name
151 ++ from jedi.evaluate.context import Context
152 + from jedi.evaluate.docstrings import _evaluate_for_statement_string
153 + from jedi.evaluate.imports import Importer
154 +
155 +@@ -175,23 +181,31 @@ try:
156 + pass
157 + return module_list
158 +
159 +- original_jedi_get_module = jedi.evaluate.compiled.fake.get_module
160 +-
161 +- def patched_jedi_get_module(obj):
162 +- "Work around a weird bug in jedi"
163 +- try:
164 +- return original_jedi_get_module(obj)
165 +- except ImportError as e:
166 +- if e.msg == "No module named 'gi._gobject._gobject'":
167 +- return original_jedi_get_module('gi._gobject')
168 ++ try:
169 ++ # Pre 0.12 workaround
170 ++ # TODO: What needs to be fixed here for 0.12?
171 ++ original_jedi_get_module = jedi.evaluate.compiled.fake.get_module
172 ++ def patched_jedi_get_module(obj):
173 ++ "Work around a weird bug in jedi"
174 ++ try:
175 ++ return original_jedi_get_module(obj)
176 ++ except ImportError as e:
177 ++ if e.msg == "No module named 'gi._gobject._gobject'":
178 ++ return original_jedi_get_module('gi._gobject')
179 ++ jedi.evaluate.compiled.fake.get_module = patched_jedi_get_module
180 ++ except:
181 ++ pass
182 +
183 +- jedi.evaluate.compiled.fake.get_module = patched_jedi_get_module
184 + jedi.evaluate.compiled.CompiledObject = PatchedJediCompiledObject
185 +- jedi.evaluate.instance.CompiledBoundMethod = PatchedCompiledBoundMethod
186 ++ try:
187 ++ jedi.evaluate.instance.CompiledBoundMethod = PatchedCompiledBoundMethod
188 ++ except AttributeError:
189 ++ jedi.evaluate.context.instance.CompiledBoundMethod = PatchedCompiledBoundMethod
190 + jedi.evaluate.imports.Importer = PatchedJediImporter
191 + HAS_JEDI = True
192 +-except ImportError:
193 ++except ImportError as ex:
194 + print("jedi not found, python auto-completion not possible.")
195 ++ print(ex)
196 + HAS_JEDI = False
197 +
198 + GIR_PATH_LIST = []
199 +@@ -376,7 +390,7 @@ class JediCompletionProvider(Ide.Object, GtkSource.CompletionProvider, Ide.Compl
200 + return False
201 +
202 + def do_populate(self, context):
203 +- self.current_word = Ide.CompletionProvider.context_current_word(context)
204 ++ self.current_word = Ide.CompletionProvider.context_current_word(context) or ''
205 + self.current_word_lower = self.current_word.lower()
206 +
207 + _, iter = context.get_iter()
208 +--
209 +2.17.0
210 +
211
212 diff --git a/dev-util/gnome-builder/files/3.28.4-python37-fix.patch b/dev-util/gnome-builder/files/3.28.4-python37-fix.patch
213 new file mode 100644
214 index 00000000000..2fc6ee5be06
215 --- /dev/null
216 +++ b/dev-util/gnome-builder/files/3.28.4-python37-fix.patch
217 @@ -0,0 +1,57 @@
218 +From e1d32d76231b1051a2380995f4a7822aa525375a Mon Sep 17 00:00:00 2001
219 +From: Simon McVittie <smcv@××××××.org>
220 +Date: Wed, 11 Jul 2018 11:57:06 +0100
221 +Subject: [PATCH] Python: Avoid identifier 'async', which became a keyword in
222 + 3.7
223 +
224 +This is an incompatible change, but so is async becoming an identifier.
225 +
226 +Fixes: #565
227 +Bug-Debian: https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=903558
228 +Signed-off-by: Simon McVittie <smcv@××××××.org>
229 +---
230 + src/libide/Ide.py | 6 +++---
231 + src/plugins/jedi/jedi_plugin.py | 2 +-
232 + 2 files changed, 4 insertions(+), 4 deletions(-)
233 +
234 +diff --git a/src/libide/Ide.py b/src/libide/Ide.py
235 +index 02bb61937..07d429c7a 100644
236 +--- a/src/libide/Ide.py
237 ++++ b/src/libide/Ide.py
238 +@@ -41,9 +41,9 @@ class _Gio_DBusMethodInfo:
239 + in_args = None
240 + out_signature = None
241 +
242 +-def DBusMethod(dbus_interface, in_signature=None, out_signature=None, async=False):
243 ++def DBusMethod(dbus_interface, in_signature=None, out_signature=None, is_async=False):
244 + def decorator(func):
245 +- func._is_async = async
246 ++ func._is_async = is_async
247 +
248 + func._dbus_method = _Gio_DBusMethodInfo()
249 + func._dbus_method.interface = dbus_interface
250 +@@ -54,7 +54,7 @@ def DBusMethod(dbus_interface, in_signature=None, out_signature=None, async=Fals
251 + in_signature_list = GLib.Variant.split_signature('('+in_signature+')')
252 + arg_names = inspect.getargspec(func).args
253 + arg_names.pop(0) # eat "self" argument
254 +- if async: arg_names.pop(0) # eat "invocation"
255 ++ if is_async: arg_names.pop(0) # eat "invocation"
256 + if len(in_signature) != len(arg_names):
257 + raise TypeError('specified signature %s for method %s does not match length of arguments' % (str(in_signature_list), func.func_name))
258 + for pair in zip(in_signature_list, arg_names):
259 +diff --git a/src/plugins/jedi/jedi_plugin.py b/src/plugins/jedi/jedi_plugin.py
260 +index 84bd11c27..a346a342e 100644
261 +--- a/src/plugins/jedi/jedi_plugin.py
262 ++++ b/src/plugins/jedi/jedi_plugin.py
263 +@@ -688,7 +688,7 @@ class JediService(Ide.DBusService):
264 + self.queue = {}
265 + self.handler_id = 0
266 +
267 +- @Ide.DBusMethod('org.gnome.builder.plugins.jedi', in_signature='siis', out_signature='a(issass)', async=True)
268 ++ @Ide.DBusMethod('org.gnome.builder.plugins.jedi', in_signature='siis', out_signature='a(issass)', is_async=True)
269 + def CodeComplete(self, invocation, filename, line, column, content):
270 + if filename in self.queue:
271 + request = self.queue.pop(filename)
272 +--
273 +2.17.0
274 +
275
276 diff --git a/dev-util/gnome-builder/files/3.28.4-valac.patch b/dev-util/gnome-builder/files/3.28.4-valac.patch
277 new file mode 100644
278 index 00000000000..acb1c54f851
279 --- /dev/null
280 +++ b/dev-util/gnome-builder/files/3.28.4-valac.patch
281 @@ -0,0 +1,15 @@
282 +diff --git a/src/plugins/vala-pack/meson.build b/src/plugins/vala-pack/meson.build
283 +index dd36d351d..a8c53c6e5 100644
284 +--- a/src/plugins/vala-pack/meson.build
285 ++++ b/src/plugins/vala-pack/meson.build
286 +@@ -6,8 +6,8 @@ endif
287 +
288 + add_languages('vala')
289 +
290 +-valac = find_program ('valac')
291 +-libvala_version = run_command(valac, '--api-version').stdout().strip()
292 ++valac = meson.get_compiler('vala')
293 ++libvala_version = run_command(valac.cmd_array()[0], '--api-version').stdout().strip()
294 + libvala = dependency('libvala-@0@'.format(libvala_version))
295 +
296 + vala_pack_sources = [
297
298 diff --git a/dev-util/gnome-builder/gnome-builder-3.28.4.ebuild b/dev-util/gnome-builder/gnome-builder-3.28.4.ebuild
299 new file mode 100644
300 index 00000000000..9fb20da3c55
301 --- /dev/null
302 +++ b/dev-util/gnome-builder/gnome-builder-3.28.4.ebuild
303 @@ -0,0 +1,185 @@
304 +# Copyright 1999-2018 Gentoo Foundation
305 +# Distributed under the terms of the GNU General Public License v2
306 +
307 +EAPI=6
308 +PYTHON_COMPAT=( python3_{4,5,6} )
309 +VALA_MIN_API_VERSION="0.36"
310 +DISABLE_AUTOFORMATTING=1
311 +FORCE_PRINT_ELOG=1
312 +
313 +inherit gnome.org gnome2-utils llvm meson python-single-r1 readme.gentoo-r1 vala virtualx xdg
314 +
315 +DESCRIPTION="An IDE for writing GNOME-based software"
316 +HOMEPAGE="https://wiki.gnome.org/Apps/Builder"
317 +
318 +# FIXME: Review licenses at some point
319 +LICENSE="GPL-3+ GPL-2+ LGPL-3+ LGPL-2+ MIT CC-BY-SA-3.0 CC0-1.0"
320 +SLOT="0"
321 +KEYWORDS="~amd64"
322 +IUSE="clang +devhelp doc +git gtk-doc sysprof vala webkit"
323 +REQUIRED_USE="${PYTHON_REQUIRED_USE}"
324 +
325 +# When bumping, pay attention to all the included plugins/*/meson.build (and other) build files and the requirements within.
326 +# `grep -rI dependency * --include='meson.build'` can give a good initial idea for external deps and their double checking.
327 +# The listed RDEPEND order shold roughly match that output as well, with toplevel one first.
328 +# Most plugins have no extra requirements and default to enabled; we need to handle the ones with extra requirements. Many of
329 +# them have optional runtime dependencies, for which we try to at least notify the user via DOC_CONTENTS (but not all small
330 +# things); `grep -rI -e 'command-pattern.*=' -e 'push_arg'` can give a (spammy) idea, plus python imports in try/except.
331 +
332 +# FIXME: with_flatpak needs flatpak.pc >=0.8.0, ${LIBGIT_DEPS} and libsoup-2.4.pc >=2.52.0
333 +# Editorconfig needs old pcre, with vte migrating away, might want it optional or ported to pcre2?
334 +# An introspection USE flag of a dep is required if any introspection based language plugin wants to use it (grep for gi.repository). Last full check at 3.28.4
335 +
336 +# These are needed with either USE=git or USE=flatpak (albeit the latter isn't supported yet)
337 +LIBGIT_DEPS="
338 + dev-libs/libgit2[ssh,threads]
339 + >=dev-libs/libgit2-glib-0.25.0[ssh]
340 +"
341 +# TODO: Handle llvm slots via llvm.eclass; see plugins/clang/meson.build
342 +RDEPEND="
343 + >=dev-libs/libdazzle-3.28.0[introspection,vala?]
344 + >=dev-libs/glib-2.56.0:2
345 + >=x11-libs/gtk+-3.22.26:3[introspection]
346 + >=x11-libs/gtksourceview-3.24.0:3.0[introspection]
347 + >=dev-libs/json-glib-1.2.0
348 + >=dev-libs/jsonrpc-glib-3.28.0[vala?]
349 + >=x11-libs/pango-1.38.0
350 + >=dev-libs/libpeas-1.22.0[python,${PYTHON_USEDEP}]
351 + >=dev-libs/template-glib-3.28.0[introspection,vala?]
352 + >=x11-libs/vte-0.40.2:2.91[vala?]
353 + >=dev-libs/libxml2-2.9.0
354 + git? ( ${LIBGIT_DEPS} )
355 + dev-libs/libpcre:3
356 + webkit? ( >=net-libs/webkit-gtk-2.12.0:4=[introspection] )
357 +
358 + >=dev-libs/gobject-introspection-1.48.0:=
359 + >=dev-python/pygobject-3.22.0:3[${PYTHON_USEDEP}]
360 + ${PYTHON_DEPS}
361 + clang? ( sys-devel/clang:= )
362 + devhelp? ( >=dev-util/devhelp-3.25.1:= )
363 + sysprof? ( >=dev-util/sysprof-3.28.0[gtk] )
364 + vala? (
365 + dev-lang/vala:=
366 + $(vala_depend)
367 + )
368 +" # We use subslot operator dep on vala in addition to $(vala_depend), because we have _runtime_
369 +# usage in vapa-pack plugin and need it rebuilt before removing an older vala it was built against
370 +# TODO: runtime ctags path finding..
371 +# FIXME: spellcheck plugin temporarily disabled due to requiring enchant-2
372 +# >=app-text/gspell-1.2.0
373 +# >=app-text/enchant:2
374 +
375 +# desktop-file-utils required for tests, but we have it in deptree for xdg update-desktop-database anyway, so be explicit and unconditional
376 +# appstream-glib needed for appdata.xml gettext translation and validation of it with appstream-util with FEATURES=test
377 +DEPEND="${RDEPEND}
378 + doc? ( dev-python/sphinx )
379 + dev-libs/appstream-glib
380 + dev-util/desktop-file-utils
381 + >=sys-devel/gettext-0.19.8
382 + virtual/pkgconfig
383 +"
384 +
385 +DOC_CONTENTS='gnome-builder can use various other dependencies on runtime to provide
386 +extra capabilities beyond these expressed via USE flags. Some of these
387 +that are currently available with packages include:
388 +
389 +* dev-util/uncrustify and dev-python/autopep8 for various Code Beautifier
390 + plugin out of the box functionality.
391 +* dev-util/ctags with exuberant-ctags selected via "eselect ctags" for
392 + C, C++, Python, JavaScript, CSS, HTML and Ruby autocompletion, semantic
393 + highlighting and symbol resolving support.
394 +* dev-python/jedi and dev-python/lxml for more accurate Python
395 + autocompletion support.
396 +* dev-util/valgrind for integration with valgrind.
397 +* dev-util/meson for integration with the Meson build system.
398 +* dev-util/cargo for integration with the Rust Cargo build system.
399 +* dev-util/cmake for integration with the CMake build system.
400 +* net-libs/nodejs[npm] for integration with the NPM package system.
401 +'
402 +# FIXME: Package gnome-code-assistance and mention here, or maybe USE flag and default enable because it's rather important
403 +# eslint for additional diagnostics in JavaScript files (what package has this? At least something via NPM..)
404 +# jhbuild support
405 +# rust language server via rls; Go via go-langserver
406 +# autotools stuff for autotools plugin; gtkmm/autoconf-archive for C++ template
407 +# gjs/gettext/mono/PHPize stuff, but most of these are probably installed for other reasons anyways, when needed inside IDE
408 +
409 +PATCHES=(
410 + "${FILESDIR}"/${PV}-python37-fix.patch # async 3.7 keyword usage removal
411 + "${FILESDIR}"/${PV}-jedi-0.12-compat.patch # preliminary jedi-0.12 compatibility from 3.29.9x/git
412 + "${FILESDIR}"/${PV}-valac.patch # Make valapack honor VALAC env var - https://gitlab.gnome.org/GNOME/gnome-builder/merge_requests/109
413 + "${FILESDIR}"/${PV}-fix-docs-option.patch # Fix USE=doc to work without USE=gtk-doc
414 + "${FILESDIR}"/${PV}-fix-tests-schemadir.patch # Fix tests GSETTINGS_SCHEMA_DIR handling (or tests fail on fresh install) - https://gitlab.gnome.org/GNOME/gnome-builder/merge_requests/111
415 +)
416 +
417 +llvm_check_deps() {
418 + has_version "sys-devel/clang:${LLVM_SLOT}"
419 +}
420 +
421 +pkg_setup() {
422 + python-single-r1_pkg_setup
423 + use clang && llvm_pkg_setup
424 +}
425 +
426 +src_prepare() {
427 + use vala && vala_src_prepare
428 + xdg_src_prepare
429 +}
430 +
431 +src_configure() {
432 + local emesonargs=(
433 + -Denable_tracing=false
434 + -Denable_profiling=false # not passing -pg to CFLAGS
435 + -Dwith_channel=other
436 + -Dwith_editorconfig=true # needs libpcre
437 + $(meson_use webkit with_webkit)
438 + $(meson_use vala with_vapi)
439 + $(meson_use doc with_help)
440 + $(meson_use gtk-doc with_docs)
441 +
442 + $(meson_use clang with_clang)
443 + $(meson_use devhelp with_devhelp)
444 + -Dwith_deviced=false
445 + -Dwith_flatpak=false
446 + $(meson_use git with_git)
447 + $(meson_use webkit with_html_preview)
448 + -Dwith_spellcheck=false # TODO: requires enchant-2
449 + $(meson_use sysprof with_sysprof)
450 + $(meson_use vala with_vala_pack)
451 + )
452 + meson_src_configure
453 +}
454 +
455 +src_install() {
456 + meson_src_install
457 + if use doc; then
458 + rm "${ED}"/usr/share/doc/gnome-builder/en/.buildinfo || die
459 + rm "${ED}"/usr/share/doc/gnome-builder/en/objects.inv || die
460 + rm -r "${ED}"/usr/share/doc/gnome-builder/en/.doctrees || die
461 + # custom docdir in build system, blocked by https://github.com/mesonbuild/meson/issues/825
462 + mv "${ED}"/usr/share/doc/gnome-builder/en "${ED}"/usr/share/doc/${PF}/html || die
463 + # _sources subdir left in on purpose, as HTML links to the rst files as "View page source". Additionally default docompress exclusion of /html/ already ensures they aren't compressed, thus linkable as-is.
464 + rmdir "${ED}"/usr/share/doc/gnome-builder/ || die
465 + fi
466 + readme.gentoo_create_doc
467 +}
468 +
469 +pkg_postinst() {
470 + xdg_pkg_postinst
471 + gnome2_icon_cache_update
472 + gnome2_schemas_update
473 + readme.gentoo_print_elog
474 +}
475 +
476 +pkg_postrm() {
477 + xdg_pkg_postrm
478 + gnome2_icon_cache_update
479 + gnome2_schemas_update
480 +}
481 +
482 +src_test() {
483 + # FIXME: this should be handled at meson level upstream like epiphany does
484 + find "${S}" -name '*.gschema.xml' -exec cp {} "${BUILD_DIR}/data/gsettings" \; || die
485 + "${EROOT}${GLIB_COMPILE_SCHEMAS}" --allow-any-name "${BUILD_DIR}/data/gsettings" || die
486 +
487 + virtx meson_src_test
488 +}
489
490 diff --git a/dev-util/gnome-builder/metadata.xml b/dev-util/gnome-builder/metadata.xml
491 index 78c212429a5..4eb8fba905d 100644
492 --- a/dev-util/gnome-builder/metadata.xml
493 +++ b/dev-util/gnome-builder/metadata.xml
494 @@ -7,6 +7,7 @@
495 </maintainer>
496 <use>
497 <flag name="clang">Provide integration with <pkg>sys-devel/clang</pkg> for best possible C/C++ autocompletion, semantic highlighting, symbol resolving, and diagnostics support</flag>
498 + <flag name="devhelp">Provide API docs browsing and integration via <pkg>dev-util/devhelp</pkg></flag>
499 <flag name="git">Provide support for the Git version control system via <pkg>dev-libs/libgit2-glib</pkg>
500 (such as setup of Git for New Project, direct cloning for Open Project and changed lines indicators in the editor gutter)</flag>
501 <flag name="sysprof">Provide an integrated profiler via <pkg>dev-util/sysprof</pkg></flag>