Subversion Repositories Games.Carmageddon

Rev

Rev 18 | Go to most recent revision | Details | Last modification | View Log | RSS feed

Rev Author Line No. Line
1 pmbaty 1
#include "netgame.h"
2
#include "brender/brender.h"
3
#include "car.h"
4
#include "displays.h"
5
#include "errors.h"
6
#include "globvars.h"
7
#include "globvrpb.h"
8
#include "grafdata.h"
9
#include "graphics.h"
10
#include "harness/trace.h"
11
#include "loading.h"
12
#include "network.h"
13
#include "newgame.h"
14
#include "opponent.h"
15
#include "pd/sys.h"
16
#include "pedestrn.h"
17
#include "powerup.h"
18
#include "racestrt.h"
19
#include "structur.h"
20
#include "utility.h"
21
#include <stdlib.h>
22
#include <string.h>
23
 
24
int gPowerup_cost[4] = { 1500, 2500, 4000, 6000 };
25
int gGame_scores[6];
26
int gPed_target;
27
int gNot_shown_race_type_headup;
28
tU32 gLast_it_change;
29
tU32 gTime_for_punishment;
30
tNet_game_player_info* gLast_lepper;
31
int gInitialised_grid;
32
int gIt_or_fox;
33
 
34
// IDA: void __usercall SendCarData(tU32 pNext_frame_time@<EAX>)
35
void SendCarData(tU32 pNext_frame_time) {
36
    //tNet_contents* contents; // Pierre-Marie Baty -- unused variable
37
    //tCar_spec* car; // Pierre-Marie Baty -- unused variable
38
    //tCollision_info* ncar; // Pierre-Marie Baty -- unused variable
39
    //int i; // Pierre-Marie Baty -- unused variable
40
    //int j; // Pierre-Marie Baty -- unused variable
41
    //static tU32 last_time; // Pierre-Marie Baty -- unused variable
42
    //tU32 time; // Pierre-Marie Baty -- unused variable
43
    //int damaged_wheels; // Pierre-Marie Baty -- unused variable
44
    LOG_TRACE("(%d)", pNext_frame_time);
45
 
46
    if (gNet_mode) {
47
        TELL_ME_IF_WE_PASS_THIS_WAY();
48
    }
49
}
50
 
51
// IDA: void __usercall ReceivedRecover(tNet_contents *pContents@<EAX>)
52
void ReceivedRecover(tNet_contents* pContents) {
53
    //int i; // Pierre-Marie Baty -- unused variable
54
    LOG_TRACE("(%p)", pContents);
55
    NOT_IMPLEMENTED();
56
}
57
 
58
// IDA: void __usercall CopyMechanics(tCar_spec *pCar@<EAX>, tNet_contents *pContents@<EDX>)
59
void CopyMechanics(tCar_spec* pCar, tNet_contents* pContents) {
60
    //int j; // Pierre-Marie Baty -- unused variable
61
    LOG_TRACE("(%p, %p)", pCar, pContents);
62
    NOT_IMPLEMENTED();
63
}
64
 
65
// IDA: void __usercall ReceivedMechanics(tNet_contents *pContents@<EAX>)
66
void ReceivedMechanics(tNet_contents* pContents) {
67
    //int i; // Pierre-Marie Baty -- unused variable
68
    //tCar_spec* car; // Pierre-Marie Baty -- unused variable
69
    LOG_TRACE("(%p)", pContents);
70
    NOT_IMPLEMENTED();
71
}
72
 
73
// IDA: void __usercall ReceivedCopInfo(tNet_contents *pContents@<EAX>)
74
void ReceivedCopInfo(tNet_contents* pContents) {
75
    //tCar_spec* c; // Pierre-Marie Baty -- unused variable
76
    //int i; // Pierre-Marie Baty -- unused variable
77
    LOG_TRACE("(%p)", pContents);
78
    NOT_IMPLEMENTED();
79
}
80
 
81
// IDA: void __cdecl SendAllNonCarPositions()
82
void SendAllNonCarPositions(void) {
83
    int i;
84
    br_actor** list;
85
    tNon_car_spec* non_car;
86
    tNet_contents* contents;
87
    LOG_TRACE("()");
88
 
89
    list = gProgram_state.track_spec.non_car_list;
90
    for (i = 0; i < gProgram_state.track_spec.ampersand_digits; ++i) {
91
        if (list[i]->type_data != NULL) {
92
            non_car = (tNon_car_spec*)list[i]->type_data;
93
            if (non_car->collision_info.driver == eDriver_non_car_unused_slot || non_car->collision_info.car_ID != i) {
94
                contents = NetGetBroadcastContents(NETMSGID_NONCARPOSITION, 0);
95
                BrMatrix34Copy(&contents->data.non_car_position.mat, &list[i]->t.t.mat);
96
                contents->data.non_car_position.ID = i;
97
                contents->data.non_car_position.flags = list[i]->identifier[3] == '!';
98
            }
99
        }
100
    }
101
    NetSendMessageStacks();
102
}
103
 
104
// IDA: void __usercall ReceivedNonCarPosition(tNet_contents *pContents@<EAX>)
105
void ReceivedNonCarPosition(tNet_contents* pContents) {
106
    //br_actor* actor; // Pierre-Marie Baty -- unused variable
107
    LOG_TRACE("(%p)", pContents);
108
    NOT_IMPLEMENTED();
109
}
110
 
