summaryrefslogtreecommitdiff
path: root/build
diff options
context:
space:
mode:
authorChun-wei Fan <fanchunwei@src.gnome.org>2016-06-22 15:16:09 +0800
committerChun-wei Fan <fanchunwei@src.gnome.org>2016-06-22 15:22:58 +0800
commitc2ba9ca810cd70658d8cc9839693b9518824d4be (patch)
tree2b7fdc5134913cac8c6051a186dd637fa89e1bdb /build
parentf44b9ef1f0b9bce88f01b258714338a9006f60e1 (diff)
downloadgtk+-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.py44
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})