aboutsummaryrefslogtreecommitdiffstats
path: root/src/extract/libgamma-method-extract
diff options
context:
space:
mode:
authorMattias Andrée <maandree@kth.se>2021-03-07 20:50:01 +0100
committerMattias Andrée <maandree@kth.se>2021-03-07 20:50:01 +0100
commit6d4d0823dc508b35c53735a872190ad43aa60315 (patch)
tree4ff15b8e91882f21393a0815a54e4865d956c040 /src/extract/libgamma-method-extract
parentAssume all EDID 1.x are compatible (diff)
downloadlibgamma-6d4d0823dc508b35c53735a872190ad43aa60315.tar.gz
libgamma-6d4d0823dc508b35c53735a872190ad43aa60315.tar.bz2
libgamma-6d4d0823dc508b35c53735a872190ad43aa60315.tar.xz
Start replacing info manual with man pages
Signed-off-by: Mattias Andrée <maandree@kth.se>
Diffstat (limited to '')
-rwxr-xr-xsrc/extract/libgamma-method-extract120
1 files changed, 0 insertions, 120 deletions
diff --git a/src/extract/libgamma-method-extract b/src/extract/libgamma-method-extract
deleted file mode 100755
index b967ab3..0000000
--- a/src/extract/libgamma-method-extract
+++ /dev/null
@@ -1,120 +0,0 @@
-#!/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]])
-