111
// IDA: void __usercall ReceivedNonCar(tNet_contents *pContents@<EAX>)
112
void ReceivedNonCar(tNet_contents* pContents) {
113
    //br_actor* actor; // Pierre-Marie Baty -- unused variable
114
    //br_vector3 tv; // Pierre-Marie Baty -- unused variable
115
    //tU8 cx; // Pierre-Marie Baty -- unused variable
116
    //tU8 cz; // Pierre-Marie Baty -- unused variable
117
    //tTrack_spec* track_spec; // Pierre-Marie Baty -- unused variable
118
    //tNon_car_spec* ncar; // Pierre-Marie Baty -- unused variable
119
    //tCollision_info* c; // Pierre-Marie Baty -- unused variable
120
    LOG_TRACE("(%p)", pContents);
121
    NOT_IMPLEMENTED();
122
}
123
 
124
// IDA: void __usercall SignalToStartRace2(int pIndex@<EAX>)
125
void SignalToStartRace2(int pIndex) {
126
    tNet_message* the_message;
127
    int i;
128
    int j;
129
    LOG_TRACE("(%d)", pIndex);
130
 
131
    if (gCurrent_race.number_of_racers > 6) {
132
        FadePaletteUp();
133
        dr_dprintf("AAAARRRGGGHHH!!!! More than 6 racers!!!!");
134
        PDFatalError("AAAARRRGGGHHH!!!! More than 6 racers!!!!");
135
    }
136
    gNeed_to_send_start_race = 0;
137
    gStart_race_sent = 1;
138
    the_message = NetBuildMessage(NETMSGID_STARTRACE, 0);
139
    the_message->contents.data.start_race.racing = gProgram_state.racing;
140
    if (pIndex >= 0) {
141
        gNet_players[pIndex].last_waste_message = 0;
142
        gNet_players[pIndex].wasteage_attributed = 0;
143
        the_message->contents.data.start_race.car_count = -1;
144
        the_message->contents.data.start_race.car_list[0].index = pIndex;
145
        BrMatrix34Copy(&the_message->contents.data.start_race.car_list[0].mat,
146
            &gCurrent_race.opponent_list[gNet_players[pIndex].opponent_list_index].car_spec->car_master_actor->t.t.mat);
147
    } else {
148
        the_message->contents.data.start_race.car_count = gCurrent_race.number_of_racers;
149
        for (i = 0; i < gCurrent_race.number_of_racers; i++) {
150
            BrMatrix34Copy(&the_message->contents.data.start_race.car_list[i].mat,
151
                &gCurrent_race.opponent_list[i].car_spec->car_master_actor->t.t.mat);
152
            for (j = 0; j < gNumber_of_net_players; j++) {
153
                if (gCurrent_race.opponent_list[i].car_spec == gNet_players[j].car) {
154
                    the_message->contents.data.start_race.car_list[i].index = j;
155
                    break;
156
                }
157
            }
158
            if (gCurrent_net_game->options.random_car_choice && (gCurrent_net_game->options.car_choice == eNet_car_all || gCurrent_net_game->options.car_choice == eNet_car_both)) {
159
                if (gNet_players[the_message->contents.data.start_race.car_list[i].index].next_car_index < 0) {
160
                    gNet_players[the_message->contents.data.start_race.car_list[i].index].next_car_index = PickARandomCar();
161
                    gCar_details[gNet_players[the_message->contents.data.start_race.car_list[i].index].next_car_index].ownership = eCar_owner_someone;
162
                }
163
                the_message->contents.data.start_race.car_list[i].next_car_index = gNet_players[the_message->contents.data.start_race.car_list[i].index].next_car_index;
164
            }
165
        }
166
        if (gPending_race < 0) {
167
            gPending_race = PickNetRace(gProgram_state.current_race_index,
168
                gCurrent_net_game->options.race_sequence_type);
169
        }
170
        the_message->contents.data.start_race.next_race = gPending_race;
171
    }
172
    NetGuaranteedSendMessageToAllPlayers(gCurrent_net_game, the_message, NULL);
173
    if (gProgram_state.racing) {
174
        SendCurrentPowerups();
175
    }
176
}
177
 
178
// IDA: void __cdecl SignalToStartRace()
179
void SignalToStartRace(void) {
180
    LOG_TRACE("()");
181
 
182
    gCurrent_net_game->no_races_yet = 0;
183
    SignalToStartRace2(-1);
184
}
185
 
