2015-03-10 13:09:31 +00:00
|
|
|
# Copyright 2014-2015 ARM Limited
|
|
|
|
#
|
|
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
# you may not use this file except in compliance with the License.
|
|
|
|
# You may obtain a copy of the License at
|
|
|
|
#
|
|
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
#
|
|
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
# See the License for the specific language governing permissions and
|
|
|
|
# limitations under the License.
|
|
|
|
#
|
|
|
|
|
|
|
|
|
|
|
|
import sys
|
|
|
|
import subprocess
|
|
|
|
from cStringIO import StringIO
|
|
|
|
|
2016-03-17 15:23:39 +00:00
|
|
|
from wlauto import Command
|
2016-03-17 13:43:45 +00:00
|
|
|
from wlauto.core.configuration import settings
|
2016-03-17 15:23:39 +00:00
|
|
|
from wlauto.core import pluginloader
|
2015-03-10 13:09:31 +00:00
|
|
|
from wlauto.utils.doc import (get_summary, get_description, get_type_name, format_column, format_body,
|
|
|
|
format_paragraph, indent, strip_inlined_text)
|
|
|
|
from wlauto.utils.misc import get_pager
|
2015-04-09 08:32:02 +01:00
|
|
|
from wlauto.utils.terminalsize import get_terminal_size
|
2015-03-10 13:09:31 +00:00
|
|
|
|
|
|
|
|
|
|
|
class ShowCommand(Command):
|
|
|
|
|
|
|
|
name = 'show'
|
|
|
|
|
|
|
|
description = """
|
2016-03-17 15:23:39 +00:00
|
|
|
Display documentation for the specified plugin (workload, instrument, etc.).
|
2015-03-10 13:09:31 +00:00
|
|
|
"""
|
|
|
|
|
2015-06-17 17:41:24 +01:00
|
|
|
def initialize(self, context):
|
2015-03-10 13:09:31 +00:00
|
|
|
self.parser.add_argument('name', metavar='EXTENSION',
|
2016-03-17 15:23:39 +00:00
|
|
|
help='''The name of the plugin for which information will
|
2015-03-10 13:09:31 +00:00
|
|
|
be shown.''')
|
|
|
|
|
|
|
|
def execute(self, args):
|
2015-04-09 08:32:02 +01:00
|
|
|
# pylint: disable=unpacking-non-sequence
|
2016-03-17 15:23:39 +00:00
|
|
|
plugin = pluginloader.get_plugin_class(args.name)
|
2015-03-10 13:09:31 +00:00
|
|
|
out = StringIO()
|
|
|
|
term_width, term_height = get_terminal_size()
|
2016-03-17 15:23:39 +00:00
|
|
|
format_plugin(plugin, out, term_width)
|
2015-03-10 13:09:31 +00:00
|
|
|
text = out.getvalue()
|
|
|
|
pager = get_pager()
|
|
|
|
if len(text.split('\n')) > term_height and pager:
|
2015-05-07 12:02:03 +01:00
|
|
|
try:
|
|
|
|
sp = subprocess.Popen(pager, stdin=subprocess.PIPE)
|
|
|
|
sp.communicate(text)
|
|
|
|
except OSError:
|
|
|
|
self.logger.warning('Could not use PAGER "{}"'.format(pager))
|
|
|
|
sys.stdout.write(text)
|
2015-03-10 13:09:31 +00:00
|
|
|
else:
|
|
|
|
sys.stdout.write(text)
|
|
|
|
|
|
|
|
|
2016-03-17 15:23:39 +00:00
|
|
|
def format_plugin(plugin, out, width):
|
|
|
|
format_plugin_name(plugin, out)
|
2015-03-10 13:09:31 +00:00
|
|
|
out.write('\n')
|
2016-03-17 15:23:39 +00:00
|
|
|
format_plugin_summary(plugin, out, width)
|
2015-03-10 13:09:31 +00:00
|
|
|
out.write('\n')
|
2016-03-17 15:23:39 +00:00
|
|
|
if hasattr(plugin, 'supported_platforms'):
|
|
|
|
format_supported_platforms(plugin, out, width)
|
2015-06-16 12:56:48 +01:00
|
|
|
out.write('\n')
|
2016-03-17 15:23:39 +00:00
|
|
|
if plugin.parameters:
|
|
|
|
format_plugin_parameters(plugin, out, width)
|
2015-03-10 13:09:31 +00:00
|
|
|
out.write('\n')
|
2016-03-17 15:23:39 +00:00
|
|
|
format_plugin_description(plugin, out, width)
|
2015-03-10 13:09:31 +00:00
|
|
|
|
|
|
|
|
2016-03-17 15:23:39 +00:00
|
|
|
def format_plugin_name(plugin, out):
|
|
|
|
out.write('\n{}\n'.format(plugin.name))
|
2015-03-10 13:09:31 +00:00
|
|
|
|
|
|
|
|
2016-03-17 15:23:39 +00:00
|
|
|
def format_plugin_summary(plugin, out, width):
|
|
|
|
out.write('{}\n'.format(format_body(strip_inlined_text(get_summary(plugin)), width)))
|
2015-03-10 13:09:31 +00:00
|
|
|
|
|
|
|
|
2016-03-17 15:23:39 +00:00
|
|
|
def format_supported_platforms(plugin, out, width):
|
|
|
|
text = 'supported on: {}'.format(', '.join(plugin.supported_platforms))
|
2015-06-16 12:56:48 +01:00
|
|
|
out.write('{}\n'.format(format_body(text, width)))
|
|
|
|
|
|
|
|
|
2016-03-17 15:23:39 +00:00
|
|
|
def format_plugin_description(plugin, out, width):
|
2015-03-10 13:09:31 +00:00
|
|
|
# skip the initial paragraph of multi-paragraph description, as already
|
|
|
|
# listed above.
|
2016-03-17 15:23:39 +00:00
|
|
|
description = get_description(plugin).split('\n\n', 1)[-1]
|
2015-03-10 13:09:31 +00:00
|
|
|
out.write('{}\n'.format(format_body(strip_inlined_text(description), width)))
|
|
|
|
|
|
|
|
|
2016-03-17 15:23:39 +00:00
|
|
|
def format_plugin_parameters(plugin, out, width, shift=4):
|
2015-03-10 13:09:31 +00:00
|
|
|
out.write('parameters:\n\n')
|
|
|
|
param_texts = []
|
2016-03-17 15:23:39 +00:00
|
|
|
for param in plugin.parameters:
|
2015-03-10 13:09:31 +00:00
|
|
|
description = format_paragraph(strip_inlined_text(param.description or ''), width - shift)
|
|
|
|
param_text = '{}'.format(param.name)
|
|
|
|
if param.mandatory:
|
|
|
|
param_text += " (MANDATORY)"
|
|
|
|
param_text += '\n{}\n'.format(description)
|
|
|
|
param_text += indent('type: {}\n'.format(get_type_name(param.kind)))
|
|
|
|
if param.allowed_values:
|
|
|
|
param_text += indent('allowed values: {}\n'.format(', '.join(map(str, param.allowed_values))))
|
|
|
|
elif param.constraint:
|
|
|
|
param_text += indent('constraint: {}\n'.format(get_type_name(param.constraint)))
|
2015-06-03 15:14:31 +01:00
|
|
|
if param.default is not None:
|
2015-03-10 13:09:31 +00:00
|
|
|
param_text += indent('default: {}\n'.format(param.default))
|
|
|
|
param_texts.append(indent(param_text, shift))
|
|
|
|
|
|
|
|
out.write(format_column('\n'.join(param_texts), width))
|