hedgewars/uAI.pas
author koda
Sat, 06 Aug 2011 07:09:30 +0200
changeset 5505 a55aab592950
parent 5396 4a0a8f32b7e3
child 5495 272ed78e59a7
child 5600 c6da15eddab3
permissions -rw-r--r--
Ditch the renderer system in sdl1.3 and use the 'old fashioned' sdl/opengl context. This gives us more flexibility and less problem in receiving video events (expecially on mobile platform) as well as not having to care to reset the gl context every time sdl interferes. This is a major sdl1.3 update so it should be tested with care (working great on ios)
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
4
bcbd7adb4e4b - set svn:eol-style to native
unc0rr
parents: 1
diff changeset
     1
(*
1066
1f1b3686a2b0 Update copyright headers a bit
unc0rr
parents: 941
diff changeset
     2
 * Hedgewars, a free turn based strategy game
4976
088d40d8aba2 Happy 2011 :)
koda
parents: 4900
diff changeset
     3
 * Copyright (c) 2004-2011 Andrey Korotaev <unC0Rr@gmail.com>
4
bcbd7adb4e4b - set svn:eol-style to native
unc0rr
parents: 1
diff changeset
     4
 *
183
57c2ef19f719 Relicense to GPL
unc0rr
parents: 146
diff changeset
     5
 * This program is free software; you can redistribute it and/or modify
57c2ef19f719 Relicense to GPL
unc0rr
parents: 146
diff changeset
     6
 * it under the terms of the GNU General Public License as published by
57c2ef19f719 Relicense to GPL
unc0rr
parents: 146
diff changeset
     7
 * the Free Software Foundation; version 2 of the License
4
bcbd7adb4e4b - set svn:eol-style to native
unc0rr
parents: 1
diff changeset
     8
 *
183
57c2ef19f719 Relicense to GPL
unc0rr
parents: 146
diff changeset
     9
 * This program is distributed in the hope that it will be useful,
57c2ef19f719 Relicense to GPL
unc0rr
parents: 146
diff changeset
    10
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
57c2ef19f719 Relicense to GPL
unc0rr
parents: 146
diff changeset
    11
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
57c2ef19f719 Relicense to GPL
unc0rr
parents: 146
diff changeset
    12
 * GNU General Public License for more details.
4
bcbd7adb4e4b - set svn:eol-style to native
unc0rr
parents: 1
diff changeset
    13
 *
183
57c2ef19f719 Relicense to GPL
unc0rr
parents: 146
diff changeset
    14
 * You should have received a copy of the GNU General Public License
57c2ef19f719 Relicense to GPL
unc0rr
parents: 146
diff changeset
    15
 * along with this program; if not, write to the Free Software
57c2ef19f719 Relicense to GPL
unc0rr
parents: 146
diff changeset
    16
 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
4
bcbd7adb4e4b - set svn:eol-style to native
unc0rr
parents: 1
diff changeset
    17
 *)
bcbd7adb4e4b - set svn:eol-style to native
unc0rr
parents: 1
diff changeset
    18
2630
079ef82eac75 revamped file access and debug display
koda
parents: 2608
diff changeset
    19
{$INCLUDE "options.inc"}
079ef82eac75 revamped file access and debug display
koda
parents: 2608
diff changeset
    20
4
bcbd7adb4e4b - set svn:eol-style to native
unc0rr
parents: 1
diff changeset
    21
unit uAI;
bcbd7adb4e4b - set svn:eol-style to native
unc0rr
parents: 1
diff changeset
    22
interface
351
29bc9c36ad5f Fixed-point arithmetics in engine.
unc0rr
parents: 295
diff changeset
    23
uses uFloat;
2630
079ef82eac75 revamped file access and debug display
koda
parents: 2608
diff changeset
    24
3038
4e48c276a468 In pascal unit is a namespace
unc0rr
parents: 2948
diff changeset
    25
procedure initModule;
4e48c276a468 In pascal unit is a namespace
unc0rr
parents: 2948
diff changeset
    26
procedure freeModule;
2716
b9ca1bfca24f complete the replacement of init/free wrappers for every unit
koda
parents: 2695
diff changeset
    27
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
    28
procedure ProcessBot;
64
9df467527ae5 - Start AI rewrite
unc0rr
parents: 53
diff changeset
    29
procedure FreeActionsList;
4
bcbd7adb4e4b - set svn:eol-style to native
unc0rr
parents: 1
diff changeset
    30
bcbd7adb4e4b - set svn:eol-style to native
unc0rr
parents: 1
diff changeset
    31