186
// IDA: void __cdecl SetUpNetCarPositions()
187
void SetUpNetCarPositions(void) {
188
    int i;
189
    //int j; // Pierre-Marie Baty -- unused variable
190
    int k;
191
    int grid_index;
192
    int racer_count;
193
    LOG_TRACE("()");
194
 
195
    DisableNetService();
196
    if (!gInitialised_grid) {
197
        for (i = 0; i < gNumber_of_net_players; i++) {
198
            gNet_players[i].grid_position_set = 0;
199
            gNet_players[i].last_waste_message = 0;
200
            gNet_players[i].wasteage_attributed = 0;
201
        }
202
    }
203
    for (i = 0; i < gNumber_of_net_players; i++) {
204
        gCurrent_race.opponent_list[i].index = -1;
205
        gCurrent_race.opponent_list[i].ranking = IRandomBetween(0, 99);
206
        gCurrent_race.opponent_list[i].car_spec = gNet_players[i].car;
207
        gCurrent_race.opponent_list[i].net_player_index = i;
208
        gNet_players[i].opponent_list_index = i;
209
    }
210
    if (!gInitialised_grid && gCurrent_net_game->options.grid_start) {
211
        qsort(gCurrent_race.opponent_list, gNumber_of_net_players, sizeof(tOpp_spec), SortGridFunction);
212
    }
213
    gCurrent_race.number_of_racers = 0;
214
    for (i = 0; i < gNumber_of_net_players; i++) {
215
        gNet_players[gCurrent_race.opponent_list[i].net_player_index].opponent_list_index = i;
216
    }
217
    for (i = 0; i < gNumber_of_net_players; i++) {
218
        if ((gCurrent_race.opponent_list[i].car_spec->driver == eDriver_oppo && !gInitialised_grid)
219
            || (gCurrent_race.opponent_list[i].car_spec->driver >= eDriver_net_human && !gNet_players[gCurrent_race.opponent_list[i].net_player_index].grid_position_set)) {
220
            grid_index = -1;
221
            racer_count = 0;
222
            while (racer_count < 6 && grid_index < 0) {
223
                grid_index = racer_count;
224
                for (k = 0; k < gNumber_of_net_players; k++) {
225
                    if (k != i
226
                        && gNet_players[gCurrent_race.opponent_list[k].net_player_index].grid_position_set
227
                        && gNet_players[gCurrent_race.opponent_list[k].net_player_index].grid_index == racer_count) {
228
                        grid_index = -1;
229
                        break;
230
                    }
231
                }
232
                racer_count++;
233
            }
234
            if (grid_index < 0) {
235
                FatalError(kFatalError_NetworkCodeSelfCheck);
236
            }
237
            SetInitialPosition(&gCurrent_race, i, grid_index);
238
            gNet_players[gCurrent_race.opponent_list[i].net_player_index].grid_index = grid_index;
239
            if (gInitialised_grid) {
240
                InitialiseCar2(gCurrent_race.opponent_list[i].car_spec, 0);
241
            } else {
242
                gCurrent_race.number_of_racers = i + 1;
243
            }
244
            gNet_players[gCurrent_race.opponent_list[i].net_player_index].grid_position_set = 1;
245
        }
246
    }
247
    gCurrent_race.number_of_racers = gNumber_of_net_players;
248
    gInitialised_grid = 1;
249
    ReenableNetService();
250
}
251
 
252
// IDA: void __usercall ReinitialiseCar(tCar_spec *pCar@<EAX>)
253
void ReinitialiseCar(tCar_spec* pCar) {
254
    //int i; // Pierre-Marie Baty -- unused variable
255
    LOG_TRACE("(%p)", pCar);
256
    NOT_IMPLEMENTED();
257
}
258
 
259
// IDA: void __usercall RepositionPlayer(int pIndex@<EAX>)
260
void RepositionPlayer(int pIndex) {
261
    //tNet_message* the_message; // Pierre-Marie Baty -- unused variable
262
    //tCar_spec* car;            // Pierre-Marie Baty -- unused variable
263
    LOG_TRACE("(%d)", pIndex);
264
    NOT_IMPLEMENTED();
265
}
266
 
267
// IDA: void __usercall DisableCar(tCar_spec *pCar@<EAX>)
268
void DisableCar(tCar_spec* pCar) {
269
    LOG_TRACE("(%p)", pCar);
270
 
271
    if (pCar->driver_name[0] != '\0') {
272
        if (!pCar->disabled) {
273
            pCar->disabled = 1;
274
            ForceRebuildActiveCarList();
275
        }
276
        if (pCar->car_master_actor->t.t.mat.m[3][0] < 500.0f) {
277
            pCar->car_master_actor->t.t.mat.m[3][0] = pCar->car_master_actor->t.t.mat.m[3][0] + 1000.0f;
278
            pCar->car_master_actor->t.t.mat.m[3][1] = pCar->car_master_actor->t.t.mat.m[3][1] + 1000.0f;
279
            pCar->car_master_actor->t.t.mat.m[3][2] = pCar->car_master_actor->t.t.mat.m[3][2] + 1000.0f;
280
            pCar->old_frame_mat.m[3][0] = pCar->car_master_actor->t.t.mat.m[3][0];
281
            pCar->old_frame_mat.m[3][1] = pCar->car_master_actor->t.t.mat.m[3][1];
282
            pCar->old_frame_mat.m[3][2] = pCar->car_master_actor->t.t.mat.m[3][2];
283
        }
284
    }
285
}
286
 
