blob: d37b17a5341e4cfdde2f82b4648aa6664fdaa1d0 (
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
|
# Copyright (C) 2020 The Qt Company Ltd.
# SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only
import pandas as pd
from option_management import function_describing_options
from function_signature import build_function_signature
def generate_excel_file_of_functions(filename):
olist = []
for options in function_describing_options():
# filter out unneccesary cases:
if options["reduce"] and options["inplace"]:
# we cannot do a reduction in-place
options["comment"] = "reduce-inplace:nonsense"
options["signature"] = ""
elif options["initialvalue"] and not options["reduce"]:
options["comment"] = "initial-noreduce:nonsense"
options["signature"] = ""
elif not options["reduce"] and not options["map"] and not options["filter"]:
# no operation at all
options["comment"] = "noop"
options["signature"] = ""
else:
options["comment"] = ""
if options["map"] and options["filter"]:
options["implemented"] = "no:filter+map"
elif not options["map"] and not options["filter"]:
options["implemented"] = "no:nofilter+nomap"
elif options["inplace"] and options["iterators"] and options["filter"]:
options["implemented"] = "no:inplace+iterator+filter"
else:
options["implemented"] = "yes"
options["signature"] = build_function_signature(options)
olist.append(options)
df = pd.DataFrame(olist)
df.to_excel(filename)
generate_excel_file_of_functions("functions.xls")
|