implementation
4377
43945842da0c Haven't found a better place than uIO for OutError
unC0Rr
parents: 4374
diff changeset
    32
uses uConsts, SDLh, uAIMisc, uAIAmmoTests, uAIActions,
4373
fe0e3903bb9e Introduce uCommands.pas
unC0Rr
parents: 4372
diff changeset
    33
     uAmmos, SysUtils{$IFDEF UNIX}, cthreads{$ENDIF}, uTypes,
4403
unc0rr
parents: 4377
diff changeset
    34
     uVariables, uCommands, uUtils, uDebug;
4
bcbd7adb4e4b - set svn:eol-style to native
unc0rr
parents: 1
diff changeset
    35
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
    36
var BestActions: TActions;
509
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
    37
    CanUseAmmo: array [TAmmoType] of boolean;
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
    38
    StopThinking: boolean;
599
7c7b90c402d3 Fix THandle -> TThreadID
unc0rr
parents: 553
diff changeset
    39
    ThinkThread: TThreadID;
2716
b9ca1bfca24f complete the replacement of init/free wrappers for every unit
koda
parents: 2695
diff changeset
    40
    hasThread: LongInt;
599
7c7b90c402d3 Fix THandle -> TThreadID
unc0rr
parents: 553
diff changeset
    41
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
    42
procedure FreeActionsList;
64
9df467527ae5 - Start AI rewrite
unc0rr
parents: 53
diff changeset
    43
begin
4900
8ad0e23e6d63 addfilelog <3 debugfile
koda
parents: 4403
diff changeset
    44
AddFileLog('FreeActionsList called');
509
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
    45
if hasThread <> 0 then
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
    46
   begin
4900
8ad0e23e6d63 addfilelog <3 debugfile
koda
parents: 4403
diff changeset
    47
   AddFileLog('Waiting AI thread to finish');
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
    48
   StopThinking:= true;
509
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
    49
   repeat
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
    50
     SDL_Delay(10)
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
    51
   until hasThread = 0
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
    52
   end;
434
2c6ccce17f39 Many small improvements
unc0rr
parents: 433
diff changeset
    53
602
f7628ebfccde Add CurrentHedgehog variable which simplifies code
unc0rr
parents: 599
diff changeset
    54
with CurrentHedgehog^ do
445
fb66abeb551f Now really proper fix
unc0rr
parents: 442
diff changeset
    55
     if Gear <> nil then
fb66abeb551f Now really proper fix
unc0rr
parents: 442
diff changeset
    56
        if BotLevel <> 0 then
2289
cb850ba733bd Fix queue bug triggered by AI
unc0rr
parents: 1066
diff changeset
    57
           StopMessages(Gear^.Message);
740
5ac69a012b69 - Small cleanup
unc0rr
parents: 676
diff changeset
    58
64
9df467527ae5 - Start AI rewrite
unc0rr
parents: 53
diff changeset
    59
BestActions.Count:= 0;
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
    60
BestActions.Pos:= 0
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
    61
end;
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
    62
543
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
    63
procedure TestAmmos(var Actions: TActions; Me: PGear; isMoved: boolean);
3407
dcc129c4352e Engine:
smxx
parents: 3236
diff changeset
    64
var BotLevel: Byte;
543
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
    65
    ap: TAttackParams;
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
    66
    Score, i: LongInt;
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
    67
    a, aa: TAmmoType;
4
bcbd7adb4e4b - set svn:eol-style to native
unc0rr
parents: 1
diff changeset
    68
begin
4372
3836973380b9 remove some more PHedgehog casts
nemo
parents: 4368
diff changeset
    69
BotLevel:= Me^.Hedgehog^.BotLevel;
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
    70
64
9df467527ae5 - Start AI rewrite
unc0rr
parents: 53
diff changeset
    71
for i:= 0 to Pred(Targets.Count) do
509
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
    72
    if (Targets.ar[i].Score >= 0) and (not StopThinking) then
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
    73
       begin
602
f7628ebfccde Add CurrentHedgehog variable which simplifies code
unc0rr
parents: 599
diff changeset
    74
       with CurrentHedgehog^ do
3836
833c0f32e326 Change all use of curslot/idx to CurAmmoType to try and avoid some bugs with use of last weapon.
nemo
parents: 3617
diff changeset
    75
            a:= CurAmmoType;
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
    76
       aa:= a;
5396
4a0a8f32b7e3 This seems to be a much better place
unc0rr
parents: 5394
diff changeset
    77
       
4a0a8f32b7e3 This seems to be a much better place
unc0rr
parents: 5394
diff changeset
    78
       ThreadSwitch();