287
// IDA: void __usercall EnableCar(tCar_spec *pCar@<EAX>)
288
void EnableCar(tCar_spec* pCar) {
289
    LOG_TRACE("(%p)", pCar);
290
 
291
    if (pCar->driver_name[0] != '\0') {
292
        if (pCar->disabled) {
293
            pCar->disabled = 0;
294
            ForceRebuildActiveCarList();
295
        }
296
        if (pCar->car_master_actor->t.t.mat.m[3][0] > 500.0f) {
297
            pCar->car_master_actor->t.t.mat.m[3][0] = pCar->car_master_actor->t.t.mat.m[3][0] - 1000.0f;
298
            pCar->car_master_actor->t.t.mat.m[3][1] = pCar->car_master_actor->t.t.mat.m[3][1] - 1000.0f;
299
            pCar->car_master_actor->t.t.mat.m[3][2] = pCar->car_master_actor->t.t.mat.m[3][2] - 1000.0f;
300
            pCar->old_frame_mat.m[3][0] = pCar->car_master_actor->t.t.mat.m[3][0];
301
            pCar->old_frame_mat.m[3][1] = pCar->car_master_actor->t.t.mat.m[3][1];
302
            pCar->old_frame_mat.m[3][2] = pCar->car_master_actor->t.t.mat.m[3][2];
303
        }
304
    }
305
}
306
 
307
// IDA: void __usercall DoNetworkHeadups(int pCredits@<EAX>)
308
void DoNetworkHeadups(int pCredits) {
309
    char s[256];
310
    char s2[256];
311
    static tU32 last_flash;
312
    static int flash_state;
313
    LOG_TRACE("(%d)", pCredits);
314
 
315
    if (gNot_shown_race_type_headup) {
316
        gNot_shown_race_type_headup = 0;
317
        NewTextHeadupSlot(4, 0, 2000, -4, GetMiscString(kMiscString_NetworkGameTypeNames_START + gCurrent_net_game->type));
318
    }
319
    if (gTime_for_punishment && gTime_for_punishment <= (tU32) PDGetTotalTime()) { // Pierre-Marie Baty -- added type cast
320
        gTime_for_punishment = 0;
321
        switch (gCurrent_net_game->type) {
322
        case eNet_game_type_carnage:
323
            NewTextHeadupSlot(4, 0, 2000, -4, GetMiscString(kMiscString_THAT_HALVED_YOUR_KILL_COUNT));
324
            break;
325
        case eNet_game_type_checkpoint:
326
            NewTextHeadupSlot(4, 0, 2000, -4, GetMiscString(kMiscString_THAT_LOST_YOU_A_CHECKPOINT));
327
            break;
328
        case eNet_game_type_sudden_death:
329
            NewTextHeadupSlot(4, 0, 2000, -4, GetMiscString(kMiscString_BACK_TO_THE_START));
330
            break;
331
        case eNet_game_type_foxy:
332
            NewTextHeadupSlot(4, 0, 2000, -4, GetMiscString(kMiscString_THAT_HALVED_YOUR_TIME));
333
            break;
334
        default:
335
            break;
336
        }
337
    }
338
    if (gNet_mode == eNet_mode_none || gNet_recovery_cost[gCurrent_net_game->type] <= gProgram_state.credits_earned - gProgram_state.credits_lost || Flash(200, &last_flash, &flash_state)) {
339
        sprintf(s, "\xf8%d\xfa %s", pCredits, GetMiscString(kMiscString_CREDITS));
340
        ChangeHeadupText(gNet_cash_headup, s);
341
    } else {
342
        ChangeHeadupText(gNet_cash_headup, "");
343
    }
344
    switch (gCurrent_net_game->type) {
345
    case eNet_game_type_carnage:
346
        sprintf(s, "%s \xf8%d\xfa", GetMiscString(kMiscString_TARGET_180), gPed_target);
347
        break;
348
    case eNet_game_type_car_crusher:
349
        sprintf(s, "%s \xf8%d\xfa", GetMiscString(kMiscString_TARGET_181), gCurrent_net_game->options.race_end_target);
350
        break;
351
    case eNet_game_type_foxy:
352
        TimerString(gCurrent_net_game->options.race_end_target, s2, 1, 1);
353
        sprintf(s, "%s \xf8%s\xfa", GetMiscString(kMiscString_TARGET_182), s2);
354
        break;
355
    case eNet_game_type_tag:
356
        TimerString(gCurrent_net_game->options.race_end_target, s2, 1, 1);
357
        sprintf(s, "%s \xf8%s\xfa", GetMiscString(kMiscString_LIMIT), s2);
358
        break;
359
    default:
360
        s[0] = '\0';
361
        break;
362
    }
363
    ChangeHeadupText(gNet_ped_headup, s);
364
}
365
 
366
// IDA: int __usercall SortNetHeadAscending@<EAX>(void *pFirst_one@<EAX>, void *pSecond_one@<EDX>)
367
int SortNetHeadAscending(void* pFirst_one, void* pSecond_one) {
368
    LOG_TRACE("(%p, %p)", pFirst_one, pSecond_one);
369
    NOT_IMPLEMENTED();
370
}
371
 
372
// IDA: int __usercall SortNetHeadDescending@<EAX>(void *pFirst_one@<EAX>, void *pSecond_one@<EDX>)
373
int SortNetHeadDescending(void* pFirst_one, void* pSecond_one) {
374
    LOG_TRACE("(%p, %p)", pFirst_one, pSecond_one);
375
    NOT_IMPLEMENTED();
376
}
377
 
378
// IDA: void __usercall ClipName(char *pName@<EAX>, tDR_font *pFont@<EDX>, int pMax_width@<EBX>)
379
void ClipName(char* pName, tDR_font* pFont, int pMax_width) {
380
    LOG_TRACE("(\"%s\", %p, %d)", pName, pFont, pMax_width);
381
    NOT_IMPLEMENTED();
382
}
383
 
