hedgewars/uLocale.pas
author displacer
Sat, 25 Nov 2006 17:08:39 +0000
changeset 277 04a613bab65c
parent 263 36379e6abcdd
child 281 5b483aa9f2ab
permissions -rw-r--r--
rollback to main.cpp.in
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
184
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
     1
(*
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
     2
 * Hedgewars, a worms-like game
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
     3
 * Copyright (c) 2006 Andrey Korotaev <unC0Rr@gmail.com>
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
     4
 *
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
     5
 * This program is free software; you can redistribute it and/or modify
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
     6
 * it under the terms of the GNU General Public License as published by
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
     7
 * the Free Software Foundation; version 2 of the License
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
     8
 *
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
     9
 * This program is distributed in the hope that it will be useful,
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    10
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    11
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    12
 * GNU General Public License for more details.
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    13
 *
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    14
 * You should have received a copy of the GNU General Public License
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    15
 * along with this program; if not, write to the Free Software
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    16
 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    17
 *)
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    18
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    19
unit uLocale;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    20
interface
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    21
type TAmmoStrId = (sidGrenade, sidClusterBomb, sidBazooka, sidUFO, sidShotgun,
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    22
                   sidPickHammer, sidSkip, sidRope, sidMine, sidDEagle,
211
558476056205 Parachute
unc0rr
parents: 184
diff changeset
    23
                   sidDynamite, sidBaseballBat, sidFirePunch, sidSeconds,
263
36379e6abcdd - Health tags over drowned hedgehogs
unc0rr
parents: 211
diff changeset
    24
                   sidParachute, sidAirAttack);
184
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    25
     TMsgStrId = (sidStartFight, sidDraw, sidWinner, sidVolume);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    26
var trammo: array[TAmmoStrId] of string;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    27
    trmsg: array[TMsgStrId] of string;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    28
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    29
procedure LoadLocale(FileName: string);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    30
function Format(fmt: shortstring; var arg: shortstring): shortstring;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    31
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    32
implementation
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    33
uses uMisc;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    34
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    35
procedure LoadLocale(FileName: string);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    36
var s: shortstring;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    37
    f: textfile;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    38
    a, b, c: integer;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    39
begin
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    40
{$I-}
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    41
AssignFile(f, FileName);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    42
reset(f);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    43
TryDo(IOResult = 0, 'Cannot load locale "' + FileName + '"', true);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    44
while not eof(f) do
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    45
      begin
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    46
      readln(f, s);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    47
      if Length(s) = 0 then continue;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    48
      if s[1] = ';' then continue;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    49
      TryDo(Length(s) > 6, 'Load locale: empty string', true);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    50
      val(s[1]+s[2], a, c);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    51
      TryDo(c = 0, 'Load locale: numbers should be two-digit', true);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    52
      TryDo(s[3] = ':', 'Load locale: ":" expected', true);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    53
      val(s[4]+s[5], b, c);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    54
      TryDo(c = 0, 'Load locale: numbers should be two-digit', true);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    55
      TryDo(s[6] = '=', 'Load locale: "=" expected', true);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    56
      Delete(s, 1, 6);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    57
      case a of
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    58
           0: if (b >=0) and (b <= ord(High(TAmmoStrId))) then trammo[TAmmoStrId(b)]:= s;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    59
           1: if (b >=0) and (b <= ord(High(TMsgStrId))) then trmsg[TMsgStrId(b)]:= s;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    60
           end;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    61
      end;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    62
closefile(f)
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    63
{$I+}
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    64
end;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    65
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    66
function Format(fmt: shortstring; var arg: shortstring): shortstring;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    67
var i: integer;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    68
begin
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    69
i:= Pos('%1', fmt);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    70
if i = 0 then Result:= fmt
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    71
         else Result:= copy(fmt, 1, i - 1) + arg + Format(copy(fmt, i + 2, Length(fmt) - i - 1), arg)
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    72
end;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    73
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    74
end.