4a0a8f32b7e3 This seems to be a much better place
unc0rr
parents: 5394
diff changeset
    79
       
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
    80
       repeat
543
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
    81
        if (CanUseAmmo[a]) and
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
    82
           ((not isMoved) or ((AmmoTests[a].flags and amtest_OnTurn) = 0)) then
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
    83
           begin
3407
dcc129c4352e Engine:
smxx
parents: 3236
diff changeset
    84
{$HINTS OFF}
543
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
    85
           Score:= AmmoTests[a].proc(Me, Targets.ar[i].Point, BotLevel, ap);
3407
dcc129c4352e Engine:
smxx
parents: 3236
diff changeset
    86
{$HINTS ON}
139
340ded7cc336 Fixed AI bug, introduced by previous changes
unc0rr
parents: 136
diff changeset
    87
           if Actions.Score + Score > BestActions.Score then
3407
dcc129c4352e Engine:
smxx
parents: 3236
diff changeset
    88
            if (BestActions.Score < 0) or (Actions.Score + Score > BestActions.Score + Byte(BotLevel) * 2048) then
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
    89
              begin
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
    90
              BestActions:= Actions;
136
89970b70b076 Implement bot levels
unc0rr
parents: 111
diff changeset
    91
              inc(BestActions.Score, Score);
194
88652abdce9a Fixed weird bots behavior
unc0rr
parents: 193
diff changeset
    92
5162
60bc1af75c82 Fix AI trying to turn around in targeting mode
unc0rr
parents: 5148
diff changeset
    93
              if (ap.Angle > 0) then AddAction(BestActions, aia_LookRight, 0, 200, 0, 0)
60bc1af75c82 Fix AI trying to turn around in targeting mode
unc0rr
parents: 5148
diff changeset
    94
              else if (ap.Angle < 0) then AddAction(BestActions, aia_LookLeft, 0, 200, 0, 0);
60bc1af75c82 Fix AI trying to turn around in targeting mode
unc0rr
parents: 5148
diff changeset
    95
543
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
    96
              AddAction(BestActions, aia_Weapon, Longword(a), 300 + random(400), 0, 0);
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
    97
              if (ap.Time <> 0) then AddAction(BestActions, aia_Timer, ap.Time div 1000, 400, 0, 0);
83
207c85fbef51 - First hedgehog in team has first turn in team
unc0rr
parents: 82
diff changeset
    98
              if (Ammoz[a].Ammo.Propz and ammoprop_NoCrosshair) = 0 then
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
    99
                 begin
543
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
   100
                 ap.Angle:= LongInt(Me^.Angle) - Abs(ap.Angle);
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
   101
                 if ap.Angle > 0 then
83
207c85fbef51 - First hedgehog in team has first turn in team
unc0rr
parents: 82
diff changeset
   102
                    begin
543
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
   103
                    AddAction(BestActions, aia_Up, aim_push, 300 + random(250), 0, 0);
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
   104
                    AddAction(BestActions, aia_Up, aim_release, ap.Angle, 0, 0)
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
   105
                    end else if ap.Angle < 0 then
83
207c85fbef51 - First hedgehog in team has first turn in team
unc0rr
parents: 82
diff changeset
   106
                    begin
543
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
   107
                    AddAction(BestActions, aia_Down, aim_push, 300 + random(250), 0, 0);
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
   108
                    AddAction(BestActions, aia_Down, aim_release, -ap.Angle, 0, 0)
83
207c85fbef51 - First hedgehog in team has first turn in team
unc0rr
parents: 82
diff changeset
   109
                    end
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   110
                 end;
543
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
   111
              if (Ammoz[a].Ammo.Propz and ammoprop_NeedTarget) <> 0 then
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
   112
                 begin
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
   113
                 AddAction(BestActions, aia_Put, 0, 1, ap.AttackPutX, ap.AttackPutY)
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
   114
                 end;
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
   115
              if (Ammoz[a].Ammo.Propz and ammoprop_AttackingPut) = 0 then
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
   116
                 begin
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
   117
                 AddAction(BestActions, aia_attack, aim_push, 650 + random(300), 0, 0);
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
   118
                 AddAction(BestActions, aia_attack, aim_release, ap.Power, 0, 0);
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
   119
                 end;
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
   120
              if ap.ExplR > 0 then
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
   121
                 AddAction(BestActions, aia_AwareExpl, ap.ExplR, 10, ap.ExplX, ap.ExplY);
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   122
              end
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   123
           end;
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   124
        if a = High(TAmmoType) then a:= Low(TAmmoType)
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   125
                               else inc(a)
