Merge pull request #278 from winksaville/enhance-mesonconfig-help

Enhance mesonconfig.py output
pull/313/head
Jussi Pakkanen 9 years ago
commit 7cbf703b4a
  1. 16
      coredata.py
  2. 92
      mesonconf.py
  3. 4
      optinterpreter.py

@ -44,17 +44,18 @@ class MesonException(Exception):
Exception.__init__(self, *args, **kwargs) Exception.__init__(self, *args, **kwargs)
class UserOption: class UserOption:
def __init__(self, name, description): def __init__(self, name, description, choices):
super().__init__() super().__init__()
self.name = name self.name = name
self.choices = choices
self.description = description self.description = description
def parse_string(self, valuestring): def parse_string(self, valuestring):
return valuestring return valuestring
class UserStringOption(UserOption): class UserStringOption(UserOption):
def __init__(self, name, description, value): def __init__(self, name, description, value, choices=None):
super().__init__(name, description) super().__init__(name, description, choices)
self.set_value(value) self.set_value(value)
def validate(self, value): def validate(self, value):
@ -72,7 +73,7 @@ class UserStringOption(UserOption):
class UserBooleanOption(UserOption): class UserBooleanOption(UserOption):
def __init__(self, name, description, value): def __init__(self, name, description, value):
super().__init__(name, description) super().__init__(name, description, '[true, false]')
self.set_value(value) self.set_value(value)
def tobool(self, thing): def tobool(self, thing):
@ -96,8 +97,7 @@ class UserBooleanOption(UserOption):
class UserComboOption(UserOption): class UserComboOption(UserOption):
def __init__(self, name, description, choices, value): def __init__(self, name, description, choices, value):
super().__init__(name, description) super().__init__(name, description, choices)
self.choices = choices
if not isinstance(self.choices, list): if not isinstance(self.choices, list):
raise MesonException('Combo choices must be an array.') raise MesonException('Combo choices must be an array.')
for i in self.choices: for i in self.choices:
@ -112,8 +112,8 @@ class UserComboOption(UserOption):
self.value = newvalue self.value = newvalue
class UserStringArrayOption(UserOption): class UserStringArrayOption(UserOption):
def __init__(self, name, description, value): def __init__(self, name, description, value, **kwargs):
super().__init__(name, description) super().__init__(name, description, kwargs.get('choices', []))
self.set_value(value) self.set_value(value)
def set_value(self, newvalue): def set_value(self, newvalue):

