hedgewars/uAI.pas
author nemo
Sun, 24 Jan 2010 16:46:06 +0000
changeset 2712 8f4527c9137c
parent 2695 ed789a7ef68d
child 2716 b9ca1bfca24f
permissions -rw-r--r--
Minor tweak, try to make long flavour text last longer, move the hurt self messages to unused messages group, so they don't get wiped by crate an instant later.
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
883
07a568ba44e0 Update copyright info in source files headers
unc0rr
parents: 791
diff changeset
     3
 * Copyright (c) 2005-2008 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
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
    25
procedure ProcessBot;
64
9df467527ae5 - Start AI rewrite
unc0rr
parents: 53
diff changeset
    26
procedure FreeActionsList;
4
bcbd7adb4e4b - set svn:eol-style to native
unc0rr
parents: 1
diff changeset
    27
bcbd7adb4e4b - set svn:eol-style to native
unc0rr
parents: 1
diff changeset
    28
implementation
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
    29
uses uTeams, uConsts, SDLh, uAIMisc, uGears, uAIAmmoTests, uAIActions, uMisc,
509
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
    30
     uAmmos, uConsole, uCollisions, SysUtils{$IFDEF UNIX}, cthreads{$ENDIF};
4
bcbd7adb4e4b - set svn:eol-style to native
unc0rr
parents: 1
diff changeset
    31
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
    32
var BestActions: TActions;
509
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
    33
    CanUseAmmo: array [TAmmoType] of boolean;
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
    34
    StopThinking: boolean;
599
7c7b90c402d3 Fix THandle -> TThreadID
unc0rr
parents: 553
diff changeset
    35
    ThinkThread: TThreadID;
509
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
    36
    hasThread: LongInt = 0;
599
7c7b90c402d3 Fix THandle -> TThreadID
unc0rr
parents: 553
diff changeset
    37
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
    38
procedure FreeActionsList;
64
9df467527ae5 - Start AI rewrite
unc0rr
parents: 53
diff changeset
    39
begin
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
    40
{$IFDEF DEBUGFILE}AddFileLog('FreeActionsList called');{$ENDIF}
509
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
    41
if hasThread <> 0 then
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
    42
   begin
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
    43
   {$IFDEF DEBUGFILE}AddFileLog('Waiting AI thread to finish');{$ENDIF}
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
    44
   StopThinking:= true;
509
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
    45
   repeat
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
    46
     SDL_Delay(10)
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
    47
   until hasThread = 0
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
    48
   end;
434
2c6ccce17f39 Many small improvements
unc0rr
parents: 433
diff changeset
    49
602
f7628ebfccde Add CurrentHedgehog variable which simplifies code
unc0rr
parents: 599
diff changeset
    50
with CurrentHedgehog^ do
445
fb66abeb551f Now really proper fix
unc0rr
parents: 442
diff changeset
    51
     if Gear <> nil then
fb66abeb551f Now really proper fix
unc0rr
parents: 442
diff changeset
    52
        if BotLevel <> 0 then
2289
cb850ba733bd Fix queue bug triggered by AI
unc0rr
parents: 1066
diff changeset
    53
           StopMessages(Gear^.Message);
740
5ac69a012b69 - Small cleanup
unc0rr
parents: 676
diff changeset
    54
64
9df467527ae5 - Start AI rewrite
unc0rr
parents: 53
diff changeset
    55
BestActions.Count:= 0;
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
    56
BestActions.Pos:= 0
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
    57
end;
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
    58
543
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
    59
procedure TestAmmos(var Actions: TActions; Me: PGear; isMoved: boolean);
545
f527450337c1 Fix some warnings
unc0rr
parents: 544
diff changeset
    60
var BotLevel: Longword;
543
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
    61
    ap: TAttackParams;
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
    62
    Score, i: LongInt;
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
    63
    a, aa: TAmmoType;
4
bcbd7adb4e4b - set svn:eol-style to native
unc0rr
parents: 1
diff changeset
    64
begin
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
    65
