diff options
Diffstat (limited to 'backend/scripts/pixma_gen_options.py')
| -rwxr-xr-x | backend/scripts/pixma_gen_options.py | 389 | 
1 files changed, 0 insertions, 389 deletions
| diff --git a/backend/scripts/pixma_gen_options.py b/backend/scripts/pixma_gen_options.py deleted file mode 100755 index c4c75e0..0000000 --- a/backend/scripts/pixma_gen_options.py +++ /dev/null @@ -1,389 +0,0 @@ -#!/usr/bin/env python - -import sys,os,re - -class Error(Exception): -    pass - - -class ParseError(Error): -    def __init__(self, errline): -        Error.__init__(self, errline) - - -class Struct: -    pass - - -def createCNameMap(): -    t = '' -    for i in range(256): -        if ((ord('A') <= i) and (i <= ord('Z'))) or \ -               ((ord('a') <= i) and (i <= ord('z'))) or \ -               ((ord('0') <= i) and (i <= ord('9'))): -            t += chr(i) -        else: -            t += '_' -    return t - - -def seekBegin(f): -    while True: -        line = f.readline() -        if not line: -            return False -        if line.startswith('BEGIN SANE_Option_Descriptor'): -            return True - - -def parseVerbatim(o, line): -    words = line.split(None, 1) -    if (len(words) < 2) or (words[1][0] != '@'): -        return False -    o[words[0]] = words[1] -    return True - - -def parseLine_type(o, line): -    words = line.split(None, 2) -    otype = words[1] -    o['type'] = 'SANE_TYPE_' + otype.upper() -    if otype == 'group': -        g.ngroups += 1 -        oname = '_group_%d' % g.ngroups -        o['size'] = 0 -    else: -        temp = words[2] -        idx = temp.find('[') -        if idx == -1: -            oname = temp -            o['size'] = 1 -        else: -            oname = temp[0:idx] -            o['size'] = int(temp[idx+1:-1]) -    o['name'] = oname - - -def parseLine_title(o, line): -    o['title'] = line.split(None, 1)[1] - - -def parseLine_desc(o, line): -    o['desc'] = line.split(None, 1)[1] - - -def parseLine_unit(o, line): -    o['unit'] = 'SANE_UNIT_' + line.split(None, 1)[1].upper() - - -def parseLine_default(o, line): -    o['default'] = line.split(None, 1)[1] - - -def parseLine_cap(o, line): -    words = line.split() -    o['cap'] = ['SANE_CAP_' + s.upper() for s in words[1:]] - - -def parseLine_constraint(o, line): -    c = line.split(None,1)[1] -    if c[0] == '{': -        o['constraint'] = c[1:-1].split('|') -    elif c[0] == '(': -        o['constraint'] = tuple(c[1:-1].split(',')) -    else: -        sys.stderr.write('Ignored: %s\n' % line) - - -def parseLine_info(o, line): -    words = line.split() -    o['info'] = ['SANE_INFO_' + s.upper() for s in words[1:]] - -def parseLine_rem(o, line): -    pass - -def normalize(o): -    if 'cname' not in o: -        cname = o['name'].translate(cnameMap) -        o['cname'] = cname -    else: -        cname = o['cname'] -    o['cname_opt'] = 'opt_' + cname -    o['cname_con'] = 'constraint_' + cname -    if 'title' not in o: -        o['title'] = 'NO TITLE' -    if 'desc' not in o: -        o['desc'] = '@sod->title' % o -    if 'unit' not in o: -        o['unit'] = 'SANE_UNIT_NONE' -    if 'constraint_type' not in o: -        if 'constraint' not in o: -            ct = 'SANE_CONSTRAINT_NONE' -        elif isinstance(o['constraint'], list): -            if o['type'] == 'SANE_TYPE_STRING': -                ct = 'SANE_CONSTRAINT_STRING_LIST' -            else: -                ct = 'SANE_CONSTRAINT_WORD_LIST' -        elif isinstance(o['constraint'], tuple): -            ct = 'SANE_CONSTRAINT_RANGE' -        elif isinstance(o['constraint'], str): -            oc = o['constraint'] -            if oc.startswith('@range'): -                ct = 'SANE_CONSTRAINT_RANGE' -            elif oc.startswith('@word_list'): -                ct = 'SANE_CONSTRAINT_WORD_LIST' -            elif oc.startswith('@string_list'): -                ct = 'SANE_CONSTRAINT_STRING_LIST' -        o['constraint_type'] = ct -    return o - - -def parseFile(f): -    if not seekBegin(f): -        return None -    options = [ { -        'name' : '', -        'cname' : 'opt_num_opts', -        'title' : '@SANE_TITLE_NUM_OPTIONS', -        'desc' : '@SANE_DESC_NUM_OPTIONS', -        'type' : 'SANE_TYPE_INT', -        'unit' : 'SANE_UNIT_NONE', -        'size' : 1, -        'cap' : ['SANE_CAP_SOFT_DETECT'], -        'constraint_type' : 'SANE_CONSTRAINT_NONE', -        'default' : '@w = ' + opt_prefix + 'last' -        } ] -    o = {} -    while True: -        line = f.readline() -        if not line: -            break -        line = line.strip() -        if not line: -            continue -        token = line.split(None, 1)[0].lower() -        if token == 'end': -            break -        if token == 'type': -            if 'name' in o: -                options.append(o) -            o = {} -        funcName = 'parseLine_' + token -        if funcName in globals(): -            if not parseVerbatim(o, line): -                func = globals()[funcName] -                func(o, line) -        else: -            sys.stderr.write('Skip: %s\n' % line) -    if 'name' in o: -        options.append(o) -    return [normalize(o) for o in options] - - -def genHeader(options): -    print """ -typedef union { -  SANE_Word w; -  SANE_Int  i; -  SANE_Bool b; -  SANE_Fixed f; -  SANE_String s; -  void *ptr; -} option_value_t; -""" -    print 'typedef enum {' -    for o in options: -        print '  %(cname_opt)s,' % o -    print '  ' + opt_prefix + 'last' -    print '} option_t;' -    print """ - -typedef struct { -  SANE_Option_Descriptor sod; -  option_value_t val,def; -  SANE_Word info; -} option_descriptor_t; - - -struct pixma_sane_t; -static int build_option_descriptors(struct pixma_sane_t *ss); -""" - - -def genMinMaxRange(n, t, r): -    if t == 'SANE_TYPE_FIXED': -        r = ['SANE_FIX(%s)' % x for x in r] -    print 'static const SANE_Range ' + n + ' = ' -    print '  { ' + r[0] + ',' + r[1] + ',' + r[2] + ' };' - - -def genList(n, t, l): -    if t == 'SANE_TYPE_INT': -        etype = 'SANE_Word' -        l = [str(len(l))] + l -    elif t == 'SANE_TYPE_FIXED': -        etype = 'SANE_Word' -        l = [str(len(l))] + ['SANE_FIX(%s)' % x for x in l] -    elif t == 'SANE_TYPE_STRING': -        etype = 'SANE_String_Const' -        l = ['SANE_I18N("%s")' % x for x in l] + ['NULL'] -    print 'static const %s %s[%d] = {' % (etype, n, len(l)) -    for x in l[0:-1]: -        print '\t' + x + ',' -    print '\t' + l[-1] + ' };' - - -def genConstraints(options): -    for o in options: -        if 'constraint' not in o: continue -        c = o['constraint'] -        oname = o['cname_con'] -        otype = o['type'] -        if isinstance(c, tuple): -            genMinMaxRange(oname, otype, c) -        elif isinstance(c, list): -            genList(oname, otype, c) -    print - -def buildCodeVerbatim(o): -    for f in ('name', 'title', 'desc', 'type', 'unit', 'size', 'cap', -              'constraint_type', 'constraint', 'default'): -        if (f not in o): continue -        temp = o[f] -        if (not isinstance(temp,str)) or \ -           (len(temp) < 1) or (temp[0] != '@'): -            continue -        o['code_' + f] = temp[1:] - -def ccode(o): -    buildCodeVerbatim(o) -    if 'code_name' not in o: -        o['code_name'] = '"' + o['name'] + '"' -    for f in ('title', 'desc'): -        cf = 'code_' + f -        if cf in o: continue -        o[cf] = 'SANE_I18N("' + o[f] + '")' - -    for f in ('type', 'unit', 'constraint_type'): -        cf = 'code_' + f -        if cf in o: continue -        o[cf] = o[f] - -    if 'code_size' not in o: -        otype = o['type'] -        osize = o['size'] -        if otype == 'SANE_TYPE_STRING': -            code = str(osize + 1) -        elif otype == 'SANE_TYPE_INT' or otype == 'SANE_TYPE_FIXED': -            code = str(osize) + ' * sizeof(SANE_Word)' -        elif otype == 'SANE_TYPE_BUTTON': -            code = '0' -        else: -            code = 'sizeof(SANE_Word)' -        o['code_size'] = code - -    if ('code_cap' not in o) and ('cap' in o): -        o['code_cap'] = reduce(lambda a,b: a+'|'+b, o['cap']) -    else: -        o['code_cap'] = '0' - -    if ('code_info' not in o) and ('info' in o): -        o['code_info'] = reduce(lambda a,b: a+'|'+b, o['info']) -    else: -        o['code_info'] = '0' - -    if ('code_default' not in o) and ('default' in o): -        odefault = o['default'] -        otype = o['type'] -        if odefault == '_MIN': -            rhs = 'w = sod->constraint.range->min' -        elif odefault == '_MAX': -            rhs = 'w = sod->constraint.range->max' -        elif otype in ('SANE_TYPE_INT', 'SANE_TYPE_BOOL'): -            rhs = 'w = %(default)s' -        elif otype == 'SANE_TYPE_FIXED': -            rhs = 'w = SANE_FIX(%(default)s)' -        elif otype == 'SANE_TYPE_STRING': -            rhs = 's = SANE_I18N("%(default)s")' -        o['code_default'] = rhs % o -    if 'code_default' in o: -        code = '  opt->def.%(code_default)s;\n' -        if o['constraint_type'] != 'SANE_CONSTRAINT_STRING_LIST': -            code += '  opt->val.%(code_default)s;\n' -        else: -            code += '  opt->val.w = find_string_in_list' \ -                    '(opt->def.s, sod->constraint.string_list);\n' -        o['full_code_default'] = code % o -    else: -        o['full_code_default'] = '' - -    if ('code_constraint' not in o) and ('constraint' in o): -        ct = o['constraint_type'] -        idx = len('SANE_CONSTRAINT_') -        ctype = ct[idx:].lower() -        if ctype == 'range': -            rhs = '&%(cname_con)s' % o -        else: -            rhs = '%(cname_con)s' % o -        o['code_constraint'] = ctype + ' = ' + rhs -    if 'code_constraint' in o: -        code = '  sod->constraint.%(code_constraint)s;\n' -        o['full_code_constraint'] = code % o -    else: -        o['full_code_constraint'] = '' - -    return o - -def genBuildOptions(options): -  print """ -static -int find_string_in_list(SANE_String_Const str, const SANE_String_Const *list) -{ -  int i; -  for (i = 0; list[i] && strcmp(str, list[i]) != 0; i++) {} -  return i; -} - -static -int build_option_descriptors(struct pixma_sane_t *ss) -{ -  SANE_Option_Descriptor *sod; -  option_descriptor_t *opt; - -  memset(OPT_IN_CTX, 0, sizeof(OPT_IN_CTX));""" - -  for o in options: -      o = ccode(o) -      otype = o['type'] -      code = '\n  opt = &(OPT_IN_CTX[%(cname_opt)s]);\n' \ -             '  sod = &opt->sod;\n' \ -             '  sod->type = %(code_type)s;\n' \ -             '  sod->title = %(code_title)s;\n' \ -             '  sod->desc = %(code_desc)s;\n' -      if otype != 'SANE_TYPE_GROUP': -          code += '  sod->name = %(code_name)s;\n' \ -                  '  sod->unit = %(code_unit)s;\n' \ -                  '  sod->size = %(code_size)s;\n' \ -                  '  sod->cap  = %(code_cap)s;\n' \ -                  '  sod->constraint_type = %(code_constraint_type)s;\n' \ -                  '%(full_code_constraint)s' \ -                  '  OPT_IN_CTX[%(cname_opt)s].info = %(code_info)s;\n' \ -                  '%(full_code_default)s' -      sys.stdout.write(code % o) -  print -  print '  return 0;\n' -  print '}' -  print - -g = Struct() -g.ngroups = 0 -opt_prefix = 'opt_' -con_prefix = 'constraint_' -cnameMap = createCNameMap() -options = parseFile(sys.stdin) -print "/* Automatically generated from pixma_sane.c */" -if (len(sys.argv) == 2) and (sys.argv[1] == 'h'): -    genHeader(options) -else: -    genConstraints(options) -    genBuildOptions(options) | 
