buildframework/helium/tools/common/python/lib/integration/templatebuilder.py
changeset 179 d8ac696cc51f
parent 1 be27ed110b50
child 180 e02a83d4c571
child 592 3215c239276a
equal deleted inserted replaced
1:be27ed110b50 179:d8ac696cc51f
     1 #============================================================================ 
       
     2 #Name        : templatebuilder.py 
       
     3 #Part of     : Helium 
       
     4 
       
     5 #Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
       
     6 #All rights reserved.
       
     7 #This component and the accompanying materials are made available
       
     8 #under the terms of the License "Eclipse Public License v1.0"
       
     9 #which accompanies this distribution, and is available
       
    10 #at the URL "http://www.eclipse.org/legal/epl-v10.html".
       
    11 #
       
    12 #Initial Contributors:
       
    13 #Nokia Corporation - initial contribution.
       
    14 #
       
    15 #Contributors:
       
    16 #
       
    17 #Description:
       
    18 #===============================================================================
       
    19 
       
    20 """ The template builder. """
       
    21 import logging
       
    22 
       
    23 # Uncomment this line to enable logging in this module, or configure logging elsewhere
       
    24 #logging.basicConfig(level=logging.INFO)
       
    25 logger = logging.getLogger('integration.templatebuilder')
       
    26 
       
    27 class TemplateBuilder:
       
    28     """ This class implements a template builder.
       
    29     """
       
    30     
       
    31     def __init__(self, config, product):
       
    32         self._config = config
       
    33         self._product = product
       
    34         
       
    35     def build(self):
       
    36         """ Render all the templates for the current product. """
       
    37         for config in self._config.getConfigurations(self._product, 'TemplateBuilder'):
       
    38             self._build_config(config)
       
    39 
       
    40     def __read_template(self, config):
       
    41         """ Read the whole file content.
       
    42         """
       
    43         logger.info("Using template '%s'..." % config['template.file'])
       
    44         ftr = open(config['template.file'], "r")
       
    45         content = ftr.read()
       
    46         ftr.close()
       
    47         return content
       
    48 
       
    49             
       
    50     def _build_config(self, config):
       
    51         """ Open config and render the template. """
       
    52         if config.name != None:
       
    53             logger.info("Building config '%s'..." % config.name)
       
    54         logger.info("Creating file '%s'..." % config['output.file'])
       
    55         output = open(config['output.file'], 'w+')        
       
    56         output.write(config.interpolate(self.__read_template(config)))
       
    57         output.close()
       
    58