hedgewars/uLocale.pas
author unc0rr
Thu, 11 Jan 2007 20:45:59 +0000
changeset 316 57d50189ad86
parent 302 7aca131ecd7f
child 351 29bc9c36ad5f
permissions -rw-r--r--
Calculate land digest
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,
302
7aca131ecd7f First implementation of Blow Torch
unc0rr
parents: 285
diff changeset
    24
                   sidParachute, sidAirAttack, sidMineStrike, sidBlowTorch);
285
cdab49768c83 Mine Strike weapon
unc0rr
parents: 281
diff changeset
    25
281
5b483aa9f2ab Pause support (mouse cursor is released when the game is paused)
unc0rr
parents: 263
diff changeset
    26
     TMsgStrId = (sidStartFight, sidDraw, sidWinner, sidVolume, sidPaused);
285
cdab49768c83 Mine Strike weapon
unc0rr
parents: 281
diff changeset
    27
184
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    28
var trammo: array[TAmmoStrId] of string;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    29
    trmsg: array[TMsgStrId] of string;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    30
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    31
procedure LoadLocale(FileName: string);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    32
function Format(fmt: shortstring; var arg: shortstring): shortstring;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    33
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    34
implementation
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    35
uses uMisc;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    36
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    37
procedure LoadLocale(FileName: string);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    38
var s: shortstring;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    39
    f: textfile;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    40
    a, b, c: integer;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    41
begin
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    42
{$I-}
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    43
AssignFile(f, FileName);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    44
reset(f);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    45
TryDo(IOResult = 0, 'Cannot load locale "' + FileName + '"', true);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    46
while not eof(f) do
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    47
      begin
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    48
      readln(f, s);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    49
      if Length(s) = 0 then continue;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    50
      if s[1] = ';' then continue;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    51
      TryDo(Length(s) > 6, 'Load locale: empty string', true);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    52
      val(s[1]+s[2], a, c);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    53
      TryDo(c = 0, 'Load locale: numbers should be two-digit', true);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    54
      TryDo(s[3] = ':', 'Load locale: ":" expected', true);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    55
      val(s[4]+s[5], b, c);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    56
      TryDo(c = 0, 'Load locale: numbers should be two-digit', true);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    57
      TryDo(s[6] = '=', 'Load locale: "=" expected', true);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    58
      Delete(s, 1, 6);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    59
      case a of
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    60
           0: if (b >=0) and (b <= ord(High(TAmmoStrId))) then trammo[TAmmoStrId(b)]:= s;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    61
           1: if (b >=0) and (b <= ord(High(TMsgStrId))) then trmsg[TMsgStrId(b)]:= s;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    62
           end;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    63
      end;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    64
closefile(f)
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    65
{$I+}
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    66
end;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    67
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    68
function Format(fmt: shortstring; var arg: shortstring): shortstring;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    69
var i: integer;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    70
begin
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    71
i:= Pos('%1', fmt);
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    72
if i = 0 then Result:= fmt
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    73
         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
    74
end;
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    75
f97a7a3dc8f6 - Update more headers
unc0rr
parents: 183
diff changeset
    76
end.