blob: afc24ae6da1a638770f2bd9c4ff559a8aa6809bc [file] [log] [blame]
Chris Luke90f52bf2016-09-12 08:55:13 -04001# Copyright (c) 2016 Comcast Cable Communications Management, LLC.
2#
3# Licensed under the Apache License, Version 2.0 (the "License");
4# you may not use this file except in compliance with the License.
5# You may obtain a copy of the License at:
6#
7# http://www.apache.org/licenses/LICENSE-2.0
8#
9# Unless required by applicable law or agreed to in writing, software
10# distributed under the License is distributed on an "AS IS" BASIS,
11# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12# See the License for the specific language governing permissions and
13# limitations under the License.
14
15# Generate clicmd formatted output
16
Paul Vinciguerra464e5e02019-11-01 15:07:32 -040017from . import process, parsers
Nathan Skrzypczak9ad39c02021-08-19 11:38:06 +020018import os
Chris Luke90f52bf2016-09-12 08:55:13 -040019
Klement Sekerad9b0c6f2022-04-26 19:02:15 +020020
Chris Luke90f52bf2016-09-12 08:55:13 -040021class SiphonCLICMD(process.Siphon):
22
23 name = "clicmd"
24 identifier = "VLIB_CLI_COMMAND"
25
26 def __init__(self, *args, **kwargs):
27 super(SiphonCLICMD, self).__init__(*args, **kwargs)
28 self._parser = parsers.MacroInitializer()
29
Chris Luke90f52bf2016-09-12 08:55:13 -040030 # Output renderers
31
Nathan Skrzypczak9ad39c02021-08-19 11:38:06 +020032 def separate_page_names(self, group):
33 return self.page_label(group) + ".rst"
34
Chris Luke90f52bf2016-09-12 08:55:13 -040035 def index_sort_key(self, group):
Klement Sekerad9b0c6f2022-04-26 19:02:15 +020036 _global = self._cmds["_global"]
Chris Luke90f52bf2016-09-12 08:55:13 -040037 if group not in self._group:
38 return group
39 (directory, file) = self._group[group]
40
Klement Sekerad9b0c6f2022-04-26 19:02:15 +020041 if file in _global and "group_label" in _global[file]:
42 return _global[file]["group_label"]
Chris Luke90f52bf2016-09-12 08:55:13 -040043
Klement Sekerad9b0c6f2022-04-26 19:02:15 +020044 if directory in _global and "group_label" in _global[directory]:
45 return _global[directory]["group_label"]
Chris Luke90f52bf2016-09-12 08:55:13 -040046
47 return group
48
49 def item_sort_key(self, item):
Klement Sekerad9b0c6f2022-04-26 19:02:15 +020050 return item["value"]["path"]
Chris Luke90f52bf2016-09-12 08:55:13 -040051
52 def item_label(self, group, item):
Klement Sekerad9b0c6f2022-04-26 19:02:15 +020053 return "_".join(
54 (self.name, self.sanitize_label(self._cmds[group][item]["value"]["path"]))
55 )
Chris Luke90f52bf2016-09-12 08:55:13 -040056
Nathan Skrzypczak9ad39c02021-08-19 11:38:06 +020057 def page_title(self, group):
Klement Sekerad9b0c6f2022-04-26 19:02:15 +020058 _global = self._cmds["_global"]
Nathan Skrzypczak9ad39c02021-08-19 11:38:06 +020059 (directory, file) = self._group[group]
60
Klement Sekerad9b0c6f2022-04-26 19:02:15 +020061 if file and file in _global and "group_label" in _global[file]:
62 return _global[file]["group_label"]
Nathan Skrzypczak9ad39c02021-08-19 11:38:06 +020063
Klement Sekerad9b0c6f2022-04-26 19:02:15 +020064 if directory in _global and "group_label" in _global[directory]:
65 return _global[directory]["group_label"]
Nathan Skrzypczak9ad39c02021-08-19 11:38:06 +020066
67 file_ext = os.path.basename(directory)
68 fname, ext = os.path.splitext(file_ext)
69 return "%s cli reference" % fname.capitalize()
70
Chris Luke90f52bf2016-09-12 08:55:13 -040071
72# Register our processor
73process.siphons["clicmd"] = SiphonCLICMD