509
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
   126
       until (a = aa) or
2608
cebfea02f8b5 - Formatting changes
unc0rr
parents: 2605
diff changeset
   127
             (CurrentHedgehog^.MultiShootAttacks > 0) or // shooting same weapon
509
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
   128
             StopThinking
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   129
       end
64
9df467527ae5 - Start AI rewrite
unc0rr
parents: 53
diff changeset
   130
end;
4
bcbd7adb4e4b - set svn:eol-style to native
unc0rr
parents: 1
diff changeset
   131
64
9df467527ae5 - Start AI rewrite
unc0rr
parents: 53
diff changeset
   132
procedure Walk(Me: PGear);
80
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 75
diff changeset
   133
const FallPixForBranching = cHHRadius * 2 + 8;
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   134
      cBranchStackSize = 12;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   135
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   136
type TStackEntry = record
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   137
                   WastedTicks: Longword;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   138
                   MadeActions: TActions;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   139
                   Hedgehog: TGear;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   140
                   end;
941
b5222ddafe1f - Fix bug with picking up ammos from cases, when total ammo count may become more than AMMO_INFINITE
unc0rr
parents: 936
diff changeset
   141
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   142
var Stack: record
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   143
           Count: Longword;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   144
           States: array[0..Pred(cBranchStackSize)] of TStackEntry;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   145
           end;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   146
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   147
    function Push(Ticks: Longword; const Actions: TActions; const Me: TGear; Dir: integer): boolean;
2695
ed789a7ef68d makes freepascal code compatible with OBJFPC mode
koda
parents: 2630
diff changeset
   148
    var bRes: boolean;
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   149
    begin
2695
ed789a7ef68d makes freepascal code compatible with OBJFPC mode
koda
parents: 2630
diff changeset
   150
    bRes:= (Stack.Count < cBranchStackSize) and (Actions.Count < MAXACTIONS - 5);
ed789a7ef68d makes freepascal code compatible with OBJFPC mode
koda
parents: 2630
diff changeset
   151
    if bRes then
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   152
       with Stack.States[Stack.Count] do
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   153
            begin
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   154
            WastedTicks:= Ticks;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   155
            MadeActions:= Actions;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   156
            Hedgehog:= Me;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   157
            Hedgehog.Message:= Dir;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   158
            inc(Stack.Count)
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   159
            end;
2695
ed789a7ef68d makes freepascal code compatible with OBJFPC mode
koda
parents: 2630
diff changeset
   160
    Push:= bRes
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   161
    end;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   162
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   163
    procedure Pop(var Ticks: Longword; var Actions: TActions; var Me: TGear);
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   164
    begin
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   165
    dec(Stack.Count);
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   166
    with Stack.States[Stack.Count] do
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   167
         begin
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   168
         Ticks:= WastedTicks;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   169
         Actions:= MadeActions;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   170
         Me:= Hedgehog
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   171
         end
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   172
    end;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   173
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   174
    function PosInThinkStack(Me: PGear): boolean;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   175
    var i: Longword;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   176
    begin
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   177
    i:= 0;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   178
    while (i < Stack.Count) do
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   179
          begin
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   180
          if(not(hwAbs(Stack.States[i].Hedgehog.X - Me^.X) +
498
9c8b385dc9a1 - Get rid of operator := to have GPC support
unc0rr
parents: 445
diff changeset
   181
                 hwAbs(Stack.States[i].Hedgehog.Y - Me^.Y) > _2)) and
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   182
              (Stack.States[i].Hedgehog.Message = Me^.Message) then exit(true);
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   183
          inc(i)
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   184
          end;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   185
    PosInThinkStack:= false
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   186
    end;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   187
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   188
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   189
var Actions: TActions;
3407
dcc129c4352e Engine:
smxx
parents: 3236
diff changeset
   190
    ticks, maxticks, steps, tmp: Longword;
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   191
    BaseRate, BestRate, Rate: integer;
75
d2b737858ff7 - New First Aid powerup
unc0rr
parents: 74
diff changeset
   192
    GoInfo: TGoInfo;
80
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 75
diff changeset
   193
    CanGo: boolean;
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 75
diff changeset
   194
    AltMe: TGear;
3407
dcc129c4352e Engine:
smxx
parents: 3236
diff changeset
   195
    BotLevel: Byte;
64
9df467527ae5 - Start AI rewrite
unc0rr
parents: 53
diff changeset
   196
begin
3407
dcc129c4352e Engine:
smxx
parents: 3236
diff changeset
   197
