configurationengine/source/plugins/symbian/ConeHCRPlugin/hcrplugin/hcr_writer.py
author terytkon
Thu, 11 Mar 2010 17:04:37 +0200
changeset 0 2e8eeb919028
child 3 e7e0ae78773e
permissions -rw-r--r--
Adding EPL version of configurationengine.
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
     1
#
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
     2
# Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
     3
# All rights reserved.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
     4
# This component and the accompanying materials are made available
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
     5
# under the terms of "Eclipse Public License v1.0"
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
     6
# which accompanies this distribution, and is available
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
     7
# at the URL "http://www.eclipse.org/legal/epl-v10.html".
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
     8
#
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
     9
# Initial Contributors:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    10
# Nokia Corporation - initial contribution.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    11
#
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    12
# Contributors:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    13
#
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    14
# Description: 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    15
#
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    16
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    17
import logging
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    18
import __init__
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    19
  
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    20
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    21
from struct import pack, unpack
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    22
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    23
from cone.public import exceptions,plugin,utils,api
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    24
from hcrplugin.hcrrepository import HcrRecord
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    25
from hcrplugin.hcr_exceptions import *
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    26
from hcrplugin.hcr_header import HcrHeader
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    27
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    28
# Dictionary for mapping the HCRML value types to their
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    29
# implementation values
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    30
VALUE_TYPE_MAP = {
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    31
    HcrRecord.VALTYPE_INT32         : 0x00000001,
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    32
    HcrRecord.VALTYPE_INT16         : 0x00000002,
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    33
    HcrRecord.VALTYPE_INT8          : 0x00000004,
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    34
    HcrRecord.VALTYPE_BOOL          : 0x00000008,
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    35
    HcrRecord.VALTYPE_UINT32        : 0x00000010,
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    36
    HcrRecord.VALTYPE_UINT16        : 0x00000020,
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    37
    HcrRecord.VALTYPE_UINT8         : 0x00000040,
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    38
    HcrRecord.VALTYPE_LIN_ADDR      : 0x00000100,
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    39
    HcrRecord.VALTYPE_BIN_DATA      : 0x00010000,
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    40
    HcrRecord.VALTYPE_TEXT8         : 0x00020000,
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    41
    HcrRecord.VALTYPE_ARRAY_INT32   : 0x00040000,
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    42
    HcrRecord.VALTYPE_ARRAY_UINT32  : 0x00080000,
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    43
    HcrRecord.VALTYPE_INT64         : 0x01000000,
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    44
    HcrRecord.VALTYPE_UINT64        : 0x02000000,
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    45
    }
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    46
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    47
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    48
VALUE_TYPES_WITH_LSD = [
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    49
    HcrRecord.VALTYPE_BIN_DATA,
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    50
    HcrRecord.VALTYPE_TEXT8,
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    51
    HcrRecord.VALTYPE_ARRAY_INT32,
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    52
    HcrRecord.VALTYPE_ARRAY_UINT32,
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    53
    HcrRecord.VALTYPE_INT64,
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    54
    HcrRecord.VALTYPE_UINT64
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    55
    ]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    56
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    57
VALUE_TYPES_UNSIGNED_INT = [
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    58
    HcrRecord.VALTYPE_UINT32,
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    59
    HcrRecord.VALTYPE_UINT16,
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    60
    HcrRecord.VALTYPE_UINT8,
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    61
    HcrRecord.VALTYPE_LIN_ADDR,
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    62
    HcrRecord.VALTYPE_UINT64,
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    63
    ]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    64
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    65
NUMERIC_VALUE_RANGES = {
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    66
    HcrRecord.VALTYPE_INT32         : (-2**31,  2**31-1),
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    67
    HcrRecord.VALTYPE_INT16         : (-2**15,  2**15-1),
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    68
    HcrRecord.VALTYPE_INT8          : (-2**7,   2**7-1),
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    69
    HcrRecord.VALTYPE_UINT32        : (0,       2**32-1),
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    70
    HcrRecord.VALTYPE_UINT16        : (0,       2**16-1),
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    71
    HcrRecord.VALTYPE_UINT8         : (0,       2**8-1),
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    72
    HcrRecord.VALTYPE_LIN_ADDR      : (0,       2**32-1),
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    73
    HcrRecord.VALTYPE_INT64         : (-2**63,  2**63-1),
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    74
    HcrRecord.VALTYPE_UINT64        : (0,       2**64-1),
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    75
    HcrRecord.VALTYPE_ARRAY_INT32   : (-2**31,  2**31-1),
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    76
    HcrRecord.VALTYPE_ARRAY_UINT32  : (0,       2**32-1),
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    77
}
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    78
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    79
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    80
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    81
class HcrWriter(object):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    82
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    83
    # Maximum size of LSD section data for one record
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    84
    LSD_MAX_SIZE_PER_RECORD = 512
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    85
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    86
    def get_record_setting_id(self, record):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    87
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    88
        Return the setting ID value used for sorting the records in the repository.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    89
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    90
        return (record.category_id, record.element_id)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    91
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    92
    def get_repository_bindata(self, repository):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    93
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    94
        @return: The binary data to write into a file for the given repository.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    95
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    96
        dup_ids = repository.get_duplicate_record_ids()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    97
        if len(dup_ids) > 0:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    98
            raise DuplicateRecordError("The repository contains the following duplicate records (category ID, element ID): %r" % dup_ids)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    99
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   100
        header_data   = None
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   101
        header_size   = 32
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   102
        record_data   = []
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   103
        records_size  = 0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   104
        lsd_data      = []
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   105
        lsd_size      = 0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   106
        lsd_offset    = None
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   107
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   108
        # Generate the record and LSD section data
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   109
        records = sorted(repository.records, key=self.get_record_setting_id)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   110
        for record in records:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   111
            lsd_pos = None
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   112
            lsd = self.get_record_lsd_bindata(record)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   113
            if lsd != None:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   114
                # Store the position before adding the padding,
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   115
                # because it shouldn't include the padding bytes
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   116
                lsd_pos = (lsd_size, len(lsd))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   117
                lsd += self._get_padding(len(lsd))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   118
                lsd_data.append(lsd)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   119
                lsd_size += len(lsd)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   120
            
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   121
            rdata = self.get_record_bindata(record, lsd_pos)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   122
            record_data.append(rdata)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   123
            records_size += len(rdata)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   124
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   125
        lsd_offset = header_size + records_size
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   126
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   127
        header = HcrHeader()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   128
        header.version = repository.version
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   129
        header.flags = repository.flags
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   130
        header.nrecords = len(repository.records)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   131
        header.lsd_offset = lsd_offset
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   132
        header.lsd_size = lsd_size
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   133
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   134
        header_data = header.dumps()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   135
        if len(header_data) != header_size:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   136
            raise RuntimeError("Internal logic error! Header size is %d and not %d as it should be!" % (len(header_data), header_size))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   137
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   138
        output = []
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   139
        output.append(header_data)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   140
        output.extend(record_data)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   141
        output.extend(lsd_data)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   142
        output = ''.join(output)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   143
        if len(output) % 4 != 0:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   144
            raise RuntimeError("Internal logic error! Output size is not divisible by 4 (%d)" % (len(output)))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   145
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   146
        return output
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   147
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   148
    def _get_padding(self, size, padding_char='\x00'):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   149
        if size % 4 == 0:   amount = 0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   150
        else:               amount = 4 - (size % 4)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   151
        return amount * padding_char
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   152
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   153
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   154
    def get_record_bindata(self, record, lsd_pos=None):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   155
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   156
        @param lsd_pos: The position of the record's data in the Large
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   157
            Setting Data section. Should be a tuple: (offset, size).
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   158
        @return: The binary data to write for the given record object.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   159
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   160
        self._check_value_range(record)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   161
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   162
        if record.type in VALUE_TYPES_WITH_LSD:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   163
            RECORD_FMT = "<IIIHHI"
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   164
            return pack(RECORD_FMT,record.category_id,record.element_id,VALUE_TYPE_MAP[record.type],record.flags,lsd_pos[1],lsd_pos[0])
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   165
        else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   166
            if record.type in VALUE_TYPES_UNSIGNED_INT:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   167
                RECORD_FMT = "<IIIHHI"
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   168
            else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   169
                RECORD_FMT = "<IIIHHi"
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   170
            return pack(RECORD_FMT,record.category_id,record.element_id,VALUE_TYPE_MAP[record.type],record.flags,0,record.value)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   171
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   172
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   173
    def get_record_lsd_bindata(self, record):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   174
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   175
        @return: The binary data to write into the Large Setting Data
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   176
            section for the given setting, or None if an entry in the
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   177
            LSD section is not necessary.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   178
        """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   179
        result = None
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   180
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   181
        if record.type == HcrRecord.VALTYPE_TEXT8:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   182
            result = record.value.encode("utf-8")
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   183
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   184
        elif record.type == HcrRecord.VALTYPE_BIN_DATA:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   185
            result = record.value 
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   186
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   187
        elif record.type == HcrRecord.VALTYPE_ARRAY_INT32:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   188
            result = pack("<%di"%len(record.value),*record.value)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   189
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   190
        elif record.type == HcrRecord.VALTYPE_ARRAY_UINT32:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   191
            result = pack("<%dI"%len(record.value),*record.value)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   192
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   193
        elif record.type == HcrRecord.VALTYPE_INT64:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   194
            result = pack("<q",record.value)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   195
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   196
        elif record.type == HcrRecord.VALTYPE_UINT64:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   197
            result = pack("<Q",record.value)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   198
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   199
        if result != None:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   200
            if len(result) > self.LSD_MAX_SIZE_PER_RECORD:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   201
                msg = "Data size for value in record (category=%d, element=%d) is too large: size %d bytes, but maximum is %d bytes" \
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   202
                    % (record.category_id, record.element_id, len(result), self.LSD_MAX_SIZE_PER_RECORD)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   203
                raise TooLargeLsdDataError(msg)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   204
        return result
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   205
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   206
    def _check_value_range(self, record):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   207
        if record.type in NUMERIC_VALUE_RANGES:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   208
            range = NUMERIC_VALUE_RANGES[record.type]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   209
            
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   210
            values = record.value
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   211
            if not isinstance(values, list): values = [values]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   212
            
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   213
            for val in values:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   214
                if val < range[0] or val > range[1]:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   215
                    msg = "Value in record (category=%d, element=%d) is invalid for its type ('%s'): %d is not in the range %d-%d" \
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   216
                        % (record.category_id, record.element_id, record.type, val, range[0], range[1])
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   217
                    raise ValueNotInRangeError(msg)