384
// IDA: void __usercall DoNetScores2(int pOnly_sort_scores@<EAX>)
385
void DoNetScores2(int pOnly_sort_scores) {
386
    //int i; // Pierre-Marie Baty -- unused variable
387
    //int j; // Pierre-Marie Baty -- unused variable
388
    //int score; // Pierre-Marie Baty -- unused variable
389
    //int flags; // Pierre-Marie Baty -- unused variable
390
    //int index; // Pierre-Marie Baty -- unused variable
391
    //int right_edge; // Pierre-Marie Baty -- unused variable
392
    //int x; // Pierre-Marie Baty -- unused variable
393
    //int len; // Pierre-Marie Baty -- unused variable
394
    //int ascending_order; // Pierre-Marie Baty -- unused variable
395
    //char s[256]; // Pierre-Marie Baty -- unused variable
396
    //static tU32 last_flash; // Pierre-Marie Baty -- unused variable
397
    //static int flash_state; // Pierre-Marie Baty -- unused variable
398
    //tHeadup_pair headup_pairs[6]; // Pierre-Marie Baty -- unused variable
399
    LOG_TRACE("(%d)", pOnly_sort_scores);
400
    NOT_IMPLEMENTED();
401
}
402
 
403
// IDA: void __cdecl DoNetScores()
404
void DoNetScores(void) {
405
    LOG_TRACE("()");
406
    NOT_IMPLEMENTED();
407
}
408
 
409
// IDA: void __cdecl InitNetHeadups()
410
void InitNetHeadups(void) {
411
    LOG_TRACE("()");
412
 
413
    gIcons_pix = LoadPixelmap("CARICONS.PIX");
414
    if (gIcons_pix != NULL) {
415
        BrMapAdd(gIcons_pix);
416
    }
417
    gDigits_pix = LoadPixelmap("HDIGITS.PIX");
418
    if (gDigits_pix != NULL) {
419
        BrMapAdd(gDigits_pix);
420
    }
421
    /* The Windows version does not use gIcons_pix_low_res. */
422
    if (gGraf_data_index != 0) {
423
        SwitchToLoresMode();
424
        gIcons_pix_low_res = LoadPixelmap("CARICONS.PIX");
425
        SwitchToRealResolution();
426
    } else {
427
        gIcons_pix_low_res = gIcons_pix;
428
    }
429
}
430
 
431
// IDA: void __cdecl DisposeNetHeadups()
432
void DisposeNetHeadups(void) {
433
    LOG_TRACE("()");
434
 
435
    /* Windows version does not use gIcons_pix_low_res. */
436
    if (gIcons_pix_low_res != NULL && gIcons_pix_low_res != gIcons_pix) {
437
        BrPixelmapFree(gIcons_pix_low_res);
438
    }
439
 
440
    if (gIcons_pix != NULL) {
441
        BrMapRemove(gIcons_pix);
442
        BrPixelmapFree(gIcons_pix);
443
    }
444
    if (gDigits_pix != NULL) {
445
        BrMapRemove(gDigits_pix);
446
        BrPixelmapFree(gDigits_pix);
447
    }
448
}
449
 
450
// IDA: void __cdecl EverybodysLost()
451
void EverybodysLost(void) {
452
    //tNet_message* the_message; // Pierre-Marie Baty -- unused variable
453
    //int i; // Pierre-Marie Baty -- unused variable
454
    LOG_TRACE("()");
455
    NOT_IMPLEMENTED();
456
}
457
 
458
// IDA: void __usercall DeclareWinner(int pWinner_index@<EAX>)
459
void DeclareWinner(int pWinner_index) {
460
    //tNet_message* the_message; // Pierre-Marie Baty -- unused variable
461
    //int i; // Pierre-Marie Baty -- unused variable
462
    //int j; // Pierre-Marie Baty -- unused variable
463
    //int best_score_index; // Pierre-Marie Baty -- unused variable
464
    //char s[256]; // Pierre-Marie Baty -- unused variable
465
    LOG_TRACE("(%d)", pWinner_index);
466
    NOT_IMPLEMENTED();
467
}
468
 
469
// IDA: void __usercall PlayerIsIt(tNet_game_player_info *pPlayer@<EAX>)
470
void PlayerIsIt(tNet_game_player_info* pPlayer) {
471
    //int i; // Pierre-Marie Baty -- unused variable
472
    //char s[256]; // Pierre-Marie Baty -- unused variable
473
    LOG_TRACE("(%p)", pPlayer);
474
    NOT_IMPLEMENTED();
475
}
476
 
477
// IDA: int __usercall FarEnoughAway@<EAX>(tNet_game_player_info *pPlayer_1@<EAX>, tNet_game_player_info *pPlayer_2@<EDX>)
478
int FarEnoughAway(tNet_game_player_info* pPlayer_1, tNet_game_player_info* pPlayer_2) {
479
    //br_vector3 difference; // Pierre-Marie Baty -- unused variable
480
    LOG_TRACE("(%p, %p)", pPlayer_1, pPlayer_2);
481
    NOT_IMPLEMENTED();
482
}
483
 
484
// IDA: void __usercall CarInContactWithItOrFox(tNet_game_player_info *pPlayer@<EAX>)
485
void CarInContactWithItOrFox(tNet_game_player_info* pPlayer) {
486
    LOG_TRACE("(%p)", pPlayer);
487
    NOT_IMPLEMENTED();
488
}
489
 
