benedict.core.keylists   A
last analyzed

Complexity

Total Complexity 9

Size/Duplication

Total Lines 33
Duplicated Lines 0 %

Importance

Changes 0
Metric Value
wmc 9
eloc 26
dl 0
loc 33
rs 10
c 0
b 0
f 0

4 Functions

Rating   Name   Duplication   Size   Complexity  
A keylists() 0 2 1
A _get_keylist_for_dict() 0 7 2
A _get_keylist_for_list() 0 8 2
A _get_keylist_for_value() 0 6 4
1
from benedict.utils import type_util
2
3
4
def _get_keylist_for_dict(d, parent_keys, indexes):
5
    keylist = []
6
    for key, value in d.items():
7
        keys = parent_keys + [key]
8
        keylist += [keys]
9
        keylist += _get_keylist_for_value(value, keys, indexes)
10
    return keylist
11
12
13
def _get_keylist_for_list(ls, parent_keys, indexes):
14
    keylist = []
15
    for key, value in enumerate(ls):
16
        keys = list(parent_keys)
17
        keys[-1] += f"[{key}]"
18
        keylist += [keys]
19
        keylist += _get_keylist_for_value(value, keys, indexes)
20
    return keylist
21
22
23
def _get_keylist_for_value(value, parent_keys, indexes):
24
    if type_util.is_dict(value):
25
        return _get_keylist_for_dict(value, parent_keys, indexes)
26
    elif type_util.is_list(value) and indexes:
27
        return _get_keylist_for_list(value, parent_keys, indexes)
28
    return []
29
30
31
def keylists(d, indexes=False):
32
    return _get_keylist_for_value(d, [], indexes)
33