BotLevel:= PHedgehog(Me^.Hedgehog)^.BotLevel;
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
    66
64
9df467527ae5 - Start AI rewrite
unc0rr
parents: 53
diff changeset
    67
for i:= 0 to Pred(Targets.Count) do
509
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
    68
    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
    69
       begin
602
f7628ebfccde Add CurrentHedgehog variable which simplifies code
unc0rr
parents: 599
diff changeset
    70
       with CurrentHedgehog^ do
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
    71
            a:= Ammo^[CurSlot, CurAmmo].AmmoType;
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
    72
       aa:= a;
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
    73
       repeat
543
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
    74
        if (CanUseAmmo[a]) and
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
    75
           ((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
    76
           begin
543
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
    77
           Score:= AmmoTests[a].proc(Me, Targets.ar[i].Point, BotLevel, ap);
139
340ded7cc336 Fixed AI bug, introduced by previous changes
unc0rr
parents: 136
diff changeset
    78
           if Actions.Score + Score > BestActions.Score then
543
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
    79
            if (BestActions.Score < 0) or (Actions.Score + Score > BestActions.Score + LongInt(BotLevel) * 2048) then
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
    80
              begin
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
    81
              BestActions:= Actions;
136
89970b70b076 Implement bot levels
unc0rr
parents: 111
diff changeset
    82
              inc(BestActions.Score, Score);
194
88652abdce9a Fixed weird bots behavior
unc0rr
parents: 193
diff changeset
    83
543
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
    84
              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
    85
              if (ap.Time <> 0) then AddAction(BestActions, aia_Timer, ap.Time div 1000, 400, 0, 0);
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
    86
              if (ap.Angle > 0) then AddAction(BestActions, aia_LookRight, 0, 200, 0, 0)
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
    87
              else if (ap.Angle < 0) then AddAction(BestActions, aia_LookLeft, 0, 200, 0, 0);
83
207c85fbef51 - First hedgehog in team has first turn in team
unc0rr
parents: 82
diff changeset
    88
              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
    89
                 begin
543
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
    90
                 ap.Angle:= LongInt(Me^.Angle) - Abs(ap.Angle);
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
    91
                 if ap.Angle > 0 then
83
207c85fbef51 - First hedgehog in team has first turn in team
unc0rr
parents: 82
diff changeset
    92
                    begin
543
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
    93
                    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
    94
                    AddAction(BestActions, aia_Up, aim_release, ap.Angle, 0, 0)
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
    95
                    end else if ap.Angle < 0 then
83
207c85fbef51 - First hedgehog in team has first turn in team
unc0rr
parents: 82
diff changeset
    96
                    begin
543
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
    97
                    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
    98
                    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
    99
                    end
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   100
                 end;
543
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
   101
              if (Ammoz[a].Ammo.Propz and ammoprop_NeedTarget) <> 0 then
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
   102
                 begin
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
   103
                 AddAction(BestActions, aia_Put, 0, 1, ap.AttackPutX, ap.AttackPutY)
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
   104
                 end;
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
   105
              if (Ammoz[a].Ammo.Propz and ammoprop_AttackingPut) = 0 then
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
   106
                 begin
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
   107
                 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
   108
                 AddAction(BestActions, aia_attack, aim_release, ap.Power, 0, 0);
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
   109
                 end;
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
   110
              if ap.ExplR > 0 then
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
   111
                 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
   112
              end
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   113
           end;
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   114
        if a = High(TAmmoType) then a:= Low(TAmmoType)
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   115
                               else inc(a)
509
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
   116
       until (a = aa) or
2608
cebfea02f8b5 - Formatting changes
unc0rr
parents: 2605
diff changeset
   117
             (CurrentHedgehog^.MultiShootAttacks > 0) or // shooting same weapon
509
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
   118
             StopThinking
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   119
       end
64
9df467527ae5 - Start AI rewrite
unc0rr
parents: 53
diff changeset
   120
end;
4
bcbd7adb4e4b - set svn:eol-style to native
unc0rr
parents: 1
diff changeset
   121
64
9df467527ae5 - Start AI rewrite
unc0rr
parents: 53
diff changeset
   122
procedure Walk(Me: PGear);
80
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 75
diff changeset
   123
const FallPixForBranching = cHHRadius * 2 + 8;
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   124
      cBranchStackSize = 12;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   125
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   126
type TStackEntry = record
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   127
                   WastedTicks: Longword;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   128
                   MadeActions: TActions;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   129
                   Hedgehog: TGear;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   130
                   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
   131
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   132
var Stack: record
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   133
           Count: Longword;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   134
           States: array[0..Pred(cBranchStackSize)] of TStackEntry;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   135
           end;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   136
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   137
    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
   138
    var bRes: boolean;
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   139
    begin
2695
ed789a7ef68d makes freepascal code compatible with OBJFPC mode
koda
parents: 2630
diff changeset
   140
    bRes:= (Stack.Count < cBranchStackSize) and (Actions.Count < MAXACTIONS - 5);
ed789a7ef68d makes freepascal code compatible with OBJFPC mode
koda
parents: 2630
diff changeset
   141
    if bRes then
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   142
       with Stack.States[Stack.Count] do
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   143
            begin
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   144
            WastedTicks:= Ticks;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   145
            MadeActions:= Actions;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   146
            Hedgehog:= Me;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   147
            Hedgehog.Message:= Dir;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   148
            inc(Stack.Count)
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   149
            end;
2695
ed789a7ef68d makes freepascal code compatible with OBJFPC mode
koda
parents: 2630
diff changeset
   150
    Push:= bRes
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   151
    end;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   152
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   153
    procedure Pop(var Ticks: Longword; var Actions: TActions; var Me: TGear);
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   154
    begin
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   155
    dec(Stack.Count);
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   156
    with Stack.States[Stack.Count] do
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   157
         begin
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   158
         Ticks:= WastedTicks;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   159
         Actions:= MadeActions;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   160
         Me:= Hedgehog
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
    end;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   163
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   164
    function PosInThinkStack(Me: PGear): boolean;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   165
    var i: Longword;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   166
    begin
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   167
    i:= 0;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   168
    while (i < Stack.Count) do
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   169
          begin
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   170
          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
   171
                 hwAbs(Stack.States[i].Hedgehog.Y - Me^.Y) > _2)) and
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   172
              (Stack.States[i].Hedgehog.Message = Me^.Message) then exit(true);
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   173
          inc(i)
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   174
          end;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   175
    PosInThinkStack:= false
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   176
    end;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   177
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   178
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   179
var Actions: TActions;
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   180
    ticks, maxticks, steps, BotLevel, tmp: Longword;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   181
    BaseRate, BestRate, Rate: integer;
