summaryrefslogtreecommitdiffstats
path: root/mod/onboardingapi/docs/source/dcaeclidoctools.py
diff options
context:
space:
mode:
authorMichael Hwang <mhwang@research.att.com>2019-11-12 16:04:20 -0500
committerMichael Hwang <mhwang@research.att.com>2019-12-13 16:46:11 -0500
commitc698e66797bad69b4c77b26b487bf8322989beb0 (patch)
treee40a8449728768107e4ab4c1ac506af13230a580 /mod/onboardingapi/docs/source/dcaeclidoctools.py
parent9cb529e42f5625f2fa802e21919b10f814a89ca7 (diff)
Copy dcae-cli->onboardingapi, copy component specs
Issue-ID: DCAEGEN2-1860 Change-Id: I4805398c76479fad51cbdb74470ccc8f706ce9dc Signed-off-by: Michael Hwang <mhwang@research.att.com>
Diffstat (limited to 'mod/onboardingapi/docs/source/dcaeclidoctools.py')
-rw-r--r--mod/onboardingapi/docs/source/dcaeclidoctools.py78
1 files changed, 78 insertions, 0 deletions
diff --git a/mod/onboardingapi/docs/source/dcaeclidoctools.py b/mod/onboardingapi/docs/source/dcaeclidoctools.py
new file mode 100644
index 0000000..b54e5e2
--- /dev/null
+++ b/mod/onboardingapi/docs/source/dcaeclidoctools.py
@@ -0,0 +1,78 @@
+# ============LICENSE_START=======================================================
+# org.onap.dcae
+# ================================================================================
+# Copyright (c) 2017 AT&T Intellectual Property. All rights reserved.
+# ================================================================================
+# 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.
+# ============LICENSE_END=========================================================
+#
+# ECOMP is a trademark and service mark of AT&T Intellectual Property.
+
+import pkg_resources
+
+from docutils.nodes import literal_block
+from sphinx.domains import Domain
+from sphinx.util.compat import Directive
+
+import click
+
+from dcae_cli.cli import cli as group # PYTHONPATH dynamically altered in conf.py
+
+
+def generate_help_texts(command, prefix):
+ ctx = click.Context(command)
+ yield make_block(
+ ' '.join(prefix),
+ command.get_help_option(ctx).opts[0],
+ command.get_help(ctx),
+ )
+
+ if isinstance(command, click.core.Group):
+ for c in command.list_commands(ctx):
+ c = command.resolve_command(ctx, [c])[1]
+ prefix.append(c.name)
+ for h in generate_help_texts(c, prefix):
+ yield h
+ prefix.pop()
+
+
+def find_script_callable(name):
+ return list(pkg_resources.iter_entry_points(
+ 'console_scripts', name))[0].load()
+
+
+def make_block(command, opt, content):
+ h = "$ {} {}\n".format(command, opt) + content
+ return literal_block(h, h, language='bash')
+
+
+class ClickHelpDirective(Directive):
+ has_content = True
+ required_arguments = 1
+
+ def run(self):
+ root_cmd = self.arguments[0]
+ #group = find_script_callable(root_cmd)
+ return list(generate_help_texts(group, [root_cmd]))
+
+
+class DcaeCliDomain(Domain):
+ name = 'dcae_cli'
+ label = 'DCAE-CLI'
+ directives = {
+ 'click-help': ClickHelpDirective,
+ }
+
+
+def setup(app):
+ app.add_domain(DcaeCliDomain)