brandingserver/tools/xml/loc2xml.pl
author hgs
Wed, 03 Nov 2010 09:32:20 +0530
changeset 51 61fad867f68e
child 21 5872ac9a5671
permissions -rw-r--r--
201041
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
51
hgs
parents:
diff changeset
     1
#
hgs
parents:
diff changeset
     2
# Copyright (c) 2006-2006 Nokia Corporation and/or its subsidiary(-ies).
hgs
parents:
diff changeset
     3
# All rights reserved.
hgs
parents:
diff changeset
     4
# This component and the accompanying materials are made available
hgs
parents:
diff changeset
     5
# under the terms of "Eclipse Public License v1.0"
hgs
parents:
diff changeset
     6
# which accompanies this distribution, and is available
hgs
parents:
diff changeset
     7
# at the URL "http://www.eclipse.org/legal/epl-v10.html".
hgs
parents:
diff changeset
     8
#
hgs
parents:
diff changeset
     9
# Initial Contributors:
hgs
parents:
diff changeset
    10
# Nokia Corporation - initial contribution.
hgs
parents:
diff changeset
    11
#
hgs
parents:
diff changeset
    12
# Contributors:
hgs
parents:
diff changeset
    13
#
hgs
parents:
diff changeset
    14
# Description:  Converts loc file into branding xml file
hgs
parents:
diff changeset
    15
#
hgs
parents:
diff changeset
    16
hgs
parents:
diff changeset
    17
#------------------------------------------------------------------------------
hgs
parents:
diff changeset
    18
# Trim string
hgs
parents:
diff changeset
    19
#------------------------------------------------------------------------------
hgs
parents:
diff changeset
    20
#
hgs
parents:
diff changeset
    21
sub trim($)
hgs
parents:
diff changeset
    22
{
hgs
parents:
diff changeset
    23
	my $string = shift;
hgs
parents:
diff changeset
    24
	$string =~ s/^[ ]+//;
hgs
parents:
diff changeset
    25
	$string =~ s/[ ]+$//;
hgs
parents:
diff changeset
    26
	return $string;
hgs
parents:
diff changeset
    27
}
hgs
parents:
diff changeset
    28
hgs
parents:
diff changeset
    29
hgs
parents:
diff changeset
    30
#------------------------------------------------------------------------------
hgs
parents:
diff changeset
    31
# Prints usage information
hgs
parents:
diff changeset
    32
#------------------------------------------------------------------------------
hgs
parents:
diff changeset
    33
#
hgs
parents:
diff changeset
    34
sub UsageInformation
hgs
parents:
diff changeset
    35
{
hgs
parents:
diff changeset
    36
    print <<EOF;
hgs
parents:
diff changeset
    37
LOC2XML.PL
hgs
parents:
diff changeset
    38
converts loc file into branding xml file. XML file is overwritten!
hgs
parents:
diff changeset
    39
hgs
parents:
diff changeset
    40
Usage:
hgs
parents:
diff changeset
    41
loc2xml.pl [in file:loc] [out file:xml] [brand_id] [application_id]
hgs
parents:
diff changeset
    42
           [language id] [version]
hgs
parents:
diff changeset
    43
EOF
hgs
parents:
diff changeset
    44
hgs
parents:
diff changeset
    45
    exit;
hgs
parents:
diff changeset
    46
}
hgs
parents:
diff changeset
    47
hgs
parents:
diff changeset
    48
#------------------------------------------------------------------------------
hgs
parents:
diff changeset
    49
# Reads LOC file and constructs associative array
hgs
parents:
diff changeset
    50
#------------------------------------------------------------------------------
hgs
parents:
diff changeset
    51
#
hgs
parents:
diff changeset
    52