490
// IDA: void __usercall SelectRandomItOrFox(int pNot_this_one@<EAX>)
491
void SelectRandomItOrFox(int pNot_this_one) {
492
    //int i; // Pierre-Marie Baty -- unused variable
493
    //int new_choice; // Pierre-Marie Baty -- unused variable
494
    LOG_TRACE("(%d)", pNot_this_one);
495
    NOT_IMPLEMENTED();
496
}
497
 
498
// IDA: void __cdecl CalcPlayerScores()
499
void CalcPlayerScores(void) {
500
    //int i; // Pierre-Marie Baty -- unused variable
501
    //int j; // Pierre-Marie Baty -- unused variable
502
    //int knock_out_bit; // Pierre-Marie Baty -- unused variable
503
    //int e_dam; // Pierre-Marie Baty -- unused variable
504
    //int t_dam; // Pierre-Marie Baty -- unused variable
505
    //int d_dam; // Pierre-Marie Baty -- unused variable
506
    //int w_dam; // Pierre-Marie Baty -- unused variable
507
    //int cars_left; // Pierre-Marie Baty -- unused variable
508
    //int car_left; // Pierre-Marie Baty -- unused variable
509
    //int flags; // Pierre-Marie Baty -- unused variable
510
    //int score; // Pierre-Marie Baty -- unused variable
511
    //int highest; // Pierre-Marie Baty -- unused variable
512
    //int next_highest; // Pierre-Marie Baty -- unused variable
513
    //int lowest_score; // Pierre-Marie Baty -- unused variable
514
    //int player_left; // Pierre-Marie Baty -- unused variable
515
    //int new_choice; // Pierre-Marie Baty -- unused variable
516
    //tCar_spec* car; // Pierre-Marie Baty -- unused variable
517
    //tNet_message* message; // Pierre-Marie Baty -- unused variable
518
    //tS32 time; // Pierre-Marie Baty -- unused variable
519
    //char s[256]; // Pierre-Marie Baty -- unused variable
520
    //tNet_game_player_info* lowest_score_player; // Pierre-Marie Baty -- unused variable
521
    LOG_TRACE("()");
522
    NOT_IMPLEMENTED();
523
}
524
 
525
// IDA: void __cdecl SendPlayerScores()
526
void SendPlayerScores(void) {
527
    tNet_contents* the_contents;
528
    int i;
529
    LOG_TRACE("()");
530
 
531
    the_contents = NetGetBroadcastContents(NETMSGID_SCORES, 0);
532
    if (gCurrent_net_game->type == eNet_game_type_carnage) {
533
        the_contents->data.scores.general_score = gPed_target;
534
    } else if (gCurrent_net_game->type == eNet_game_type_tag || gCurrent_net_game->type == eNet_game_type_foxy) {
535
        the_contents->data.scores.general_score = gNet_players[gIt_or_fox].ID;
536
    }
537
    for (i = 0; i < gNumber_of_net_players; i++) {
538
        the_contents->data.scores.scores[i] = gNet_players[i].score;
539
    }
540
}
541
 
542
// IDA: void __cdecl DoNetGameManagement()
543
void DoNetGameManagement(void) {
544
    LOG_TRACE("()");
545
 
546
    if (gNet_mode == eNet_mode_host) {
547
        CalcPlayerScores();
548
        SendPlayerScores();
549
    }
550
}
551
 
552
// IDA: void __usercall InitialisePlayerScore(tNet_game_player_info *pPlayer@<EAX>)
553
void InitialisePlayerScore(tNet_game_player_info* pPlayer) {
554
    LOG_TRACE("(%p)", pPlayer);
555
 
556
    PossibleService();
557
    switch (gCurrent_net_game->type) {
558
    case eNet_game_type_fight_to_death:
559
        pPlayer->score = 100;
560
        break;
561
    case eNet_game_type_car_crusher:
562
    case eNet_game_type_carnage:
563
        pPlayer->score = 0;
564
        break;
565
    case eNet_game_type_checkpoint:
566
        pPlayer->score = 0xffff;
567
        break;
568
    case eNet_game_type_sudden_death:
569
        pPlayer->score = 0;
570
        break;
571
    case eNet_game_type_tag:
572
        pPlayer->score = 0;
573
        break;
574
    case eNet_game_type_foxy:
575
        pPlayer->score = 0;
576
        break;
577
    default:
578
        TELL_ME_IF_WE_PASS_THIS_WAY();
579
    }
580
    pPlayer->credits = gInitial_net_credits[gCurrent_net_game->options.starting_money_index];
581
    pPlayer->wasted = 0;
582
    pPlayer->reposition_time = 0;
583
}
584
 
585
// IDA: void __cdecl InitPlayers()
586
void InitPlayers(void) {
587
    int i;
588
    LOG_TRACE("()");
589
 
590
    for (i = 0; i < gNumber_of_net_players; i++) {
591
        InitialisePlayerScore(&gNet_players[i]);
592
    }
593
    if (gNet_mode == eNet_mode_host) {
594
        gLast_it_change = 0;
595
        gLast_lepper = NULL;
596
    }
597
    gTime_for_punishment = 0;
598
    gNot_shown_race_type_headup = 1;
599
    gIt_or_fox = -1;
600
}
601
 