ticks:= 0; // avoid compiler hint
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   198
Actions.Count:= 0;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   199
Actions.Pos:= 0;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   200
Actions.Score:= 0;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   201
Stack.Count:= 0;
4372
3836973380b9 remove some more PHedgehog casts
nemo
parents: 4368
diff changeset
   202
BotLevel:= Me^.Hedgehog^.BotLevel;
75
d2b737858ff7 - New First Aid powerup
unc0rr
parents: 74
diff changeset
   203
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   204
tmp:= random(2) + 1;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   205
Push(0, Actions, Me^, tmp);
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   206
Push(0, Actions, Me^, tmp xor 3);
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   207
4374
bcefeeabaa33 Move some stuff from uMisc to uUtils
unC0Rr
parents: 4373
diff changeset
   208
if (Me^.State and gstAttacked) = 0 then maxticks:= Max(0, TurnTimeLeft - 5000 - LongWord(4000 * BotLevel))
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   209
                                   else maxticks:= TurnTimeLeft;
75
d2b737858ff7 - New First Aid powerup
unc0rr
parents: 74
diff changeset
   210
543
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
   211
if (Me^.State and gstAttacked) = 0 then TestAmmos(Actions, Me, false);
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   212
BestRate:= RatePlace(Me);
4374
bcefeeabaa33 Move some stuff from uMisc to uUtils
unC0Rr
parents: 4373
diff changeset
   213
BaseRate:= Max(BestRate, 0);
75
d2b737858ff7 - New First Aid powerup
unc0rr
parents: 74
diff changeset
   214
5148
73b3b4b8359c Make AI switch to amNothing before trying to walk if it holds weapon which needs targeting (not tested)
unc0rr
parents: 4976
diff changeset
   215
if (Ammoz[Me^.Hedgehog^.CurAmmoType].Ammo.Propz and ammoprop_NeedTarget) <> 0 then
73b3b4b8359c Make AI switch to amNothing before trying to walk if it holds weapon which needs targeting (not tested)
unc0rr
parents: 4976
diff changeset
   216
    AddAction(Actions, aia_Weapon, Longword(amNothing), 100 + random(200), 0, 0);
73b3b4b8359c Make AI switch to amNothing before trying to walk if it holds weapon which needs targeting (not tested)
unc0rr
parents: 4976
diff changeset
   217
2605
a40a7c90ffd8 AI knows what artillery mode is
unc0rr
parents: 2599
diff changeset
   218
while (Stack.Count > 0) and (not StopThinking) and (GameFlags and gfArtillery = 0) do
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   219
    begin
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   220
    Pop(ticks, Actions, Me^);
193
56885ea29202 Fix bots regressions
unc0rr
parents: 191
diff changeset
   221
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   222
    AddAction(Actions, Me^.Message, aim_push, 250, 0, 0);
3894
9abce5468583 Engine:
smaxx
parents: 3836
diff changeset
   223
    if (Me^.Message and gmLeft) <> 0 then AddAction(Actions, aia_WaitXL, hwRound(Me^.X), 0, 0, 0)
370
c75410fe3133 - Repair bots: they can walk and use bazooka, possible cannot jump (why?)
unc0rr
parents: 369
diff changeset
   224
                                      else AddAction(Actions, aia_WaitXR, hwRound(Me^.X), 0, 0, 0);
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   225
    steps:= 0;
82
2f4f3236cccc - New fort
unc0rr
parents: 80
diff changeset
   226
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   227
    while (not StopThinking) and (not PosInThinkStack(Me)) do
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   228
       begin
3407
dcc129c4352e Engine:
smxx
parents: 3236
diff changeset
   229
{$HINTS OFF}
80
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 75
diff changeset
   230
       CanGo:= HHGo(Me, @AltMe, GoInfo);
3407
dcc129c4352e Engine:
smxx
parents: 3236
diff changeset
   231
{$HINTS ON}
75
d2b737858ff7 - New First Aid powerup
unc0rr
parents: 74
diff changeset
   232
       inc(ticks, GoInfo.Ticks);
d2b737858ff7 - New First Aid powerup
unc0rr
parents: 74
diff changeset
   233
       if ticks > maxticks then break;
194
88652abdce9a Fixed weird bots behavior
unc0rr
parents: 193
diff changeset
   234
136
89970b70b076 Implement bot levels
unc0rr
parents: 111
diff changeset
   235
       if (BotLevel < 5) and (GoInfo.JumpType = jmpHJump) then // hjump support
80
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 75
diff changeset
   236
          if Push(ticks, Actions, AltMe, Me^.Message) then
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   237
             with Stack.States[Pred(Stack.Count)] do
