mirror of
https://github.com/unknownworlds/NS.git
synced 2024-11-30 00:10:59 +00:00
168 lines
4.3 KiB
Perl
168 lines
4.3 KiB
Perl
|
#
|
||
|
# Updates titles.txt to Steam format. Written by Charlie Cleveland.
|
||
|
#
|
||
|
local ($kVersion, $inputFilename, $modName, $languageName, $numTranslationsFound, $outputFilename, %translationData);
|
||
|
|
||
|
#
|
||
|
# Constants
|
||
|
#
|
||
|
$kVersion = "v1.0";
|
||
|
$inputFilename = "";
|
||
|
$modName = "";
|
||
|
$languageName = "";
|
||
|
$numTranslationsFound = 0;
|
||
|
$outputFilename = "";
|
||
|
|
||
|
sub Main;
|
||
|
Main();
|
||
|
|
||
|
sub Main
|
||
|
{
|
||
|
print "\nRunning SteamifyTitles $kVersion by Charlie Cleveland (flayra\@overmind.org)\n\n";
|
||
|
|
||
|
# Read mod name, input filename and language name
|
||
|
$numArgs = $#ARGV + 1;
|
||
|
|
||
|
if($numArgs < 3)
|
||
|
{
|
||
|
print "Usage: <input titles.txt> <mod name> <language name> <optional \"y\" if you want to convert input titles.txt>";
|
||
|
print "Run from within your mod directory.\n"
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
# Parse arguments
|
||
|
$inputFilename = $ARGV[0];
|
||
|
$modName = $ARGV[1];
|
||
|
$languageName = $ARGV[2];
|
||
|
$convertTitles = 0;
|
||
|
|
||
|
if($numArgs > 3)
|
||
|
{
|
||
|
if($ARGV[3] == "y")
|
||
|
{
|
||
|
$convertTitles = 1;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
#print "\nReading $inputFilename, for mod $modName, in language $languageName...\n";
|
||
|
|
||
|
# Read in file name specified on command line
|
||
|
print "Reading old titles from $inputFilename.\n";
|
||
|
open(INFILE, $inputFilename) or die "Couldn't open $inputFilename for reading.\n";
|
||
|
|
||
|
# Read all data into one string
|
||
|
local $/;
|
||
|
my $theData = <INFILE>;
|
||
|
#print $theData;
|
||
|
|
||
|
#while( $theData =~ m/ (\w+) \s* \{(.*?)\} /sgx)
|
||
|
while( $theData =~ m/ (\w+) \s* \{(.*?)\} /sgx)
|
||
|
{
|
||
|
my $theKey = $1;
|
||
|
my $theUntrimmedValue = $2;
|
||
|
if($theUntrimmedValue =~ s/(.*?)\n+/ /g)
|
||
|
{
|
||
|
my $theTrimmedData = $1;
|
||
|
|
||
|
# Skip comments?
|
||
|
#if(index($theKey, "//") != -1)
|
||
|
#{
|
||
|
# print "Skipping line: \"$theKey\" = \"$theTrimmedData\"\n";
|
||
|
#}
|
||
|
#else
|
||
|
#{
|
||
|
#print "Found pair: \"$theKey\" = \"$theTrimmedData\"\n";
|
||
|
|
||
|
$translationData{$theKey} = $theTrimmedData;
|
||
|
$numTranslationsFound++;
|
||
|
#}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
close(INFILE);
|
||
|
|
||
|
print "Found $numTranslationsFound translations.\n";
|
||
|
|
||
|
if($numTranslationsFound > 0)
|
||
|
{
|
||
|
# Open file for writing as resource/modname_language.txt
|
||
|
$outputFilename = lc("resource/$modName") . "_" . lc($languageName) . ".txt";
|
||
|
print "Writing $outputFilename.\n";
|
||
|
|
||
|
open(OUTFILE, ">$outputFilename") or die "Couldn't open file $outputFilename for writing.\n";
|
||
|
|
||
|
my $kLineDelimiter = "\n";
|
||
|
my $kLineSpaceDelimiter = " \n";
|
||
|
my $kPairSeparator = "\t\t\t";
|
||
|
|
||
|
# Write "lang" tag
|
||
|
print OUTFILE "\"lang\"$kLineSpaceDelimiter";
|
||
|
|
||
|
my $caseProperLanguage = lc($languageName);
|
||
|
$caseProperLanguage = ucfirst($caseProperLanguage);
|
||
|
|
||
|
# Write "Language" tag
|
||
|
print OUTFILE "{$kLineSpaceDelimiter";
|
||
|
print OUTFILE "\"Language\"$kPairSeparator\"$caseProperLanguage\"$kLineSpaceDelimiter";
|
||
|
|
||
|
# Write "Tokens" tag
|
||
|
print OUTFILE "\"Tokens\"$kLineSpaceDelimiter\{$kLineSpaceDelimiter";
|
||
|
|
||
|
# For each translation pair
|
||
|
my $key;
|
||
|
my $value;
|
||
|
|
||
|
# sort( keys( %hash ))
|
||
|
#while(($key, $value) = each %translationData)
|
||
|
foreach my $key ( sort(keys(%translationData)))
|
||
|
{
|
||
|
my $value = $translationData{$key};
|
||
|
|
||
|
# Substitute any " for ', or HL stops reading the translation file
|
||
|
$value =~ s/\"/\'/g;
|
||
|
|
||
|
if(length($value) == 0)
|
||
|
{
|
||
|
print (" Skipping empty entry for \"$key\"\n");
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
my $theOutputString = "\"$key\"$kPairSeparator\"$value\"$kLineDelimiter";
|
||
|
#print $theOutputString;
|
||
|
print OUTFILE $theOutputString;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
# Write ending braces
|
||
|
print OUTFILE "}$kLineSpaceDelimiter";
|
||
|
print OUTFILE "}$kLineSpaceDelimiter";
|
||
|
print OUTFILE "$kLineDelimiter$kLineDelimiter$kLineDelimiter";
|
||
|
|
||
|
# close output file
|
||
|
#print("Closing $outputFilename...");
|
||
|
|
||
|
close(OUTFILE);
|
||
|
|
||
|
# if we're writing new titles.txt
|
||
|
if($convertTitles == 1)
|
||
|
{
|
||
|
my $newTitlesName = "titles.txt";
|
||
|
print("Writing $newTitlesName in VGUI2 format...");
|
||
|
open(TITLESFILE, ">$newTitlesName") or die "Couldn't open $newTitlesName for writing.\n";
|
||
|
|
||
|
foreach my $key ( sort(keys(%translationData)))
|
||
|
{
|
||
|
print TITLESFILE "$key\n";
|
||
|
print TITLESFILE "\{\n\#$key\n\}\n\n";
|
||
|
}
|
||
|
print "done.\n";
|
||
|
|
||
|
close(TITLESFILE);
|
||
|
}
|
||
|
|
||
|
print "Done. Don't forget to save \"$outputFilename\" as Unicode using Notepad before using.\n";
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|