|
@@ -89,373 +89,6 @@ int OpenRaider::initialize() {
|
89
|
89
|
return 0;
|
90
|
90
|
}
|
91
|
91
|
|
92
|
|
-int OpenRaider::loadConfig(const char *config) {
|
93
|
|
- assert(config != NULL);
|
94
|
|
- assert(config[0] != '\0');
|
95
|
|
-
|
96
|
|
- char *configFile = fullPath(config, 0);
|
97
|
|
- getConsole().print("Loading config from \"%s\"...", configFile);
|
98
|
|
-
|
99
|
|
- FILE *f = fopen(configFile, "r");
|
100
|
|
- if (f == NULL) {
|
101
|
|
- getConsole().print("Could not open file!");
|
102
|
|
- return -1;
|
103
|
|
- }
|
104
|
|
-
|
105
|
|
- char buffer[256];
|
106
|
|
- while (fgets(buffer, 256, f) != NULL) {
|
107
|
|
- int error = command(buffer);
|
108
|
|
- if (error != 0) {
|
109
|
|
- getConsole().print("Error Code: %d", error);
|
110
|
|
- }
|
111
|
|
- }
|
112
|
|
-
|
113
|
|
- fclose(f);
|
114
|
|
-
|
115
|
|
- return 0;
|
116
|
|
-}
|
117
|
|
-
|
118
|
|
-int OpenRaider::command(const char *command) {
|
119
|
|
- assert(command != NULL);
|
120
|
|
- assert(command[0] != '\0');
|
121
|
|
-
|
122
|
|
- int returnValue = 0;
|
123
|
|
- char *cmd = bufferString("%s", command);
|
124
|
|
- size_t length = strlen(cmd);
|
125
|
|
-
|
126
|
|
-
|
127
|
|
- for (size_t i = 0; i < length; i++) {
|
128
|
|
- if (cmd[i] == '\n' || cmd[i] == '#') {
|
129
|
|
- cmd[i] = '\0';
|
130
|
|
- break;
|
131
|
|
- }
|
132
|
|
- }
|
133
|
|
-
|
134
|
|
- char *token = strtok(cmd, " \t");
|
135
|
|
- if (token != NULL) {
|
136
|
|
-
|
137
|
|
-
|
138
|
|
- std::vector<char *> args;
|
139
|
|
- char *next;
|
140
|
|
- while ((next = strtok(NULL, " \t")) != NULL) {
|
141
|
|
- args.push_back(next);
|
142
|
|
- }
|
143
|
|
-
|
144
|
|
-
|
145
|
|
- returnValue = this->command(token, &args);
|
146
|
|
- }
|
147
|
|
-
|
148
|
|
- delete [] cmd;
|
149
|
|
- return returnValue;
|
150
|
|
-}
|
151
|
|
-
|
152
|
|
-char *OpenRaider::expandDirectoryNames(const char *s) {
|
153
|
|
- assert(s != NULL);
|
154
|
|
- assert(s[0] != '\0');
|
155
|
|
-
|
156
|
|
- if (mBaseDir != NULL) {
|
157
|
|
- const char *base = "$(basedir)";
|
158
|
|
- if (strstr(s, base) != NULL) {
|
159
|
|
- return stringReplace(s, base, mBaseDir);
|
160
|
|
- }
|
161
|
|
- }
|
162
|
|
-
|
163
|
|
- if (mPakDir != NULL) {
|
164
|
|
- const char *pak = "$(pakdir)";
|
165
|
|
- if (strstr(s, pak) != NULL) {
|
166
|
|
- return stringReplace(s, pak, mPakDir);
|
167
|
|
- }
|
168
|
|
- }
|
169
|
|
-
|
170
|
|
- if (mAudioDir != NULL) {
|
171
|
|
- const char *audio = "$(audiodir)";
|
172
|
|
- if (strstr(s, audio) != NULL) {
|
173
|
|
- return stringReplace(s, audio, mAudioDir);
|
174
|
|
- }
|
175
|
|
- }
|
176
|
|
-
|
177
|
|
- if (mDataDir != NULL) {
|
178
|
|
- const char *data = "$(datadir)";
|
179
|
|
- if (strstr(s, data) != NULL) {
|
180
|
|
- return stringReplace(s, data, mDataDir);
|
181
|
|
- }
|
182
|
|
- }
|
183
|
|
-
|
184
|
|
- return NULL;
|
185
|
|
-}
|
186
|
|
-
|
187
|
|
-#define CHANGE_DIR_WITH_EXPANSION(a) do { \
|
188
|
|
- char *quotes = stringRemoveQuotes(value); \
|
189
|
|
- char *tmp = expandDirectoryNames(quotes); \
|
190
|
|
- if (tmp == NULL) { \
|
191
|
|
- a = fullPath(quotes, 0); \
|
192
|
|
- } else { \
|
193
|
|
- a = fullPath(tmp, 0); \
|
194
|
|
- delete [] tmp; \
|
195
|
|
- } \
|
196
|
|
- delete [] quotes; \
|
197
|
|
-} while(false)
|
198
|
|
-
|
199
|
|
-int OpenRaider::set(const char *var, const char *value) {
|
200
|
|
- assert(var != NULL);
|
201
|
|
- assert(var[0] != '\0');
|
202
|
|
- assert(value != NULL);
|
203
|
|
- assert(value[0] != '\0');
|
204
|
|
-
|
205
|
|
- if (strcmp(var, "size") == 0) {
|
206
|
|
-
|
207
|
|
- unsigned int w = DEFAULT_WIDTH, h = DEFAULT_HEIGHT;
|
208
|
|
- if (sscanf(value, "\"%5ux%5u\"", &w, &h) != 2) {
|
209
|
|
- getConsole().print("set-size-Error: Invalid value (%s)", value);
|
210
|
|
- return -2;
|
211
|
|
- }
|
212
|
|
- getWindow().setSize(w, h);
|
213
|
|
- } else if (strcmp(var, "fullscreen") == 0) {
|
214
|
|
- bool fullscreen = false;
|
215
|
|
- if (readBool(value, &fullscreen) != 0) {
|
216
|
|
- getConsole().print("set-fullscreen-Error: Invalid value (%s)", value);
|
217
|
|
- return -3;
|
218
|
|
- }
|
219
|
|
- getWindow().setFullscreen(fullscreen);
|
220
|
|
- } else if (strcmp(var, "gldriver") == 0) {
|
221
|
|
- getWindow().setDriver(value);
|
222
|
|
- } else if (strcmp(var, "audio") == 0) {
|
223
|
|
- bool audio = false;
|
224
|
|
- if (readBool(value, &audio) != 0) {
|
225
|
|
- getConsole().print("set-audio-Error: Invalid value (%s)", value);
|
226
|
|
- return -4;
|
227
|
|
- }
|
228
|
|
- getSound().setEnabled(audio);
|
229
|
|
- } else if (strcmp(var, "volume") == 0) {
|
230
|
|
- float vol = 1.0f;
|
231
|
|
- if (sscanf(value, "%5f", &vol) != 1) {
|
232
|
|
- getConsole().print("set-volume-Error: Invalid value (%s)", value);
|
233
|
|
- return -5;
|
234
|
|
- }
|
235
|
|
- getSound().setVolume(vol);
|
236
|
|
- } else if (strcmp(var, "mouse_x") == 0) {
|
237
|
|
- float sense = 1.0f;
|
238
|
|
- if (sscanf(value, "%5f", &sense) != 1) {
|
239
|
|
- getConsole().print("set-mouse_x-Error: Invalid value (%s)", value);
|
240
|
|
- return -6;
|
241
|
|
- }
|
242
|
|
- getCamera().setSensitivityX(OR_DEG_TO_RAD(sense));
|
243
|
|
- } else if (strcmp(var, "mouse_y") == 0) {
|
244
|
|
- float sense = 1.0f;
|
245
|
|
- if (sscanf(value, "%5f", &sense) != 1) {
|
246
|
|
- getConsole().print("set-mouse_y-Error: Invalid value (%s)", value);
|
247
|
|
- return -7;
|
248
|
|
- }
|
249
|
|
- getCamera().setSensitivityY(OR_DEG_TO_RAD(sense));
|
250
|
|
- } else if (strcmp(var, "fps") == 0) {
|
251
|
|
- bool fps = false;
|
252
|
|
- if (readBool(value, &fps) != 0) {
|
253
|
|
- getConsole().print("set-fps-Error: Invalid value (%s)", value);
|
254
|
|
- return -8;
|
255
|
|
- }
|
256
|
|
- mFPS = fps;
|
257
|
|
- } else if (strcmp(var, "basedir") == 0) {
|
258
|
|
- CHANGE_DIR_WITH_EXPANSION(mBaseDir);
|
259
|
|
- } else if (strcmp(var, "pakdir") == 0) {
|
260
|
|
- CHANGE_DIR_WITH_EXPANSION(mPakDir);
|
261
|
|
- } else if (strcmp(var, "audiodir") == 0) {
|
262
|
|
- CHANGE_DIR_WITH_EXPANSION(mAudioDir);
|
263
|
|
- } else if (strcmp(var, "datadir") == 0) {
|
264
|
|
- CHANGE_DIR_WITH_EXPANSION(mDataDir);
|
265
|
|
- } else if (strcmp(var, "font") == 0) {
|
266
|
|
- char *quotes = stringReplace(value, "\"", "");
|
267
|
|
- char *tmp = expandDirectoryNames(quotes);
|
268
|
|
- if (tmp == NULL) {
|
269
|
|
- getWindow().setFont(quotes);
|
270
|
|
- } else {
|
271
|
|
- getWindow().setFont(tmp);
|
272
|
|
- delete [] tmp;
|
273
|
|
- }
|
274
|
|
- delete [] quotes;
|
275
|
|
- } else {
|
276
|
|
- getConsole().print("set-Error: Unknown variable (%s = %s)", var, value);
|
277
|
|
- return -1;
|
278
|
|
- }
|
279
|
|
-
|
280
|
|
- return 0;
|
281
|
|
-}
|
282
|
|
-
|
283
|
|
-int OpenRaider::bind(const char *action, const char *key) {
|
284
|
|
- assert(action != NULL);
|
285
|
|
- assert(action[0] != '\0');
|
286
|
|
- assert(key != NULL);
|
287
|
|
- assert(key[0] != '\0');
|
288
|
|
-
|
289
|
|
- const char *tmp = action;
|
290
|
|
- if (action[0] == '+')
|
291
|
|
- tmp++;
|
292
|
|
-
|
293
|
|
- if (strcmp(tmp, "menu") == 0) {
|
294
|
|
- return bind(menuAction, key);
|
295
|
|
- } else if (strcmp(tmp, "console") == 0) {
|
296
|
|
- return bind(consoleAction, key);
|
297
|
|
- } else if (strcmp(tmp, "forward") == 0) {
|
298
|
|
- return bind(forwardAction, key);
|
299
|
|
- } else if (strcmp(tmp, "backward") == 0) {
|
300
|
|
- return bind(backwardAction, key);
|
301
|
|
- } else if (strcmp(tmp, "left") == 0) {
|
302
|
|
- return bind(leftAction, key);
|
303
|
|
- } else if (strcmp(tmp, "right") == 0) {
|
304
|
|
- return bind(rightAction, key);
|
305
|
|
- } else if (strcmp(tmp, "jump") == 0) {
|
306
|
|
- return bind(jumpAction, key);
|
307
|
|
- } else if (strcmp(tmp, "crouch") == 0) {
|
308
|
|
- return bind(crouchAction, key);
|
309
|
|
- } else if (strcmp(tmp, "use") == 0) {
|
310
|
|
- return bind(useAction, key);
|
311
|
|
- } else if (strcmp(tmp, "holster") == 0) {
|
312
|
|
- return bind(holsterAction, key);
|
313
|
|
- } else if (strcmp(tmp, "walk") == 0) {
|
314
|
|
- return bind(walkAction, key);
|
315
|
|
- } else {
|
316
|
|
- getConsole().print("bind-Error: Unknown action (%s --> %s)", key, action);
|
317
|
|
- return -1;
|
318
|
|
- }
|
319
|
|
-}
|
320
|
|
-
|
321
|
|
-int OpenRaider::bind(ActionEvents action, const char *key) {
|
322
|
|
- assert(action < ActionEventCount);
|
323
|
|
- assert(key != NULL);
|
324
|
|
- assert(key[0] != '\0');
|
325
|
|
-
|
326
|
|
- size_t length = strlen(key);
|
327
|
|
- if ((key[0] == '\'') && (key[length - 1] == '\'') && (length == 3)) {
|
328
|
|
-
|
329
|
|
- char c = key[1];
|
330
|
|
- if (((c >= '0') && (c <= '9'))
|
331
|
|
- || ((c >= 'a') && (c <= 'z'))) {
|
332
|
|
- keyBindings[action] = (KeyboardButton)c;
|
333
|
|
- } else {
|
334
|
|
- getConsole().print("bind-\'\'-Error: Unknown key (%s)", key);
|
335
|
|
- return -1;
|
336
|
|
- }
|
337
|
|
- } else if ((key[0] == '\"') && (key[length - 1] == '\"')) {
|
338
|
|
-
|
339
|
|
- char *tmp = stringRemoveQuotes(key);
|
340
|
|
- if (strcmp(tmp, "quote") == 0) {
|
341
|
|
- keyBindings[action] = quoteKey;
|
342
|
|
- } else if (strcmp(tmp, "backslash") == 0) {
|
343
|
|
- keyBindings[action] = backslashKey;
|
344
|
|
- } else if (strcmp(tmp, "backspace") == 0) {
|
345
|
|
- keyBindings[action] = backspaceKey;
|
346
|
|
- } else if (strcmp(tmp, "capslock") == 0) {
|
347
|
|
- keyBindings[action] = capslockKey;
|
348
|
|
- } else if (strcmp(tmp, "comma") == 0) {
|
349
|
|
- keyBindings[action] = commaKey;
|
350
|
|
- } else if (strcmp(tmp, "del") == 0) {
|
351
|
|
- keyBindings[action] = delKey;
|
352
|
|
- } else if (strcmp(tmp, "up") == 0) {
|
353
|
|
- keyBindings[action] = upKey;
|
354
|
|
- } else if (strcmp(tmp, "down") == 0) {
|
355
|
|
- keyBindings[action] = downKey;
|
356
|
|
- } else if (strcmp(tmp, "left") == 0) {
|
357
|
|
- keyBindings[action] = leftKey;
|
358
|
|
- } else if (strcmp(tmp, "right") == 0) {
|
359
|
|
- keyBindings[action] = rightKey;
|
360
|
|
- } else if (strcmp(tmp, "end") == 0) {
|
361
|
|
- keyBindings[action] = endKey;
|
362
|
|
- } else if (strcmp(tmp, "equals") == 0) {
|
363
|
|
- keyBindings[action] = equalsKey;
|
364
|
|
- } else if (strcmp(tmp, "escape") == 0) {
|
365
|
|
- keyBindings[action] = escapeKey;
|
366
|
|
- } else if (strcmp(tmp, "f1") == 0) {
|
367
|
|
- keyBindings[action] = f1Key;
|
368
|
|
- } else if (strcmp(tmp, "f2") == 0) {
|
369
|
|
- keyBindings[action] = f2Key;
|
370
|
|
- } else if (strcmp(tmp, "f3") == 0) {
|
371
|
|
- keyBindings[action] = f3Key;
|
372
|
|
- } else if (strcmp(tmp, "f4") == 0) {
|
373
|
|
- keyBindings[action] = f4Key;
|
374
|
|
- } else if (strcmp(tmp, "f5") == 0) {
|
375
|
|
- keyBindings[action] = f5Key;
|
376
|
|
- } else if (strcmp(tmp, "f6") == 0) {
|
377
|
|
- keyBindings[action] = f6Key;
|
378
|
|
- } else if (strcmp(tmp, "f7") == 0) {
|
379
|
|
- keyBindings[action] = f7Key;
|
380
|
|
- } else if (strcmp(tmp, "f8") == 0) {
|
381
|
|
- keyBindings[action] = f8Key;
|
382
|
|
- } else if (strcmp(tmp, "f9") == 0) {
|
383
|
|
- keyBindings[action] = f9Key;
|
384
|
|
- } else if (strcmp(tmp, "f10") == 0) {
|
385
|
|
- keyBindings[action] = f10Key;
|
386
|
|
- } else if (strcmp(tmp, "f11") == 0) {
|
387
|
|
- keyBindings[action] = f11Key;
|
388
|
|
- } else if (strcmp(tmp, "f12") == 0) {
|
389
|
|
- keyBindings[action] = f12Key;
|
390
|
|
- } else if (strcmp(tmp, "backquote") == 0) {
|
391
|
|
- keyBindings[action] = backquoteKey;
|
392
|
|
- } else if (strcmp(tmp, "home") == 0) {
|
393
|
|
- keyBindings[action] = homeKey;
|
394
|
|
- } else if (strcmp(tmp, "insert") == 0) {
|
395
|
|
- keyBindings[action] = insertKey;
|
396
|
|
- } else if (strcmp(tmp, "leftalt") == 0) {
|
397
|
|
- keyBindings[action] = leftaltKey;
|
398
|
|
- } else if (strcmp(tmp, "leftctrl") == 0) {
|
399
|
|
- keyBindings[action] = leftctrlKey;
|
400
|
|
- } else if (strcmp(tmp, "leftbracket") == 0) {
|
401
|
|
- keyBindings[action] = leftbracketKey;
|
402
|
|
- } else if (strcmp(tmp, "leftgui") == 0) {
|
403
|
|
- keyBindings[action] = leftguiKey;
|
404
|
|
- } else if (strcmp(tmp, "leftshift") == 0) {
|
405
|
|
- keyBindings[action] = leftshiftKey;
|
406
|
|
- } else if (strcmp(tmp, "minus") == 0) {
|
407
|
|
- keyBindings[action] = minusKey;
|
408
|
|
- } else if (strcmp(tmp, "numlock") == 0) {
|
409
|
|
- keyBindings[action] = numlockKey;
|
410
|
|
- } else if (strcmp(tmp, "pagedown") == 0) {
|
411
|
|
- keyBindings[action] = pagedownKey;
|
412
|
|
- } else if (strcmp(tmp, "pageup") == 0) {
|
413
|
|
- keyBindings[action] = pageupKey;
|
414
|
|
- } else if (strcmp(tmp, "pause") == 0) {
|
415
|
|
- keyBindings[action] = pauseKey;
|
416
|
|
- } else if (strcmp(tmp, "dot") == 0) {
|
417
|
|
- keyBindings[action] = dotKey;
|
418
|
|
- } else if (strcmp(tmp, "rightalt") == 0) {
|
419
|
|
- keyBindings[action] = rightaltKey;
|
420
|
|
- } else if (strcmp(tmp, "rightctrl") == 0) {
|
421
|
|
- keyBindings[action] = rightctrlKey;
|
422
|
|
- } else if (strcmp(tmp, "enter") == 0) {
|
423
|
|
- keyBindings[action] = enterKey;
|
424
|
|
- } else if (strcmp(tmp, "rightgui") == 0) {
|
425
|
|
- keyBindings[action] = rightguiKey;
|
426
|
|
- } else if (strcmp(tmp, "rightbracket") == 0) {
|
427
|
|
- keyBindings[action] = rightbracketKey;
|
428
|
|
- } else if (strcmp(tmp, "rightshift") == 0) {
|
429
|
|
- keyBindings[action] = rightshiftKey;
|
430
|
|
- } else if (strcmp(tmp, "scrolllock") == 0) {
|
431
|
|
- keyBindings[action] = scrolllockKey;
|
432
|
|
- } else if (strcmp(tmp, "semicolon") == 0) {
|
433
|
|
- keyBindings[action] = semicolonKey;
|
434
|
|
- } else if (strcmp(tmp, "slash") == 0) {
|
435
|
|
- keyBindings[action] = slashKey;
|
436
|
|
- } else if (strcmp(tmp, "space") == 0) {
|
437
|
|
- keyBindings[action] = spaceKey;
|
438
|
|
- } else if (strcmp(tmp, "tab") == 0) {
|
439
|
|
- keyBindings[action] = tabKey;
|
440
|
|
- } else if (strcmp(tmp, "leftmouse") == 0) {
|
441
|
|
- keyBindings[action] = leftmouseKey;
|
442
|
|
- } else if (strcmp(tmp, "middlemouse") == 0) {
|
443
|
|
- keyBindings[action] = middlemouseKey;
|
444
|
|
- } else if (strcmp(tmp, "rightmouse") == 0) {
|
445
|
|
- keyBindings[action] = rightmouseKey;
|
446
|
|
- } else {
|
447
|
|
- getConsole().print("bind-\"\"-Error: Unknown key (%s)", key);
|
448
|
|
- delete [] tmp;
|
449
|
|
- return -2;
|
450
|
|
- }
|
451
|
|
- delete [] tmp;
|
452
|
|
- } else {
|
453
|
|
- getConsole().print("bind-Error: Unknown key (%s)", key);
|
454
|
|
- return -3;
|
455
|
|
- }
|
456
|
|
- return 0;
|
457
|
|
-}
|
458
|
|
-
|
459
|
92
|
void OpenRaider::run() {
|
460
|
93
|
assert(mRunning == false);
|
461
|
94
|
mRunning = true;
|