80
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 75
diff changeset
   238
                  begin
791
928d2830fd0c Make AI aware of new high jump technique (there's still an issue with two successive jumps)
unc0rr
parents: 741
diff changeset
   239
                  if Me^.dX.isNegative then AddAction(MadeActions, aia_LookRight, 0, 200, 0, 0)
928d2830fd0c Make AI aware of new high jump technique (there's still an issue with two successive jumps)
unc0rr
parents: 741
diff changeset
   240
                                       else AddAction(MadeActions, aia_LookLeft, 0, 200, 0, 0);
928d2830fd0c Make AI aware of new high jump technique (there's still an issue with two successive jumps)
unc0rr
parents: 741
diff changeset
   241
                  AddAction(MadeActions, aia_HJump, 0, 305 + random(50), 0, 0);
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   242
                  AddAction(MadeActions, aia_HJump, 0, 350, 0, 0);
791
928d2830fd0c Make AI aware of new high jump technique (there's still an issue with two successive jumps)
unc0rr
parents: 741
diff changeset
   243
                  if Me^.dX.isNegative then AddAction(MadeActions, aia_LookLeft, 0, 200, 0, 0)
928d2830fd0c Make AI aware of new high jump technique (there's still an issue with two successive jumps)
unc0rr
parents: 741
diff changeset
   244
                                       else AddAction(MadeActions, aia_LookRight, 0, 200, 0, 0);
80
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 75
diff changeset
   245
                  end;
136
89970b70b076 Implement bot levels
unc0rr
parents: 111
diff changeset
   246
       if (BotLevel < 3) and (GoInfo.JumpType = jmpLJump) then // ljump support
80
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 75
diff changeset
   247
          if Push(ticks, Actions, AltMe, Me^.Message) then
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   248
             with Stack.States[Pred(Stack.Count)] do
791
928d2830fd0c Make AI aware of new high jump technique (there's still an issue with two successive jumps)
unc0rr
parents: 741
diff changeset
   249
                  AddAction(MadeActions, aia_LJump, 0, 305 + random(50), 0, 0);
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   250
80
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 75
diff changeset
   251
       if not CanGo then break;
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   252
       inc(steps);
544
9e068d2398ca Fix AI jumping to wrong direction on the turn start
unc0rr
parents: 543
diff changeset
   253
       Actions.actions[Pred(Actions.Count)].Param:= hwRound(Me^.X);
70
82d93eeecebe - Many AI improvements
unc0rr
parents: 66
diff changeset
   254
       Rate:= RatePlace(Me);
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   255
       if Rate > BestRate then
70
82d93eeecebe - Many AI improvements
unc0rr
parents: 66
diff changeset
   256
          begin
82d93eeecebe - Many AI improvements
unc0rr
parents: 66
diff changeset
   257
          BestActions:= Actions;
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   258
          BestRate:= Rate;
2580
aeccc8f51d3f completes touch input/control (problems with moving camera)
koda
parents: 2376
diff changeset
   259
          Me^.State:= Me^.State or gstAttacked // we have better place, go there and do not use ammo
70
82d93eeecebe - Many AI improvements
unc0rr
parents: 66
diff changeset
   260
          end
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   261
       else if Rate < BestRate then break;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   262
       if ((Me^.State and gstAttacked) = 0)
543
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
   263
           and ((steps mod 4) = 0) then TestAmmos(Actions, Me, true);
193
56885ea29202 Fix bots regressions
unc0rr
parents: 191
diff changeset
   264
       if GoInfo.FallPix >= FallPixForBranching then
56885ea29202 Fix bots regressions
unc0rr
parents: 191
diff changeset
   265
          Push(ticks, Actions, Me^, Me^.Message xor 3); // aia_Left xor 3 = aia_Right
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   266
       end;
193
56885ea29202 Fix bots regressions
unc0rr
parents: 191
diff changeset
   267
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   268
    if BestRate > BaseRate then exit
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   269
    end
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   270
end;
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   271
508
f5473c50adbd Now really fix compilation
unc0rr
parents: 507
diff changeset
   272
function Think(Me: Pointer): ptrint;
74
42257fee61ae - Unicode support for team and hedgehogs names
unc0rr
parents: 71
diff changeset
   273
var BackMe, WalkMe: TGear;
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   274
    StartTicks: Longword;
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   275
begin
509
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
   276
InterlockedIncrement(hasThread);
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   277
StartTicks:= GameTicks;
500
d9b140e9d2c2 Use freepascal's routines to manipulate threads
unc0rr
parents: 498
diff changeset
   278
BackMe:= PGear(Me)^;
509
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
   279
500
d9b140e9d2c2 Use freepascal's routines to manipulate threads
unc0rr
parents: 498
diff changeset
   280
if (PGear(Me)^.State and gstAttacked) = 0 then
74
42257fee61ae - Unicode support for team and hedgehogs names
unc0rr
parents: 71
diff changeset
   281
   if Targets.Count > 0 then
42257fee61ae - Unicode support for team and hedgehogs names
unc0rr
parents: 71
diff changeset
   282
      begin
509
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
   283
      WalkMe:= BackMe;
74
42257fee61ae - Unicode support for team and hedgehogs names
unc0rr
parents: 71
diff changeset
   284
      Walk(@WalkMe);
5394
924584407e01 This should improve performance on singlecore computers
unc0rr
parents: 5388
diff changeset
   285
      if (StartTicks > GameTicks - 1500) and not StopThinking then SDL_Delay(1000);
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   286
      if BestActions.Score < -1023 then
146
458f4f58c1b6 - Fix AI not to damage self hedgehogs
unc0rr
parents: 144
diff changeset
   287
         begin
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   288
         BestActions.Count:= 0;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   289
         AddAction(BestActions, aia_Skip, 0, 250, 0, 0);
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   290
         end;
80
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 75
diff changeset
   291
      end else
74
42257fee61ae - Unicode support for team and hedgehogs names
unc0rr
parents: 71
diff changeset
   292
else begin
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   293
      while (not StopThinking) and (BestActions.Count = 0) do
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   294
            begin
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   295
            FillBonuses(true);
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   296
            WalkMe:= BackMe;
509
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
   297
            Walk(@WalkMe);
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
   298
            if not StopThinking then SDL_Delay(100)
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   299
            end
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   300
      end;
500
d9b140e9d2c2 Use freepascal's routines to manipulate threads
unc0rr
parents: 498
diff changeset
   301
PGear(Me)^.State:= PGear(Me)^.State and not gstHHThinking;
509
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
   302
Think:= 0;
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
   303
InterlockedDecrement(hasThread)
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   304
end;
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   305
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   306
procedure StartThink(Me: PGear);
75
d2b737858ff7 - New First Aid powerup
unc0rr
parents: 74
diff changeset
   307
var a: TAmmoType;
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   308
begin
542
ec26095f1bed - Get rid of ammoProp_AttackInFall and gstFalling
unc0rr
parents: 522
diff changeset
   309
if ((Me^.State and (gstAttacking or gstHHJumping or gstMoving)) <> 0)
439
c336ed82e76d Fix bugs:
unc0rr
parents: 434
diff changeset
   310
   or isInMultiShoot then exit;
506
0889d833d47e - A good implementation of shotgun
unc0rr
parents: 500
diff changeset
   311
2376
ece7b87f1334 Strip trailing spaces
nemo
parents: 2289
diff changeset
   312
//DeleteCI(Me); // this might break demo
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   313
Me^.State:= Me^.State or gstHHThinking;
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   314
Me^.Message:= 0;
509
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
   315
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
   316
BestActions.Count:= 0;
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
   317
BestActions.Pos:= 0;
5163
1620a02d5282 Fix test for water in airstrike handler
unc0rr
parents: 5162
diff changeset
   318
BestActions.Score:= Low(LongInt);
509
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
   319
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   320
StopThinking:= false;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   321
ThinkingHH:= Me;
509
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
   322
70
82d93eeecebe - Many AI improvements
unc0rr
parents: 66
diff changeset
   323
FillTargets;
80
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 75
diff changeset
   324
if Targets.Count = 0 then
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 75
diff changeset
   325
   begin
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   326
   OutError('AI: no targets!?', false);
80
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 75
diff changeset
   327
   exit
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 75
diff changeset
   328
   end;
941
b5222ddafe1f - Fix bug with picking up ammos from cases, when total ammo count may become more than AMMO_INFINITE
unc0rr
parents: 936
diff changeset
   329
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   330
FillBonuses((Me^.State and gstAttacked) <> 0);
75
d2b737858ff7 - New First Aid powerup
unc0rr
parents: 74
diff changeset
   331
for a:= Low(TAmmoType) to High(TAmmoType) do
4372
3836973380b9 remove some more PHedgehog casts
nemo
parents: 4368
diff changeset
   332
    CanUseAmmo[a]:= Assigned(AmmoTests[a].proc) and HHHasAmmo(Me^.Hedgehog^, a);
4900
8ad0e23e6d63 addfilelog <3 debugfile
koda
parents: 4403
diff changeset
   333
AddFileLog('Enter Think Thread');
500
d9b140e9d2c2 Use freepascal's routines to manipulate threads
unc0rr
parents: 498
diff changeset
   334
BeginThread(@Think, Me, ThinkThread)
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   335
end;
191
a03c2d037e24 Bots are in the same thread as game. Fixes FreePascal issues.
unc0rr
parents: 183
diff changeset
   336
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   337
procedure ProcessBot;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   338
const StartTicks: Longword = 0;
509
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
   339
      cStopThinkTime = 40;
4
bcbd7adb4e4b - set svn:eol-style to native
unc0rr
parents: 1
diff changeset
   340
begin
602
f7628ebfccde Add CurrentHedgehog variable which simplifies code
unc0rr
parents: 599
diff changeset
   341
with CurrentHedgehog^ do
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   342
     if (Gear <> nil)
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   343
        and ((Gear^.State and gstHHDriven) <> 0)
4225
ce9e2b05e9c1 Revert yet again for breaking stuff. No more chances on this. If there'd been a release, this would have been twice with serious breakage. P.S. - as per koda's complaint last time, only reverted the non-iphone, probably means iphone is now broken. Oh well.
nemo
parents: 4211
diff changeset
   344
        and (TurnTimeLeft < cHedgehogTurnTime - 50) then
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   345
        if ((Gear^.State and gstHHThinking) = 0) then
509
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
   346
           if (BestActions.Pos >= BestActions.Count)
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
   347
              and (TurnTimeLeft > cStopThinkTime) then
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   348
              begin
936
ba582673db7d Fix 'AI may break demos playing' message while loading saves
unc0rr
parents: 883
diff changeset
   349
              if Gear^.Message <> 0 then
ba582673db7d Fix 'AI may break demos playing' message while loading saves
unc0rr
parents: 883
diff changeset
   350
                 begin
ba582673db7d Fix 'AI may break demos playing' message while loading saves
unc0rr
parents: 883
diff changeset
   351
                 StopMessages(Gear^.Message);
ba582673db7d Fix 'AI may break demos playing' message while loading saves
unc0rr
parents: 883
diff changeset
   352
                 TryDo((Gear^.Message and gmAllStoppable) = 0, 'Engine bug: AI may break demos playing', true);
ba582673db7d Fix 'AI may break demos playing' message while loading saves
unc0rr
parents: 883
diff changeset
   353
                 end;
ba582673db7d Fix 'AI may break demos playing' message while loading saves
unc0rr
parents: 883
diff changeset
   354
              if Gear^.Message <> 0 then exit;
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   355
              StartThink(Gear);
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   356
              StartTicks:= GameTicks
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   357
              end else ProcessAction(BestActions, Gear)
509
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
   358
        else if ((GameTicks - StartTicks) > cMaxAIThinkTime)
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
   359
                or (TurnTimeLeft <= cStopThinkTime) then StopThinking:= true
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   360
end;
4
bcbd7adb4e4b - set svn:eol-style to native
unc0rr
parents: 1
diff changeset
   361
3038
4e48c276a468 In pascal unit is a namespace
unc0rr
parents: 2948
diff changeset
   362
procedure initModule;
2716
b9ca1bfca24f complete the replacement of init/free wrappers for every unit
koda
parents: 2695
diff changeset
   363
begin
2948
3f21a9dc93d0 Replace tabs with spaces using 'expand -t 4' command
unc0rr
parents: 2716
diff changeset
   364
    hasThread:= 0;
2716
b9ca1bfca24f complete the replacement of init/free wrappers for every unit
koda
parents: 2695
diff changeset
   365
end;
b9ca1bfca24f complete the replacement of init/free wrappers for every unit
koda
parents: 2695
diff changeset
   366
3038
4e48c276a468 In pascal unit is a namespace
unc0rr
parents: 2948
diff changeset
   367
procedure freeModule;
2716
b9ca1bfca24f complete the replacement of init/free wrappers for every unit
koda
parents: 2695
diff changeset
   368
begin
3617
1df21e06b8ba a couple of fixes i missed previously
koda
parents: 3615
diff changeset
   369
2716
b9ca1bfca24f complete the replacement of init/free wrappers for every unit
koda
parents: 2695
diff changeset
   370
end;
b9ca1bfca24f complete the replacement of init/free wrappers for every unit
koda
parents: 2695
diff changeset
   371
4
bcbd7adb4e4b - set svn:eol-style to native
unc0rr
parents: 1
diff changeset
   372
end.