602
// IDA: void __usercall BuyPSPowerup(int pIndex@<EAX>)
603
void BuyPSPowerup(int pIndex) {
604
    char s[256];
605
    char s2[256];
606
    LOG_TRACE("(%d)", pIndex);
607
 
608
    if (gNet_mode == eNet_mode_none) {
609
        NewTextHeadupSlot(4, 0, 3000, -4, GetMiscString(kMiscString_ONLY_AVAILABLE_IN_NET_GAMES));
610
    } else if (gProgram_state.current_car.power_up_levels[pIndex] < 4) {
611
        if (gNet_mode == eNet_mode_none || gPowerup_cost[gProgram_state.current_car.power_up_levels[pIndex]] <= (gProgram_state.credits_earned - gProgram_state.credits_lost)) {
612
            SpendCredits(gPowerup_cost[gProgram_state.current_car.power_up_levels[pIndex]]);
613
            ImprovePSPowerup(&gProgram_state.current_car, pIndex);
614
        } else {
615
            strcpy(s, GetMiscString(kMiscString_CANNOT_AFFORD_IT));
616
            sprintf(s2, "%d", gPowerup_cost[gProgram_state.current_car.power_up_levels[pIndex]]);
617
            SubsStringJob(s, s2);
618
            NewTextHeadupSlot(4, 0, 3008, -4, s);
619
        }
620
    } else {
621
        NewTextHeadupSlot(4, 0, 3000, -4, GetMiscString(kMiscString_YOU_ARE_ALREADY_AT_MAX));
622
    }
623
}
624
 
625
// IDA: void __cdecl BuyArmour()
626
void BuyArmour(void) {
627
    LOG_TRACE("()");
628
 
629
    BuyPSPowerup(0);
630
}
631
 
632
// IDA: void __cdecl BuyPower()
633
void BuyPower(void) {
634
    LOG_TRACE("()");
635
 
636
    if (gNet_mode != eNet_mode_none && gCurrent_net_game->type == eNet_game_type_foxy && gThis_net_player_index == gIt_or_fox) {
637
        NewTextHeadupSlot(4, 0, 1000, -4, GetMiscString(kMiscString_THE_FOX_CANNOT_DO_THAT));
638
    } else if (gNet_mode != eNet_mode_none && gCurrent_net_game->type == eNet_game_type_tag && gThis_net_player_index != gIt_or_fox) {
639
        NewTextHeadupSlot(4, 0, 1000, -4, GetMiscString(kMiscString_ONLY_IT_CAN_DO_THAT));
640
    } else {
641
        BuyPSPowerup(1);
642
    }
643
}
644
 
645
// IDA: void __cdecl BuyOffense()
646
void BuyOffense(void) {
647
    LOG_TRACE("()");
648
 
649
    BuyPSPowerup(2);
650
}
651
 
652
// IDA: void __usercall UseGeneralScore(int pScore@<EAX>)
653
void UseGeneralScore(int pScore) {
654
    //int i; // Pierre-Marie Baty -- unused variable
655
    LOG_TRACE("(%d)", pScore);
656
    NOT_IMPLEMENTED();
657
}
658
 
659
// IDA: void __usercall NetSendEnvironmentChanges(tNet_game_player_info *pPlayer@<EAX>)
660
void NetSendEnvironmentChanges(tNet_game_player_info* pPlayer) {
661
    LOG_TRACE("(%p)", pPlayer);
662
 
663
    SendAllPedestrianPositions(pPlayer->ID);
664
    SendAllNonCarPositions();
665
}
666
 
667
// IDA: void __cdecl UpdateEnvironments()
668
void UpdateEnvironments(void) {
669
    int i;
670
    LOG_TRACE("()");
671
 
672
    for (i = 1; i < gNumber_of_net_players; i++) {
673
        if (!gNet_players[i].race_stuff_initialised) {
674
            NetSendEnvironmentChanges(&gNet_players[i]);
675
            gNet_players[i].race_stuff_initialised = 1;
676
        }
677
        NetSendMessageStacks();
678
        SendGameplay(gNet_players[i].ID, eNet_gameplay_go_for_it, 0, 0, 0, 0);
679
    }
680
}
681
 
682
// IDA: void __usercall ReceivedGameplay(tNet_contents *pContents@<EAX>, tNet_message *pMessage@<EDX>, tU32 pReceive_time@<EBX>)
683
void ReceivedGameplay(tNet_contents* pContents, tNet_message* pMessage, tU32 pReceive_time) {
684
    //int must_revert_reentrancy; // Pierre-Marie Baty -- unused variable
685
    //int gPixel_buffer_size; // Pierre-Marie Baty -- unused variable
686
    //char* gPixels_copy; // Pierre-Marie Baty -- unused variable
687
    //char* gPalette_copy; // Pierre-Marie Baty -- unused variable
688
    //static int pause_semaphore; // Pierre-Marie Baty -- unused variable
689
    LOG_TRACE("(%p, %p, %d)", pContents, pMessage, pReceive_time);
690
    NOT_IMPLEMENTED();
691
}
692
 