75
d2b737858ff7 - New First Aid powerup
unc0rr
parents: 74
diff changeset
   182
    GoInfo: TGoInfo;
80
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 75
diff changeset
   183
    CanGo: boolean;
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 75
diff changeset
   184
    AltMe: TGear;
64
9df467527ae5 - Start AI rewrite
unc0rr
parents: 53
diff changeset
   185
begin
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   186
Actions.Count:= 0;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   187
Actions.Pos:= 0;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   188
Actions.Score:= 0;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   189
Stack.Count:= 0;
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   190
BotLevel:= PHedgehog(Me^.Hedgehog)^.BotLevel;
75
d2b737858ff7 - New First Aid powerup
unc0rr
parents: 74
diff changeset
   191
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   192
tmp:= random(2) + 1;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   193
Push(0, Actions, Me^, tmp);
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   194
Push(0, Actions, Me^, tmp xor 3);
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   195
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   196
if (Me^.State and gstAttacked) = 0 then maxticks:= max(0, TurnTimeLeft - 5000 - 4000 * BotLevel)
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   197
                                   else maxticks:= TurnTimeLeft;
75
d2b737858ff7 - New First Aid powerup
unc0rr
parents: 74
diff changeset
   198
543
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
   199
if (Me^.State and gstAttacked) = 0 then TestAmmos(Actions, Me, false);
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   200
BestRate:= RatePlace(Me);
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   201
BaseRate:= max(BestRate, 0);
75
d2b737858ff7 - New First Aid powerup
unc0rr
parents: 74
diff changeset
   202
