aboutsummaryrefslogblamecommitdiffstats
path: root/src/extract/libgamma-method-extract
blob: 6477c8a178c1f8d0633c199246d8c1c69052149b (plain) (tree)





















                                                                          
                                                                                    









                                                                                                        














                                                                                       






                                                                                 






                                                                                              








                                                                                                 













                                                                                                    
     
                                             







                                                      
                                                      









                                                      

















                                                                                                 

















                                                                                                    
 
#!/usr/bin/env python3
# -*- python -*-

# libgamma — Display server abstraction layer for gamma ramp adjustments
# Copyright © 2014  Mattias Andrée (maandree@member.fsf.org)
# 
# This library is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
# 
# This library is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU General Public License for more details.
# 
# You should have received a copy of the GNU General Public License
# along with this library.  If not, see <http://www.gnu.org/licenses/>.

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', 'error')

if sys.argv[1] == '--list':
    if sys.argv[2] == '--method':
        test1 = lambda line : line.startswith('#define LIBGAMMA_METHOD_')
        test2 = lambda line : line.split(' ')[1] not in ('LIBGAMMA_METHOD_MAX', 'LIBGAMMA_METHOD_COUNT')
        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]))
    elif sys.argv[2] == '--info':
        test1 = lambda line : line.startswith('#define LIBGAMMA_CRTC_INFO_')
        test2 = lambda line : not line.split(' ')[1] == 'LIBGAMMA_CRTC_INFO_COUNT'
        defs = [line for line in data.split('\n') if test1(line) and test2(line)]
        print('\n'.join([d.split(' ')[1] for d in defs]))
    elif sys.argv[2] == '--connector':
        test1 = lambda line : line.strip().startswith('LIBGAMMA_CONNECTOR_TYPE_')
        test2 = lambda line : not line.split(' ')[1] == 'LIBGAMMA_CONNECTOR_TYPE_COUNT'
        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]))
    elif sys.argv[2] == '--subpixel':
        test1 = lambda line : line.strip().startswith('LIBGAMMA_SUBPIXEL_ORDER_')
        test2 = lambda line : not line.split(' ')[1] == 'LIBGAMMA_SUBPIXEL_ORDER_COUNT'
        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]))
    elif sys.argv[2] == '--info-t':
        data = data[data.find('\ntypedef struct libgamma_crtc_information'):]
        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(' ')[-1].rstrip(';') for d in defs]))
    elif sys.argv[2] == '--cap-t':
        data = data[data.find('\ntypedef struct libgamma_method_capabilities'):]
        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]))
elif sys.argv[1] == '--type':
    if sys.argv[2] == '--info-t':
        data = data[data.find('\ntypedef struct libgamma_crtc_information'):]
        data = data[:data.find('\n}')]
        test1 = lambda line : line.startswith('  ')
        test2 = lambda line : ' * ' not in line
        test3 = lambda line : line.strip().split(' ')[-1] == sys.argv[3] + ';'
        defs = [line for line in data.split('\n') if test1(line) and test2(line) and test3(line)]
        print('\n'.join([' '.join(d.strip().split(' ')[:-1]) for d in defs]))
    elif sys.argv[2] == '--cap-t':
        data = data[data.find('\ntypedef struct libgamma_method_capabilities'):]
        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]))
else:
    if sys.argv[1] in ('--method', '--info'):
        i = data.find('\n#define ' + sys.argv[2])
        data = data[:i]
        i = data.rfind('\n */')
        data = data[:i]
        i = data.rfind('/**\n')
        data = data[i + len('/**\n'):]
        data = [line[3:] for line in data.split('\n')]
        print('\n'.join(data))
    elif sys.argv[1] in ('--connector', '--subpixel'):
        while '\n ' in data:
            data = data.replace('\n ', '\n')
        i = data.find('\n' + sys.argv[2])
        data = data[:i]
        i = data.rfind('\n*/')
        data = data[:i]
        i = data.rfind('/**\n')
        data = data[i + len('/**\n'):]
        data = [line[2:] for line in data.split('\n')]
        print('\n'.join(data))
    elif sys.argv[1] == '--info-t':
        data = data[data.find('\ntypedef struct libgamma_crtc_information'):]
        data = data[:data.find('\n}')]
        test1 = lambda line : line.startswith('  ')
        test2 = lambda line : ' * ' not in line
        test3 = lambda line : line.strip().split(' ')[-1] == sys.argv[2] + ';'
        defs = [line for line in data.split('\n') if test1(line) and test2(line) and test3(line)]
        line = defs[0]
        i = data.find('\n' + line)
        data = data[:i]
        while '\n ' in data:
            data = data.replace('\n ', '\n')
        i = data.rfind('\n*/')
        data = data[:i]
        i = data.rfind('/**\n')
        data = data[i + len('/**\n'):]
        data = [line[2:] for line in data.split('\n')]
        print('\n'.join(data))
    elif sys.argv[1] == '--cap-t':
        data = data[data.find('\ntypedef struct libgamma_method_capabilities'):]
        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]
        i = data.find('\n' + line)
        data = data[:i]
        while '\n ' in data:
            data = data.replace('\n ', '\n')
        i = data.rfind('\n*/')
        data = data[:i]
        i = data.rfind('/**\n')
        data = data[i + len('/**\n'):]
        data = [line[2:] for line in data.split('\n')]
        print('\n'.join(data))