Skip to content

Commit

Permalink
Fix builtin variable names
Browse files Browse the repository at this point in the history
  • Loading branch information
mensinda committed Apr 29, 2019
1 parent bf98ffc commit e75211d
Show file tree
Hide file tree
Showing 14 changed files with 55 additions and 52 deletions.
6 changes: 3 additions & 3 deletions mesonbuild/ast/introspection.py
Original file line number Diff line number Diff line change
Expand Up @@ -173,9 +173,9 @@ def build_target(self, node, args, kwargs, targetclass):
arg_node = curr.args
elif isinstance(curr, IdNode):
# Try to resolve the ID and append the node to the queue
id = curr.value
if id in self.assignments and self.assignments[id]:
tmp_node = self.assignments[id][0]
var_name = curr.value
if var_name in self.assignments and self.assignments[var_name]:
tmp_node = self.assignments[var_name][0]
if isinstance(tmp_node, (ArrayNode, IdNode, FunctionNode)):
srcqueue += [tmp_node]
elif isinstance(curr, ArithmeticNode):
Expand Down
4 changes: 2 additions & 2 deletions mesonbuild/backend/ninjabackend.py
Original file line number Diff line number Diff line change
Expand Up @@ -406,9 +406,9 @@ def create_target_source_introspection(self, target: build.Target, comp: compile
}
}
'''
id = target.get_id()
tid = target.get_id()
lang = comp.get_language()
tgt = self.introspection_data[id]
tgt = self.introspection_data[tid]
# Find an existing entry or create a new one
id_hash = (lang, tuple(parameters))
src_block = tgt.get(id_hash, None)
Expand Down
4 changes: 2 additions & 2 deletions mesonbuild/compilers/cs.py
Original file line number Diff line number Diff line change
Expand Up @@ -28,10 +28,10 @@
}

class CsCompiler(Compiler):
def __init__(self, exelist, version, id, runner=None):
def __init__(self, exelist, version, comp_id, runner=None):
self.language = 'cs'
super().__init__(exelist, version)
self.id = id
self.id = comp_id
self.is_cross = False
self.runner = runner

Expand Down
8 changes: 4 additions & 4 deletions mesonbuild/dependencies/ui.py
Original file line number Diff line number Diff line change
Expand Up @@ -298,8 +298,8 @@ def _pkgconfig_detect(self, mods, kwargs):
# the Qt + m_name there is not a symlink, it's a file
mod_private_dir = qt_inc_dir
mod_private_inc = _qt_get_private_includes(mod_private_dir, m_name, m.version)
for dir in mod_private_inc:
self.compile_args.append('-I' + dir)
for directory in mod_private_inc:
self.compile_args.append('-I' + directory)
self.link_args += m.get_link_args()

if 'Core' in modules:
Expand Down Expand Up @@ -402,8 +402,8 @@ def _qmake_detect(self, mods, kwargs):

if self.private_headers:
priv_inc = self.get_private_includes(mincdir, module)
for dir in priv_inc:
self.compile_args.append('-I' + dir)
for directory in priv_inc:
self.compile_args.append('-I' + directory)
libfile = self.clib_compiler.find_library(self.qtpkgname + module + modules_lib_suffix,
self.env,
libdir)
Expand Down
16 changes: 8 additions & 8 deletions mesonbuild/mesonlib.py
Original file line number Diff line number Diff line change
Expand Up @@ -722,11 +722,11 @@ def has_path_sep(name, sep='/\\'):
return True
return False

def do_replacement(regex, line, format, confdata):
def do_replacement(regex, line, variable_format, confdata):
missing_variables = set()
start_tag = '@'
backslash_tag = '\\@'
if format == 'cmake':
if variable_format == 'cmake':
start_tag = '${'
backslash_tag = '\\${'

Expand Down Expand Up @@ -779,23 +779,23 @@ def do_mesondefine(line, confdata):
raise MesonException('#mesondefine argument "%s" is of unknown type.' % varname)


def do_conf_file(src, dst, confdata, format, encoding='utf-8'):
def do_conf_file(src, dst, confdata, variable_format, encoding='utf-8'):
try:
with open(src, encoding=encoding, newline='') as f:
data = f.readlines()
except Exception as e:
raise MesonException('Could not read input file %s: %s' % (src, str(e)))
# Only allow (a-z, A-Z, 0-9, _, -) as valid characters for a define
# Also allow escaping '@' with '\@'
if format in ['meson', 'cmake@']:
if variable_format in ['meson', 'cmake@']:
regex = re.compile(r'(?:\\\\)+(?=\\?@)|\\@|@([-a-zA-Z0-9_]+)@')
elif format == 'cmake':
elif variable_format == 'cmake':
regex = re.compile(r'(?:\\\\)+(?=\\?\$)|\\\${|\${([-a-zA-Z0-9_]+)}')
else:
raise MesonException('Format "{}" not handled'.format(format))
raise MesonException('Format "{}" not handled'.format(variable_format))

search_token = '#mesondefine'
if format != 'meson':
if variable_format != 'meson':
search_token = '#cmakedefine'

result = []
Expand All @@ -808,7 +808,7 @@ def do_conf_file(src, dst, confdata, format, encoding='utf-8'):
confdata_useless = False
line = do_mesondefine(line, confdata)
else:
line, missing = do_replacement(regex, line, format, confdata)
line, missing = do_replacement(regex, line, variable_format, confdata)
missing_variables.update(missing)
if missing:
confdata_useless = False
Expand Down
30 changes: 15 additions & 15 deletions mesonbuild/mesonmain.py
Original file line number Diff line number Diff line change
Expand Up @@ -41,41 +41,41 @@ def __init__(self):
self.subparsers = self.parser.add_subparsers(title='Commands',
description='If no command is specified it defaults to setup command.')
self.add_command('setup', msetup.add_arguments, msetup.run,
help='Configure the project')
help_msg='Configure the project')
self.add_command('configure', mconf.add_arguments, mconf.run,
help='Change project options',)
help_msg='Change project options',)
self.add_command('install', minstall.add_arguments, minstall.run,
help='Install the project')
help_msg='Install the project')
self.add_command('introspect', mintro.add_arguments, mintro.run,
help='Introspect project')
help_msg='Introspect project')
self.add_command('init', minit.add_arguments, minit.run,
help='Create a new project')
help_msg='Create a new project')
self.add_command('test', mtest.add_arguments, mtest.run,
help='Run tests')
help_msg='Run tests')
self.add_command('wrap', wraptool.add_arguments, wraptool.run,
help='Wrap tools')
help_msg='Wrap tools')
self.add_command('subprojects', msubprojects.add_arguments, msubprojects.run,
help='Manage subprojects')
help_msg='Manage subprojects')
self.add_command('help', self.add_help_arguments, self.run_help_command,
help='Print help of a subcommand')
help_msg='Print help of a subcommand')
self.add_command('rewrite', lambda parser: rewriter.add_arguments(parser, self.formater), rewriter.run,
help='Modify the project definition')
help_msg='Modify the project definition')

# Hidden commands
self.add_command('runpython', self.add_runpython_arguments, self.run_runpython_command,
help=argparse.SUPPRESS)
help_msg=argparse.SUPPRESS)
self.add_command('unstable-coredata', munstable_coredata.add_arguments, munstable_coredata.run,
help=argparse.SUPPRESS)
help_msg=argparse.SUPPRESS)

def add_command(self, name, add_arguments_func, run_func, help, aliases=None):
def add_command(self, name, add_arguments_func, run_func, help_msg, aliases=None):
aliases = aliases or []
# FIXME: Cannot have hidden subparser:
# https://bugs.python.org/issue22848
if help == argparse.SUPPRESS:
if help_msg == argparse.SUPPRESS:
p = argparse.ArgumentParser(prog='meson ' + name, formatter_class=self.formater)
self.hidden_commands.append(name)
else:
p = self.subparsers.add_parser(name, help=help, aliases=aliases, formatter_class=self.formater)
p = self.subparsers.add_parser(name, help=help_msg, aliases=aliases, formatter_class=self.formater)
add_arguments_func(p)
p.set_defaults(run_func=run_func)
for i in [name] + aliases:
Expand Down
2 changes: 1 addition & 1 deletion mesonbuild/minstall.py
Original file line number Diff line number Diff line change
Expand Up @@ -65,7 +65,7 @@ def makedirs(self, path, exist_ok=False):
def __enter__(self):
return self

def __exit__(self, type, value, traceback):
def __exit__(self, exception_type, value, traceback):
self.dirs.reverse()
for d in self.dirs:
append_to_log(self.lf, d)
Expand Down
10 changes: 5 additions & 5 deletions mesonbuild/mlog.py
Original file line number Diff line number Diff line change
Expand Up @@ -234,14 +234,14 @@ def exception(e: Exception, prefix: AnsiDecorator = red('ERROR:')) -> None:

# Format a list for logging purposes as a string. It separates
# all but the last item with commas, and the last with 'and'.
def format_list(list_: typing.List[str]) -> str:
l = len(list_)
def format_list(input_list: typing.List[str]) -> str:
l = len(input_list)
if l > 2:
return ' and '.join([', '.join(list_[:-1]), list_[-1]])
return ' and '.join([', '.join(input_list[:-1]), input_list[-1]])
elif l == 2:
return ' and '.join(list_)
return ' and '.join(input_list)
elif l == 1:
return list_[0]
return input_list[0]
else:
return ''

Expand Down
6 changes: 3 additions & 3 deletions mesonbuild/modules/python.py
Original file line number Diff line number Diff line change
Expand Up @@ -477,9 +477,9 @@ def _get_win_pythonpath(self, name_or_path):
ver = {'python2': '-2', 'python3': '-3'}[name_or_path]
cmd = ['py', ver, '-c', "import sysconfig; print(sysconfig.get_config_var('BINDIR'))"]
_, stdout, _ = mesonlib.Popen_safe(cmd)
dir = stdout.strip()
if os.path.exists(dir):
return os.path.join(dir, 'python')
directory = stdout.strip()
if os.path.exists(directory):
return os.path.join(directory, 'python')
else:
return None

Expand Down
4 changes: 2 additions & 2 deletions mesonbuild/modules/windows.py
Original file line number Diff line number Diff line change
Expand Up @@ -59,15 +59,15 @@ def _find_resource_compiler(self, state):
if not rescomp.found():
raise MesonException('Could not find Windows resource compiler')

for (arg, match, type) in [
for (arg, match, rc_type) in [
('/?', '^.*Microsoft.*Resource Compiler.*$', ResourceCompilerType.rc),
('--version', '^.*GNU windres.*$', ResourceCompilerType.windres),
]:
p, o, e = mesonlib.Popen_safe(rescomp.get_command() + [arg])
m = re.search(match, o, re.MULTILINE)
if m:
mlog.log('Windows resource compiler: %s' % m.group())
self._rescomp = (rescomp, type)
self._rescomp = (rescomp, rc_type)
break
else:
raise MesonException('Could not determine type of Windows resource compiler')
Expand Down
10 changes: 5 additions & 5 deletions mesonbuild/munstable_coredata.py
Original file line number Diff line number Diff line change
Expand Up @@ -51,7 +51,7 @@ def run(options):
'change the working directory to it.')
return 1

all = options.all
all_backends = options.all

print('This is a dump of the internal unstable cache of meson. This is for debugging only.')
print('Do NOT parse, this will change from version to version in incompatible ways')
Expand All @@ -64,18 +64,18 @@ def run(options):
# use `meson configure` to view these
pass
elif k in ['install_guid', 'test_guid', 'regen_guid']:
if all or backend.startswith('vs'):
if all_backends or backend.startswith('vs'):
print(k + ': ' + v)
elif k == 'target_guids':
if all or backend.startswith('vs'):
if all_backends or backend.startswith('vs'):
print(k + ':')
dump_guids(v)
elif k in ['lang_guids']:
if all or backend.startswith('vs') or backend == 'xcode':
if all_backends or backend.startswith('vs') or backend == 'xcode':
print(k + ':')
dump_guids(v)
elif k == 'meson_command':
if all or backend.startswith('vs'):
if all_backends or backend.startswith('vs'):
print('Meson command used in build file regeneration: ' + ' '.join(v))
elif k == 'pkgconf_envvar':
print('Last seen PKGCONFIG enviroment variable value: ' + v)
Expand Down
4 changes: 2 additions & 2 deletions run_unittests.py
Original file line number Diff line number Diff line change
Expand Up @@ -2681,9 +2681,9 @@ def test_templates(self):
if ninja is None:
raise unittest.SkipTest('This test currently requires ninja. Fix this once "meson build" works.')
for lang in ('c', 'cpp'):
for type in ('executable', 'library'):
for target_type in ('executable', 'library'):
with tempfile.TemporaryDirectory() as tmpdir:
self._run(self.meson_command + ['init', '--language', lang, '--type', type],
self._run(self.meson_command + ['init', '--language', lang, '--type', target_type],
workdir=tmpdir)
self._run(self.setup_command + ['--backend=ninja', 'builddir'],
workdir=tmpdir)
Expand Down
2 changes: 2 additions & 0 deletions setup.cfg
Original file line number Diff line number Diff line change
Expand Up @@ -28,4 +28,6 @@ ignore =
E722
# W504: line break after binary operator
W504
# A003: builtin class attribute
A003
max-line-length = 120
1 change: 1 addition & 0 deletions sideci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -3,3 +3,4 @@ linter:
version: 3
plugins:
- flake8-blind-except
- flake8-builtins

0 comments on commit e75211d

Please sign in to comment.