mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-03 05:59:10 +00:00
gst-env: Load gio modules in the devenv
By setting GIO_EXTRA_MODULES we can ensure that any gio modules we built are loaded by the devenv. Part-of: <https://gitlab.freedesktop.org/gstreamer/gst-build/-/merge_requests/180>
This commit is contained in:
parent
ef4059d4ad
commit
2a4d7f2264
1 changed files with 47 additions and 2 deletions
49
gst-env.py
49
gst-env.py
|
@ -15,7 +15,8 @@ import sys
|
||||||
import tempfile
|
import tempfile
|
||||||
import pathlib
|
import pathlib
|
||||||
import signal
|
import signal
|
||||||
from pathlib import PurePath
|
from functools import lru_cache
|
||||||
|
from pathlib import PurePath, Path
|
||||||
|
|
||||||
from distutils.sysconfig import get_python_lib
|
from distutils.sysconfig import get_python_lib
|
||||||
from distutils.util import strtobool
|
from distutils.util import strtobool
|
||||||
|
@ -82,6 +83,46 @@ def get_target_install_filename(target, filename):
|
||||||
return install_filename
|
return install_filename
|
||||||
return None
|
return None
|
||||||
|
|
||||||
|
def get_pkgconfig_variable_from_pcfile(pcfile, varname):
|
||||||
|
variables = {}
|
||||||
|
substre = re.compile('\$\{[^${}]+\}')
|
||||||
|
with open(pcfile, 'r', encoding='utf-8') as f:
|
||||||
|
for line in f:
|
||||||
|
if '=' not in line:
|
||||||
|
continue
|
||||||
|
key, value = line[:-1].split('=', 1)
|
||||||
|
subst = {}
|
||||||
|
for each in substre.findall(value):
|
||||||
|
substkey = each[2:-1]
|
||||||
|
subst[each] = variables.get(substkey, '')
|
||||||
|
for k, v in subst.items():
|
||||||
|
value = value.replace(k, v)
|
||||||
|
variables[key] = value
|
||||||
|
return variables.get(varname, '')
|
||||||
|
|
||||||
|
@lru_cache()
|
||||||
|
def get_pkgconfig_variable(builddir, pcname, varname):
|
||||||
|
'''
|
||||||
|
Parsing isn't perfect, but it's good enough.
|
||||||
|
'''
|
||||||
|
pcfile = Path(builddir) / 'meson-private' / (pcname + '.pc')
|
||||||
|
if pcfile.is_file():
|
||||||
|
return get_pkgconfig_variable_from_pcfile(pcfile, varname)
|
||||||
|
return subprocess.check_output(['pkg-config', pcname, '--variable=' + varname],
|
||||||
|
universal_newlines=True, encoding='utf-8')
|
||||||
|
|
||||||
|
|
||||||
|
def is_gio_module(target, filename, builddir):
|
||||||
|
if target['type'] != 'shared module':
|
||||||
|
return False
|
||||||
|
install_filename = get_target_install_filename(target, filename)
|
||||||
|
if not install_filename:
|
||||||
|
return False
|
||||||
|
giomoduledir = PurePath(get_pkgconfig_variable(builddir, 'gio-2.0', 'giomoduledir'))
|
||||||
|
fpath = PurePath(install_filename)
|
||||||
|
if fpath.parent != giomoduledir:
|
||||||
|
return False
|
||||||
|
return True
|
||||||
|
|
||||||
def is_library_target_and_not_plugin(target, filename):
|
def is_library_target_and_not_plugin(target, filename):
|
||||||
'''
|
'''
|
||||||
|
@ -89,7 +130,7 @@ def is_library_target_and_not_plugin(target, filename):
|
||||||
1. We don't need to
|
1. We don't need to
|
||||||
2. It causes us to exceed the PATH length limit on Windows and Wine
|
2. It causes us to exceed the PATH length limit on Windows and Wine
|
||||||
'''
|
'''
|
||||||
if not target['type'].startswith('shared'):
|
if target['type'] != 'shared library':
|
||||||
return False
|
return False
|
||||||
# Check if this output of that target is a shared library
|
# Check if this output of that target is a shared library
|
||||||
if not SHAREDLIB_REG.search(filename):
|
if not SHAREDLIB_REG.search(filename):
|
||||||
|
@ -298,6 +339,10 @@ def get_subprocess_env(options, gst_version):
|
||||||
options.sysroot)
|
options.sysroot)
|
||||||
elif is_binary_target_and_in_path(target, filename, bindir):
|
elif is_binary_target_and_in_path(target, filename, bindir):
|
||||||
paths.add(os.path.join(options.builddir, root))
|
paths.add(os.path.join(options.builddir, root))
|
||||||
|
elif is_gio_module(target, filename, options.builddir):
|
||||||
|
prepend_env_var(env, 'GIO_EXTRA_MODULES',
|
||||||
|
os.path.join(options.builddir, root),
|
||||||
|
options.sysroot)
|
||||||
|
|
||||||
with open(os.path.join(options.builddir, 'GstPluginsPath.json')) as f:
|
with open(os.path.join(options.builddir, 'GstPluginsPath.json')) as f:
|
||||||
for plugin_path in json.load(f):
|
for plugin_path in json.load(f):
|
||||||
|
|
Loading…
Reference in a new issue