1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90
|
#!/usr/bin/perl
# Copyright (C) 2000-2018 The Xastir Group
#
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License
# as published by the Free Software Foundation; either version 2
# of the License, or (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
# 02111-1307, USA.
#
# Look at the README for more information on the program.
# Run it like this:
#
# cd xastir/config
# ../scripts/langElmerFudd.pl -split <language-English.sys >language-ElmerFudd.sys
# or
# ../scripts/langElmerFudd.pl <some-input-file >some-output-file
#
# "-split": Translate 2nd part of line only (Xastir language file).
# Without it: Translate entire text.
# Regex strings derived from:
# http://www.faqs.org/docs/diveintopython/dialect_divein.html
# http://www.siafoo.net/snippet/133
# http://dougal.gunters.org/blog/2004/08/30/text-filter-suite
# Check whether we're translating an Xastir language file or plain
# text:
# "-split" present: Translate the 2nd piece of each line.
# "-split" absent: Translate the entire text.
my $a;
if ($#ARGV < 0) { $a = ""; }
else { $a = shift; }
$do_split = 0;
if (length($a) > 0 && $a =~ m/-split/) {
$do_split = 1;
}
# Add these two l ines to show that we translated the file.
print "# language-ElmerFudd.sys, translated from language-English.sys\n";
print "# Please do not edit this derived file.\n";
while ( <> ) {
# Skip other comment lines
if (m/^#/) {
next;
}
if ($do_split) {
# Split each incoming line by the '|' character
@pieces = split /\|/;
# Translate the second portion of each line only
$_ = $pieces[1];
}
s/[rl]/w/g;
s/[RL]/W/g;
s/([Qq])u/$1w/g;
s/th(\b)/f/g;
s/TH(\b)/F/g;
s/th/d/g;
s/Th/D/g;
s/([Nn])[.]/$1, uh-hah-hah-hah./g;
if ($do_split) {
# Combine the line again for output to STDOUT
$pieces[1] = $_;
print join '|', @pieces;
}
else {
print;
}
}
|