configurationengine/source/plugins/symbian/ConeCRMLPlugin/CRMLPlugin/tests/centrepconv_txt_to_cre.py
author terytkon
Thu, 11 Mar 2010 17:04:37 +0200
changeset 0 2e8eeb919028
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
#   Helper script for running CentRepConv.exe to convert .txt files to
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    16
#   .cre files. The script is given a drive where an S60 environment is
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    17
#   substed and it handles all necessary input/output file moving and
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    18
#   command running to do the conversion.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    19
#   
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    20
#   The .txt files for which the conversion fails are reported at the end
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    21
#   of the conversion.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    22
#
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    23
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    24
import sys, os, subprocess, shutil, re
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    25
import logging
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    26
from optparse import OptionParser, OptionGroup
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    27
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    28
log = logging.getLogger()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    29
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    30
# Paths to the temporary directories on the environment level
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    31
TEMP_INPUT_DIR = r'\epoc32\WINSCW\C\cenrepconv_temp\input'
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    32
TEMP_OUTPUT_DIR = r'\epoc32\WINSCW\C\cenrepconv_temp\output'
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    33
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    34
# The same temporary directories in the form the emulator sees them
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    35
TEMP_INPUT_DIR_EMULATOR = r'C:\cenrepconv_temp\input'
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    36
TEMP_OUTPUT_DIR_EMULATOR = r'C:\cenrepconv_temp\output'
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    37
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    38
def recreate_dir(dir):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    39
    if os.path.exists(dir):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    40
        shutil.rmtree(dir)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    41
    os.makedirs(dir)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    42
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    43
def find_cenrep_txt_files(dir):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    44
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    45
    Find all CenRep txt files in the given directory.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    46
    @return: List of absolute paths to the files.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    47
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    48
    pattern = re.compile(r'^[a-fA-F0-9]{8}\.txt$')
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    49
    dir = os.path.abspath(dir)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    50
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    51
    result = []
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    52
    for root, dirs, files in os.walk(dir):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    53
        for file in files:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    54
            if pattern.match(file) is not None:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    55
                result.append(os.path.join(root, file))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    56
    return result
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    57
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    58
def convert_txt_to_cre(file_path, output_dir):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    59
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    60
    Convert a CenRep .txt file into a .cre file using CentRepConv.exe.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    61
    @param file_path: Path to the .txt file.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    62
    @param output_dir: Directory where the resulting .cre file will be copied.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    63
        If None, the output file will not be copied anywhere.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    64
    @return: True if conversion was OK and the corresponding .cre file was
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    65
        created, False if not.
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    66
    """
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    67
    output_dir = os.path.abspath(output_dir)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    68
    file_path = os.path.abspath(file_path)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    69
    filename = os.path.basename(file_path)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    70
    filename_out = filename[:-4] + '.cre'
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    71
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    72
    # Copy the input file into place
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    73
    temp_input_file = os.path.join(TEMP_INPUT_DIR, filename)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    74
    shutil.copy2(file_path, temp_input_file)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    75
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    76
    # Run the conversion
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    77
    cmd = r'\epoc32\release\WINSCW\udeb\centrepconv.exe -dNoGui -dtextshell -Mconsole -- -o %s %s' \
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    78
        % (os.path.join(TEMP_OUTPUT_DIR_EMULATOR, filename_out), os.path.join(TEMP_INPUT_DIR_EMULATOR, filename))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    79
    p = subprocess.Popen(cmd, stdout=subprocess.PIPE, stderr=subprocess.STDOUT, shell=True)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    80
    out, err = p.communicate()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    81
    if p.returncode != 0:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    82
        log.debug("Failed to execute command: %s" % cmd)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    83
        log.debug("Command output:\n%s", out)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    84
        return False
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    85
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    86
    temp_output_file = os.path.join(TEMP_OUTPUT_DIR, filename_out)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    87
    if not os.path.exists(temp_output_file):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    88
        log.debug("Expected output file '%s' does not exist" % temp_output_file)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    89
        return False
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    90
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    91
    # Copy to output if necessary
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    92
    if output_dir:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    93
        if not os.path.exists(output_dir):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    94
            os.makedirs(output_dir)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    95
        output_file = os.path.join(output_dir, os.path.basename(temp_output_file))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    96
        log.debug("Copying output file to '%s'" % output_file)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    97
        shutil.copy2(temp_output_file, output_file)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    98
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
    99
    log.debug("Removing temp output file '%s'" % temp_output_file)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   100
    os.remove(temp_output_file)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   101
    return True
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   102
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   103
def main():
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   104
    parser = OptionParser()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   105
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   106
    parser.add_option("--env-drive",
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   107
                      help="Specifies the drive where the S60 environment containing CentRepConv.exe is located. Note that the drive needs to be writable, since input/output files need to be moved there in order to make the conversion work. Example: 'X:'",
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   108
                      metavar="DRIVE")
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   109
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   110
    parser.add_option("--input-file",
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   111
                      help="Specifies a single CenRep .txt file to convert.",
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   112
                      metavar="FILE")
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   113
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   114
    parser.add_option("--input-dir",
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   115
                      help="Specifies a directory containing the CenRep .txt files to convert. Only CenRep .txt files converted.",
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   116
                      metavar="FILE")
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   117
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   118
    parser.add_option("--output",
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   119
                      help="The directory where the resulting .cre files are generated",
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   120
                      metavar="DIR")
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   121
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   122
    parser.add_option("--validate",
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   123
                      action="store_true",
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   124
                      help="Don't copy output files to --output, only check if a .cre file is generated for each .txt file.",
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   125
                      default=False)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   126
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   127
    parser.add_option("-v", "--verbose",
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   128
                      action="store_true",
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   129
                      help="Show debug information",
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   130
                      default=False)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   131
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   132
    (options, args) = parser.parse_args()
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   133
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   134
    if not options.env_drive:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   135
        parser.error("--env-drive must be specified")
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   136
    if re.match('^[A-Za-z]:$', options.env_drive) is None:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   137
        parser.error("Invalid --env-drive '%s', should be e.g. 'X:'" % options.env_drive)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   138
    if not os.path.exists(options.env_drive):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   139
        parser.error("Specified --env-drive '%s' does not exist" % options.env_drive)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   140
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   141
    if not options.input_file and not options.input_dir:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   142
        parser.error("--input-file or --input-dir must be specified")
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   143
    if options.input_file and options.input_dir:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   144
        parser.error("Only one for --input-file and --input-dir may be specified")
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   145
    if options.input_file and not os.path.isfile(options.input_file):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   146
        parser.error("Specified --input-file does not exist or is not a file")
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   147
    if options.input_dir and not os.path.isdir(options.input_dir):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   148
        parser.error("Specified --input-dir does not exist or is not a directory")
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   149
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   150
    if not options.output and not options.validate:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   151
        parser.error("Either --output or --validate must be specified")
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   152
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   153
    if options.verbose: log_level = logging.DEBUG
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   154
    else:               log_level = logging.INFO
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   155
    logging.basicConfig(format="%(levelname)-8s: %(message)s", stream=sys.stdout, level=log_level)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   156
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   157
    if options.output:  output_dir = os.path.abspath(options.output)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   158
    else:               output_dir = None
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   159
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   160
    # Find input files
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   161
    log.info("Determining input files")
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   162
    if options.input_file:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   163
        input_files = [os.path.abspath(options.input_file)]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   164
    else:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   165
        input_files = find_cenrep_txt_files(options.input_dir)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   166
    log.info("%d input file(s)" % len(input_files))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   167
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   168
    if len(input_files) == 0:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   169
        log.info("No input files")
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   170
        return
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   171
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   172
    log.debug("Changing working directory to '%s'" % options.env_drive)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   173
    os.chdir(options.env_drive)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   174
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   175
    log.debug("Creating/cleaning temporary output directory '%s'" % TEMP_OUTPUT_DIR)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   176
    recreate_dir(TEMP_OUTPUT_DIR)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   177
    log.debug("Creating/cleaning temporary input directory '%s'" % TEMP_INPUT_DIR)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   178
    recreate_dir(TEMP_INPUT_DIR)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   179
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   180
    log.info("Running conversion")
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   181
    failed_files = []
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   182
    PROGRESS_STEP_PERCENTAGE = 5.0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   183
    ratio = 100.0 / float(len(input_files))
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   184
    last_percentage = 0
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   185
    for i, file in enumerate(input_files):
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   186
        percentage = ratio * float(i)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   187
        if percentage - last_percentage > PROGRESS_STEP_PERCENTAGE:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   188
            log.info("%d%%" % percentage)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   189
            last_percentage = percentage
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   190
        
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   191
        log.debug("Converting '%s'" % file)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   192
        ok = convert_txt_to_cre(file, output_dir)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   193
        if not ok:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   194
            log.debug("Conversion of '%s' failed" % file)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   195
            failed_files.append(file)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   196
    
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   197
    if failed_files:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   198
        print "Conversion failed for %d file(s)" % len(failed_files)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   199
        prefix = os.path.commonprefix(failed_files)
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   200
        print "Common prefix: %s" % prefix
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   201
        for file in failed_files:
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   202
            print file[len(prefix):]
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   203
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   204
if __name__ == "__main__":
2e8eeb919028 Adding EPL version of configurationengine.
terytkon
parents:
diff changeset
   205
    main()