2605
a40a7c90ffd8 AI knows what artillery mode is
unc0rr
parents: 2599
diff changeset
   203
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
   204
    begin
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   205
    Pop(ticks, Actions, Me^);
193
56885ea29202 Fix bots regressions
unc0rr
parents: 191
diff changeset
   206
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   207
    AddAction(Actions, Me^.Message, aim_push, 250, 0, 0);
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   208
    if (Me^.Message and gm_Left) <> 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
   209
                                      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
   210
    steps:= 0;
82
2f4f3236cccc - New fort
unc0rr
parents: 80
diff changeset
   211
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   212
    while (not StopThinking) and (not PosInThinkStack(Me)) do
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   213
       begin
80
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 75
diff changeset
   214
       CanGo:= HHGo(Me, @AltMe, GoInfo);
75
d2b737858ff7 - New First Aid powerup
unc0rr
parents: 74
diff changeset
   215
       inc(ticks, GoInfo.Ticks);
d2b737858ff7 - New First Aid powerup
unc0rr
parents: 74
diff changeset
   216
       if ticks > maxticks then break;
194
88652abdce9a Fixed weird bots behavior
unc0rr
parents: 193
diff changeset
   217
136
89970b70b076 Implement bot levels
unc0rr
parents: 111
diff changeset
   218
       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
   219
          if Push(ticks, Actions, AltMe, Me^.Message) then
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   220
             with Stack.States[Pred(Stack.Count)] do
80
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 75
diff changeset
   221
                  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
   222
                  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
   223
                                       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
   224
                  AddAction(MadeActions, aia_HJump, 0, 305 + random(50), 0, 0);
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   225
                  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
   226
                  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
   227
                                       else AddAction(MadeActions, aia_LookRight, 0, 200, 0, 0);
80
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 75
diff changeset
   228
                  end;
136
89970b70b076 Implement bot levels
unc0rr
parents: 111
diff changeset
   229
       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
   230
          if Push(ticks, Actions, AltMe, Me^.Message) then
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   231
             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
   232
                  AddAction(MadeActions, aia_LJump, 0, 305 + random(50), 0, 0);
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   233
80
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 75
diff changeset
   234
       if not CanGo then break;
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   235
       inc(steps);
544
9e068d2398ca Fix AI jumping to wrong direction on the turn start
unc0rr
parents: 543
diff changeset
   236
       Actions.actions[Pred(Actions.Count)].Param:= hwRound(Me^.X);
70
82d93eeecebe - Many AI improvements
unc0rr
parents: 66
diff changeset
   237
       Rate:= RatePlace(Me);
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   238
       if Rate > BestRate then
70
82d93eeecebe - Many AI improvements
unc0rr
parents: 66
diff changeset
   239
          begin
82d93eeecebe - Many AI improvements
unc0rr
parents: 66
diff changeset
   240
          BestActions:= Actions;
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   241
          BestRate:= Rate;
2580
aeccc8f51d3f completes touch input/control (problems with moving camera)
koda
parents: 2376
diff changeset
   242
          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
   243
          end
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   244
       else if Rate < BestRate then break;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   245
       if ((Me^.State and gstAttacked) = 0)
543
465e2ec8f05f - Better randomness of placing hedgehogs on the land
unc0rr
parents: 542
diff changeset
   246
           and ((steps mod 4) = 0) then TestAmmos(Actions, Me, true);
193
56885ea29202 Fix bots regressions
unc0rr
parents: 191
diff changeset
   247
       if GoInfo.FallPix >= FallPixForBranching then
56885ea29202 Fix bots regressions
unc0rr
parents: 191
diff changeset
   248
          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
   249
       end;
193
56885ea29202 Fix bots regressions
unc0rr
parents: 191
diff changeset
   250
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   251
    if BestRate > BaseRate then exit
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   252
    end
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   253
end;
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   254
508
f5473c50adbd Now really fix compilation
unc0rr
parents: 507
diff changeset
   255
