hedgewars/hwengine.pas
author spudpiggy <facetakers@gmail.com>
Fri, 05 Apr 2024 13:10:55 +0100
changeset 16006 1f9f971adec4
parent 15949 668c88b31dd6
permissions -rw-r--r--
sndCover now falls back to sndWatchThis OR sndFire. sndDrat and sndBugger now fall back to each other.
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
2947
803b277e4894 hate Smaxx (tested)
unc0rr
parents: 2905
diff changeset
     1
(*
6952
7f70f37bbf08 license header year range adjustments
sheepluva
parents: 6917
diff changeset
     2
 * Hedgewars, a free turn based strategy game
11046
47a8c19ecb60 more copyright fixes
sheepluva
parents: 11025
diff changeset
     3
 * Copyright (c) 2004-2015 Andrey Korotaev <unC0Rr@gmail.com>
6952
7f70f37bbf08 license header year range adjustments
sheepluva
parents: 6917
diff changeset
     4
 *
7f70f37bbf08 license header year range adjustments
sheepluva
parents: 6917
diff changeset
     5
 * This program is free software; you can redistribute it and/or modify
7f70f37bbf08 license header year range adjustments
sheepluva
parents: 6917
diff changeset
     6
 * it under the terms of the GNU General Public License as published by
7f70f37bbf08 license header year range adjustments
sheepluva
parents: 6917
diff changeset
     7
 * the Free Software Foundation; version 2 of the License
7f70f37bbf08 license header year range adjustments
sheepluva
parents: 6917
diff changeset
     8
 *
7f70f37bbf08 license header year range adjustments
sheepluva
parents: 6917
diff changeset
     9
 * This program is distributed in the hope that it will be useful,
7f70f37bbf08 license header year range adjustments
sheepluva
parents: 6917
diff changeset
    10
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
7f70f37bbf08 license header year range adjustments
sheepluva
parents: 6917
diff changeset
    11
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
7f70f37bbf08 license header year range adjustments
sheepluva
parents: 6917
diff changeset
    12
 * GNU General Public License for more details.
7f70f37bbf08 license header year range adjustments
sheepluva
parents: 6917
diff changeset
    13
 *
7f70f37bbf08 license header year range adjustments
sheepluva
parents: 6917
diff changeset
    14
 * You should have received a copy of the GNU General Public License
7f70f37bbf08 license header year range adjustments
sheepluva
parents: 6917
diff changeset
    15
 * along with this program; if not, write to the Free Software
10108
c68cf030eded update FSF address. note: two sdl include files (by Sam Lantinga) still have the old FSF address in their copyright - but I ain't gonna touch their copyright headers
sheepluva
parents: 10015
diff changeset
    16
 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
6952
7f70f37bbf08 license header year range adjustments
sheepluva
parents: 6917
diff changeset
    17
 *)
51
b6e3ae05857f - Get rid of hwserv and runhelper
unc0rr
parents:
diff changeset
    18
2599
c7153d2348f3 move compiler directives to standard pascal
koda
parents: 2591
diff changeset
    19
{$INCLUDE "options.inc"}
2587
0dfa56a8513c fix a segfault in the iphone simulator by moving options.inc at the beginning of the file
koda
parents: 2586
diff changeset
    20
14199
3c36a4e66c82 make engine windows checks work for 64bit builds
alfadur
parents: 13820
diff changeset
    21
{$IFDEF WINDOWS}
15949
668c88b31dd6 workaround for FPC 3.2.2 linking bug
alfadur <mail@none>
parents: 15299
diff changeset
    22
{$IFNDEF SKIP_RESOURCES}
8340
46a9fde631f4 install shaders only when needed, find clang only when needed, fix building on windows, better cmake boolean vars
koda
parents: 8330
diff changeset
    23
{$R res/hwengine.rc}
2800
f286d91157b8 Engine:
smxx
parents: 2799
diff changeset
    24
{$ENDIF}
15949
668c88b31dd6 workaround for FPC 3.2.2 linking bug
alfadur <mail@none>
parents: 15299
diff changeset
    25
{$ENDIF}
2800
f286d91157b8 Engine:
smxx
parents: 2799
diff changeset
    26
2803
1f446fc5c8ec allow to compile engine as library with HWLIBRARY symbol
koda
parents: 2800
diff changeset
    27
{$IFDEF HWLIBRARY}
2698
90585aba87ad objc/pascal finally working
koda
parents: 2697
diff changeset
    28
unit hwengine;
90585aba87ad objc/pascal finally working
koda
parents: 2697
diff changeset
    29
interface
90585aba87ad objc/pascal finally working
koda
parents: 2697
diff changeset
    30
{$ELSE}
51
b6e3ae05857f - Get rid of hwserv and runhelper
unc0rr
parents:
diff changeset
    31
program hwengine;
2698
90585aba87ad objc/pascal finally working
koda
parents: 2697
diff changeset
    32
{$ENDIF}
3407
dcc129c4352e Engine:
smxx
parents: 3387
diff changeset
    33
11150
877de65e0e13 - ifdef for CMEM
antonc27 <antonc27@mail.ru>
parents: 11149
diff changeset
    34
uses {$IFDEF IPHONEOS}cmem, {$ENDIF} SDLh, uMisc, uConsole, uGame, uConsts, uLand, uAmmos, uVisualGears, uGears, uStore, uWorld, uInputHandler
7959
644b757d20e6 Start work on physfs support in engine
unc0rr
parents: 7929
diff changeset
    35
     , uSound, uScript, uTeams, uStats, uIO, uLocale, uChat, uAI, uAIMisc, uAILandMarks, uLandTexture, uCollisions
644b757d20e6 Start work on physfs support in engine
unc0rr
parents: 7929
diff changeset
    36
     , SysUtils, uTypes, uVariables, uCommands, uUtils, uCaptions, uDebug, uCommandHandlers, uLandPainted
10304
7e40820b7ed6 fix gl2 build, further rendering cleanup WIP, also new chat command: /debugvl
sheepluva
parents: 10302
diff changeset
    37
     , uPhysFSLayer, uCursor, uRandom, ArgParsers, uVisualGearsHandlers, uTextures, uRender
7447
01111960a48d uploading to youtube, it works, but user interface is still incomplete
Stepan777 <stepik-777@mail.ru>
parents: 7442
diff changeset
    38
     {$IFDEF USE_VIDEO_RECORDING}, uVideoRec {$ENDIF}
7837
3e031b3b33e6 minor macro cleanup
koda
parents: 7615
diff changeset
    39
     {$IFDEF USE_TOUCH_INTERFACE}, uTouch {$ENDIF}
3e031b3b33e6 minor macro cleanup
koda
parents: 7615
diff changeset
    40
     {$IFDEF ANDROID}, GLUnit{$ENDIF}
14599
b86e6e4f3c58 Make game engine load the user's locale correctly (bug 688)
Wuzzy <Wuzzy2@mail.ru>
parents: 14598
diff changeset
    41
     {$IFDEF UNIX}, clocale{$ENDIF}
14199
3c36a4e66c82 make engine windows checks work for 64bit builds
alfadur
parents: 13820
diff changeset
    42
     {$IFDEF WINDOWS}, dynlibs{$ENDIF}
7837
3e031b3b33e6 minor macro cleanup
koda
parents: 7615
diff changeset
    43
     ;
3697
d5b30d6373fc remove trailing spaces from end of line
koda
parents: 3693
diff changeset
    44
2803
1f446fc5c8ec allow to compile engine as library with HWLIBRARY symbol
koda
parents: 2800
diff changeset
    45
{$IFDEF HWLIBRARY}
11685
a2e86a867fb5 pas2c converts exit to return, so change RunEngine signature
frd
parents: 11644
diff changeset
    46
function RunEngine(argc: LongInt; argv: PPChar): LongInt; cdecl; export;
10175
c92668840ea8 Remove game/preview functions split in library mode, just let normal procedure run instead:
unc0rr
parents: 10162
diff changeset
    47
7896
67217e6108fd another stake at variable pre-initialisation - we lost preview logging in the course
koda
parents: 7850
diff changeset
    48
procedure preInitEverything();
3525
1d7b056ff866 some memory caring code
koda
parents: 3523
diff changeset
    49
procedure initEverything(complete:boolean);
1d7b056ff866 some memory caring code
koda
parents: 3523
diff changeset
    50
procedure freeEverything(complete:boolean);
13820
cf7626f46bb2 IFNDEF custom exception handlung away in pas2c builds
Wuzzy <Wuzzy2@mail.ru>
parents: 13586
diff changeset
    51
{$IFNDEF PAS2C}
13488
dbf4f7a677be When hwengine crashes w/ error 217, write backtrace in log, too
Wuzzy <Wuzzy2@mail.ru>
parents: 13487
diff changeset
    52
procedure catchUnhandledException(Obj: TObject; Addr: Pointer; FrameCount: Longint; Frames: PPointer);
13820
cf7626f46bb2 IFNDEF custom exception handlung away in pas2c builds
Wuzzy <Wuzzy2@mail.ru>
parents: 13586
diff changeset
    53
{$ENDIF}
51
b6e3ae05857f - Get rid of hwserv and runhelper
unc0rr
parents:
diff changeset
    54
2698
90585aba87ad objc/pascal finally working
koda
parents: 2697
diff changeset
    55
implementation
90585aba87ad objc/pascal finally working
koda
parents: 2697
diff changeset
    56
{$ELSE}
7896
67217e6108fd another stake at variable pre-initialisation - we lost preview logging in the course
koda
parents: 7850
diff changeset
    57
procedure preInitEverything(); forward;
3611
ed00aa2b339e interpret parameters before initializing everything
koda
parents: 3610
diff changeset
    58
procedure initEverything(complete:boolean); forward;
3525
1d7b056ff866 some memory caring code
koda
parents: 3523
diff changeset
    59
procedure freeEverything(complete:boolean); forward;
13820
cf7626f46bb2 IFNDEF custom exception handlung away in pas2c builds
Wuzzy <Wuzzy2@mail.ru>
parents: 13586
diff changeset
    60
{$IFNDEF PAS2C}
13488
dbf4f7a677be When hwengine crashes w/ error 217, write backtrace in log, too
Wuzzy <Wuzzy2@mail.ru>
parents: 13487
diff changeset
    61
procedure catchUnhandledException(Obj: TObject; Addr: Pointer; FrameCount: Longint; Frames: PPointer); forward;
2698
90585aba87ad objc/pascal finally working
koda
parents: 2697
diff changeset
    62
{$ENDIF}
13820
cf7626f46bb2 IFNDEF custom exception handlung away in pas2c builds
Wuzzy <Wuzzy2@mail.ru>
parents: 13586
diff changeset
    63
{$ENDIF}
51
b6e3ae05857f - Get rid of hwserv and runhelper
unc0rr
parents:
diff changeset
    64
14199
3c36a4e66c82 make engine windows checks work for 64bit builds
alfadur
parents: 13820
diff changeset
    65
{$IFDEF WINDOWS}
12657
2065819170ce (Hopefully) fix game camera being shifted on Windows 10
alfadur
parents: 12621
diff changeset
    66
type TSetProcessDpiAwareness = function(value: Integer): Integer; stdcall;
2065819170ce (Hopefully) fix game camera being shifted on Windows 10
alfadur
parents: 12621
diff changeset
    67
var SetProcessDpiAwareness: TSetProcessDpiAwareness;
2065819170ce (Hopefully) fix game camera being shifted on Windows 10
alfadur
parents: 12621
diff changeset
    68
var ShcoreLibHandle: TLibHandle;
2065819170ce (Hopefully) fix game camera being shifted on Windows 10
alfadur
parents: 12621
diff changeset
    69
{$ENDIF}
2065819170ce (Hopefully) fix game camera being shifted on Windows 10
alfadur
parents: 12621
diff changeset
    70
7896
67217e6108fd another stake at variable pre-initialisation - we lost preview logging in the course
koda
parents: 7850
diff changeset
    71
///////////////////////////////////////////////////////////////////////////////
7025
831a25c74c7b revisit isTerminated in hwengine
koda
parents: 7021
diff changeset
    72
function DoTimer(Lag: LongInt): boolean;
2905
f3c79f7193a9 Engine:
smxx
parents: 2825
diff changeset
    73
var s: shortstring;
10580
17560eb73b4c Reset max team health after script may have screwed with it on start. Maybe a script max health reset function could be useful too. Set climbhome hogs to invulnerable while not their turn if needed to avoid accidental mine/dead hog damage. Tweak cake fire boom a bit.
nemo
parents: 10445
diff changeset
    74
    t: LongWord;
51
b6e3ae05857f - Get rid of hwserv and runhelper
unc0rr
parents:
diff changeset
    75
begin
7025
831a25c74c7b revisit isTerminated in hwengine
koda
parents: 7021
diff changeset
    76
    DoTimer:= false;