@ -53,16 +53,33 @@ class Conf:
def print_aligned(self, arr): def print_aligned(self, arr):
if len(arr) == 0: if len(arr) == 0:
return return
longest_name = max((len(x[0]) for x in arr)) titles = ['Option', 'Description', 'Current Value', '']
longest_descr = max((len(x[1]) for x in arr)) longest_name = len(titles[0])
longest_descr = len(titles[1])
longest_value = len(titles[2])
longest_possible_value = len(titles[3])
for x in arr:
longest_name = max(longest_name, len(x[0]))
longest_descr = max(longest_descr, len(x[1]))
longest_value = max(longest_value, len(str(x[2])))
longest_possible_value = max(longest_possible_value, len(x[3]))
if longest_possible_value > 0:
titles[3] = 'Possible Values'
print(' %s%s %s%s %s%s %s' % (titles[0], ' '*(longest_name - len(titles[0])), titles[1], ' '*(longest_descr - len(titles[1])), titles[2], ' '*(longest_value - len(titles[2])), titles[3]))
print(' %s%s %s%s %s%s %s' % ('-'*len(titles[0]), ' '*(longest_name - len(titles[0])), '-'*len(titles[1]), ' '*(longest_descr - len(titles[1])), '-'*len(titles[2]), ' '*(longest_value - len(titles[2])), '-'*len(titles[3])))
for i in arr: for i in arr:
name = i[0] name = i[0]
descr = i[1] descr = i[1]
value = i[2] value = i[2]
if isinstance(value, bool):
value = 'true' if value else 'false'
possible_values = i[3]
namepad = ' '*(longest_name - len(name)) namepad = ' '*(longest_name - len(name))
descrpad = ' '*(longest_descr - len(descr)) descrpad = ' '*(longest_descr - len(descr))
f = '%s%s %s%s' % (name, namepad, descr, descrpad) valuepad = ' '*(longest_value - len(str(value)))
print(f, value) f = ' %s%s %s%s %s%s %s' % (name, namepad, descr, descrpad, value, valuepad, possible_values)
print(f)
def set_options(self, options): def set_options(self, options):
for o in options: for o in options:
@ -97,62 +114,69 @@ class Conf:
def print_conf(self): def print_conf(self):
print('Core properties\n') print('Core properties:')
print('Source dir', self.build.environment.source_dir) print(' Source dir', self.build.environment.source_dir)
print('Build dir ', self.build.environment.build_dir) print(' Build dir ', self.build.environment.build_dir)
print('') print('')
print('Core options\n') print('Core options:')
carr = [] carr = []
carr.append(['buildtype', 'Build type', self.coredata.get_builtin_option('buildtype')]) booleans = '[true, false]'
carr.append(['warning_level', 'Warning level', self.coredata.get_builtin_option('warning_level')]) carr.append(['buildtype', 'Build type', self.coredata.get_builtin_option('buildtype'), build_types])
carr.append(['strip', 'Strip on install', self.coredata.get_builtin_option('strip')]) carr.append(['warning_level', 'Warning level', self.coredata.get_builtin_option('warning_level'), warning_levels])
carr.append(['coverage', 'Coverage report', self.coredata.get_builtin_option('coverage')]) carr.append(['strip', 'Strip on install', self.coredata.get_builtin_option('strip'), booleans])
carr.append(['use_pch', 'Precompiled headers', self.coredata.get_builtin_option('use_pch')]) carr.append(['coverage', 'Coverage report', self.coredata.get_builtin_option('coverage'), booleans])
carr.append(['unity', 'Unity build', self.coredata.get_builtin_option('unity')]) carr.append(['use_pch', 'Precompiled headers', self.coredata.get_builtin_option('use_pch'), booleans])
carr.append(['default_library', 'Default library type', self.coredata.get_builtin_option('default_library')]) carr.append(['unity', 'Unity build', self.coredata.get_builtin_option('unity'), booleans])
carr.append(['default_library', 'Default library type', self.coredata.get_builtin_option('default_library'), booleans])
self.print_aligned(carr) self.print_aligned(carr)
print('') print('')
print('Compiler arguments\n') print('Compiler arguments:')
for (lang, args) in self.coredata.external_args.items(): for (lang, args) in self.coredata.external_args.items():
print(lang + 'args', str(args)) print(' ' + lang + 'args', str(args))
print('') print('')
print('Linker args\n') print('Linker args:')
for (lang, args) in self.coredata.external_link_args.items(): for (lang, args) in self.coredata.external_link_args.items():
print(lang + 'linkargs', str(args)) print(' ' + lang + 'linkargs', str(args))
print('') print('')
print('Compiler options:')
okeys = sorted(self.coredata.compiler_options.keys()) okeys = sorted(self.coredata.compiler_options.keys())
if len(okeys) == 0: if len(okeys) == 0:
print('No compiler options\n') print(' No compiler options\n')
else: else:
print('Compiler options\n')
coarr = [] coarr = []
for k in okeys: for k in okeys:
o = self.coredata.compiler_options[k] o = self.coredata.compiler_options[k]
coarr.append([k, o.description, o.value]) coarr.append([k, o.description, o.value, ''])
self.print_aligned(coarr) self.print_aligned(coarr)
print('') print('')
print('Directories\n') print('Directories:')
parr = [] parr = []
parr.append(['prefix', 'Install prefix', self.coredata.get_builtin_option('prefix')]) parr.append(['prefix', 'Install prefix', self.coredata.get_builtin_option('prefix'), ''])
parr.append(['libdir', 'Library directory', self.coredata.get_builtin_option('libdir')]) parr.append(['libdir', 'Library directory', self.coredata.get_builtin_option('libdir'), ''])
parr.append(['bindir', 'Binary directory', self.coredata.get_builtin_option('bindir')]) parr.append(['bindir', 'Binary directory', self.coredata.get_builtin_option('bindir'), ''])
parr.append(['includedir', 'Header directory', self.coredata.get_builtin_option('includedir')]) parr.append(['includedir', 'Header directory', self.coredata.get_builtin_option('includedir'), ''])
parr.append(['datadir', 'Data directory', self.coredata.get_builtin_option('datadir')]) parr.append(['datadir', 'Data directory', self.coredata.get_builtin_option('datadir'), ''])
parr.append(['mandir', 'Man page directory', self.coredata.get_builtin_option('mandir')]) parr.append(['mandir', 'Man page directory', self.coredata.get_builtin_option('mandir'), ''])
parr.append(['localedir', 'Locale file directory', self.coredata.get_builtin_option('localedir')]) parr.append(['localedir', 'Locale file directory', self.coredata.get_builtin_option('localedir'), ''])
self.print_aligned(parr) self.print_aligned(parr)
print('') print('')
print('Project options:')
if len(self.coredata.user_options) == 0: if len(self.coredata.user_options) == 0:
print('This project does not have user options') print(' This project does not have any options')
else: else:
print('Project options\n')
options = self.coredata.user_options options = self.coredata.user_options
keys = list(options.keys()) keys = list(options.keys())
keys.sort() keys.sort()
optarr = [] optarr = []
for key in keys: for key in keys:
opt = options[key] opt = options[key]
optarr.append([key, opt.description, opt.value]) if (opt.choices is None) or (len(opt.choices) == 0):
# Zero length list or string
choices = '';
else:
# A non zero length list or string, convert to string
choices = str(opt.choices);
optarr.append([key, opt.description, opt.value, choices])
self.print_aligned(optarr) self.print_aligned(optarr)
if __name__ == '__main__': if __name__ == '__main__':
@ -172,7 +196,7 @@ if __name__ == '__main__':
c.save() c.save()
else: else:
c.print_conf() c.print_conf()
except coredata.MesonException as e: except ConfException as e:
print('Meson configurator encountered an error:\n') print('Meson configurator encountered an error:\n')
print(e) print(e)

@ -1,4 +1,4 @@
# Copyright 2013-2015 The Meson development team # Copyright 2013-2014 The Meson development team
# Licensed under the Apache License, Version 2.0 (the "License"); # Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License. # you may not use this file except in compliance with the License.
@ -41,7 +41,7 @@ optname_regex = re.compile('[^a-zA-Z0-9_-]')
def StringParser(name, description, kwargs): def StringParser(name, description, kwargs):
return coredata.UserStringOption(name, description, return coredata.UserStringOption(name, description,
kwargs.get('value', '')) kwargs.get('value', ''), kwargs.get('choices', []))
def BooleanParser(name, description, kwargs): def BooleanParser(name, description, kwargs):
return coredata.UserBooleanOption(name, description, kwargs.get('value', True)) return coredata.UserBooleanOption(name, description, kwargs.get('value', True))

Loading…
Cancel
Save