diff options
author | Chun-wei Fan <fanchunwei@src.gnome.org> | 2016-06-22 15:16:09 +0800 |
---|---|---|
committer | Chun-wei Fan <fanchunwei@src.gnome.org> | 2016-06-22 15:22:58 +0800 |
commit | c2ba9ca810cd70658d8cc9839693b9518824d4be (patch) | |
tree | 2b7fdc5134913cac8c6051a186dd637fa89e1bdb /build | |
parent | f44b9ef1f0b9bce88f01b258714338a9006f60e1 (diff) | |
download | gtk+-c2ba9ca810cd70658d8cc9839693b9518824d4be.tar.gz |
Visual Studio builds: Make .pc generation more flexible
Allow the use of ${exec_prefix} for libdir and includedir when passing
them in as arguments to the script.
Diffstat (limited to 'build')
-rw-r--r-- | build/win32/pc_base.py | 44 |
1 files changed, 30 insertions, 14 deletions
diff --git a/build/win32/pc_base.py b/build/win32/pc_base.py index da10560a28..587ba83d19 100644 --- a/build/win32/pc_base.py +++ b/build/win32/pc_base.py @@ -50,15 +50,27 @@ class BasePCItems: if not os.path.exists(args.prefix): raise SystemExit('Specified prefix \'%s\' is invalid' % args.prefix) + # use absolute paths for prefix + self.prefix = os.path.abspath(args.prefix).replace('\\','/') + # check and setup the exec_prefix if getattr(args, 'exec_prefix', None) is None: - input_exec_prefix = args.prefix + exec_prefix_use_shorthand = True + self.exec_prefix = '${prefix}' else: - input_exec_prefix = args.exec_prefix - if not os.path.exists(input_exec_prefix): - raise SystemExit('Specified exec-prefix \'%s\' is invalid' % - input_exec_prefix) - + if args.exec_prefix.startswith('${prefix}'): + exec_prefix_use_shorthand = True + input_exec_prefix = args.prefix + args.exec_prefix[len('${prefix}'):] + else: + exec_prefix_use_shorthand = False + input_exec_prefix = args.exec_prefix + if not os.path.exists(input_exec_prefix): + raise SystemExit('Specified exec_prefix \'%s\' is invalid' % + args.exec_prefix) + if exec_prefix_use_shorthand is True: + self.exec_prefix = args.exec_prefix.replace('\\','/') + else: + self.exec_prefix = os.path.abspath(input_exec_prefix).replace('\\','/') # check and setup the includedir if getattr(args, 'includedir', None) is None: @@ -68,8 +80,12 @@ class BasePCItems: includedir_use_shorthand = True input_includedir = args.prefix + args.includedir[len('${prefix}'):] else: - includedir_use_shorthand = False - input_includedir = args.includedir + if args.includedir.startswith('${exec_prefix}'): + includedir_use_shorthand = True + input_includedir = input_exec_prefix + args.includedir[len('${exec_prefix}'):] + else: + includedir_use_shorthand = False + input_includedir = args.includedir if not os.path.exists(input_includedir): raise SystemExit('Specified includedir \'%s\' is invalid' % args.includedir) @@ -86,8 +102,12 @@ class BasePCItems: libdir_use_shorthand = True input_libdir = args.prefix + args.libdir[len('${prefix}'):] else: - libdir_use_shorthand = False - input_libdir = args.libdir + if args.libdir.startswith('${exec_prefix}'): + libdir_use_shorthand = True + input_libdir = input_exec_prefix + args.libdir[len('${exec_prefix}'):] + else: + libdir_use_shorthand = False + input_libdir = args.libdir if not os.path.exists(input_libdir): raise SystemExit('Specified libdir \'%s\' is invalid' % args.libdir) @@ -96,10 +116,6 @@ class BasePCItems: else: self.libdir = os.path.abspath(input_libdir).replace('\\','/') - # use absolute paths for prefix and exec_prefix - self.prefix = os.path.abspath(args.prefix).replace('\\','/') - self.exec_prefix = os.path.abspath(input_exec_prefix).replace('\\','/') - # setup dictionary for replacing items in *.pc.in self.base_replace_items.update({'@VERSION@': self.version}) self.base_replace_items.update({'@prefix@': self.prefix}) |