sub ReadLocFile
hgs
parents:
diff changeset
    53
{
hgs
parents:
diff changeset
    54
# Parse LOC file
hgs
parents:
diff changeset
    55
my $infile = shift;
hgs
parents:
diff changeset
    56
open(INPUT, $infile) || die "Can't open file: '$infile'";   # Open the file
hgs
parents:
diff changeset
    57
my %array = ();
hgs
parents:
diff changeset
    58
hgs
parents:
diff changeset
    59
while( <INPUT> )
hgs
parents:
diff changeset
    60
    {
hgs
parents:
diff changeset
    61
    $_ = trim( $_ );
hgs
parents:
diff changeset
    62
    if( /^\#define\s+qtn.+\s+\".+\"/i )
hgs
parents:
diff changeset
    63
        {
hgs
parents:
diff changeset
    64
        # find ID
hgs
parents:
diff changeset
    65
        /(qtn[\w\d_]+)/i;
hgs
parents:
diff changeset
    66
        $id = $1;
hgs
parents:
diff changeset
    67
        $id =~ s/_//g;      # remove all '_' chars
hgs
parents:
diff changeset
    68
hgs
parents:
diff changeset
    69
        #find value
hgs
parents:
diff changeset
    70
        /\"(.+)\"/i;
hgs
parents:
diff changeset
    71
        $value = $1;
hgs
parents:
diff changeset
    72
hgs
parents:
diff changeset
    73
        $array{$id} = $value;
hgs
parents:
diff changeset
    74
#        print "$id \t: \'$value\'\n\r"
hgs
parents:
diff changeset
    75
        }
hgs
parents:
diff changeset
    76
    }
hgs
parents:
diff changeset
    77
close(INPUT);			    # Close the file
hgs
parents:
diff changeset
    78
hgs
parents:
diff changeset
    79
return %array;
hgs
parents:
diff changeset
    80
}
hgs
parents:
diff changeset
    81
hgs
parents:
diff changeset
    82
#------------------------------------------------------------------------------
hgs
parents:
diff changeset
    83
# Write XML file from given array
hgs
parents:
diff changeset
    84
#------------------------------------------------------------------------------
hgs
parents:
diff changeset
    85
#
hgs
parents:
diff changeset
    86
sub WriteXmlFile
hgs
parents:
diff changeset
    87
{
hgs
parents:
diff changeset
    88
my %strings = @_;
hgs
parents:
diff changeset
    89
open( OUTPUT, ">$ARGV[1]" ) || die "Can't open file: '$ARGV[1]'";
hgs
parents:
diff changeset
    90
hgs
parents:
diff changeset
    91
hgs
parents:
diff changeset
    92
print OUTPUT <<EOF;
hgs
parents:
diff changeset
    93
<?xml version="1.0" encoding="ISO-8859-1"?>
hgs
parents:
diff changeset
    94
<branding>
hgs
parents:
diff changeset
    95
    <brand>
hgs
parents:
diff changeset
    96
        <application_id>$ARGV[3]</application_id>
hgs
parents:
diff changeset
    97
        <brand_id>$ARGV[2]</brand_id>
hgs
parents:
diff changeset
    98
        <brand_language_id>$ARGV[4]</brand_language_id>
hgs
parents:
diff changeset
    99
        <brand_version>$ARGV[5]</brand_version>
hgs
parents:
diff changeset
   100
hgs
parents:
diff changeset
   101
EOF
hgs
parents:
diff changeset
   102
hgs
parents:
diff changeset
   103
while( ($key, $value) = each(%strings) )
hgs
parents:
diff changeset
   104
    {
hgs
parents:
diff changeset
   105
    print OUTPUT <<EOF;
hgs
parents:
diff changeset
   106
        <element id="$key" type="text">
hgs
parents:
diff changeset
   107
         <element_value>$value</element_value>
hgs
parents:
diff changeset
   108
        </element>
hgs
parents:
diff changeset
   109
hgs
parents:
diff changeset
   110
EOF
hgs
parents:
diff changeset
   111
    }
hgs
parents:
diff changeset
   112
hgs
parents:
diff changeset
   113
print OUTPUT "    </brand>\n";
hgs
parents:
diff changeset
   114
print OUTPUT "</branding>\n";
hgs
parents:
diff changeset
   115
hgs
parents:
diff changeset
   116
close( OUTPUT );
hgs
parents:
diff changeset
   117
}
hgs
parents:
diff changeset
   118
hgs
parents:
diff changeset
   119
#------------------------------------------------------------------------------
hgs
parents:
diff changeset
   120
# Main function
hgs
parents:
diff changeset
   121
#------------------------------------------------------------------------------
hgs
parents:
diff changeset
   122
#
hgs
parents:
diff changeset
   123
hgs
parents:
diff changeset
   124
# Check parameters
hgs
parents:
diff changeset
   125
my $count = @ARGV;
hgs
parents:
diff changeset
   126
if( $count != 6 )
hgs
parents:
diff changeset
   127
    {
hgs
parents:
diff changeset
   128
    UsageInformation();
hgs
parents:
diff changeset
   129
    }
hgs
parents:
diff changeset
   130
hgs
parents:
diff changeset
   131
# Parse LOC file
hgs
parents:
diff changeset
   132
my %strings = &ReadLocFile( $ARGV[0] );
hgs
parents:
diff changeset
   133
hgs
parents:
diff changeset
   134
# Write XML file
hgs
parents:
diff changeset
   135
WriteXmlFile( %strings );
hgs
parents:
diff changeset
   136
hgs
parents:
diff changeset
   137
# Done!
hgs
parents:
diff changeset
   138
my @list = %strings;
hgs
parents:
diff changeset
   139
$count = @list / 2;
hgs
parents:
diff changeset
   140
print "Processed succesfully $count strings."
hgs
parents:
diff changeset
   141
hgs
parents:
diff changeset
   142
# end of file