function Think(Me: Pointer): ptrint;
74
42257fee61ae - Unicode support for team and hedgehogs names
unc0rr
parents: 71
diff changeset
   256
var BackMe, WalkMe: TGear;
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   257
    StartTicks: Longword;
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   258
begin
509
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
   259
InterlockedIncrement(hasThread);
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   260
StartTicks:= GameTicks;
500
d9b140e9d2c2 Use freepascal's routines to manipulate threads
unc0rr
parents: 498
diff changeset
   261
BackMe:= PGear(Me)^;
509
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
   262
500
d9b140e9d2c2 Use freepascal's routines to manipulate threads
unc0rr
parents: 498
diff changeset
   263
if (PGear(Me)^.State and gstAttacked) = 0 then
74
42257fee61ae - Unicode support for team and hedgehogs names
unc0rr
parents: 71
diff changeset
   264
   if Targets.Count > 0 then
42257fee61ae - Unicode support for team and hedgehogs names
unc0rr
parents: 71
diff changeset
   265
      begin
509
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
   266
      WalkMe:= BackMe;
74
42257fee61ae - Unicode support for team and hedgehogs names
unc0rr
parents: 71
diff changeset
   267
      Walk(@WalkMe);
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   268
      if (StartTicks > GameTicks - 1500) and not StopThinking then SDL_Delay(2000);
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   269
      if BestActions.Score < -1023 then
146
458f4f58c1b6 - Fix AI not to damage self hedgehogs
unc0rr
parents: 144
diff changeset
   270
         begin
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   271
         BestActions.Count:= 0;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   272
         AddAction(BestActions, aia_Skip, 0, 250, 0, 0);
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   273
         end;
80
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 75
diff changeset
   274
      end else
74
42257fee61ae - Unicode support for team and hedgehogs names
unc0rr
parents: 71
diff changeset
   275
else begin
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   276
      while (not StopThinking) and (BestActions.Count = 0) do
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   277
            begin
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   278
            FillBonuses(true);
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   279
            WalkMe:= BackMe;
509
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
   280
            Walk(@WalkMe);
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
   281
            if not StopThinking then SDL_Delay(100)
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   282
            end
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   283
      end;
500
d9b140e9d2c2 Use freepascal's routines to manipulate threads
unc0rr
parents: 498
diff changeset
   284
PGear(Me)^.State:= PGear(Me)^.State and not gstHHThinking;
509
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
   285
Think:= 0;
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
   286
InterlockedDecrement(hasThread)
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   287
end;
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   288
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   289
procedure StartThink(Me: PGear);
75
d2b737858ff7 - New First Aid powerup
unc0rr
parents: 74
diff changeset
   290
var a: TAmmoType;
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   291
begin
542
ec26095f1bed - Get rid of ammoProp_AttackInFall and gstFalling
unc0rr
parents: 522
diff changeset
   292
if ((Me^.State and (gstAttacking or gstHHJumping or gstMoving)) <> 0)
439
c336ed82e76d Fix bugs:
unc0rr
parents: 434
diff changeset
   293
   or isInMultiShoot then exit;
506
0889d833d47e - A good implementation of shotgun
unc0rr
parents: 500
diff changeset
   294
2376
ece7b87f1334 Strip trailing spaces
nemo
parents: 2289
diff changeset
   295
//DeleteCI(Me); // this might break demo
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   296
Me^.State:= Me^.State or gstHHThinking;
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   297
Me^.Message:= 0;
509
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
   298
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
   299
BestActions.Count:= 0;
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
   300
BestActions.Pos:= 0;
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
   301
BestActions.Score:= Low(integer);
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
   302
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   303
StopThinking:= false;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   304
ThinkingHH:= Me;
509
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
   305
70
82d93eeecebe - Many AI improvements
unc0rr
parents: 66
diff changeset
   306
FillTargets;
80
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 75
diff changeset
   307
