diff options
| author | Christoph Reiter <reiter.christoph@gmail.com> | 2018-08-04 10:04:10 +0200 | 
|---|---|---|
| committer | Nirbheek Chauhan <nirbheek.chauhan@gmail.com> | 2018-08-07 04:42:03 -0700 | 
| commit | 69a65006f2261953083df30d14cd67b5d8998897 (patch) | |
| tree | 0fbbf8fb2949969b5b815ff6f328712d33cac097 /mesonbuild/scripts/gtkdochelper.py | |
| parent | e0ed1ceae2e00d6c6efab39d4712d2522d89e929 (diff) | |
| download | meson-69a65006f2261953083df30d14cd67b5d8998897.tar.gz | |
gtkdoc: set PATH on Windows when executing gtkdoc-scangobj. Fixes #3307
The code was adding the library paths to LD_LIBRARY_PATH, but that
doesn't work on Windows where they need to be added to PATH instead.
Move the environ handling into gtkdoc_run_check() and add paths to PATH
instead of LD_LIBRARY_PATH when on Windows.
This fixes the gtk-doc build for glib on Windows
(in case glib isn't installed already)
Diffstat (limited to 'mesonbuild/scripts/gtkdochelper.py')
| -rw-r--r-- | mesonbuild/scripts/gtkdochelper.py | 23 | 
1 files changed, 15 insertions, 8 deletions
| diff --git a/mesonbuild/scripts/gtkdochelper.py b/mesonbuild/scripts/gtkdochelper.py index 371d95d6e..bf3d9f6af 100644 --- a/mesonbuild/scripts/gtkdochelper.py +++ b/mesonbuild/scripts/gtkdochelper.py @@ -17,7 +17,7 @@ import subprocess  import shlex  import shutil  import argparse -from ..mesonlib import MesonException, Popen_safe +from ..mesonlib import MesonException, Popen_safe, is_windows  from . import destdir_join  parser = argparse.ArgumentParser() @@ -47,10 +47,20 @@ parser.add_argument('--mode', dest='mode', default='')  parser.add_argument('--installdir', dest='install_dir')  parser.add_argument('--run', dest='run', default='') -def gtkdoc_run_check(cmd, cwd, library_path=None): +def gtkdoc_run_check(cmd, cwd, library_paths=None): +    if library_paths is None: +        library_paths = [] +      env = dict(os.environ) -    if library_path: -        env['LD_LIBRARY_PATH'] = library_path +    if is_windows(): +        if 'PATH' in env: +            library_paths.extend(env['PATH'].split(os.pathsep)) +        env['PATH'] = os.pathsep.join(library_paths) +    else: +        if 'LD_LIBRARY_PATH' in env: +            library_paths.extend(env['LD_LIBRARY_PATH'].split(os.pathsep)) +        env['LD_LIBRARY_PATH'] = os.pathsep.join(library_paths) +      # Put stderr into stdout since we want to print it out anyway.      # This preserves the order of messages.      p, out = Popen_safe(cmd, cwd=cwd, env=env, stderr=subprocess.STDOUT)[0:2] @@ -137,11 +147,8 @@ def build_gtkdoc(source_root, build_root, doc_subdir, src_subdirs,          for ldflag in shlex.split(ldflags):              if ldflag.startswith('-Wl,-rpath,'):                  library_paths.append(ldflag[11:]) -        if 'LD_LIBRARY_PATH' in os.environ: -            library_paths.append(os.environ['LD_LIBRARY_PATH']) -        library_path = ':'.join(library_paths) -        gtkdoc_run_check(scanobjs_cmd, build_root, library_path) +        gtkdoc_run_check(scanobjs_cmd, build_root, library_paths)      # Make docbook files      if mode == 'auto': | 
