Added support for removing sources from a target

pull/4814/head
Daniel Mensinger 6 years ago
parent 0ce6632393
commit 8dd9b44831
No known key found for this signature in database
GPG Key ID: 54DD94C131E277D4
  1. 69
      mesonbuild/rewriter.py
  2. 19
      run_unittests.py
  3. 83
      test cases/rewrite/1 basic/rmSrc.json

@ -117,7 +117,23 @@ class Rewriter:
if cmd['debug']: if cmd['debug']:
pprint(target) pprint(target)
# Utility function to get a list of the sources from a node
def arg_list_from_node(n):
args = []
if isinstance(n, mparser.FunctionNode):
args = list(n.args.arguments)
if n.func_name in build_target_functions:
args.pop(0)
elif isinstance(n, mparser.ArrayNode):
args = n.args.arguments
elif isinstance(n, mparser.ArgumentNode):
args = n.arguments
return args
if cmd['operation'] == 'src_add': if cmd['operation'] == 'src_add':
#################################
### Add sources to the target ###
#################################
node = None node = None
if target['sources']: if target['sources']:
node = target['sources'][0] node = target['sources'][0]
@ -142,22 +158,51 @@ class Rewriter:
node.arguments += to_append node.arguments += to_append
# Mark the node as modified # Mark the node as modified
self.modefied_nodes += [node] if node not in self.modefied_nodes:
self.modefied_nodes += [node]
elif cmd['operation'] == 'src_rm': elif cmd['operation'] == 'src_rm':
mlog.warning('TODO') ######################################
### Remove sources from the target ###
######################################
# Helper to find the exact string node and its parent
def find_node(src):
for i in target['sources']:
for j in arg_list_from_node(i):
if isinstance(j, mparser.StringNode):
if j.value == src:
return i, j
return None, None
for i in cmd['sources']:
# Try to find the node with the source string
root, string_node = find_node(i)
if root is None:
mlog.warning(' -- Unable to find source', mlog.green(i), 'in the target')
continue
# Remove the found string node from the argument list
arg_node = None
if isinstance(root, mparser.FunctionNode):
arg_node = root.args
if isinstance(root, mparser.ArrayNode):
arg_node = root.args
if isinstance(root, mparser.ArgumentNode):
arg_node = root
assert(arg_node is not None)
mlog.log(' -- Removing source', mlog.green(i), 'from',
mlog.yellow('{}:{}'.format(os.path.join(string_node.subdir, environment.build_filename), string_node.lineno)))
arg_node.arguments.remove(string_node)
# Mark the node as modified
if root not in self.modefied_nodes:
self.modefied_nodes += [root]
elif cmd['operation'] == 'test': elif cmd['operation'] == 'test':
######################################
### List all sources in the target ###
######################################
src_list = [] src_list = []
for i in target['sources']: for i in target['sources']:
args = [] for j in arg_list_from_node(i):
if isinstance(i, mparser.FunctionNode):
args = list(i.args.arguments)
if i.func_name in build_target_functions:
args.pop(0)
elif isinstance(i, mparser.ArrayNode):
args = i.args.arguments
elif isinstance(i, mparser.ArgumentNode):
args = i.arguments
for j in args:
if isinstance(j, mparser.StringNode): if isinstance(j, mparser.StringNode):
src_list += [j.value] src_list += [j.value]
test_data = { test_data = {

@ -4984,6 +4984,25 @@ class RewriterTests(BasePlatformTests):
} }
self.assertDictEqual(out, expected) self.assertDictEqual(out, expected)
def test_target_remove_sources(self):
self.prime('1 basic')
out = self.rewrite(self.builddir, os.path.join(self.builddir, 'rmSrc.json'))
out = self.extract_test_data(out)
expected = {
'target': {
'trivialprog1@exe': {'name': 'trivialprog1', 'sources': ['main.cpp']},
'trivialprog2@exe': {'name': 'trivialprog2', 'sources': ['fileC.cpp']},
'trivialprog3@exe': {'name': 'trivialprog3', 'sources': ['main.cpp']},
'trivialprog4@exe': {'name': 'trivialprog4', 'sources': ['main.cpp']},
'trivialprog5@exe': {'name': 'trivialprog5', 'sources': ['main.cpp', 'fileC.cpp']},
'trivialprog6@exe': {'name': 'trivialprog6', 'sources': ['main.cpp']},
'trivialprog7@exe': {'name': 'trivialprog7', 'sources': ['fileC.cpp', 'main.cpp']},
'trivialprog8@exe': {'name': 'trivialprog8', 'sources': ['main.cpp']},
'trivialprog9@exe': {'name': 'trivialprog9', 'sources': ['main.cpp']},
}
}
self.assertDictEqual(out, expected)
class NativeFileTests(BasePlatformTests): class NativeFileTests(BasePlatformTests):
def setUp(self): def setUp(self):

@ -0,0 +1,83 @@
[
{
"type": "target",
"target": "trivialprog1",
"operation": "src_rm",
"sources": ["fileA.cpp"]
},
{
"type": "target",
"target": "trivialprog3",
"operation": "src_rm",
"sources": ["fileA.cpp"]
},
{
"type": "target",
"target": "trivialprog4",
"operation": "src_rm",
"sources": ["fileA.cpp"]
},
{
"type": "target",
"target": "trivialprog5",
"operation": "src_rm",
"sources": ["fileB.cpp"]
},
{
"type": "target",
"target": "trivialprog6",
"operation": "src_rm",
"sources": ["fileA.cpp"]
},
{
"type": "target",
"target": "trivialprog7",
"operation": "src_rm",
"sources": ["fileB.cpp"]
},
{
"type": "target",
"target": "trivialprog1",
"operation": "test"
},
{
"type": "target",
"target": "trivialprog2",
"operation": "test"
},
{
"type": "target",
"target": "trivialprog3",
"operation": "test"
},
{
"type": "target",
"target": "trivialprog4",
"operation": "test"
},
{
"type": "target",
"target": "trivialprog5",
"operation": "test"
},
{
"type": "target",
"target": "trivialprog6",
"operation": "test"
},
{
"type": "target",
"target": "trivialprog7",
"operation": "test"
},
{
"type": "target",
"target": "trivialprog8",
"operation": "test"
},
{
"type": "target",
"target": "trivialprog9",
"operation": "test"
}
]
Loading…
Cancel
Save