if Targets.Count = 0 then
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 75
diff changeset
   308
   begin
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   309
   OutError('AI: no targets!?', false);
80
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 75
diff changeset
   310
   exit
3c3dc6a148ca - Fixed bug with hedgehog under water using rope
unc0rr
parents: 75
diff changeset
   311
   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
   312
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   313
FillBonuses((Me^.State and gstAttacked) <> 0);
75
d2b737858ff7 - New First Aid powerup
unc0rr
parents: 74
diff changeset
   314
for a:= Low(TAmmoType) to High(TAmmoType) do
553
5478386d935f - Switch to bazooka (or whatever) after use of some weapon (fixes problem with bots)
unc0rr
parents: 545
diff changeset
   315
    CanUseAmmo[a]:= Assigned(AmmoTests[a].proc) and HHHasAmmo(PHedgehog(Me^.Hedgehog)^, a);
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   316
{$IFDEF DEBUGFILE}AddFileLog('Enter Think Thread');{$ENDIF}
500
d9b140e9d2c2 Use freepascal's routines to manipulate threads
unc0rr
parents: 498
diff changeset
   317
BeginThread(@Think, Me, ThinkThread)
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   318
end;
191
a03c2d037e24 Bots are in the same thread as game. Fixes FreePascal issues.
unc0rr
parents: 183
diff changeset
   319
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   320
procedure ProcessBot;
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   321
const StartTicks: Longword = 0;
509
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
   322
      cStopThinkTime = 40;
4
bcbd7adb4e4b - set svn:eol-style to native
unc0rr
parents: 1
diff changeset
   323
begin
602
f7628ebfccde Add CurrentHedgehog variable which simplifies code
unc0rr
parents: 599
diff changeset
   324
with CurrentHedgehog^ do
66
9643d75baf1e Many AI improvements, bots do think in separate thread
unc0rr
parents: 64
diff changeset
   325
     if (Gear <> nil)
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   326
        and ((Gear^.State and gstHHDriven) <> 0)
144
e6084b0c9316 - Fix 'new team' regression
unc0rr
parents: 143
diff changeset
   327
        and (TurnTimeLeft < cHedgehogTurnTime - 50) then
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   328
        if ((Gear^.State and gstHHThinking) = 0) then
509
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
   329
           if (BestActions.Pos >= BestActions.Count)
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
   330
              and (TurnTimeLeft > cStopThinkTime) then
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   331
              begin
936
ba582673db7d Fix 'AI may break demos playing' message while loading saves
unc0rr
parents: 883
diff changeset
   332
              if Gear^.Message <> 0 then
ba582673db7d Fix 'AI may break demos playing' message while loading saves
unc0rr
parents: 883
diff changeset
   333
                 begin
ba582673db7d Fix 'AI may break demos playing' message while loading saves
unc0rr
parents: 883
diff changeset
   334
                 StopMessages(Gear^.Message);
ba582673db7d Fix 'AI may break demos playing' message while loading saves
unc0rr
parents: 883
diff changeset
   335
                 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
   336
                 end;
ba582673db7d Fix 'AI may break demos playing' message while loading saves
unc0rr
parents: 883
diff changeset
   337
              if Gear^.Message <> 0 then exit;
433
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   338
              StartThink(Gear);
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   339
              StartTicks:= GameTicks
9f8f22094c0e AI thinks in separate thread
unc0rr
parents: 425
diff changeset
   340
              end else ProcessAction(BestActions, Gear)
509
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
   341
        else if ((GameTicks - StartTicks) > cMaxAIThinkTime)
fd58135a4407 Bots know shotgun behavior better
unc0rr
parents: 508
diff changeset
   342
                or (TurnTimeLeft <= cStopThinkTime) then StopThinking:= true
369
2aed85310727 AI compiles, but doesn't work
unc0rr
parents: 351
diff changeset
   343
end;
4
bcbd7adb4e4b - set svn:eol-style to native
unc0rr
parents: 1
diff changeset
   344
bcbd7adb4e4b - set svn:eol-style to native
unc0rr
parents: 1
diff changeset
   345
end.