aboutsummaryrefslogtreecommitdiffstats
path: root/docs/_scripts/siphon/process_clicmd.py
blob: 4bf84edf0868b44b99b034fc7fe6937044a27f4d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
# 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