693
// IDA: void __usercall SendGameplay(tPlayer_ID pPlayer@<EAX>, tNet_gameplay_mess pMess@<EDX>, int pParam_1@<EBX>, int pParam_2@<ECX>, int pParam_3, int pParam_4)
694
void SendGameplay(tPlayer_ID pPlayer, tNet_gameplay_mess pMess, int pParam_1, int pParam_2, int pParam_3, int pParam_4) {
695
    tNet_message* the_message;
696
    LOG_TRACE("(%d, %d, %d, %d, %d, %d)", pPlayer, pMess, pParam_1, pParam_2, pParam_3, pParam_4);
697
 
698
    the_message = NetBuildMessage(NETMSGID_GAMEPLAY, 0);
699
    the_message->contents.data.gameplay.mess = pMess;
700
    the_message->contents.data.gameplay.param_1 = pParam_1;
701
    the_message->contents.data.gameplay.param_2 = pParam_2;
702
    the_message->contents.data.gameplay.param_3 = pParam_3;
703
    the_message->contents.data.gameplay.param_4 = pParam_4;
704
    NetGuaranteedSendMessageToPlayer(gCurrent_net_game, the_message, pPlayer, 0);
705
}
706
 
707
// IDA: void __usercall SendGameplayToAllPlayers(tNet_gameplay_mess pMess@<EAX>, int pParam_1@<EDX>, int pParam_2@<EBX>, int pParam_3@<ECX>, int pParam_4)
708
void SendGameplayToAllPlayers(tNet_gameplay_mess pMess, int pParam_1, int pParam_2, int pParam_3, int pParam_4) {
709
    tNet_message* the_message;
710
    LOG_TRACE("(%d, %d, %d, %d, %d)", pMess, pParam_1, pParam_2, pParam_3, pParam_4);
711
 
712
    the_message = NetBuildMessage(NETMSGID_GAMEPLAY, 0);
713
    the_message->contents.data.gameplay.mess = pMess;
714
    the_message->contents.data.gameplay.param_1 = pParam_1;
715
    the_message->contents.data.gameplay.param_2 = pParam_2;
716
    the_message->contents.data.gameplay.param_3 = pParam_3;
717
    the_message->contents.data.gameplay.param_4 = pParam_4;
718
    NetGuaranteedSendMessageToAllPlayers(gCurrent_net_game, the_message, NULL);
719
}
720
 
721
// IDA: void __usercall SendGameplayToHost(tNet_gameplay_mess pMess@<EAX>, int pParam_1@<EDX>, int pParam_2@<EBX>, int pParam_3@<ECX>, int pParam_4)
722
void SendGameplayToHost(tNet_gameplay_mess pMess, int pParam_1, int pParam_2, int pParam_3, int pParam_4) {
723
    //tNet_message* the_message; // Pierre-Marie Baty -- unused variable
724
    LOG_TRACE("(%d, %d, %d, %d, %d)", pMess, pParam_1, pParam_2, pParam_3, pParam_4);
725
    NOT_IMPLEMENTED();
726
}
727
 
728
// IDA: void __cdecl InitNetGameplayStuff()
729
void InitNetGameplayStuff(void) {
730
    LOG_TRACE("()");
731
}
732
 
733
// IDA: void __cdecl DefaultNetName()
734
void DefaultNetName(void) {
735
    NetObtainSystemUserName(gNet_player_name, 32);
736
}
737
 
738
// IDA: void __usercall NetSendPointCrush(tCar_spec *pCar@<EAX>, tU16 pCrush_point_index@<EDX>, br_vector3 *pEnergy_vector@<EBX>)
739
void NetSendPointCrush(tCar_spec* pCar, tU16 pCrush_point_index, br_vector3* pEnergy_vector) {
740
    //tNet_contents* contents; // Pierre-Marie Baty -- unused variable
741
    LOG_TRACE("(%p, %d, %p)", pCar, pCrush_point_index, pEnergy_vector);
742
 
743
    STUB_ONCE();
744
}
745
 
746
// IDA: void __usercall RecievedCrushPoint(tNet_contents *pContents@<EAX>)
747
void RecievedCrushPoint(tNet_contents* pContents) {
748
    //tCar_spec* car; // Pierre-Marie Baty -- unused variable
749
    LOG_TRACE("(%p)", pContents);
750
    NOT_IMPLEMENTED();
751
}
752
 
753
// IDA: void __usercall GetReducedMatrix(tReduced_matrix *m1@<EAX>, br_matrix34 *m2@<EDX>)
754
void GetReducedMatrix(tReduced_matrix* m1, br_matrix34* m2) {
755
    LOG_TRACE("(%p, %p)", m1, m2);
756
    NOT_IMPLEMENTED();
757
}
758
 
759
// IDA: void __usercall GetExpandedMatrix(br_matrix34 *m1@<EAX>, tReduced_matrix *m2@<EDX>)
760
void GetExpandedMatrix(br_matrix34* m1, tReduced_matrix* m2) {
761
    LOG_TRACE("(%p, %p)", m1, m2);
762
    NOT_IMPLEMENTED();
763
}
764
 
765
// IDA: void __usercall NetEarnCredits(tNet_game_player_info *pPlayer@<EAX>, tS32 pCredits@<EDX>)
766
void NetEarnCredits(tNet_game_player_info* pPlayer, tS32 pCredits) {
767
    LOG_TRACE("(%p, %d)", pPlayer, pCredits);
768
    NOT_IMPLEMENTED();
769
}