Total Complexity | 3 |
Total Lines | 42 |
Duplicated Lines | 69.05 % |
Coverage | 0% |
Changes | 0 |
Duplicate code is one of the most pungent code smells. A rule that is often used is to re-structure code once it is duplicated in three or more places.
Common duplication problems, and corresponding solutions are:
1 | from typing import Dict |
||
2 | |||
3 | from cleo.styles import OutputStyle |
||
4 | |||
5 | from sdoc.sdoc2.node.HeadingNode import HeadingNode |
||
6 | from sdoc.sdoc2.NodeStore import NodeStore |
||
7 | |||
8 | |||
9 | View Code Duplication | class SectionNode(HeadingNode): |
|
|
|||
10 | """ |
||
11 | SDoc2 node for sections. |
||
12 | """ |
||
13 | |||
14 | # ------------------------------------------------------------------------------------------------------------------ |
||
15 | def __init__(self, io: OutputStyle, options: Dict[str, str], argument: str): |
||
16 | """ |
||
17 | Object constructor. |
||
18 | |||
19 | :param OutputStyle io: The IO object. |
||
20 | :param dict[str,str] options: The options of this section. |
||
21 | :param str argument: The title of this section. |
||
22 | """ |
||
23 | super().__init__(io, 'section', options, argument) |
||
24 | |||
25 | # ------------------------------------------------------------------------------------------------------------------ |
||
26 | def get_command(self) -> str: |
||
27 | """ |
||
28 | Returns the command of this node, i.e. section. |
||
29 | """ |
||
30 | return 'section' |
||
31 | |||
32 | # ------------------------------------------------------------------------------------------------------------------ |
||
33 | def get_hierarchy_level(self, parent_hierarchy_level: int = -1) -> int: |
||
34 | """ |
||
35 | Returns 2. |
||
36 | """ |
||
37 | return 2 |
||
38 | |||
39 | |||
40 | # ---------------------------------------------------------------------------------------------------------------------- |
||
41 | NodeStore.register_inline_command('section', SectionNode) |
||
42 |