File: buzhug_info.py

package info (click to toggle)
python-buzhug 1.8-2
  • links: PTS
  • area: main
  • in suites: jessie, jessie-kfreebsd
  • size: 144 kB
  • ctags: 197
  • sloc: python: 1,653; makefile: 32
file content (88 lines) | stat: -rw-r--r-- 3,448 bytes parent folder | download | duplicates (3)
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
"""Manage general information about buzhug bases :
field definitions with types and default values"""

import os
import urllib

def set_info(base,fields):
    base.defaults = {}
    for field in fields:
        validate_field(base,field)

def validate_field(base,field_def):
    """Validate field definition"""
    name,typ = field_def[:2]
    if name in ['__id__','__version__']:
        raise ValueError,'Field name "%s" is reserved' %name
    elif name.startswith('_'):
        raise ValueError,"Error for %s : names can't begin with _" \
            % name
    if typ not in base.types.values():
        if isinstance(typ,base.__class__): # external link
            base._register_base(typ)
        else:
            raise TypeError,"type %s not allowed" %typ    
    if len(field_def)>2:
        # if a default value is provided, check if it is valid
        default = field_def[2]
        if isinstance(typ,base.__class__):
            if not hasattr(default.__class__,"db") or \
                not default.__class__.db is typ:
                raise ValueError,'Incorrect default value for field "%s"' \
                    " : expected %s, got %s (class %s)" %(name,typ,
                        default,default.__class__)
        elif not isinstance(default,typ):
            raise ValueError,'Incorrect default value for field "%s"' \
                " : expected %s, got %s (class %s)" %(name,typ,
                    default,default.__class__)
        base.defaults[name] = default
    else:
        base.defaults[name] = None

def save_info(base):
    """Save field information in files __info___ and __defaults__"""
    _info = open(base.info_name,'wb')
    fields = []
    for k in base.field_names:
        if isinstance(base.fields[k],base.__class__):
            fields.append((k,'<base>'+urllib.quote(base.fields[k].name)))
        else:
            fields.append((k,base.fields[k].__name__))
    _info.write(' '.join(['%s:%s' %(k,v) for (k,v) in fields]))
    _info.close()
    out = open(os.path.join(base.name,"__defaults__"),"wb")
    for field_name,default_value in base.defaults.iteritems():
        if field_name in ["__id__","__version__"]:
            continue
        value = base._file[field_name].to_block(default_value)
        out.write("%s %s" %(field_name,value))
    out.close()

def read_defaults(base):
    import buzhug_files
    defaults = dict([(f,None) for f in base.field_names[2:]])
    if os.path.exists(os.path.join(base.name,"__defaults__")):
        defs = open(os.path.join(base.name,"__defaults__"),"rb").read()
        ix = 0
        f_name = ""
        while ix<len(defs):
            if defs[ix]==" ":
                ix += 1
                if issubclass(base._file[f_name].__class__,
                    buzhug_files.FixedLengthFile):
                    length = base._file[f_name].block_len
                    block = defs[ix:ix+length]
                    ix += length
                else:
                    block = ""
                    while not defs[ix] == "\n":
                        block += defs[ix]
                        ix += 1
                    block += "\n"
                    ix += 1
                defaults[f_name] = base._file[f_name].from_block(block)
                f_name = ""
            else:
                f_name += defs[ix]
                ix += 1
    return defaults