aboutsummaryrefslogtreecommitdiffstats
path: root/src/extract/libgamma-method-extract
blob: b967ab384f4888ff68f8e3c6c8e7ce235a0213c9 (plain) (blame)
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
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
#!/usr/bin/env python
# -*- mode: python, encoding: utf-8 -*-
# See LICENSE file for copyright and license details.

import sys
import os

with open(os.path.dirname(sys.argv[0]) + '/../lib/libgamma-method.h', 'rb') as file:
    data = file.read()
data = data.decode('utf-8')


def list_define(prefix, *blacklist):
    global data
    test1 = lambda line : line.startswith('#define ' + prefix)
    test2 = lambda line : line.split(' ')[1] not in [prefix + b for b in list(blacklist)]
    test3 = lambda line : not line.endswith('_H')
    defs = [line for line in data.split('\n') if test1(line) and test2(line) and test3(line)]
    print('\n'.join([d.split(' ')[1] for d in defs]))

def list_enum(prefix, *blacklist):
    global data
    test1 = lambda line : line.strip().startswith(prefix)
    test2 = lambda line : line.split(' ')[1] not in [prefix + b for b in list(blacklist)]
    defs = [line for line in data.split('\n') if test1(line) and test2(line)]
    print('\n'.join([d.strip().split(' ')[0].rstrip(',') for d in defs]))

def list_struct(name):
    global data
    data = data[data.find('\ntypedef struct ' + name + '\n'):]
    data = data[:data.find('\n}')]
    test1 = lambda line : line.startswith('  ') and line.endswith(';')
    test2 = lambda line : ' * ' not in line
    defs = [line for line in data.split('\n') if test1(line) and test2(line)]
    print('\n'.join([d.strip().split(' : ')[0].split(' ')[-1].rstrip(';') for d in defs]))


def type_struct(name):
    global data
    data = data[data.find('\ntypedef struct ' + name + '\n'):]
    data = data[:data.find('\n}')]
    test1 = lambda line : line.startswith('  ')
    test2 = lambda line : ' * ' not in line
    test3 = lambda line : line.strip().split(' : ')[0].split(' ')[-1].rstrip(';') == sys.argv[3]
    defs = [line for line in data.split('\n') if test1(line) and test2(line) and test3(line)]
    line = defs[0].strip().rstrip(';')
    if ' : ' in line:
        line = line.split(' : ')
        line[0] = ' '.join(line[0].split(' ')[:-1])
        print(':'.join(line))
    else:
        print(' '.join(line.split(' ')[:-1]))


def doc_typedef(name):
    global data
    data = data[:data.find('\ntypedef ' + name + '\n'):]
    data = data[:data.rfind('\n */')]
    data = data[data.rfind('/**\n') + len('/**\n'):]
    data = [line[3:] for line in data.split('\n')]
    print('\n'.join(data))


def doc_define():
    global data
    data = data[:data.find('\n#define ' + sys.argv[2] + ' ')]
    data = data[:data.rfind('\n */')]
    data = data[data.rfind('/**\n') + len('/**\n'):]
    data = [line[3:] for line in data.split('\n')]
    print('\n'.join(data))

def doc_enum():
    global data
    while '\n ' in data:
        data = data.replace('\n ', '\n')
    data = data[:data.find('\n' + sys.argv[2])]
    data = data[:data.rfind('\n*/')]
    data = data[data.rfind('/**\n') + len('/**\n'):]
    data = [line[2:] for line in data.split('\n')]
    print('\n'.join(data))

def doc_struct(name):
    global data
    data = data[data.find('\ntypedef struct ' + name + '\n'):]
    data = data[:data.find('\n}')]
    test1 = lambda line : line.startswith('  ')
    test2 = lambda line : ' * ' not in line
    test3 = lambda line : line.strip().split(' : ')[0].split(' ')[-1].rstrip(';') == sys.argv[2]
    defs = [line for line in data.split('\n') if test1(line) and test2(line) and test3(line)]
    line = defs[0]
    data = data[:data.find('\n' + line)]
    while '\n ' in data:
        data = data.replace('\n ', '\n')
    data = data[:data.rfind('\n*/')]
    data = data[data.rfind('/**\n') + len('/**\n'):]
    data = [line[2:] for line in data.split('\n')]
    print('\n'.join(data))


struct_map = {'--info-t' : 'libgamma_crtc_information',
              '--cap-t'  : 'libgamma_method_capabilities',
              '--site-t' : 'libgamma_site_state',
              '--part-t' : 'libgamma_partition_state',
              '--crtc-t' : 'libgamma_crtc_state'}

if sys.argv[1] == '--list':
    if sys.argv[2] == '--method':       list_define('LIBGAMMA_METHOD_', 'MAX', 'COUNT')
    elif sys.argv[2] == '--info':       list_define('LIBGAMMA_CRTC_INFO_', 'COUNT')
    elif sys.argv[2] == '--connector':  list_enum('LIBGAMMA_CONNECTOR_TYPE_', 'COUNT')
    elif sys.argv[2] == '--subpixel':   list_enum('LIBGAMMA_SUBPIXEL_ORDER_', 'COUNT')
    elif sys.argv[2] in struct_map:     list_struct(struct_map[sys.argv[2]])
elif sys.argv[1] == '--type':
    if sys.argv[2] in struct_map:       type_struct(struct_map[sys.argv[2]])
elif sys.argv[1] == '--doc':
    if sys.argv[2] in struct_map:       doc_typedef('struct ' + struct_map[sys.argv[2]])
else:
    if sys.argv[1] in ('--method', '--info'):           doc_define()
    elif sys.argv[1] in ('--connector', '--subpixel'):  doc_enum()
    elif sys.argv[1] in struct_map:     doc_struct(struct_map[sys.argv[1]])