vpp/docs/_scripts/siphon/process_clicmd.py
Dave Wallace 7b8b465269 tests docs: update python3 venv packages
- Package update performed by
  1. updating pip, pip-tools, setuptools
  2. 'make test-refresh-deps' on ubuntu 22.04
  3. fixing 'make test' and 'make docs' issues
     on ubuntu 22.04
  4. 'make test-refresh-deps' on ubuntu 20.04
- Add dependency for 'make test-refresh-deps'
  to insure python venv is set up.
- Update of python formatter, black,
  caused reformating of 41 python code
  files.

Type: make

Change-Id: I7cafdf4b5189065ac57cb6b254937f6e0897a924
Signed-off-by: Dave Wallace <dwallacelf@gmail.com>
2023-08-16 19:53:12 +00:00

73 lines
2.3 KiB
Python

# Copyright (c) 2016 Comcast Cable Communications Management, LLC.
#
# 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.
# Generate clicmd formatted output
from . import process, parsers
import os
class SiphonCLICMD(process.Siphon):
name = "clicmd"
identifier = "VLIB_CLI_COMMAND"
def __init__(self, *args, **kwargs):
super(SiphonCLICMD, self).__init__(*args, **kwargs)
self._parser = parsers.MacroInitializer()
# Output renderers
def separate_page_names(self, group):
return self.page_label(group) + ".rst"
def index_sort_key(self, group):
_global = self._cmds["_global"]
if group not in self._group:
return group
(directory, file) = self._group[group]
if file in _global and "group_label" in _global[file]:
return _global[file]["group_label"]
if directory in _global and "group_label" in _global[directory]:
return _global[directory]["group_label"]
return group
def item_sort_key(self, item):
return item["value"]["path"]
def item_label(self, group, item):
return "_".join(
(self.name, self.sanitize_label(self._cmds[group][item]["value"]["path"]))
)
def page_title(self, group):
_global = self._cmds["_global"]
(directory, file) = self._group[group]
if file and file in _global and "group_label" in _global[file]:
return _global[file]["group_label"]
if directory in _global and "group_label" in _global[directory]:
return _global[directory]["group_label"]
file_ext = os.path.basename(directory)
fname, ext = os.path.splitext(file_ext)
return "%s cli reference" % fname.capitalize()
# Register our processor
process.siphons["clicmd"] = SiphonCLICMD