6734
9709d15dabfa Revert most of 033e4a8a9c74 and 9d501dc22f71 (see bug #362)
nemo
parents: 6700
diff changeset
    77
    inc(RealTicks, Lag);
564
17fb45c670c1 Finalize basic playlists implementation
unc0rr
parents: 529
diff changeset
    78
2947
803b277e4894 hate Smaxx (tested)
unc0rr
parents: 2905
diff changeset
    79
    case GameState of
6580
6155187bf599 A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents: 6415
diff changeset
    80
        gsLandGen:
6155187bf599 A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents: 6415
diff changeset
    81
            begin
6155187bf599 A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents: 6415
diff changeset
    82
            GenMap;
7850
fcbb024090a4 cleanup in initEverything and freeEverything
koda
parents: 7848
diff changeset
    83
            SetLandTexture;
fcbb024090a4 cleanup in initEverything and freeEverything
koda
parents: 7848
diff changeset
    84
            UpdateLandTexture(0, LAND_WIDTH, 0, LAND_HEIGHT, false);
fcbb024090a4 cleanup in initEverything and freeEverything
koda
parents: 7848
diff changeset
    85
            setAILandMarks;
6580
6155187bf599 A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents: 6415
diff changeset
    86
            GameState:= gsStart;
6155187bf599 A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents: 6415
diff changeset
    87
            end;
6155187bf599 A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents: 6415
diff changeset
    88
        gsStart:
6155187bf599 A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents: 6415
diff changeset
    89
            begin
9464
901e363d5837 Finish rework of default binds system. Default binds now work even before first turn.
unc0rr
parents: 9379
diff changeset
    90
            SetDefaultBinds;
6580
6155187bf599 A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents: 6415
diff changeset
    91
            if HasBorder then
6155187bf599 A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents: 6415
diff changeset
    92
                DisableSomeWeapons;
10445
dac3bfb3a2b1 cosmetic disabling of clouds with sea edges and underwater theme
nemo
parents: 10306
diff changeset
    93
            // wave "clouds" on underwater theme look weird w/ weSea, esp the blended bottom portion
dac3bfb3a2b1 cosmetic disabling of clouds with sea edges and underwater theme
nemo
parents: 10306
diff changeset
    94
            if (WorldEdge <> weSea) or (Theme <> 'Underwater') then
dac3bfb3a2b1 cosmetic disabling of clouds with sea edges and underwater theme
nemo
parents: 10306
diff changeset
    95
                AddClouds;
6580
6155187bf599 A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents: 6415
diff changeset
    96
            AddFlakes;
8912
78ea1839aac9 Implement issue 308 with '|' as separator
unc0rr
parents: 8838
diff changeset
    97
            SetRandomSeed(cSeed, false);
11477
e425a6eb9da3 Force locations for hogs if even TryHard fails on initial spawn.
nemo
parents: 11365
diff changeset
    98
            StoreLoad(false);
12711
20dbb3a03e61 extend land digest to all surfaces that could possibly be loaded into Land[] - i.e. ones that impact sync
nemo
parents: 12657
diff changeset
    99
            ParseCommand('sendlanddigest', true); // extending land digest to all synced pixels (anything that could modify land)
11534
0ead3a2e0309 Fix a crasher
unc0rr
parents: 11532
diff changeset
   100
            if not allOK then exit;
6580
6155187bf599 A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents: 6415
diff changeset
   101
            AssignHHCoords;
6155187bf599 A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents: 6415
diff changeset
   102
            AddMiscGears;
6155187bf599 A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents: 6415
diff changeset
   103
            InitWorld;
6155187bf599 A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents: 6415
diff changeset
   104
            ResetKbd;
6155187bf599 A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents: 6415
diff changeset
   105
            if GameType = gmtSave then
7021
0c75512a8920 adjust the scope of a few uSound variables and functions
koda
parents: 6986
diff changeset
   106
                SetSound(false);
6580
6155187bf599 A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents: 6415
diff changeset
   107
            FinishProgress;
6155187bf599 A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents: 6415
diff changeset
   108
            PlayMusic;
10302
ea0b0e2efd95 huh? me? nono, don't mind me. I'm just here to clean up.
sheepluva
parents: 10273
diff changeset
   109
            InitZoom(zoom);
6580
6155187bf599 A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents: 6415
diff changeset
   110
            ScriptCall('onGameStart');
14765
ba8dd081359d Fix map preview not matching actual map
Wuzzy <Wuzzy2@mail.ru>
parents: 14628
diff changeset
   111
            RandomizeHHAnim;
10580
17560eb73b4c Reset max team health after script may have screwed with it on start. Maybe a script max health reset function could be useful too. Set climbhome hogs to invulnerable while not their turn if needed to avoid accidental mine/dead hog damage. Tweak cake fire boom a bit.
nemo
parents: 10445
diff changeset
   112
            for t:= 0 to Pred(TeamsCount) do
17560eb73b4c Reset max team health after script may have screwed with it on start. Maybe a script max health reset function could be useful too. Set climbhome hogs to invulnerable while not their turn if needed to avoid accidental mine/dead hog damage. Tweak cake fire boom a bit.
nemo
parents: 10445
diff changeset
   113
                with TeamsArray[t]^ do
17560eb73b4c Reset max team health after script may have screwed with it on start. Maybe a script max health reset function could be useful too. Set climbhome hogs to invulnerable while not their turn if needed to avoid accidental mine/dead hog damage. Tweak cake fire boom a bit.
nemo
parents: 10445
diff changeset
   114
                    MaxTeamHealth:= TeamHealth;
10581
f0b4c14a3c62 Wuzzy's changes to climbhome w/ some tweaks by me
nemo
parents: 10580
diff changeset
   115
            RecountAllTeamsHealth;
6580
6155187bf599 A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents: 6415
diff changeset
   116
            GameState:= gsGame;
6155187bf599 A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents: 6415
diff changeset
   117
            end;
13077
c213645ff848 Having chat mode as game state was a mistake
unc0rr
parents: 13040
diff changeset
   118
        gsConfirm, gsGame:
6580
6155187bf599 A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents: 6415
diff changeset
   119
            begin
11497
66f1cff4284b stop screenshot-flash-effects from showing up on consecutive screenshots
sheepluva
parents: 11486
diff changeset
   120
            // disable screenshot flash effect when about to make another screenshot
66f1cff4284b stop screenshot-flash-effects from showing up on consecutive screenshots
sheepluva
parents: 11486
diff changeset
   121
            if flagMakeCapture and (ScreenFade = sfFromWhite) then
66f1cff4284b stop screenshot-flash-effects from showing up on consecutive screenshots
sheepluva
parents: 11486
diff changeset
   122
                ScreenFade:= sfNone;
8096
453917e94e55 updated branch
koda
parents: 8026 8057
diff changeset
   123
            if not cOnlyStats then
453917e94e55 updated branch
koda
parents: 8026 8057
diff changeset
   124
                // never place between ProcessKbd and DoGameTick - bugs due to /put cmd and isCursorVisible
453917e94e55 updated branch
koda
parents: 8026 8057
diff changeset
   125
                DrawWorld(Lag);
6734
9709d15dabfa Revert most of 033e4a8a9c74 and 9d501dc22f71 (see bug #362)
nemo
parents: 6700
diff changeset
   126
            DoGameTick(Lag);
8027
e5ba3dd12531 make stats-only mode work headless. also skip a few things to save time/memory.
nemo
parents: 7984
diff changeset
   127
            if not cOnlyStats then ProcessVisualGears(Lag);
6580
6155187bf599 A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents: 6415
diff changeset
   128
            end;
6155187bf599 A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents: 6415
diff changeset
   129
        gsExit:
6155187bf599 A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents: 6415
diff changeset
   130
            begin
7025
831a25c74c7b revisit isTerminated in hwengine
koda
parents: 7021
diff changeset
   131
            DoTimer:= true;
6580
6155187bf599 A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents: 6415
diff changeset
   132
            end;
6155187bf599 A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents: 6415
diff changeset
   133
        gsSuspend:
7054
7e8fb07ef91c Function to compare string to char ftw
unc0rr
parents: 7051
diff changeset
   134
            exit(false);
6580
6155187bf599 A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents: 6415
diff changeset
   135
            end;
564
17fb45c670c1 Finalize basic playlists implementation
unc0rr
parents: 529
diff changeset
   136
8039
a3b86c1f63b4 another tweak tomake --stats-only work on headless servers
Xeli
parents: 8027
diff changeset
   137
    if not cOnlyStats then SwapBuffers;
4454
42bfc1a70968 more retina support and multitasking support
koda
parents: 4437
diff changeset
   138
7198
5debd5fe526e 1. Add IFDEFs for video recording
Stepan777 <stepik-777@mail.ru>
parents: 7180
diff changeset
   139
{$IFDEF USE_VIDEO_RECORDING}
7180
53ffc8853008 here it is
Stepan777 <stepik-777@mail.ru>
parents: 7151
diff changeset
   140
    if flagPrerecording then
53ffc8853008 here it is
Stepan777 <stepik-777@mail.ru>
parents: 7151
diff changeset
   141
        SaveCameraPosition;
7198
5debd5fe526e 1. Add IFDEFs for video recording
Stepan777 <stepik-777@mail.ru>
parents: 7180
diff changeset
   142
{$ENDIF}
7180
53ffc8853008 here it is
Stepan777 <stepik-777@mail.ru>
parents: 7151
diff changeset
   143
2947
803b277e4894 hate Smaxx (tested)
unc0rr
parents: 2905
diff changeset
   144
    if flagMakeCapture then
6580
6155187bf599 A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents: 6415
diff changeset
   145
        begin
2947
803b277e4894 hate Smaxx (tested)
unc0rr
parents: 2905
diff changeset
   146
        flagMakeCapture:= false;
10633
2f062fac5791 Add that "make screenshots of Land/LandPixels" thing for map creators
nemo
parents: 10622
diff changeset
   147
        if flagDumpLand then
2f062fac5791 Add that "make screenshots of Land/LandPixels" thing for map creators
nemo
parents: 10622
diff changeset
   148
             s:= '/Screenshots/mapdump_'
2f062fac5791 Add that "make screenshots of Land/LandPixels" thing for map creators
nemo
parents: 10622
diff changeset
   149
        else s:= '/Screenshots/hw_';
14422
e8723f97324c Backed out changeset 1ffa8bfc5c58
nemo
parents: 14420
diff changeset
   150
        {$IFDEF PAS2C}
10633
2f062fac5791 Add that "make screenshots of Land/LandPixels" thing for map creators
nemo
parents: 10622
diff changeset
   151
        s:= s + inttostr(GameTicks);
14422
e8723f97324c Backed out changeset 1ffa8bfc5c58
nemo
parents: 14420
diff changeset
   152
        {$ELSE}
10633
2f062fac5791 Add that "make screenshots of Land/LandPixels" thing for map creators
nemo
parents: 10622
diff changeset
   153
        s:= s + FormatDateTime('YYYY-MM-DD_HH-mm-ss', Now()) + inttostr(GameTicks);
14422
e8723f97324c Backed out changeset 1ffa8bfc5c58
nemo
parents: 14420
diff changeset
   154
        {$ENDIF}
5912
d31eba29e706 screenshots: display a msg on failure and log causative error
sheepluva
parents: 5825
diff changeset
   155
7306
3cff5c769509 Here they come - thumbnails.
Stepan777 <stepik-777@mail.ru>
parents: 7286
diff changeset
   156
        // flash
4359
83ef50815535 Move variables from uMisc to uVariables
unC0Rr
parents: 4357
diff changeset
   157
        playSound(sndShutter);
7306
3cff5c769509 Here they come - thumbnails.
Stepan777 <stepik-777@mail.ru>
parents: 7286
diff changeset
   158
        ScreenFade:= sfFromWhite;
3cff5c769509 Here they come - thumbnails.
Stepan777 <stepik-777@mail.ru>
parents: 7286
diff changeset
   159
        ScreenFadeValue:= sfMax;
3cff5c769509 Here they come - thumbnails.
Stepan777 <stepik-777@mail.ru>
parents: 7286
diff changeset
   160
        ScreenFadeSpeed:= 5;
11532
bf86c6cb9341 Bye-bye TryDo
unc0rr
parents: 11507
diff changeset
   161
11025
999afa63035f just disable landpixels w/ blurry land instead. the mask can be helpful for debugging at least.
nemo
parents: 10836
diff changeset
   162
        if (not flagDumpLand and MakeScreenshot(s, 1, 0)) or
999afa63035f just disable landpixels w/ blurry land instead. the mask can be helpful for debugging at least.
nemo
parents: 10836
diff changeset
   163
           (flagDumpLand and MakeScreenshot(s, 1, 1) and ((cReducedQuality and rqBlurryLand <> 0) or MakeScreenshot(s, 1, 2))) then
6580
6155187bf599 A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents: 6415
diff changeset
   164
            WriteLnToConsole('Screenshot saved: ' + s)
6155187bf599 A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents: 6415
diff changeset
   165
        else
6155187bf599 A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents: 6415
diff changeset
   166
            begin
5912
d31eba29e706 screenshots: display a msg on failure and log causative error
sheepluva
parents: 5825
diff changeset
   167
            WriteLnToConsole('Screenshot failed.');
d31eba29e706 screenshots: display a msg on failure and log causative error
sheepluva
parents: 5825
diff changeset
   168
            AddChatString(#5 + 'screen capture failed (lack of memory or write permissions)');
6267
be5d40bb1e86 make screenshots with 32bits of depths, so that they are more opengles friendly
koda
parents: 6219
diff changeset
   169
            end
6580
6155187bf599 A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents: 6415
diff changeset
   170
        end;
51
b6e3ae05857f - Get rid of hwserv and runhelper
unc0rr
parents:
diff changeset
   171
end;
b6e3ae05857f - Get rid of hwserv and runhelper
unc0rr
parents:
diff changeset
   172
7896
67217e6108fd another stake at variable pre-initialisation - we lost preview logging in the course
koda
parents: 7850
diff changeset
   173
///////////////////////////////////////////////////////////////////////////////
3697
d5b30d6373fc remove trailing spaces from end of line
koda
parents: 3693
diff changeset
   174
procedure MainLoop;
6267
be5d40bb1e86 make screenshots with 32bits of depths, so that they are more opengles friendly
koda
parents: 6219
diff changeset
   175
var event: TSDL_Event;
10015
4feced261c68 partial merge of the webgl branch
koda
parents: 10012 9950
diff changeset
   176
    PrevTime, CurrTime: LongWord;
7025
831a25c74c7b revisit isTerminated in hwengine
koda
parents: 7021
diff changeset
   177
    isTerminated: boolean;
5975
c3a8cab64fcb let's use the built in events, shall we
koda
parents: 5968
diff changeset
   178
    previousGameState: TGameState;
11486
2b30283a402c fix/clean-up mousewheel code
sheepluva
parents: 11477
diff changeset
   179
    wheelEvent: boolean;
2698
90585aba87ad objc/pascal finally working
koda
parents: 2697
diff changeset
   180
begin
12818
d3113a4cba36 initialise previousGameState to something valid and not gsSuspend
nemo
parents: 12801
diff changeset
   181
    previousGameState:= gsStart;
7025
831a25c74c7b revisit isTerminated in hwengine
koda
parents: 7021
diff changeset
   182
    isTerminated:= false;
2947
803b277e4894 hate Smaxx (tested)
unc0rr
parents: 2905
diff changeset
   183
    PrevTime:= SDL_GetTicks;
11532
bf86c6cb9341 Bye-bye TryDo
unc0rr
parents: 11507
diff changeset
   184
    while (not isTerminated) and allOK do
3063
0092dc37fbd6 reworked interaction of engine/frontend when closing
koda
parents: 3058
diff changeset
   185
    begin
11486
2b30283a402c fix/clean-up mousewheel code
sheepluva
parents: 11477
diff changeset
   186
        wheelEvent:= false;
5724
3064ed85a5bd Changed SDL_PollEvent to SDL_PeepEvents
Xeli
parents: 5686
diff changeset
   187
        SDL_PumpEvents();
8924
13ac59499066 update 0.9.19 with dev branch
koda
parents: 8912
diff changeset
   188
11360
7a7611adf715 drop support for SDL 1.2
sheepluva
parents: 9699
diff changeset
   189
        while SDL_PeepEvents(@event, 1, SDL_GETEVENT, SDL_FIRSTEVENT, SDL_LASTEVENT) > 0 do
2947
803b277e4894 hate Smaxx (tested)
unc0rr
parents: 2905
diff changeset
   190
        begin
5339
bc8560452143 Fixed the incomplete merge of rev: 22c1f4833a86
Xeli
parents: 5286
diff changeset
   191
            case event.type_ of
6580
6155187bf599 A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents: 6415
diff changeset
   192
                SDL_KEYDOWN:
13077
c213645ff848 Having chat mode as game state was a mistake
unc0rr
parents: 13040
diff changeset
   193
                    if isInChatMode then
8742
b7b8bd398c1b Key returned 0 for arrows under linux. Sym works, clearer anyway.
nemo
parents: 8615
diff changeset
   194
                        begin
3647
0d0df215fb52 making chat work... (keyboard support is heavily broken in sdl upstream)
koda
parents: 3634
diff changeset
   195
                    // sdl on iphone supports only ashii keyboards and the unicode field is deprecated in sdl 1.3
11365
b8b208501475 reenable cursor movement etc.
sheepluva
parents: 11362
diff changeset
   196
                        KeyPressChat(event.key.keysym);
8742
b7b8bd398c1b Key returned 0 for arrows under linux. Sym works, clearer anyway.
nemo
parents: 8615
diff changeset
   197
                        end
7025
831a25c74c7b revisit isTerminated in hwengine
koda
parents: 7021
diff changeset
   198
                    else
9028
3a38c9453697 Don't accept keyboard/mouse events on startup phase
unc0rr
parents: 8948
diff changeset
   199
                        if GameState >= gsGame then ProcessKey(event.key);
6917
4889c2b779b4 - change uKeys to be event based rather than polling
Xeli
parents: 6863
diff changeset
   200
                SDL_KEYUP:
13077
c213645ff848 Having chat mode as game state was a mistake
unc0rr
parents: 13040
diff changeset
   201
                    if (not isInChatMode) and (GameState >= gsGame) then
7025
831a25c74c7b revisit isTerminated in hwengine
koda
parents: 7021
diff changeset
   202
                        ProcessKey(event.key);
8924
13ac59499066 update 0.9.19 with dev branch
koda
parents: 8912
diff changeset
   203
13077
c213645ff848 Having chat mode as game state was a mistake
unc0rr
parents: 13040
diff changeset
   204
                SDL_TEXTINPUT: if isInChatMode then uChat.TextInput(event.text);
9697
198c3ed28fe8 All I want is to receive some events...
unc0rr
parents: 9694
diff changeset
   205
5339
bc8560452143 Fixed the incomplete merge of rev: 22c1f4833a86
Xeli
parents: 5286
diff changeset
   206
                SDL_WINDOWEVENT:
7025
831a25c74c7b revisit isTerminated in hwengine
koda
parents: 7021
diff changeset
   207
                    begin
11501
2d72489cc5b6 finish SDL2-window focus change detection code
sheepluva
parents: 11497
diff changeset
   208
                    case event.window.event of
2d72489cc5b6 finish SDL2-window focus change detection code
sheepluva
parents: 11497
diff changeset
   209
                        SDL_WINDOWEVENT_FOCUS_GAINED:
2d72489cc5b6 finish SDL2-window focus change detection code
sheepluva
parents: 11497
diff changeset
   210
                                begin
2d72489cc5b6 finish SDL2-window focus change detection code
sheepluva
parents: 11497
diff changeset
   211
                                cHasFocus:= true;
2d72489cc5b6 finish SDL2-window focus change detection code
sheepluva
parents: 11497
diff changeset
   212
                                onFocusStateChanged();
2d72489cc5b6 finish SDL2-window focus change detection code
sheepluva
parents: 11497
diff changeset
   213
                                end;
2d72489cc5b6 finish SDL2-window focus change detection code
sheepluva
parents: 11497
diff changeset
   214
                        SDL_WINDOWEVENT_FOCUS_LOST:
2d72489cc5b6 finish SDL2-window focus change detection code
sheepluva
parents: 11497
diff changeset
   215
                                begin
2d72489cc5b6 finish SDL2-window focus change detection code
sheepluva
parents: 11497
diff changeset
   216
                                cHasFocus:= false;
2d72489cc5b6 finish SDL2-window focus change detection code
sheepluva
parents: 11497
diff changeset
   217
                                onFocusStateChanged();
2d72489cc5b6 finish SDL2-window focus change detection code
sheepluva
parents: 11497
diff changeset
   218
                                end;
12801
8a359cc248d1 Fix Hedgewars going into suspension mode (game freezes) when windows got minimized
Wuzzy <Wuzzy2@mail.ru>
parents: 12793
diff changeset
   219
{$IFDEF MOBILE}
8a359cc248d1 Fix Hedgewars going into suspension mode (game freezes) when windows got minimized
Wuzzy <Wuzzy2@mail.ru>
parents: 12793
diff changeset
   220
(* Suspend game if minimized on mobile.
8a359cc248d1 Fix Hedgewars going into suspension mode (game freezes) when windows got minimized
Wuzzy <Wuzzy2@mail.ru>
parents: 12793
diff changeset
   221
NOTE: Mobile doesn't support online multiplayer yet, so it's not a problem.
8a359cc248d1 Fix Hedgewars going into suspension mode (game freezes) when windows got minimized
Wuzzy <Wuzzy2@mail.ru>
parents: 12793
diff changeset
   222
BUT: This section WILL become a bug when online multiplayer is added to
8a359cc248d1 Fix Hedgewars going into suspension mode (game freezes) when windows got minimized
Wuzzy <Wuzzy2@mail.ru>
parents: 12793
diff changeset
   223
Hedgewars and needs to be rethought. This is because it will cause the
8a359cc248d1 Fix Hedgewars going into suspension mode (game freezes) when windows got minimized
Wuzzy <Wuzzy2@mail.ru>
parents: 12793
diff changeset
   224
game to freeze if one online player minimizes Hedgewars. *)
11501
2d72489cc5b6 finish SDL2-window focus change detection code
sheepluva
parents: 11497
diff changeset
   225
                        SDL_WINDOWEVENT_MINIMIZED:
2d72489cc5b6 finish SDL2-window focus change detection code
sheepluva
parents: 11497
diff changeset
   226
                                begin
2d72489cc5b6 finish SDL2-window focus change detection code
sheepluva
parents: 11497
diff changeset
   227
                                previousGameState:= GameState;
2d72489cc5b6 finish SDL2-window focus change detection code
sheepluva
parents: 11497
diff changeset
   228
                                GameState:= gsSuspend;
2d72489cc5b6 finish SDL2-window focus change detection code
sheepluva
parents: 11497
diff changeset
   229
                                end;
12801
8a359cc248d1 Fix Hedgewars going into suspension mode (game freezes) when windows got minimized
Wuzzy <Wuzzy2@mail.ru>
parents: 12793
diff changeset
   230
{$ENDIF}
11501
2d72489cc5b6 finish SDL2-window focus change detection code
sheepluva
parents: 11497
diff changeset
   231
                        SDL_WINDOWEVENT_RESTORED:
2d72489cc5b6 finish SDL2-window focus change detection code
sheepluva
parents: 11497
diff changeset
   232
                                begin
11853
837f9f1b84a5 fix issue 110
sheepluva
parents: 11835
diff changeset
   233
                                if GameState = gsSuspend then
837f9f1b84a5 fix issue 110
sheepluva
parents: 11835
diff changeset
   234
                                    GameState:= previousGameState;
15299
3bf780084c86 Remember maximized state of game window
Wuzzy <Wuzzy2@mail.ru>
parents: 14896
diff changeset
   235
                                cWindowedMaximized:= false;
6611
d9d00e537010 rotation ftw!!! (engine part)
koda
parents: 6603
diff changeset
   236
{$IFDEF ANDROID}
11501
2d72489cc5b6 finish SDL2-window focus change detection code
sheepluva
parents: 11497
diff changeset
   237
                                //This call is used to reinitialize the glcontext and reload the textures
2d72489cc5b6 finish SDL2-window focus change detection code
sheepluva
parents: 11497
diff changeset
   238
                                ParseCommand('fullscr '+intToStr(LongInt(cFullScreen)), true);
6598
fa518383563b added pause/resume functionality for android, android need the opengl context to be recreated along with textures and whatnot
Xeli
parents: 6580
diff changeset
   239
{$ENDIF}
11501
2d72489cc5b6 finish SDL2-window focus change detection code
sheepluva
parents: 11497
diff changeset
   240
                                end;
15299
3bf780084c86 Remember maximized state of game window
Wuzzy <Wuzzy2@mail.ru>
parents: 14896
diff changeset
   241
                        SDL_WINDOWEVENT_MAXIMIZED:
3bf780084c86 Remember maximized state of game window
Wuzzy <Wuzzy2@mail.ru>
parents: 14896
diff changeset
   242
                                cWindowedMaximized:= true;
11501
2d72489cc5b6 finish SDL2-window focus change detection code
sheepluva
parents: 11497
diff changeset
   243
                        SDL_WINDOWEVENT_RESIZED:
2d72489cc5b6 finish SDL2-window focus change detection code
sheepluva
parents: 11497
diff changeset
   244
                                begin
2d72489cc5b6 finish SDL2-window focus change detection code
sheepluva
parents: 11497
diff changeset
   245
                                cNewScreenWidth:= max(2 * (event.window.data1 div 2), cMinScreenWidth);
2d72489cc5b6 finish SDL2-window focus change detection code
sheepluva
parents: 11497
diff changeset
   246
                                cNewScreenHeight:= max(2 * (event.window.data2 div 2), cMinScreenHeight);
2d72489cc5b6 finish SDL2-window focus change detection code
sheepluva
parents: 11497
diff changeset
   247
                                cScreenResizeDelay:= RealTicks + 500{$IFDEF IPHONEOS}div 2{$ENDIF};
2d72489cc5b6 finish SDL2-window focus change detection code
sheepluva
parents: 11497
diff changeset
   248
                                end;
2d72489cc5b6 finish SDL2-window focus change detection code
sheepluva
parents: 11497
diff changeset
   249
                        end; // case closed
7025
831a25c74c7b revisit isTerminated in hwengine
koda
parents: 7021
diff changeset
   250
                    end;
11501
2d72489cc5b6 finish SDL2-window focus change detection code
sheepluva
parents: 11497
diff changeset
   251
9651
c0a389ccb0c1 correctly use USE_TOUCH_INTERFACE
koda
parents: 9543
diff changeset
   252
{$IFDEF USE_TOUCH_INTERFACE}
6580
6155187bf599 A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents: 6415
diff changeset
   253
                SDL_FINGERMOTION:
9379
1bcfcaf0926e update the touch interface to the new SDL2 API
koda
parents: 9317
diff changeset
   254
                    onTouchMotion(event.tfinger.x, event.tfinger.y, event.tfinger.dx, event.tfinger.dy, event.tfinger.fingerId);
8924
13ac59499066 update 0.9.19 with dev branch
koda
parents: 8912
diff changeset
   255
6580
6155187bf599 A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents: 6415
diff changeset
   256
                SDL_FINGERDOWN:
6155187bf599 A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents: 6415
diff changeset
   257
                    onTouchDown(event.tfinger.x, event.tfinger.y, event.tfinger.fingerId);
8924
13ac59499066 update 0.9.19 with dev branch
koda
parents: 8912
diff changeset
   258
6580
6155187bf599 A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents: 6415
diff changeset
   259
                SDL_FINGERUP:
6155187bf599 A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents: 6415
diff changeset
   260
                    onTouchUp(event.tfinger.x, event.tfinger.y, event.tfinger.fingerId);
11548
45982bda46cc Fix for cursor movement problems on touch devices
Anton Malmygin <antonc27@mail.ru>
parents: 11534
diff changeset
   261
{$ELSE}
14808
9443dc6663ba Refactor mouse movement handling
Wuzzy <Wuzzy2@mail.ru>
parents: 14765
diff changeset
   262
                SDL_MOUSEMOTION:
9443dc6663ba Refactor mouse movement handling
Wuzzy <Wuzzy2@mail.ru>
parents: 14765
diff changeset
   263
                    ProcessMouseMotion(event.motion.xrel, event.motion.yrel);
9443dc6663ba Refactor mouse movement handling
Wuzzy <Wuzzy2@mail.ru>
parents: 14765
diff changeset
   264
11548
45982bda46cc Fix for cursor movement problems on touch devices
Anton Malmygin <antonc27@mail.ru>
parents: 11534
diff changeset
   265
                SDL_MOUSEBUTTONDOWN:
45982bda46cc Fix for cursor movement problems on touch devices
Anton Malmygin <antonc27@mail.ru>
parents: 11534
diff changeset
   266
                    if GameState = gsConfirm then
45982bda46cc Fix for cursor movement problems on touch devices
Anton Malmygin <antonc27@mail.ru>
parents: 11534
diff changeset
   267
                        ParseCommand('quit', true)
45982bda46cc Fix for cursor movement problems on touch devices
Anton Malmygin <antonc27@mail.ru>
parents: 11534
diff changeset
   268
                    else
14808
9443dc6663ba Refactor mouse movement handling
Wuzzy <Wuzzy2@mail.ru>
parents: 14765
diff changeset
   269
                        if (GameState >= gsGame) then ProcessMouseButton(event.button, true);
11548
45982bda46cc Fix for cursor movement problems on touch devices
Anton Malmygin <antonc27@mail.ru>
parents: 11534
diff changeset
   270
45982bda46cc Fix for cursor movement problems on touch devices
Anton Malmygin <antonc27@mail.ru>
parents: 11534
diff changeset
   271
                SDL_MOUSEBUTTONUP:
14808
9443dc6663ba Refactor mouse movement handling
Wuzzy <Wuzzy2@mail.ru>
parents: 14765
diff changeset
   272
                    if (GameState >= gsGame) then ProcessMouseButton(event.button, false);
11548
45982bda46cc Fix for cursor movement problems on touch devices
Anton Malmygin <antonc27@mail.ru>
parents: 11534
diff changeset
   273
45982bda46cc Fix for cursor movement problems on touch devices
Anton Malmygin <antonc27@mail.ru>
parents: 11534
diff changeset
   274
                SDL_MOUSEWHEEL:
45982bda46cc Fix for cursor movement problems on touch devices
Anton Malmygin <antonc27@mail.ru>
parents: 11534
diff changeset
   275
                    begin
45982bda46cc Fix for cursor movement problems on touch devices
Anton Malmygin <antonc27@mail.ru>
parents: 11534
diff changeset
   276
                    wheelEvent:= true;
12621
d972b31f8881 fix some fpc hints
sheepluva
parents: 12456
diff changeset
   277
                    ProcessMouseWheel(event.wheel.y);
11548
45982bda46cc Fix for cursor movement problems on touch devices
Anton Malmygin <antonc27@mail.ru>
parents: 11534
diff changeset
   278
                    end;
9651
c0a389ccb0c1 correctly use USE_TOUCH_INTERFACE
koda
parents: 9543
diff changeset
   279
{$ENDIF}
11548
45982bda46cc Fix for cursor movement problems on touch devices
Anton Malmygin <antonc27@mail.ru>
parents: 11534
diff changeset
   280
6580
6155187bf599 A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents: 6415
diff changeset
   281
                SDL_JOYAXISMOTION:
6155187bf599 A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents: 6415
diff changeset
   282
                    ControllerAxisEvent(event.jaxis.which, event.jaxis.axis, event.jaxis.value);
6155187bf599 A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents: 6415
diff changeset
   283
                SDL_JOYHATMOTION:
6155187bf599 A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents: 6415
diff changeset
   284
                    ControllerHatEvent(event.jhat.which, event.jhat.hat, event.jhat.value);
6155187bf599 A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents: 6415
diff changeset
   285
                SDL_JOYBUTTONDOWN:
6155187bf599 A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents: 6415
diff changeset
   286
                    ControllerButtonEvent(event.jbutton.which, event.jbutton.button, true);
6155187bf599 A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents: 6415
diff changeset
   287
                SDL_JOYBUTTONUP:
6155187bf599 A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents: 6415
diff changeset
   288
                    ControllerButtonEvent(event.jbutton.which, event.jbutton.button, false);
6155187bf599 A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents: 6415
diff changeset
   289
                SDL_QUITEV:
6155187bf599 A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents: 6415
diff changeset
   290
                    isTerminated:= true
7025
831a25c74c7b revisit isTerminated in hwengine
koda
parents: 7021
diff changeset
   291
            end; //end case event.type_ of
831a25c74c7b revisit isTerminated in hwengine
koda
parents: 7021
diff changeset
   292
        end; //end while SDL_PollEvent(@event) <> 0 do
5732
f3f381011728 Add a delay before applying screen resize to cut down on resize events (especially bad on OSes that need texture recreation)
nemo
parents: 5730
diff changeset
   293
11486
2b30283a402c fix/clean-up mousewheel code
sheepluva
parents: 11477
diff changeset
   294
        if (not wheelEvent) then
2b30283a402c fix/clean-up mousewheel code
sheepluva
parents: 11477
diff changeset
   295
            ResetMouseWheel();
2b30283a402c fix/clean-up mousewheel code
sheepluva
parents: 11477
diff changeset
   296
8346
3443e0de2c9d GCI2012: Advanced Keyboard Configuration
dag10
parents: 8327
diff changeset
   297
        if (CursorMovementX <> 0) or (CursorMovementY <> 0) then
14896
63357ed39886 Precise + camera movement keys = move camera at slower
Wuzzy <Wuzzy2@mail.ru>
parents: 14860
diff changeset
   298
            handlePositionUpdate(CursorMovementX, CursorMovementY);
8346
3443e0de2c9d GCI2012: Advanced Keyboard Configuration
dag10
parents: 8327
diff changeset
   299
7025
831a25c74c7b revisit isTerminated in hwengine
koda
parents: 7021
diff changeset
   300
        if (cScreenResizeDelay <> 0) and (cScreenResizeDelay < RealTicks) and
831a25c74c7b revisit isTerminated in hwengine
koda
parents: 7021
diff changeset
   301
           ((cNewScreenWidth <> cScreenWidth) or (cNewScreenHeight <> cScreenHeight)) then
831a25c74c7b revisit isTerminated in hwengine
koda
parents: 7021
diff changeset
   302
        begin
831a25c74c7b revisit isTerminated in hwengine
koda
parents: 7021
diff changeset
   303
            cScreenResizeDelay:= 0;
8354
c25bee85d6f8 Separated fullscreen and windowed hwengine resolution parameters.
vitiv <nikita.utiu@gmail.com>
parents: 8350
diff changeset
   304
            cWindowedWidth:= cNewScreenWidth;
c25bee85d6f8 Separated fullscreen and windowed hwengine resolution parameters.
vitiv <nikita.utiu@gmail.com>
parents: 8350
diff changeset
   305
            cWindowedHeight:= cNewScreenHeight;
c25bee85d6f8 Separated fullscreen and windowed hwengine resolution parameters.
vitiv <nikita.utiu@gmail.com>
parents: 8350
diff changeset
   306
            cScreenWidth:= cWindowedWidth;
c25bee85d6f8 Separated fullscreen and windowed hwengine resolution parameters.
vitiv <nikita.utiu@gmail.com>
parents: 8350
diff changeset
   307
            cScreenHeight:= cWindowedHeight;
3463
23c50be687a9 update sdl functions to latest revision
koda
parents: 3449
diff changeset
   308
7025
831a25c74c7b revisit isTerminated in hwengine
koda
parents: 7021
diff changeset
   309
            ParseCommand('fullscr '+intToStr(LongInt(cFullScreen)), true);
15299
3bf780084c86 Remember maximized state of game window
Wuzzy <Wuzzy2@mail.ru>
parents: 14896
diff changeset
   310
            if cWindowedMaximized then
3bf780084c86 Remember maximized state of game window
Wuzzy <Wuzzy2@mail.ru>
parents: 14896
diff changeset
   311
                WriteLnToConsole('window resize: ' + IntToStr(cScreenWidth) + ' x ' + IntToStr(cScreenHeight) + ' (maximized)')
3bf780084c86 Remember maximized state of game window
Wuzzy <Wuzzy2@mail.ru>
parents: 14896
diff changeset
   312
            else
3bf780084c86 Remember maximized state of game window
Wuzzy <Wuzzy2@mail.ru>
parents: 14896
diff changeset
   313
                WriteLnToConsole('window resize: ' + IntToStr(cScreenWidth) + ' x ' + IntToStr(cScreenHeight));
7025
831a25c74c7b revisit isTerminated in hwengine
koda
parents: 7021
diff changeset
   314
            ScriptOnScreenResize();
831a25c74c7b revisit isTerminated in hwengine
koda
parents: 7021
diff changeset
   315
            InitCameraBorders();
831a25c74c7b revisit isTerminated in hwengine
koda
parents: 7021
diff changeset
   316
            InitTouchInterface();
10302
ea0b0e2efd95 huh? me? nono, don't mind me. I'm just here to clean up.
sheepluva
parents: 10273
diff changeset
   317
            InitZoom(zoomValue);
15299
3bf780084c86 Remember maximized state of game window
Wuzzy <Wuzzy2@mail.ru>
parents: 14896
diff changeset
   318
            if cWindowedMaximized then
3bf780084c86 Remember maximized state of game window
Wuzzy <Wuzzy2@mail.ru>
parents: 14896
diff changeset
   319
                SendIPC('W' + IntToStr(cScreenWidth) + 'x' + IntToStr(cScreenHeight) + 'M')
3bf780084c86 Remember maximized state of game window
Wuzzy <Wuzzy2@mail.ru>
parents: 14896
diff changeset
   320
            else
3bf780084c86 Remember maximized state of game window
Wuzzy <Wuzzy2@mail.ru>
parents: 14896
diff changeset
   321
                SendIPC('W' + IntToStr(cScreenWidth) + 'x' + IntToStr(cScreenHeight));
7025
831a25c74c7b revisit isTerminated in hwengine
koda
parents: 7021
diff changeset
   322
        end;
831a25c74c7b revisit isTerminated in hwengine
koda
parents: 7021
diff changeset
   323
831a25c74c7b revisit isTerminated in hwengine
koda
parents: 7021
diff changeset
   324
        CurrTime:= SDL_GetTicks();
6863
4d1ce4b4f7c6 formatting
koda
parents: 6734
diff changeset
   325
        if PrevTime + longword(cTimerInterval) <= CurrTime then
4d1ce4b4f7c6 formatting
koda
parents: 6734
diff changeset
   326
        begin
8026
4a4f21070479 merge xymeng's gsoc engine with a few updates (and further checks on symbol definitions)
koda
parents: 8018
diff changeset
   327
            isTerminated:= isTerminated or DoTimer(CurrTime - PrevTime);
4a4f21070479 merge xymeng's gsoc engine with a few updates (and further checks on symbol definitions)
koda
parents: 8018
diff changeset
   328
            PrevTime:= CurrTime;
6863
4d1ce4b4f7c6 formatting
koda
parents: 6734
diff changeset
   329
        end
4d1ce4b4f7c6 formatting
koda
parents: 6734
diff changeset
   330
        else SDL_Delay(1);
4d1ce4b4f7c6 formatting
koda
parents: 6734
diff changeset
   331
        IPCCheckSock();
8026
4a4f21070479 merge xymeng's gsoc engine with a few updates (and further checks on symbol definitions)
koda
parents: 8018
diff changeset
   332
3063
0092dc37fbd6 reworked interaction of engine/frontend when closing
koda
parents: 3058
diff changeset
   333
    end;
2698
90585aba87ad objc/pascal finally working
koda
parents: 2697
diff changeset
   334
end;
90585aba87ad objc/pascal finally working
koda
parents: 2697
diff changeset
   335
7198
5debd5fe526e 1. Add IFDEFs for video recording
Stepan777 <stepik-777@mail.ru>
parents: 7180
diff changeset
   336
{$IFDEF USE_VIDEO_RECORDING}
7180
53ffc8853008 here it is
Stepan777 <stepik-777@mail.ru>
parents: 7151
diff changeset
   337
procedure RecorderMainLoop;
7392
bc3306c59a08 Correctly distinguish between game and real ticks while recording video,
Stepan777 <stepik-777@mail.ru>
parents: 7386
diff changeset
   338
var oldGameTicks, oldRealTicks, newGameTicks, newRealTicks: LongInt;
7180
53ffc8853008 here it is
Stepan777 <stepik-777@mail.ru>
parents: 7151
diff changeset
   339
begin
53ffc8853008 here it is
Stepan777 <stepik-777@mail.ru>
parents: 7151
diff changeset
   340
    if not BeginVideoRecording() then
53ffc8853008 here it is
Stepan777 <stepik-777@mail.ru>
parents: 7151
diff changeset
   341
        exit;
53ffc8853008 here it is
Stepan777 <stepik-777@mail.ru>
parents: 7151
diff changeset
   342
    DoTimer(0); // gsLandGen -> gsStart
53ffc8853008 here it is
Stepan777 <stepik-777@mail.ru>
parents: 7151
diff changeset
   343
    DoTimer(0); // gsStart -> gsGame
53ffc8853008 here it is
Stepan777 <stepik-777@mail.ru>
parents: 7151
diff changeset
   344
14628
a049926fcdd3 Initialize newGameTicks/newRealTicks
Wuzzy <Wuzzy2@mail.ru>
parents: 14599
diff changeset
   345
    newGameTicks:= 0;
a049926fcdd3 Initialize newGameTicks/newRealTicks
Wuzzy <Wuzzy2@mail.ru>
parents: 14599
diff changeset
   346
    newRealTicks:= 0;
a049926fcdd3 Initialize newGameTicks/newRealTicks
Wuzzy <Wuzzy2@mail.ru>
parents: 14599
diff changeset
   347
7392
bc3306c59a08 Correctly distinguish between game and real ticks while recording video,
Stepan777 <stepik-777@mail.ru>
parents: 7386
diff changeset
   348
    if not LoadNextCameraPosition(newRealTicks, newGameTicks) then
bc3306c59a08 Correctly distinguish between game and real ticks while recording video,
Stepan777 <stepik-777@mail.ru>
parents: 7386
diff changeset
   349
        exit;
7180
53ffc8853008 here it is
Stepan777 <stepik-777@mail.ru>
parents: 7151
diff changeset
   350
    fastScrolling:= true;
7392
bc3306c59a08 Correctly distinguish between game and real ticks while recording video,
Stepan777 <stepik-777@mail.ru>
parents: 7386
diff changeset
   351
    DoGameTick(newGameTicks);
7180
53ffc8853008 here it is
Stepan777 <stepik-777@mail.ru>
parents: 7151
diff changeset
   352
    fastScrolling:= false;
7392
bc3306c59a08 Correctly distinguish between game and real ticks while recording video,
Stepan777 <stepik-777@mail.ru>
parents: 7386
diff changeset
   353
    oldRealTicks:= 0;
bc3306c59a08 Correctly distinguish between game and real ticks while recording video,
Stepan777 <stepik-777@mail.ru>
parents: 7386
diff changeset
   354
    oldGameTicks:= newGameTicks;
bc3306c59a08 Correctly distinguish between game and real ticks while recording video,
Stepan777 <stepik-777@mail.ru>
parents: 7386
diff changeset
   355
bc3306c59a08 Correctly distinguish between game and real ticks while recording video,
Stepan777 <stepik-777@mail.ru>
parents: 7386
diff changeset
   356
    while LoadNextCameraPosition(newRealTicks, newGameTicks) do
7180
53ffc8853008 here it is
Stepan777 <stepik-777@mail.ru>
parents: 7151
diff changeset
   357
    begin
7392
bc3306c59a08 Correctly distinguish between game and real ticks while recording video,
Stepan777 <stepik-777@mail.ru>
parents: 7386
diff changeset
   358
        IPCCheckSock();
13040
a87d3119c962 VideoRec: Fix many effects not being recorded
Wuzzy <Wuzzy2@mail.ru>
parents: 12844
diff changeset
   359
        RealTicks:= newRealTicks;
7392
bc3306c59a08 Correctly distinguish between game and real ticks while recording video,
Stepan777 <stepik-777@mail.ru>
parents: 7386
diff changeset
   360
        DoGameTick(newGameTicks - oldGameTicks);
bc3306c59a08 Correctly distinguish between game and real ticks while recording video,
Stepan777 <stepik-777@mail.ru>
parents: 7386
diff changeset
   361
        if GameState = gsExit then
bc3306c59a08 Correctly distinguish between game and real ticks while recording video,
Stepan777 <stepik-777@mail.ru>
parents: 7386
diff changeset
   362
            break;
bc3306c59a08 Correctly distinguish between game and real ticks while recording video,
Stepan777 <stepik-777@mail.ru>
parents: 7386
diff changeset
   363
        ProcessVisualGears(newRealTicks - oldRealTicks);
bc3306c59a08 Correctly distinguish between game and real ticks while recording video,
Stepan777 <stepik-777@mail.ru>
parents: 7386
diff changeset
   364
        DrawWorld(newRealTicks - oldRealTicks);
7180
53ffc8853008 here it is
Stepan777 <stepik-777@mail.ru>
parents: 7151
diff changeset
   365
        EncodeFrame();
7392
bc3306c59a08 Correctly distinguish between game and real ticks while recording video,
Stepan777 <stepik-777@mail.ru>
parents: 7386
diff changeset
   366
        oldRealTicks:= newRealTicks;
bc3306c59a08 Correctly distinguish between game and real ticks while recording video,
Stepan777 <stepik-777@mail.ru>
parents: 7386
diff changeset
   367
        oldGameTicks:= newGameTicks;
7180
53ffc8853008 here it is
Stepan777 <stepik-777@mail.ru>
parents: 7151
diff changeset
   368
    end;
53ffc8853008 here it is
Stepan777 <stepik-777@mail.ru>
parents: 7151
diff changeset
   369
    StopVideoRecording();
53ffc8853008 here it is
Stepan777 <stepik-777@mail.ru>
parents: 7151
diff changeset
   370
end;
7198
5debd5fe526e 1. Add IFDEFs for video recording
Stepan777 <stepik-777@mail.ru>
parents: 7180
diff changeset
   371
{$ENDIF}
7180
53ffc8853008 here it is
Stepan777 <stepik-777@mail.ru>
parents: 7151
diff changeset
   372
7896
67217e6108fd another stake at variable pre-initialisation - we lost preview logging in the course
koda
parents: 7850
diff changeset
   373
///////////////////////////////////////////////////////////////////////////////
11532
bf86c6cb9341 Bye-bye TryDo
unc0rr
parents: 11507
diff changeset
   374
procedure GameRoutine;
8370
0c79946e96f8 Fix tons of warnings
martin_bede
parents: 8354
diff changeset
   375
var s: shortstring;
3611
ed00aa2b339e interpret parameters before initializing everything
koda
parents: 3610
diff changeset
   376
    i: LongInt;
2698
90585aba87ad objc/pascal finally working
koda
parents: 2697
diff changeset
   377
begin
14368
c2a3d15df7d3 Add log note just in case pas2c does anything odd.
nemo
parents: 14199
diff changeset
   378
{$IFDEF PAS2C}
c2a3d15df7d3 Add log note just in case pas2c does anything odd.
nemo
parents: 14199
diff changeset
   379
    AddFileLog('Generated using pas2c');
c2a3d15df7d3 Add log note just in case pas2c does anything odd.
nemo
parents: 14199
diff changeset
   380
{$ENDIF}
8615
a4cb6168016e split version information in engine too
koda
parents: 8437
diff changeset
   381
    WriteLnToConsole('Hedgewars engine ' + cVersionString + '-r' + cRevisionString +
a4cb6168016e split version information in engine too
koda
parents: 8437
diff changeset
   382
                     ' (' + cHashString + ') with protocol #' + inttostr(cNetProtoVersion));
10127
7f29a65aa1e4 It compiles \o/
unc0rr
parents: 10122
diff changeset
   383
    AddFileLog('Prefix: "' + shortstring(PathPrefix) +'"');
7f29a65aa1e4 It compiles \o/
unc0rr
parents: 10122
diff changeset
   384
    AddFileLog('UserPrefix: "' + shortstring(UserPathPrefix) +'"');
8924
13ac59499066 update 0.9.19 with dev branch
koda
parents: 8912
diff changeset
   385
3611
ed00aa2b339e interpret parameters before initializing everything
koda
parents: 3610
diff changeset
   386
    for i:= 0 to ParamCount do
ed00aa2b339e interpret parameters before initializing everything
koda
parents: 3610
diff changeset
   387
        AddFileLog(inttostr(i) + ': ' + ParamStr(i));
2698
90585aba87ad objc/pascal finally working
koda
parents: 2697
diff changeset
   388
2947
803b277e4894 hate Smaxx (tested)
unc0rr
parents: 2905
diff changeset
   389
    WriteToConsole('Init SDL... ');
11507
bd9a2f1b0080 SDLTry doesn't halt engine no more
unc0rr
parents: 11502
diff changeset
   390
    if not cOnlyStats then SDLCheck(SDL_Init(SDL_INIT_VIDEO or SDL_INIT_NOPARACHUTE) >= 0, 'SDL_Init', true);
2947
803b277e4894 hate Smaxx (tested)
unc0rr
parents: 2905
diff changeset
   391
    WriteLnToConsole(msgOK);
11507
bd9a2f1b0080 SDLTry doesn't halt engine no more
unc0rr
parents: 11502
diff changeset
   392
    if not cOnlyStats then
bd9a2f1b0080 SDLTry doesn't halt engine no more
unc0rr
parents: 11502
diff changeset
   393
        begin
bd9a2f1b0080 SDLTry doesn't halt engine no more
unc0rr
parents: 11502
diff changeset
   394
        WriteToConsole('Init SDL_ttf... ');
bd9a2f1b0080 SDLTry doesn't halt engine no more
unc0rr
parents: 11502
diff changeset
   395
        SDLCheck(TTF_Init() <> -1, 'TTF_Init', true);
bd9a2f1b0080 SDLTry doesn't halt engine no more
unc0rr
parents: 11502
diff changeset
   396
        WriteLnToConsole(msgOK);
bd9a2f1b0080 SDLTry doesn't halt engine no more
unc0rr
parents: 11502
diff changeset
   397
        end;
2698
90585aba87ad objc/pascal finally working
koda
parents: 2697
diff changeset
   398
11532
bf86c6cb9341 Bye-bye TryDo
unc0rr
parents: 11507
diff changeset
   399
    if not allOK then exit;
2698
90585aba87ad objc/pascal finally working
koda
parents: 2697
diff changeset
   400
14808
9443dc6663ba Refactor mouse movement handling
Wuzzy <Wuzzy2@mail.ru>
parents: 14765
diff changeset
   401
    SDL_ShowCursor(SDL_DISABLE);
2698
90585aba87ad objc/pascal finally working
koda
parents: 2697
diff changeset
   402
7286
068adc6948e3 remaining IFDEFs
Stepan777 <stepik-777@mail.ru>
parents: 7235
diff changeset
   403
{$IFDEF USE_VIDEO_RECORDING}
7180
53ffc8853008 here it is
Stepan777 <stepik-777@mail.ru>
parents: 7151
diff changeset
   404
    if GameType = gmtRecord then
53ffc8853008 here it is
Stepan777 <stepik-777@mail.ru>
parents: 7151
diff changeset
   405
        InitOffscreenOpenGL()
6580
6155187bf599 A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents: 6415
diff changeset
   406
    else
7286
068adc6948e3 remaining IFDEFs
Stepan777 <stepik-777@mail.ru>
parents: 7235
diff changeset
   407
{$ENDIF}
8924
13ac59499066 update 0.9.19 with dev branch
koda
parents: 8912
diff changeset
   408
        begin
7180
53ffc8853008 here it is
Stepan777 <stepik-777@mail.ru>
parents: 7151
diff changeset
   409
        // show main window
53ffc8853008 here it is
Stepan777 <stepik-777@mail.ru>
parents: 7151
diff changeset
   410
        if cFullScreen then
53ffc8853008 here it is
Stepan777 <stepik-777@mail.ru>
parents: 7151
diff changeset
   411
            ParseCommand('fullscr 1', true)
53ffc8853008 here it is
Stepan777 <stepik-777@mail.ru>
parents: 7151
diff changeset
   412
        else
53ffc8853008 here it is
Stepan777 <stepik-777@mail.ru>
parents: 7151
diff changeset
   413
            ParseCommand('fullscr 0', true);
53ffc8853008 here it is
Stepan777 <stepik-777@mail.ru>
parents: 7151
diff changeset
   414
        end;
2698
90585aba87ad objc/pascal finally working
koda
parents: 2697
diff changeset
   415
9686
352393fc75be Sounds can be heard now
unc0rr
parents: 9684
diff changeset
   416
    ControllerInit(); // has to happen before InitKbdKeyTable to map keys
2947
803b277e4894 hate Smaxx (tested)
unc0rr
parents: 2905
diff changeset
   417
    InitKbdKeyTable();
11532
bf86c6cb9341 Bye-bye TryDo
unc0rr
parents: 11507
diff changeset
   418
    if not allOK then exit;
2698
90585aba87ad objc/pascal finally working
koda
parents: 2697
diff changeset
   419
8025
07862ab415c8 Get rid of Pathz and UserPathz
unc0rr
parents: 8019
diff changeset
   420
    LoadLocale(cPathz[ptLocale] + '/en.txt');  // Do an initial load with english
14598
62dea281e4d5 Refactor hwengine: Rename cLocale to cLanguage
Wuzzy <Wuzzy2@mail.ru>
parents: 14572
diff changeset
   421
    if cLanguageFName <> 'en.txt' then
4046
cfdbddc4b385 making indentation consistent (noticed while debugging)
nemo
parents: 3976
diff changeset
   422
        begin
2719
0efcaa69d30c Tweak load order
nemo
parents: 2717
diff changeset
   423
        // Try two letter locale first before trying specific locale overrides
14598
62dea281e4d5 Refactor hwengine: Rename cLocale to cLanguage
Wuzzy <Wuzzy2@mail.ru>
parents: 14572
diff changeset
   424
        if (Length(cLanguage) > 3) and (Copy(cLanguage, 1, 2) <> 'en') then
5339
bc8560452143 Fixed the incomplete merge of rev: 22c1f4833a86
Xeli
parents: 5286
diff changeset
   425
            begin
14598
62dea281e4d5 Refactor hwengine: Rename cLocale to cLanguage
Wuzzy <Wuzzy2@mail.ru>
parents: 14572
diff changeset
   426
            LoadLocale(cPathz[ptLocale] + '/' + Copy(cLanguage, 1, 2) + '.txt')
5339
bc8560452143 Fixed the incomplete merge of rev: 22c1f4833a86
Xeli
parents: 5286
diff changeset
   427
            end;
14598
62dea281e4d5 Refactor hwengine: Rename cLocale to cLanguage
Wuzzy <Wuzzy2@mail.ru>
parents: 14572
diff changeset
   428
        LoadLocale(cPathz[ptLocale] + '/' + cLanguageFName)
5107
d7fc678d78f4 Allow override of voicepack with a locale voicepack. Untested, but should mean that a Default voice should use the Ukranian version if that is their locale.
nemo
parents: 5066
diff changeset
   429
        end
14598
62dea281e4d5 Refactor hwengine: Rename cLocale to cLanguage
Wuzzy <Wuzzy2@mail.ru>
parents: 14572
diff changeset
   430
    else cLanguage := 'en';
2698
90585aba87ad objc/pascal finally working
koda
parents: 2697
diff changeset
   431
11532
bf86c6cb9341 Bye-bye TryDo
unc0rr
parents: 11507
diff changeset
   432
    if not allOK then exit;
3904
22e4d74240e5 finishing touches to save games handling (help label, dim on overlay, edit text only when table is editable)
koda
parents: 3843
diff changeset
   433
    WriteLnToConsole(msgGettingConfig);
4046
cfdbddc4b385 making indentation consistent (noticed while debugging)
nemo
parents: 3976
diff changeset
   434
12186
322aaad4a93d Load screen: Move “LOADING” from image into text box
Wuzzy <almikes@aol.com>
parents: 11853
diff changeset
   435
    LoadFonts();
322aaad4a93d Load screen: Move “LOADING” from image into text box
Wuzzy <almikes@aol.com>
parents: 11853
diff changeset
   436
    AddProgress();
13586
41e0446fb254 Load default clan colors from settings file
Wuzzy <Wuzzy2@mail.ru>
parents: 13488
diff changeset
   437
    LoadDefaultClanColors(cPathz[ptConfig] + '/settings.ini');
12186
322aaad4a93d Load screen: Move “LOADING” from image into text box
Wuzzy <almikes@aol.com>
parents: 11853
diff changeset
   438
9988
317d46a2afd2 simple mechanism to run lua-based test cases. experimental - I will back it out if it turns out to be nonsense
sheepluva
parents: 9651
diff changeset
   439
    if cTestLua then
4046
cfdbddc4b385 making indentation consistent (noticed while debugging)
nemo
parents: 3976
diff changeset
   440
        begin
9988
317d46a2afd2 simple mechanism to run lua-based test cases. experimental - I will back it out if it turns out to be nonsense
sheepluva
parents: 9651
diff changeset
   441
        ParseCommand('script ' + cScriptName, true);
4046
cfdbddc4b385 making indentation consistent (noticed while debugging)
nemo
parents: 3976
diff changeset
   442
        end
2947
803b277e4894 hate Smaxx (tested)
unc0rr
parents: 2905
diff changeset
   443
    else
9988
317d46a2afd2 simple mechanism to run lua-based test cases. experimental - I will back it out if it turns out to be nonsense
sheepluva
parents: 9651
diff changeset
   444
        begin
317d46a2afd2 simple mechanism to run lua-based test cases. experimental - I will back it out if it turns out to be nonsense
sheepluva
parents: 9651
diff changeset
   445
        if recordFileName = '' then
317d46a2afd2 simple mechanism to run lua-based test cases. experimental - I will back it out if it turns out to be nonsense
sheepluva
parents: 9651
diff changeset
   446
            begin
317d46a2afd2 simple mechanism to run lua-based test cases. experimental - I will back it out if it turns out to be nonsense
sheepluva
parents: 9651
diff changeset
   447
            InitIPC;
317d46a2afd2 simple mechanism to run lua-based test cases. experimental - I will back it out if it turns out to be nonsense
sheepluva
parents: 9651
diff changeset
   448
            SendIPCAndWaitReply(_S'C');        // ask for game config
317d46a2afd2 simple mechanism to run lua-based test cases. experimental - I will back it out if it turns out to be nonsense
sheepluva
parents: 9651
diff changeset
   449
            end
317d46a2afd2 simple mechanism to run lua-based test cases. experimental - I will back it out if it turns out to be nonsense
sheepluva
parents: 9651
diff changeset
   450
        else
317d46a2afd2 simple mechanism to run lua-based test cases. experimental - I will back it out if it turns out to be nonsense
sheepluva
parents: 9651
diff changeset
   451
            LoadRecordFromFile(recordFileName);
317d46a2afd2 simple mechanism to run lua-based test cases. experimental - I will back it out if it turns out to be nonsense
sheepluva
parents: 9651
diff changeset
   452
        end;
2698
90585aba87ad objc/pascal finally working
koda
parents: 2697
diff changeset
   453
11532
bf86c6cb9341 Bye-bye TryDo
unc0rr
parents: 11507
diff changeset
   454
    if not allOK then exit;
bf86c6cb9341 Bye-bye TryDo
unc0rr
parents: 11507
diff changeset
   455
    ScriptOnGameInit;
bf86c6cb9341 Bye-bye TryDo
unc0rr
parents: 11507
diff changeset
   456
    s:= 'eproto ' + inttostr(cNetProtoVersion);
bf86c6cb9341 Bye-bye TryDo
unc0rr
parents: 11507
diff changeset
   457
    SendIPCRaw(@s[0], Length(s) + 1); // send proto version
2947
803b277e4894 hate Smaxx (tested)
unc0rr
parents: 2905
diff changeset
   458
11532
bf86c6cb9341 Bye-bye TryDo
unc0rr
parents: 11507
diff changeset
   459
    InitTeams();
bf86c6cb9341 Bye-bye TryDo
unc0rr
parents: 11507
diff changeset
   460
    AssignStores();
7180
53ffc8853008 here it is
Stepan777 <stepik-777@mail.ru>
parents: 7151
diff changeset
   461
11532
bf86c6cb9341 Bye-bye TryDo
unc0rr
parents: 11507
diff changeset
   462
    if GameType = gmtRecord then
bf86c6cb9341 Bye-bye TryDo
unc0rr
parents: 11507
diff changeset
   463
        SetSound(false);
7180
53ffc8853008 here it is
Stepan777 <stepik-777@mail.ru>
parents: 7151
diff changeset
   464
11532
bf86c6cb9341 Bye-bye TryDo
unc0rr
parents: 11507
diff changeset
   465
    InitSound();
2590
e7e87e3c67db touch control completely revamped
koda
parents: 2587
diff changeset
   466
11532
bf86c6cb9341 Bye-bye TryDo
unc0rr
parents: 11507
diff changeset
   467
    isDeveloperMode:= false;
bf86c6cb9341 Bye-bye TryDo
unc0rr
parents: 11507
diff changeset
   468
    if checkFails(InitStepsFlags = cifAllInited, 'Some parameters not set (flags = ' + inttostr(InitStepsFlags) + ')', true) then exit;
bf86c6cb9341 Bye-bye TryDo
unc0rr
parents: 11507
diff changeset
   469
    if not allOK then exit;
7286
068adc6948e3 remaining IFDEFs
Stepan777 <stepik-777@mail.ru>
parents: 7235
diff changeset
   470
11532
bf86c6cb9341 Bye-bye TryDo
unc0rr
parents: 11507
diff changeset
   471
{$IFDEF USE_VIDEO_RECORDING}
bf86c6cb9341 Bye-bye TryDo
unc0rr
parents: 11507
diff changeset
   472
    if GameType = gmtRecord then
bf86c6cb9341 Bye-bye TryDo
unc0rr
parents: 11507
diff changeset
   473
    begin
bf86c6cb9341 Bye-bye TryDo
unc0rr
parents: 11507
diff changeset
   474
        RecorderMainLoop();
bf86c6cb9341 Bye-bye TryDo
unc0rr
parents: 11507
diff changeset
   475
        exit;
bf86c6cb9341 Bye-bye TryDo
unc0rr
parents: 11507
diff changeset
   476
    end;
bf86c6cb9341 Bye-bye TryDo
unc0rr
parents: 11507
diff changeset
   477
{$ENDIF}
11507
bd9a2f1b0080 SDLTry doesn't halt engine no more
unc0rr
parents: 11502
diff changeset
   478
11532
bf86c6cb9341 Bye-bye TryDo
unc0rr
parents: 11507
diff changeset
   479
    MainLoop;
bf86c6cb9341 Bye-bye TryDo
unc0rr
parents: 11507
diff changeset
   480
end;
bf86c6cb9341 Bye-bye TryDo
unc0rr
parents: 11507
diff changeset
   481
bf86c6cb9341 Bye-bye TryDo
unc0rr
parents: 11507
diff changeset
   482
procedure Game;
bf86c6cb9341 Bye-bye TryDo
unc0rr
parents: 11507
diff changeset
   483
begin
bf86c6cb9341 Bye-bye TryDo
unc0rr
parents: 11507
diff changeset
   484
    initEverything(true);
bf86c6cb9341 Bye-bye TryDo
unc0rr
parents: 11507
diff changeset
   485
    GameRoutine;
7026
8d1724e1337e split OnDestroy across the appropriate modules (this doen't cause leaks on mobile, right?)
koda
parents: 7025
diff changeset
   486
    // clean up all the memory allocated
3611
ed00aa2b339e interpret parameters before initializing everything
koda
parents: 3610
diff changeset
   487
    freeEverything(true);
2698
90585aba87ad objc/pascal finally working
koda
parents: 2697
diff changeset
   488
end;
7896
67217e6108fd another stake at variable pre-initialisation - we lost preview logging in the course
koda
parents: 7850
diff changeset
   489
///////////////////////////////////////////////////////////////////////////////
67217e6108fd another stake at variable pre-initialisation - we lost preview logging in the course
koda
parents: 7850
diff changeset
   490
// preInitEverything - init variables that are going to be ovewritten by arguments
67217e6108fd another stake at variable pre-initialisation - we lost preview logging in the course
koda
parents: 7850
diff changeset
   491
// initEverything - init variables only. Should be coupled by below
67217e6108fd another stake at variable pre-initialisation - we lost preview logging in the course
koda
parents: 7850
diff changeset
   492
// freeEverything - free above. Pay attention to the init/free order!
67217e6108fd another stake at variable pre-initialisation - we lost preview logging in the course
koda
parents: 7850
diff changeset
   493
procedure preInitEverything;
2699
249adefa9c1c replace initialization/finalization statements with custom init functions
koda
parents: 2698
diff changeset
   494
begin
11507
bd9a2f1b0080 SDLTry doesn't halt engine no more
unc0rr
parents: 11502
diff changeset
   495
    allOK:= true;
3365
37ac593e9027 wow all these files only for land preview and seed generation
koda
parents: 3312
diff changeset
   496
    Randomize();
37ac593e9027 wow all these files only for land preview and seed generation
koda
parents: 3312
diff changeset
   497
7896
67217e6108fd another stake at variable pre-initialisation - we lost preview logging in the course
koda
parents: 7850
diff changeset
   498
    uVariables.preInitModule;
67217e6108fd another stake at variable pre-initialisation - we lost preview logging in the course
koda
parents: 7850
diff changeset
   499
    uSound.preInitModule;
67217e6108fd another stake at variable pre-initialisation - we lost preview logging in the course
koda
parents: 7850
diff changeset
   500
end;
67217e6108fd another stake at variable pre-initialisation - we lost preview logging in the course
koda
parents: 7850
diff changeset
   501
67217e6108fd another stake at variable pre-initialisation - we lost preview logging in the course
koda
parents: 7850
diff changeset
   502
procedure initEverything (complete:boolean);
67217e6108fd another stake at variable pre-initialisation - we lost preview logging in the course
koda
parents: 7850
diff changeset
   503
begin
11644
f17df78181d8 - Init physfs before creating debug log
unc0rr
parents: 11631
diff changeset
   504
    PathPrefix:= PathPrefix + #0;
f17df78181d8 - Init physfs before creating debug log
unc0rr
parents: 11631
diff changeset
   505
    UserPathPrefix:= UserPathPrefix + #0;
f17df78181d8 - Init physfs before creating debug log
unc0rr
parents: 11631
diff changeset
   506
    uPhysFSLayer.initModule(@PathPrefix[1], @UserPathPrefix[1]);
f17df78181d8 - Init physfs before creating debug log
unc0rr
parents: 11631
diff changeset
   507
    PathPrefix:= copy(PathPrefix, 1, length(PathPrefix) - 1);
f17df78181d8 - Init physfs before creating debug log
unc0rr
parents: 11631
diff changeset
   508
    UserPathPrefix:= copy(UserPathPrefix, 1, length(UserPathPrefix) - 1);
f17df78181d8 - Init physfs before creating debug log
unc0rr
parents: 11631
diff changeset
   509
7850
fcbb024090a4 cleanup in initEverything and freeEverything
koda
parents: 7848
diff changeset
   510
    uUtils.initModule(complete);    // opens the debug file, must be the first
fcbb024090a4 cleanup in initEverything and freeEverything
koda
parents: 7848
diff changeset
   511
    uVariables.initModule;          // inits all global variables
fcbb024090a4 cleanup in initEverything and freeEverything
koda
parents: 7848
diff changeset
   512
    uCommands.initModule;           // helps below
fcbb024090a4 cleanup in initEverything and freeEverything
koda
parents: 7848
diff changeset
   513
    uCommandHandlers.initModule;    // registers all messages from frontend
3525
1d7b056ff866 some memory caring code
koda
parents: 3523
diff changeset
   514
7850
fcbb024090a4 cleanup in initEverything and freeEverything
koda
parents: 7848
diff changeset
   515
    uLand.initModule;               // computes land
fcbb024090a4 cleanup in initEverything and freeEverything
koda
parents: 7848
diff changeset
   516
    uLandPainted.initModule;        // computes drawn land
fcbb024090a4 cleanup in initEverything and freeEverything
koda
parents: 7848
diff changeset
   517
    uIO.initModule;                 // sets up sockets
11631
b3db79b56f28 Pass paths to initModule of uPhysFSLayer (as in 4be6cd55f1cf from qmlfrontend branch)
unc0rr
parents: 11548
diff changeset
   518
10150
fa5c83fd0ad9 Allow lua drawn maps (shoppamap, tunnels, diagonal maze etc) to generate previews.
nemo
parents: 10139
diff changeset
   519
    uScript.initModule;
3697
d5b30d6373fc remove trailing spaces from end of line
koda
parents: 3693
diff changeset
   520
3525
1d7b056ff866 some memory caring code
koda
parents: 3523
diff changeset
   521
    if complete then
7026
8d1724e1337e split OnDestroy across the appropriate modules (this doen't cause leaks on mobile, right?)
koda
parents: 7025
diff changeset
   522
    begin
9468
3d07fd84c39d - Actually call uTexture.initModule and .freeModule
unc0rr
parents: 9466
diff changeset
   523
        uTextures.initModule;
7850
fcbb024090a4 cleanup in initEverything and freeEverything
koda
parents: 7848
diff changeset
   524
{$IFDEF ANDROID}GLUnit.initModule;{$ENDIF}
7837
3e031b3b33e6 minor macro cleanup
koda
parents: 7615
diff changeset
   525
{$IFDEF USE_TOUCH_INTERFACE}uTouch.initModule;{$ENDIF}
9543
1826b5315369 Fix bug 656 by using the right resolution values
koda
parents: 9468
diff changeset
   526
{$IFDEF USE_VIDEO_RECORDING}uVideoRec.initModule;{$ENDIF}
6415
af2047bb4f70 GSoC 2011: Android port - merged mainstream
koda
parents: 6341
diff changeset
   527
        uAI.initModule;
3525
1d7b056ff866 some memory caring code
koda
parents: 3523
diff changeset
   528
        uAIMisc.initModule;
7850
fcbb024090a4 cleanup in initEverything and freeEverything
koda
parents: 7848
diff changeset
   529
        uAILandMarks.initModule;    //stub
3525
1d7b056ff866 some memory caring code
koda
parents: 3523
diff changeset
   530
        uAmmos.initModule;
7850
fcbb024090a4 cleanup in initEverything and freeEverything
koda
parents: 7848
diff changeset
   531
        uCaptions.initModule;
fcbb024090a4 cleanup in initEverything and freeEverything
koda
parents: 7848
diff changeset
   532
3525
1d7b056ff866 some memory caring code
koda
parents: 3523
diff changeset
   533
        uChat.initModule;
1d7b056ff866 some memory caring code
koda
parents: 3523
diff changeset
   534
        uCollisions.initModule;
1d7b056ff866 some memory caring code
koda
parents: 3523
diff changeset
   535
        uGears.initModule;
9466
8b48c27201af - Load default binds from settings.ini
unc0rr
parents: 9464
diff changeset
   536
        uInputHandler.initModule;
7850
fcbb024090a4 cleanup in initEverything and freeEverything
koda
parents: 7848
diff changeset
   537
        uMisc.initModule;
fcbb024090a4 cleanup in initEverything and freeEverything
koda
parents: 7848
diff changeset
   538
        uLandTexture.initModule;    //stub
3525
1d7b056ff866 some memory caring code
koda
parents: 3523
diff changeset
   539
        uSound.initModule;
1d7b056ff866 some memory caring code
koda
parents: 3523
diff changeset
   540
        uStats.initModule;
1d7b056ff866 some memory caring code
koda
parents: 3523
diff changeset
   541
        uStore.initModule;
10304
7e40820b7ed6 fix gl2 build, further rendering cleanup WIP, also new chat command: /debugvl
sheepluva
parents: 10302
diff changeset
   542
        uRender.initModule;
3525
1d7b056ff866 some memory caring code
koda
parents: 3523
diff changeset
   543
        uTeams.initModule;
1d7b056ff866 some memory caring code
koda
parents: 3523
diff changeset
   544
        uVisualGears.initModule;
9283
76e68c136a11 Refactoring: VGSHandlers.inc -> uVisualGearsHandlers.pas
unc0rr
parents: 9280
diff changeset
   545
        uVisualGearsHandlers.initModule;
3525
1d7b056ff866 some memory caring code
koda
parents: 3523
diff changeset
   546
        uWorld.initModule;
7026
8d1724e1337e split OnDestroy across the appropriate modules (this doen't cause leaks on mobile, right?)
koda
parents: 7025
diff changeset
   547
    end;
2699
249adefa9c1c replace initialization/finalization statements with custom init functions
koda
parents: 2698
diff changeset
   548
end;
249adefa9c1c replace initialization/finalization statements with custom init functions
koda
parents: 2698
diff changeset
   549
3525
1d7b056ff866 some memory caring code
koda
parents: 3523
diff changeset
   550
procedure freeEverything (complete:boolean);
2699
249adefa9c1c replace initialization/finalization statements with custom init functions
koda
parents: 2698
diff changeset
   551
begin
3525
1d7b056ff866 some memory caring code
koda
parents: 3523
diff changeset
   552
    if complete then
10012
82dd9f0c88f7 Make poison damage possibly variable (might as well since effects is a count). Scripts might find it handy.
nemo
parents: 10009
diff changeset
   553
        begin
7026
8d1724e1337e split OnDestroy across the appropriate modules (this doen't cause leaks on mobile, right?)
koda
parents: 7025
diff changeset
   554
        WriteLnToConsole('Freeing resources...');
7850
fcbb024090a4 cleanup in initEverything and freeEverything
koda
parents: 7848
diff changeset
   555
        uAI.freeModule;             // AI things need to be freed first
fcbb024090a4 cleanup in initEverything and freeEverything
koda
parents: 7848
diff changeset
   556
        uAIMisc.freeModule;         //stub
7433
c7fff3e61d49 - Implement AI land marks which only used to tracks visited areas on the map for now. Significantly reduces wasting of cpu time by AI checking same place several times (10x or even more in rare cases)
unc0rr
parents: 7151
diff changeset
   557
        uAILandMarks.freeModule;
4393
883b979697e4 uCaptions
unc0rr
parents: 4389
diff changeset
   558
        uCaptions.freeModule;
3525
1d7b056ff866 some memory caring code
koda
parents: 3523
diff changeset
   559
        uWorld.freeModule;
3615
b78d7959540a further code cleanup and less redundancy
koda
parents: 3613
diff changeset
   560
        uVisualGears.freeModule;
3525
1d7b056ff866 some memory caring code
koda
parents: 3523
diff changeset
   561
        uTeams.freeModule;
7026
8d1724e1337e split OnDestroy across the appropriate modules (this doen't cause leaks on mobile, right?)
koda
parents: 7025
diff changeset
   562
        uInputHandler.freeModule;
3525
1d7b056ff866 some memory caring code
koda
parents: 3523
diff changeset
   563
        uStats.freeModule;          //stub
3615
b78d7959540a further code cleanup and less redundancy
koda
parents: 3613
diff changeset
   564
        uSound.freeModule;
7850
fcbb024090a4 cleanup in initEverything and freeEverything
koda
parents: 7848
diff changeset
   565
        uMisc.freeModule;
3612
b50215a8a43d land arrays are allocated dynamically, so DOWNSCALE and LOWRES macros are now removed and replaced by run time flags rqBlurryLand and rqLowRes
koda
parents: 3611
diff changeset
   566
        uLandTexture.freeModule;
3525
1d7b056ff866 some memory caring code
koda
parents: 3523
diff changeset
   567
        uGears.freeModule;
1d7b056ff866 some memory caring code
koda
parents: 3523
diff changeset
   568
        uCollisions.freeModule;     //stub
4901
d1e2d82d9ccc Thou shalt not leak!
sheepluva
parents: 4900
diff changeset
   569
        uChat.freeModule;
3525
1d7b056ff866 some memory caring code
koda
parents: 3523
diff changeset
   570
        uAmmos.freeModule;
10304
7e40820b7ed6 fix gl2 build, further rendering cleanup WIP, also new chat command: /debugvl
sheepluva
parents: 10302
diff changeset
   571
        uRender.freeModule;
7850
fcbb024090a4 cleanup in initEverything and freeEverything
koda
parents: 7848
diff changeset
   572
        uStore.freeModule;          // closes SDL
7286
068adc6948e3 remaining IFDEFs
Stepan777 <stepik-777@mail.ru>
parents: 7235
diff changeset
   573
{$IFDEF USE_VIDEO_RECORDING}uVideoRec.freeModule;{$ENDIF}
7850
fcbb024090a4 cleanup in initEverything and freeEverything
koda
parents: 7848
diff changeset
   574
{$IFDEF USE_TOUCH_INTERFACE}uTouch.freeModule;{$ENDIF}  //stub
fcbb024090a4 cleanup in initEverything and freeEverything
koda
parents: 7848
diff changeset
   575
{$IFDEF ANDROID}GLUnit.freeModule;{$ENDIF}
9468
3d07fd84c39d - Actually call uTexture.initModule and .freeModule
unc0rr
parents: 9466
diff changeset
   576
        uTextures.freeModule;
12844
22cc3d82905a Should probably have gl context stuff in its own unit separate from store, but, don't close the gl context before anything that might still want to do gl operations
nemo
parents: 12831
diff changeset
   577
        SDL_GL_DeleteContext(SDLGLcontext);
22cc3d82905a Should probably have gl context stuff in its own unit separate from store, but, don't close the gl context before anything that might still want to do gl operations
nemo
parents: 12831
diff changeset
   578
        SDL_DestroyWindow(SDLwindow);
22cc3d82905a Should probably have gl context stuff in its own unit separate from store, but, don't close the gl context before anything that might still want to do gl operations
nemo
parents: 12831
diff changeset
   579
        SDL_Quit()
10012
82dd9f0c88f7 Make poison damage possibly variable (might as well since effects is a count). Scripts might find it handy.
nemo
parents: 10009
diff changeset
   580
        end;
3697
d5b30d6373fc remove trailing spaces from end of line
koda
parents: 3693
diff changeset
   581
7026
8d1724e1337e split OnDestroy across the appropriate modules (this doen't cause leaks on mobile, right?)
koda
parents: 7025
diff changeset
   582
    uIO.freeModule;
3038
4e48c276a468 In pascal unit is a namespace
unc0rr
parents: 3029
diff changeset
   583
    uLand.freeModule;
5066
d2684b6f02ce fix leaking of hand-drawn maps
sheepluva
parents: 5052
diff changeset
   584
    uLandPainted.freeModule;
2716
b9ca1bfca24f complete the replacement of init/free wrappers for every unit
koda
parents: 2715
diff changeset
   585
4413
46caab3a8f84 uCommandHandlers
unc0rr
parents: 4408
diff changeset
   586
    uCommandHandlers.freeModule;
4373
fe0e3903bb9e Introduce uCommands.pas
unC0Rr
parents: 4359
diff changeset
   587
    uCommands.freeModule;
4359
83ef50815535 Move variables from uMisc to uVariables
unC0Rr
parents: 4357
diff changeset
   588
    uVariables.freeModule;
7850
fcbb024090a4 cleanup in initEverything and freeEverything
koda
parents: 7848
diff changeset
   589
    uUtils.freeModule;              // closes debug file
10159
5848ed144e0b move the freeModule too, couple of style tweaks
nemo
parents: 10150
diff changeset
   590
    uPhysFSLayer.freeModule;
5848ed144e0b move the freeModule too, couple of style tweaks
nemo
parents: 10150
diff changeset
   591
    uScript.freeModule;
2699
249adefa9c1c replace initialization/finalization statements with custom init functions
koda
parents: 2698
diff changeset
   592
end;
2803
1f446fc5c8ec allow to compile engine as library with HWLIBRARY symbol
koda
parents: 2800
diff changeset
   593
7896
67217e6108fd another stake at variable pre-initialisation - we lost preview logging in the course
koda
parents: 7850
diff changeset
   594
///////////////////////////////////////////////////////////////////////////////
11133
fa3d227fb308 - Fix for retrieving 'Maze' preview genration
antonc27 <antonc27@mail.ru>
parents: 11113
diff changeset
   595
procedure GenLandPreview;
fa3d227fb308 - Fix for retrieving 'Maze' preview genration
antonc27 <antonc27@mail.ru>
parents: 11113
diff changeset
   596
{$IFDEF MOBILE}
7026
8d1724e1337e split OnDestroy across the appropriate modules (this doen't cause leaks on mobile, right?)
koda
parents: 7025
diff changeset
   597
var Preview: TPreview;
11133
fa3d227fb308 - Fix for retrieving 'Maze' preview genration
antonc27 <antonc27@mail.ru>
parents: 11113
diff changeset
   598
{$ELSE}
10162
38dbf26475d8 Add alpha channel to preview
unc0rr
parents: 10159
diff changeset
   599
var Preview: TPreviewAlpha;
11155
a10143c3d87d pas2c doesn't like {$ENDIF} with argument
sheepluva
parents: 11151
diff changeset
   600
{$ENDIF}
2698
90585aba87ad objc/pascal finally working
koda
parents: 2697
diff changeset
   601
begin
7896
67217e6108fd another stake at variable pre-initialisation - we lost preview logging in the course
koda
parents: 7850
diff changeset
   602
    initEverything(false);
10175
c92668840ea8 Remove game/preview functions split in library mode, just let normal procedure run instead:
unc0rr
parents: 10162
diff changeset
   603
2947
803b277e4894 hate Smaxx (tested)
unc0rr
parents: 2905
diff changeset
   604
    InitIPC;
11507
bd9a2f1b0080 SDLTry doesn't halt engine no more
unc0rr
parents: 11502
diff changeset
   605
    if allOK then
bd9a2f1b0080 SDLTry doesn't halt engine no more
unc0rr
parents: 11502
diff changeset
   606
    begin
bd9a2f1b0080 SDLTry doesn't halt engine no more
unc0rr
parents: 11502
diff changeset
   607
        IPCWaitPongEvent;
11532
bf86c6cb9341 Bye-bye TryDo
unc0rr
parents: 11507
diff changeset
   608
        if checkFails(InitStepsFlags = cifRandomize, 'Some parameters not set (flags = ' + inttostr(InitStepsFlags) + ')', true) then exit;
2698
90585aba87ad objc/pascal finally working
koda
parents: 2697
diff changeset
   609
11507
bd9a2f1b0080 SDLTry doesn't halt engine no more
unc0rr
parents: 11502
diff changeset
   610
        ScriptOnPreviewInit;
bd9a2f1b0080 SDLTry doesn't halt engine no more
unc0rr
parents: 11502
diff changeset
   611
    {$IFDEF MOBILE}
bd9a2f1b0080 SDLTry doesn't halt engine no more
unc0rr
parents: 11502
diff changeset
   612
        GenPreview(Preview);
bd9a2f1b0080 SDLTry doesn't halt engine no more
unc0rr
parents: 11502
diff changeset
   613
    {$ELSE}
bd9a2f1b0080 SDLTry doesn't halt engine no more
unc0rr
parents: 11502
diff changeset
   614
        GenPreviewAlpha(Preview);
bd9a2f1b0080 SDLTry doesn't halt engine no more
unc0rr
parents: 11502
diff changeset
   615
    {$ENDIF}
bd9a2f1b0080 SDLTry doesn't halt engine no more
unc0rr
parents: 11502
diff changeset
   616
        WriteLnToConsole('Sending preview...');
bd9a2f1b0080 SDLTry doesn't halt engine no more
unc0rr
parents: 11502
diff changeset
   617
        SendIPCRaw(@Preview, sizeof(Preview));
bd9a2f1b0080 SDLTry doesn't halt engine no more
unc0rr
parents: 11502
diff changeset
   618
        SendIPCRaw(@MaxHedgehogs, sizeof(byte));
bd9a2f1b0080 SDLTry doesn't halt engine no more
unc0rr
parents: 11502
diff changeset
   619
        WriteLnToConsole('Preview sent, disconnect');
bd9a2f1b0080 SDLTry doesn't halt engine no more
unc0rr
parents: 11502
diff changeset
   620
    end;
bd9a2f1b0080 SDLTry doesn't halt engine no more
unc0rr
parents: 11502
diff changeset
   621
3525
1d7b056ff866 some memory caring code
koda
parents: 3523
diff changeset
   622
    freeEverything(false);
2698
90585aba87ad objc/pascal finally working
koda
parents: 2697
diff changeset
   623
end;
90585aba87ad objc/pascal finally working
koda
parents: 2697
diff changeset
   624
13820
cf7626f46bb2 IFNDEF custom exception handlung away in pas2c builds
Wuzzy <Wuzzy2@mail.ru>
parents: 13586
diff changeset
   625
{$IFNDEF PAS2C}
13488
dbf4f7a677be When hwengine crashes w/ error 217, write backtrace in log, too
Wuzzy <Wuzzy2@mail.ru>
parents: 13487
diff changeset
   626
// Write backtrace to console and log when an unhandled exception occurred
dbf4f7a677be When hwengine crashes w/ error 217, write backtrace in log, too
Wuzzy <Wuzzy2@mail.ru>
parents: 13487
diff changeset
   627
procedure catchUnhandledException(Obj: TObject; Addr: Pointer; FrameCount: Longint; Frames: PPointer);
dbf4f7a677be When hwengine crashes w/ error 217, write backtrace in log, too
Wuzzy <Wuzzy2@mail.ru>
parents: 13487
diff changeset
   628
var
dbf4f7a677be When hwengine crashes w/ error 217, write backtrace in log, too
Wuzzy <Wuzzy2@mail.ru>
parents: 13487
diff changeset
   629
  Message: string;
dbf4f7a677be When hwengine crashes w/ error 217, write backtrace in log, too
Wuzzy <Wuzzy2@mail.ru>
parents: 13487
diff changeset
   630
  i: LongInt;
dbf4f7a677be When hwengine crashes w/ error 217, write backtrace in log, too
Wuzzy <Wuzzy2@mail.ru>
parents: 13487
diff changeset
   631
begin
dbf4f7a677be When hwengine crashes w/ error 217, write backtrace in log, too
Wuzzy <Wuzzy2@mail.ru>
parents: 13487
diff changeset
   632
  WriteLnToConsole('An unhandled exception occurred at $' + HexStr(Addr) + ':');
dbf4f7a677be When hwengine crashes w/ error 217, write backtrace in log, too
Wuzzy <Wuzzy2@mail.ru>
parents: 13487
diff changeset
   633
  if Obj is exception then
dbf4f7a677be When hwengine crashes w/ error 217, write backtrace in log, too
Wuzzy <Wuzzy2@mail.ru>
parents: 13487
diff changeset
   634
   begin
dbf4f7a677be When hwengine crashes w/ error 217, write backtrace in log, too
Wuzzy <Wuzzy2@mail.ru>
parents: 13487
diff changeset
   635
     Message := Exception(Obj).ClassName + ': ' + Exception(Obj).Message;
dbf4f7a677be When hwengine crashes w/ error 217, write backtrace in log, too
Wuzzy <Wuzzy2@mail.ru>
parents: 13487
diff changeset
   636
     WriteLnToConsole(Message);
dbf4f7a677be When hwengine crashes w/ error 217, write backtrace in log, too
Wuzzy <Wuzzy2@mail.ru>
parents: 13487
diff changeset
   637
   end
dbf4f7a677be When hwengine crashes w/ error 217, write backtrace in log, too
Wuzzy <Wuzzy2@mail.ru>
parents: 13487
diff changeset
   638
  else
dbf4f7a677be When hwengine crashes w/ error 217, write backtrace in log, too
Wuzzy <Wuzzy2@mail.ru>
parents: 13487
diff changeset
   639
    WriteLnToConsole('Exception object ' + Obj.ClassName + ' is not of class Exception.');
dbf4f7a677be When hwengine crashes w/ error 217, write backtrace in log, too
Wuzzy <Wuzzy2@mail.ru>
parents: 13487
diff changeset
   640
  WriteLnToConsole(BackTraceStrFunc(Addr));
dbf4f7a677be When hwengine crashes w/ error 217, write backtrace in log, too
Wuzzy <Wuzzy2@mail.ru>
parents: 13487
diff changeset
   641
  if (FrameCount > 0) then
dbf4f7a677be When hwengine crashes w/ error 217, write backtrace in log, too
Wuzzy <Wuzzy2@mail.ru>
parents: 13487
diff changeset
   642
    begin
dbf4f7a677be When hwengine crashes w/ error 217, write backtrace in log, too
Wuzzy <Wuzzy2@mail.ru>
parents: 13487
diff changeset
   643
      for i := 0 to FrameCount - 1 do
dbf4f7a677be When hwengine crashes w/ error 217, write backtrace in log, too
Wuzzy <Wuzzy2@mail.ru>
parents: 13487
diff changeset
   644
        WriteLnToConsole(BackTraceStrFunc(Frames[i]));
dbf4f7a677be When hwengine crashes w/ error 217, write backtrace in log, too
Wuzzy <Wuzzy2@mail.ru>
parents: 13487
diff changeset
   645
    end;
dbf4f7a677be When hwengine crashes w/ error 217, write backtrace in log, too
Wuzzy <Wuzzy2@mail.ru>
parents: 13487
diff changeset
   646
end;
13820
cf7626f46bb2 IFNDEF custom exception handlung away in pas2c builds
Wuzzy <Wuzzy2@mail.ru>
parents: 13586
diff changeset
   647
{$ENDIF}
13488
dbf4f7a677be When hwengine crashes w/ error 217, write backtrace in log, too
Wuzzy <Wuzzy2@mail.ru>
parents: 13487
diff changeset
   648
10175
c92668840ea8 Remove game/preview functions split in library mode, just let normal procedure run instead:
unc0rr
parents: 10162
diff changeset
   649
{$IFDEF HWLIBRARY}
11685
a2e86a867fb5 pas2c converts exit to return, so change RunEngine signature
frd
parents: 11644
diff changeset
   650
function RunEngine(argc: LongInt; argv: PPChar): LongInt; cdecl; export;
2008
fc2fb5c938c3 Patch by koda:
unc0rr
parents: 2006
diff changeset
   651
begin
10175
c92668840ea8 Remove game/preview functions split in library mode, just let normal procedure run instead:
unc0rr
parents: 10162
diff changeset
   652
    operatingsystem_parameter_argc:= argc;
c92668840ea8 Remove game/preview functions split in library mode, just let normal procedure run instead:
unc0rr
parents: 10162
diff changeset
   653
    operatingsystem_parameter_argv:= argv;
c92668840ea8 Remove game/preview functions split in library mode, just let normal procedure run instead:
unc0rr
parents: 10162
diff changeset
   654
{$ELSE}
c92668840ea8 Remove game/preview functions split in library mode, just let normal procedure run instead:
unc0rr
parents: 10162
diff changeset
   655
begin
c92668840ea8 Remove game/preview functions split in library mode, just let normal procedure run instead:
unc0rr
parents: 10162
diff changeset
   656
{$ENDIF}
2008
fc2fb5c938c3 Patch by koda:
unc0rr
parents: 2006
diff changeset
   657
14199
3c36a4e66c82 make engine windows checks work for 64bit builds
alfadur
parents: 13820
diff changeset
   658
{$IFDEF WINDOWS}
12657
2065819170ce (Hopefully) fix game camera being shifted on Windows 10
alfadur
parents: 12621
diff changeset
   659
    ShcoreLibHandle := LoadLibrary('Shcore.dll');
2065819170ce (Hopefully) fix game camera being shifted on Windows 10
alfadur
parents: 12621
diff changeset
   660
    if (ShcoreLibHandle <> 0) then
2065819170ce (Hopefully) fix game camera being shifted on Windows 10
alfadur
parents: 12621
diff changeset
   661
    begin
2065819170ce (Hopefully) fix game camera being shifted on Windows 10
alfadur
parents: 12621
diff changeset
   662
        SetProcessDpiAwareness :=
2065819170ce (Hopefully) fix game camera being shifted on Windows 10
alfadur
parents: 12621
diff changeset
   663
            TSetProcessDpiAwareness(GetProcedureAddress(ShcoreLibHandle, 'SetProcessDpiAwareness'));
2065819170ce (Hopefully) fix game camera being shifted on Windows 10
alfadur
parents: 12621
diff changeset
   664
        if (SetProcessDpiAwareness <> nil) then
2065819170ce (Hopefully) fix game camera being shifted on Windows 10
alfadur
parents: 12621
diff changeset
   665
            SetProcessDpiAwareness(1);
2065819170ce (Hopefully) fix game camera being shifted on Windows 10
alfadur
parents: 12621
diff changeset
   666
    end;
2065819170ce (Hopefully) fix game camera being shifted on Windows 10
alfadur
parents: 12621
diff changeset
   667
{$ENDIF}
2065819170ce (Hopefully) fix game camera being shifted on Windows 10
alfadur
parents: 12621
diff changeset
   668
7896
67217e6108fd another stake at variable pre-initialisation - we lost preview logging in the course
koda
parents: 7850
diff changeset
   669
///////////////////////////////////////////////////////////////////////////////
67217e6108fd another stake at variable pre-initialisation - we lost preview logging in the course
koda
parents: 7850
diff changeset
   670
/////////////////////////////////// m a i n ///////////////////////////////////
67217e6108fd another stake at variable pre-initialisation - we lost preview logging in the course
koda
parents: 7850
diff changeset
   671
///////////////////////////////////////////////////////////////////////////////
8026
4a4f21070479 merge xymeng's gsoc engine with a few updates (and further checks on symbol definitions)
koda
parents: 8018
diff changeset
   672
{$IFDEF PAS2C}
4a4f21070479 merge xymeng's gsoc engine with a few updates (and further checks on symbol definitions)
koda
parents: 8018
diff changeset
   673
    // workaround for pascal's ParamStr and ParamCount
4a4f21070479 merge xymeng's gsoc engine with a few updates (and further checks on symbol definitions)
koda
parents: 8018
diff changeset
   674
    init(argc, argv);
4a4f21070479 merge xymeng's gsoc engine with a few updates (and further checks on symbol definitions)
koda
parents: 8018
diff changeset
   675
{$ENDIF}
13820
cf7626f46bb2 IFNDEF custom exception handlung away in pas2c builds
Wuzzy <Wuzzy2@mail.ru>
parents: 13586
diff changeset
   676
{$IFNDEF PAS2C}
14860
259840ca77e3 Fix Pas2C failing to include SysUtils
Wuzzy <Wuzzy2@mail.ru>
parents: 14808
diff changeset
   677
    // Custom procedure for unhandled exceptions; ExceptProc is used by SysUtils module
13488
dbf4f7a677be When hwengine crashes w/ error 217, write backtrace in log, too
Wuzzy <Wuzzy2@mail.ru>
parents: 13487
diff changeset
   678
    ExceptProc:= @catchUnhandledException;
13820
cf7626f46bb2 IFNDEF custom exception handlung away in pas2c builds
Wuzzy <Wuzzy2@mail.ru>
parents: 13586
diff changeset
   679
{$ENDIF}
13488
dbf4f7a677be When hwengine crashes w/ error 217, write backtrace in log, too
Wuzzy <Wuzzy2@mail.ru>
parents: 13487
diff changeset
   680
7896
67217e6108fd another stake at variable pre-initialisation - we lost preview logging in the course
koda
parents: 7850
diff changeset
   681
    preInitEverything();
3678
00428183300f patch by lucass (polished by me) - command line parsing is now much more flexible
koda
parents: 3670
diff changeset
   682
2947
803b277e4894 hate Smaxx (tested)
unc0rr
parents: 2905
diff changeset
   683
    GetParams();
2008
fc2fb5c938c3 Patch by koda:
unc0rr
parents: 2006
diff changeset
   684
6580
6155187bf599 A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents: 6415
diff changeset
   685
    if GameType = gmtLandPreview then
6155187bf599 A partial reformatting of the pascal code to have consistent syntax. Things that are still inconsistent.
lovelacer
parents: 6415
diff changeset
   686
        GenLandPreview()
13487
d23731fe84d4 Fix hwengine --help returning with exit code 51
Wuzzy <Wuzzy2@mail.ru>
parents: 13077
diff changeset
   687
    else if (GameType <> gmtBadSyntax) and (GameType <> gmtSyntaxHelp) then
8308
cdf83bdf7b27 move GetParams in ArgParser, print a warning when using a deprecated command, pascalisation of +1s
koda
parents: 8307
diff changeset
   688
        Game();
3697
d5b30d6373fc remove trailing spaces from end of line
koda
parents: 3693
diff changeset
   689
13487
d23731fe84d4 Fix hwengine --help returning with exit code 51
Wuzzy <Wuzzy2@mail.ru>
parents: 13077
diff changeset
   690
    // return error when engine is not called correctly
d23731fe84d4 Fix hwengine --help returning with exit code 51
Wuzzy <Wuzzy2@mail.ru>
parents: 13077
diff changeset
   691
    if GameType = gmtBadSyntax then
10176
ea022e9483c2 Don't call halt()
unc0rr
parents: 10175
diff changeset
   692
        {$IFDEF PAS2C}
10306
4fca8bcfaff0 clean up halting a little
sheepluva
parents: 10304
diff changeset
   693
        exit(HaltUsageError);
10176
ea022e9483c2 Don't call halt()
unc0rr
parents: 10175
diff changeset
   694
        {$ELSE}
10306
4fca8bcfaff0 clean up halting a little
sheepluva
parents: 10304
diff changeset
   695
        halt(HaltUsageError);
10176
ea022e9483c2 Don't call halt()
unc0rr
parents: 10175
diff changeset
   696
        {$ENDIF}
8026
4a4f21070479 merge xymeng's gsoc engine with a few updates (and further checks on symbol definitions)
koda
parents: 8018
diff changeset
   697
10619
ee460883729e unexpected return from lua test should not return exit status 0
sheepluva
parents: 10581
diff changeset
   698
    if cTestLua then
10621
b50e094d8b00 add warning to logs when tests terminates prematurely
sheepluva
parents: 10619
diff changeset
   699
        begin
10622
9551211455a3 pas2c-whoops
sheepluva
parents: 10621
diff changeset
   700
        WriteLnToConsole(errmsgLuaTestTerm);
10619
ee460883729e unexpected return from lua test should not return exit status 0
sheepluva
parents: 10581
diff changeset
   701
        {$IFDEF PAS2C}
ee460883729e unexpected return from lua test should not return exit status 0
sheepluva
parents: 10581
diff changeset
   702
        exit(HaltTestUnexpected);
ee460883729e unexpected return from lua test should not return exit status 0
sheepluva
parents: 10581
diff changeset
   703
        {$ELSE}
ee460883729e unexpected return from lua test should not return exit status 0
sheepluva
parents: 10581
diff changeset
   704
        halt(HaltTestUnexpected);
ee460883729e unexpected return from lua test should not return exit status 0
sheepluva
parents: 10581
diff changeset
   705
        {$ENDIF}
10621
b50e094d8b00 add warning to logs when tests terminates prematurely
sheepluva
parents: 10619
diff changeset
   706
        end;
10619
ee460883729e unexpected return from lua test should not return exit status 0
sheepluva
parents: 10581
diff changeset
   707
ee460883729e unexpected return from lua test should not return exit status 0
sheepluva
parents: 10581
diff changeset
   708
    {$IFDEF PAS2C}
11149
c150602921ef - ifdef for engine exit/halt
antonc27 <antonc27@mail.ru>
parents: 11133
diff changeset
   709
        exit(HaltNoError);
10619
ee460883729e unexpected return from lua test should not return exit status 0
sheepluva
parents: 10581
diff changeset
   710
    {$ELSE}
11149
c150602921ef - ifdef for engine exit/halt
antonc27 <antonc27@mail.ru>
parents: 11133
diff changeset
   711
        {$IFDEF IPHONEOS}
11685
a2e86a867fb5 pas2c converts exit to return, so change RunEngine signature
frd
parents: 11644
diff changeset
   712
            exit(HaltNoError);
11149
c150602921ef - ifdef for engine exit/halt
antonc27 <antonc27@mail.ru>
parents: 11133
diff changeset
   713
        {$ELSE}
c150602921ef - ifdef for engine exit/halt
antonc27 <antonc27@mail.ru>
parents: 11133
diff changeset
   714
            halt(HaltNoError);
c150602921ef - ifdef for engine exit/halt
antonc27 <antonc27@mail.ru>
parents: 11133
diff changeset
   715
        {$ENDIF}
10619
ee460883729e unexpected return from lua test should not return exit status 0
sheepluva
parents: 10581
diff changeset
   716
    {$ENDIF}
10175
c92668840ea8 Remove game/preview functions split in library mode, just let normal procedure run instead:
unc0rr
parents: 10162
diff changeset
   717
{$IFDEF HWLIBRARY}
c92668840ea8 Remove game/preview functions split in library mode, just let normal procedure run instead:
unc0rr
parents: 10162
diff changeset
   718
end;
2698
90585aba87ad objc/pascal finally working
koda
parents: 2697
diff changeset
   719
{$ENDIF}
10175
c92668840ea8 Remove game/preview functions split in library mode, just let normal procedure run instead:
unc0rr
parents: 10162
diff changeset
   720
51
b6e3ae05857f - Get rid of hwserv and runhelper
unc0rr
parents:
diff changeset
   721
end.