summaryrefslogtreecommitdiffstats
path: root/waftools/features.py
diff options
context:
space:
mode:
authorStefano Pigozzi <stefano.pigozzi@gmail.com>2013-07-16 13:28:28 +0200
committerStefano Pigozzi <stefano.pigozzi@gmail.com>2013-11-21 21:22:36 +0100
commit7e2edad8efea55e8df1faa695d1389ef4e326d7c (patch)
treef9662620b8ecaf50f6c67804dd0d99d00d85fe5b /waftools/features.py
parent0cb9227a73f03a6ecdf71e837c7c33c823b194b4 (diff)
downloadmpv-7e2edad8efea55e8df1faa695d1389ef4e326d7c.tar.bz2
mpv-7e2edad8efea55e8df1faa695d1389ef4e326d7c.tar.xz
switch the build system to waf
This commit adds a new build system based on waf. configure and Makefile are deprecated effective immediately and someday in the future they will be removed (they are still available by running ./old-configure). You can find how the choice for waf came to be in `DOCS/waf-buildsystem.rst`. TL;DR: we couldn't get the same level of abstraction and customization with other build systems we tried (CMake and autotools). For guidance on how to build the software now, take a look at README.md and the cross compilation guide. CREDITS: This is a squash of ~250 commits. Some of them are not by me, so here is the deserved attribution: - @wm4 contributed some Windows fixes, renamed configure to old-configure and contributed to the bootstrap script. Also, GNU/Linux testing. - @lachs0r contributed some Windows fixes and the bootstrap script. - @Nikoli contributed a lot of testing and discovered many bugs. - @CrimsonVoid contributed changes to the bootstrap script.
Diffstat (limited to 'waftools/features.py')
-rw-r--r--waftools/features.py69
1 files changed, 69 insertions, 0 deletions
diff --git a/waftools/features.py b/waftools/features.py
new file mode 100644
index 0000000000..1385d41dbf
--- /dev/null
+++ b/waftools/features.py
@@ -0,0 +1,69 @@
+from waflib.Options import OptionsContext
+
+class Feature(object):
+ def __init__(self, group, feature):
+ self.group = group
+ self.identifier, self.attributes = feature['name'], feature
+
+ def add_options(self):
+ [self.add_option(option_rule) for option_rule in self.option_rules()]
+
+ def add_option(self, rule):
+ self.group.add_option(self.option(rule['state']),
+ action=rule['action'],
+ default=rule['default'],
+ dest=self.storage(),
+ help=self.help(rule['state']))
+
+ # private
+ def option_rules(self):
+ return {
+ 'autodetect': [
+ {'state': 'disable', 'action': 'store_false', 'default': None},
+ {'state': 'enable', 'action': 'store_true', 'default': None},
+ ],
+ 'disable': [
+ {'state': 'disable', 'action': 'store_false', 'default': False},
+ {'state': 'enable', 'action': 'store_true', 'default': False},
+ ],
+ 'enable': [
+ {'state': 'disable', 'action': 'store_false', 'default': True},
+ ],
+ }[self.behaviour()]
+
+
+ def behaviour(self):
+ if 'default' in self.attributes:
+ return self.attributes['default']
+ else:
+ return 'autodetect'
+
+
+ def option(self, state):
+ return "--{0}-{1}".format(state, self.identifier)
+
+ def help(self, state):
+ return "{0} {1} [{2}]" \
+ .format(state, self.attributes['desc'], self.behaviour())
+
+ def storage(self):
+ return "enable_{0}".format(self.identifier)
+
+def add_feature(group, feature):
+ Feature(group, feature).add_options()
+
+def parse_features(opt, group_name, features):
+ def is_feature(dep):
+ return dep['name'].find('--') >= 0
+
+ def strip_feature(dep):
+ dep['name'] = dep['name'].lstrip('-')
+ return dep
+
+ features = [strip_feature(dep) for dep in features if is_feature(dep)]
+ group = opt.get_option_group(group_name)
+ if not group:
+ group = opt.add_option_group(group_name)
+ [add_feature(group, feature) for feature in features]
+
+OptionsContext.parse_features = parse_features