aboutsummaryrefslogtreecommitdiff
path: root/interpreter.py
diff options
context:
space:
mode:
authorJussi Pakkanen <jpakkane@gmail.com>2013-01-12 13:53:19 +0200
committerJussi Pakkanen <jpakkane@gmail.com>2013-01-12 13:53:19 +0200
commit8d038ef09ed709f7db95504f04b13678ecf79816 (patch)
tree1d37bc3bfb91ae56d78b85950683b860e9f8aec9 /interpreter.py
parentb6886b2c27f6b9b18acc1c6ac57d6d64039aa815 (diff)
downloadmeson-8d038ef09ed709f7db95504f04b13678ecf79816.zip
meson-8d038ef09ed709f7db95504f04b13678ecf79816.tar.gz
meson-8d038ef09ed709f7db95504f04b13678ecf79816.tar.bz2
Can install header files.
Diffstat (limited to 'interpreter.py')
-rwxr-xr-xinterpreter.py49
1 files changed, 38 insertions, 11 deletions
diff --git a/interpreter.py b/interpreter.py
index dad45ee..b38bbbc 100755
--- a/interpreter.py
+++ b/interpreter.py
@@ -29,22 +29,45 @@ class InvalidArguments(InterpreterException):
class InterpreterObject():
- def method_call(self, method_name):
- raise InvalidCode('Object does not have method %s.' % method_name)
+ def __init__(self):
+ self.methods = {}
+
+ def method_call(self, method_name, args):
+ if method_name in self.methods:
+ return self.methods[method_name](args)
+ raise InvalidCode('Unknown method "%s" in object.' % method_name)
+
+class Headers(InterpreterObject):
+
+ def __init__(self, sources):
+ InterpreterObject.__init__(self)
+ self.sources = sources
+ self.methods.update({'set_subdir' : self.set_subdir})
+ self.subdir = ''
+
+ def set_subdir(self, args):
+ self.subdir = args[0]
+
+ def get_subdir(self):
+ return self.subdir
+
+ def get_sources(self):
+ return self.sources
class BuildTarget(InterpreterObject):
def __init__(self, name, sources):
+ InterpreterObject.__init__(self)
self.name = name
self.sources = sources
self.external_deps = []
- self.methods = {'add_dep': self.add_dep_method,
+ self.methods.update({'add_dep': self.add_dep_method,
'link' : self.link_method,
- 'install': self.install}
+ 'install': self.install})
self.link_targets = []
self.filename = 'no_name'
self.need_install = False
-
+
def get_filename(self):
return self.filename
@@ -78,11 +101,6 @@ class BuildTarget(InterpreterObject):
raise InvalidArguments('Link target is not library.')
self.link_targets.append(target)
- def method_call(self, method_name, args):
- if method_name in self.methods:
- return self.methods[method_name](args)
- raise InvalidCode('Unknown method "%s" in BuildTarget.' % method_name)
-
def install(self, args):
if len(args) != 0:
raise InvalidArguments('Install() takes no arguments.')
@@ -142,7 +160,8 @@ class Interpreter():
'find_dep' : self.func_find_dep,
'static_library' : self.func_static_lib,
'shared_library' : self.func_shared_lib,
- 'add_test' : self.func_add_test
+ 'add_test' : self.func_add_test,
+ 'headers' : self.func_headers
}
def sanity_check_ast(self):
@@ -233,6 +252,14 @@ class Interpreter():
t = Test(args[0], args[1])
self.build.tests.append(t)
print('Adding test "%s"' % args[0])
+
+ def func_headers(self, node, args):
+ for a in args:
+ if not isinstance(a, str):
+ raise InvalidArguments('Line %d: Argument %s is not a string.' % (node.lineno(), str(a)))
+ h = Headers(args)
+ self.build.headers.append(h)
+ return h
def build_target(self, node, args, targetclass):
for a in args: