2019-05-18 14:42:15 +02:00
|
|
|
# Copyright (c) 2019 Refael Ackeramnn<refack@gmail.com>. All rights reserved.
|
|
|
|
# Use of this source code is governed by an MIT-style license.
|
|
|
|
import re
|
|
|
|
import os
|
|
|
|
|
|
|
|
PLAIN_SOURCE_RE = re.compile('\s*"([^/$].+)"\s*')
|
|
|
|
def DoMain(args):
|
|
|
|
gn_filename, pattern = args
|
|
|
|
src_root = os.path.dirname(gn_filename)
|
2019-08-19 19:24:22 +02:00
|
|
|
with open(gn_filename, 'rb') as gn_file:
|
|
|
|
gn_content = gn_file.read().decode('utf-8')
|
2019-05-18 14:42:15 +02:00
|
|
|
|
|
|
|
scraper_re = re.compile(pattern + r'\[([^\]]+)', re.DOTALL)
|
|
|
|
matches = scraper_re.search(gn_content)
|
|
|
|
match = matches.group(1)
|
|
|
|
files = []
|
|
|
|
for l in match.splitlines():
|
|
|
|
m2 = PLAIN_SOURCE_RE.match(l)
|
|
|
|
if not m2:
|
|
|
|
continue
|
|
|
|
files.append(m2.group(1))
|
|
|
|
# always use `/` since GYP will process paths further downstream
|
|
|
|
rel_files = ['"%s/%s"' % (src_root, f) for f in files]
|
|
|
|
return ' '.join(rel_files)
|