Merge remote-tracking branch 'alex/main' into add_party_member_list
This commit is contained in:
commit
d4f3dddf7c
|
@ -31,6 +31,18 @@ jobs:
|
|||
- name: cppcheck
|
||||
run: cppcheck --std=c++17 src/
|
||||
|
||||
code-format:
|
||||
name: Code format check
|
||||
|
||||
runs-on: ubuntu-latest
|
||||
|
||||
steps:
|
||||
- name: Clone
|
||||
uses: actions/checkout@v3
|
||||
|
||||
- name: clang-format
|
||||
run: find src -type f -exec clang-format --dry-run --Werror {} \;
|
||||
|
||||
android:
|
||||
name: Android
|
||||
|
||||
|
@ -78,7 +90,7 @@ jobs:
|
|||
ios:
|
||||
name: iOS
|
||||
|
||||
runs-on: macos-11
|
||||
runs-on: macos-12
|
||||
|
||||
steps:
|
||||
- name: Clone
|
||||
|
@ -88,30 +100,31 @@ jobs:
|
|||
uses: actions/cache@v3
|
||||
with:
|
||||
path: build
|
||||
key: ios-cmake-v1
|
||||
key: ios-cmake-v2
|
||||
|
||||
- name: Configure
|
||||
run: |
|
||||
cmake \
|
||||
-B build \
|
||||
-D CMAKE_BUILD_TYPE=RelWithDebInfo \
|
||||
-D CMAKE_TOOLCHAIN_FILE=cmake/toolchain/ios.toolchain.cmake \
|
||||
-D ENABLE_BITCODE=0 \
|
||||
-D PLATFORM=OS64 \
|
||||
-G Xcode \
|
||||
-D CMAKE_XCODE_ATTRIBUTE_CODE_SIGN_IDENTITY='' \
|
||||
# EOL
|
||||
|
||||
- name: Build
|
||||
run: |
|
||||
cmake \
|
||||
--build build \
|
||||
--config RelWithDebInfo \
|
||||
-j $(sysctl -n hw.physicalcpu) \
|
||||
--target package \
|
||||
# EOL
|
||||
|
||||
# TODO: Should be a part of packaging.
|
||||
- name: Prepare for uploading
|
||||
- name: Pack
|
||||
run: |
|
||||
cp build/fallout2-ce.zip build/fallout2-ce.ipa
|
||||
cd build
|
||||
cpack -C RelWithDebInfo
|
||||
|
||||
- name: Upload
|
||||
uses: actions/upload-artifact@v3
|
||||
|
|
|
@ -305,21 +305,30 @@ if(WIN32)
|
|||
endif()
|
||||
|
||||
if(APPLE)
|
||||
target_sources(${EXECUTABLE_NAME} PUBLIC "os/macos/fallout2-ce.icns")
|
||||
set_source_files_properties("os/macos/fallout2-ce.icns" PROPERTIES MACOSX_PACKAGE_LOCATION "Resources")
|
||||
|
||||
if(IOS)
|
||||
target_sources(${EXECUTABLE_NAME} PUBLIC "os/ios/LaunchScreen.storyboard")
|
||||
set_source_files_properties("os/ios/LaunchScreen.storyboard" PROPERTIES MACOSX_PACKAGE_LOCATION "Resources")
|
||||
set_target_properties(${EXECUTABLE_NAME} PROPERTIES MACOSX_BUNDLE_INFO_PLIST "${CMAKE_SOURCE_DIR}/os/ios/Info.plist")
|
||||
set_target_properties(${EXECUTABLE_NAME} PROPERTIES XCODE_ATTRIBUTE_TARGETED_DEVICE_FAMILY "1,2")
|
||||
set(RESOURCES
|
||||
"os/ios/AppIcon.xcassets"
|
||||
"os/ios/LaunchScreen.storyboard"
|
||||
)
|
||||
|
||||
target_sources(${EXECUTABLE_NAME} PUBLIC ${RESOURCES})
|
||||
set_source_files_properties(${RESOURCES} PROPERTIES MACOSX_PACKAGE_LOCATION "Resources")
|
||||
|
||||
set_target_properties(${EXECUTABLE_NAME} PROPERTIES
|
||||
MACOSX_BUNDLE_INFO_PLIST "${CMAKE_SOURCE_DIR}/os/ios/Info.plist"
|
||||
XCODE_ATTRIBUTE_ASSETCATALOG_COMPILER_APPICON_NAME "AppIcon"
|
||||
XCODE_ATTRIBUTE_PRODUCT_BUNDLE_IDENTIFIER "com.alexbatalov.fallout2-ce"
|
||||
XCODE_ATTRIBUTE_TARGETED_DEVICE_FAMILY "1,2"
|
||||
)
|
||||
else()
|
||||
set_target_properties(${EXECUTABLE_NAME} PROPERTIES MACOSX_BUNDLE_INFO_PLIST "${CMAKE_SOURCE_DIR}/os/macos/Info.plist")
|
||||
target_sources(${EXECUTABLE_NAME} PUBLIC "os/macos/fallout2-ce.icns")
|
||||
set_source_files_properties("os/macos/fallout2-ce.icns" PROPERTIES MACOSX_PACKAGE_LOCATION "Resources")
|
||||
set(MACOSX_BUNDLE_ICON_FILE "fallout2-ce.icns")
|
||||
endif()
|
||||
|
||||
set(MACOSX_BUNDLE_GUI_IDENTIFIER "com.alexbatalov.fallout2-ce")
|
||||
set(MACOSX_BUNDLE_BUNDLE_NAME "${EXECUTABLE_NAME}")
|
||||
set(MACOSX_BUNDLE_ICON_FILE "fallout2-ce.icns")
|
||||
set(MACOSX_BUNDLE_DISPLAY_NAME "Fallout 2")
|
||||
set(MACOSX_BUNDLE_SHORT_VERSION_STRING "1.2.0")
|
||||
set(MACOSX_BUNDLE_BUNDLE_VERSION "1.2.0")
|
||||
|
@ -350,6 +359,7 @@ if(APPLE)
|
|||
set(CPACK_GENERATOR "ZIP")
|
||||
set(CPACK_INCLUDE_TOPLEVEL_DIRECTORY OFF)
|
||||
set(CPACK_PACKAGE_FILE_NAME "fallout2-ce")
|
||||
set(CPACK_ARCHIVE_FILE_EXTENSION "ipa")
|
||||
else()
|
||||
install(TARGETS ${EXECUTABLE_NAME} DESTINATION .)
|
||||
install(CODE "
|
||||
|
|
Binary file not shown.
After Width: | Height: | Size: 1009 KiB |
|
@ -0,0 +1,14 @@
|
|||
{
|
||||
"images" : [
|
||||
{
|
||||
"filename" : "AppIcon.png",
|
||||
"idiom" : "universal",
|
||||
"platform" : "ios",
|
||||
"size" : "1024x1024"
|
||||
}
|
||||
],
|
||||
"info" : {
|
||||
"author" : "xcode",
|
||||
"version" : 1
|
||||
}
|
||||
}
|
|
@ -0,0 +1,6 @@
|
|||
{
|
||||
"info" : {
|
||||
"author" : "xcode",
|
||||
"version" : 1
|
||||
}
|
||||
}
|
|
@ -8,8 +8,6 @@
|
|||
<string>${MACOSX_BUNDLE_DISPLAY_NAME}</string>
|
||||
<key>CFBundleExecutable</key>
|
||||
<string>${MACOSX_BUNDLE_EXECUTABLE_NAME}</string>
|
||||
<key>CFBundleIconFile</key>
|
||||
<string>${MACOSX_BUNDLE_ICON_FILE}</string>
|
||||
<key>CFBundleIdentifier</key>
|
||||
<string>${MACOSX_BUNDLE_GUI_IDENTIFIER}</string>
|
||||
<key>CFBundleInfoDictionaryVersion</key>
|
||||
|
@ -22,8 +20,6 @@
|
|||
<string>${MACOSX_BUNDLE_SHORT_VERSION_STRING}</string>
|
||||
<key>CFBundleVersion</key>
|
||||
<string>${MACOSX_BUNDLE_BUNDLE_VERSION}</string>
|
||||
<key>LSApplicationCategoryType</key>
|
||||
<string>public.app-category.role-playing-games</string>
|
||||
<key>LSMinimumSystemVersion</key>
|
||||
<string>11.0</string>
|
||||
<key>LSRequiresIPhoneOS</key>
|
||||
|
@ -32,11 +28,6 @@
|
|||
<string>True</string>
|
||||
<key>UIApplicationSupportsIndirectInputEvents</key>
|
||||
<true/>
|
||||
<key>UIDeviceFamily</key>
|
||||
<array>
|
||||
<integer>1</integer>
|
||||
<integer>2</integer>
|
||||
</array>
|
||||
<key>UIFileSharingEnabled</key>
|
||||
<true/>
|
||||
<key>UILaunchStoryboardName</key>
|
||||
|
|
|
@ -92,7 +92,7 @@ typedef enum AnimationType {
|
|||
LAST_SF_DEATH_ANIM = ANIM_FALL_FRONT_BLOOD_SF,
|
||||
} AnimationType;
|
||||
|
||||
#define FID_ANIM_TYPE(value) ((value) & 0xFF0000) >> 16
|
||||
#define FID_ANIM_TYPE(value) ((value)&0xFF0000) >> 16
|
||||
|
||||
// Signature of animation callback accepting 2 parameters.
|
||||
typedef int(AnimationCallback)(void* a1, void* a2);
|
||||
|
|
|
@ -58,7 +58,7 @@ static int audioSoundDecoderReadHandler(void* data, void* buffer, unsigned int s
|
|||
|
||||
// AudioOpen
|
||||
// 0x41A2EC
|
||||
int audioOpen(const char* fname, int* channels, int* sampleRate)
|
||||
int audioOpen(const char* fname, int* sampleRate)
|
||||
{
|
||||
char path[80];
|
||||
snprintf(path, sizeof(path), "%s", fname);
|
||||
|
@ -101,7 +101,6 @@ int audioOpen(const char* fname, int* channels, int* sampleRate)
|
|||
audioFile->soundDecoder = soundDecoderInit(audioSoundDecoderReadHandler, audioFile->stream, &(audioFile->channels), &(audioFile->sampleRate), &(audioFile->fileSize));
|
||||
audioFile->fileSize *= 2;
|
||||
|
||||
*channels = audioFile->channels;
|
||||
*sampleRate = audioFile->sampleRate;
|
||||
} else {
|
||||
audioFile->fileSize = fileGetSize(stream);
|
||||
|
|
|
@ -5,7 +5,7 @@ namespace fallout {
|
|||
|
||||
typedef bool(AudioQueryCompressedFunc)(char* filePath);
|
||||
|
||||
int audioOpen(const char* fname, int* channels, int* sampleRate);
|
||||
int audioOpen(const char* fname, int* sampleRate);
|
||||
int audioClose(int handle);
|
||||
int audioRead(int handle, void* buffer, unsigned int size);
|
||||
long audioSeek(int handle, long offset, int origin);
|
||||
|
|
|
@ -57,7 +57,7 @@ static int audioFileSoundDecoderReadHandler(void* data, void* buffer, unsigned i
|
|||
}
|
||||
|
||||
// 0x41A88C
|
||||
int audioFileOpen(const char* fname, int* channels, int* sampleRate)
|
||||
int audioFileOpen(const char* fname, int* sampleRate)
|
||||
{
|
||||
char path[COMPAT_MAX_PATH];
|
||||
strcpy(path, fname);
|
||||
|
@ -99,7 +99,6 @@ int audioFileOpen(const char* fname, int* channels, int* sampleRate)
|
|||
audioFile->soundDecoder = soundDecoderInit(audioFileSoundDecoderReadHandler, audioFile->stream, &(audioFile->channels), &(audioFile->sampleRate), &(audioFile->fileSize));
|
||||
audioFile->fileSize *= 2;
|
||||
|
||||
*channels = audioFile->channels;
|
||||
*sampleRate = audioFile->sampleRate;
|
||||
} else {
|
||||
audioFile->fileSize = getFileSize(stream);
|
||||
|
|
|
@ -5,7 +5,7 @@ namespace fallout {
|
|||
|
||||
typedef bool(AudioFileQueryCompressedFunc)(char* filePath);
|
||||
|
||||
int audioFileOpen(const char* fname, int* channels, int* sampleRate);
|
||||
int audioFileOpen(const char* fname, int* sampleRate);
|
||||
int audioFileClose(int handle);
|
||||
int audioFileRead(int handle, void* buf, unsigned int size);
|
||||
long audioFileSeek(int handle, long offset, int origin);
|
||||
|
|
|
@ -996,8 +996,8 @@ bool _critter_is_prone(Object* critter)
|
|||
int anim = FID_ANIM_TYPE(critter->fid);
|
||||
|
||||
return (critter->data.critter.combat.results & (DAM_KNOCKED_OUT | DAM_KNOCKED_DOWN)) != 0
|
||||
|| (anim >= FIRST_KNOCKDOWN_AND_DEATH_ANIM && anim <= LAST_KNOCKDOWN_AND_DEATH_ANIM)
|
||||
|| (anim >= FIRST_SF_DEATH_ANIM && anim <= LAST_SF_DEATH_ANIM);
|
||||
|| (anim >= FIRST_KNOCKDOWN_AND_DEATH_ANIM && anim <= LAST_KNOCKDOWN_AND_DEATH_ANIM)
|
||||
|| (anim >= FIRST_SF_DEATH_ANIM && anim <= LAST_SF_DEATH_ANIM);
|
||||
}
|
||||
|
||||
// critter_body_type
|
||||
|
|
10
src/game.cc
10
src/game.cc
|
@ -3,12 +3,6 @@
|
|||
#include <stdio.h>
|
||||
#include <string.h>
|
||||
|
||||
#ifdef _WIN32
|
||||
#include <io.h>
|
||||
#else
|
||||
#include <unistd.h> // access
|
||||
#endif
|
||||
|
||||
#include "actions.h"
|
||||
#include "animation.h"
|
||||
#include "art.h"
|
||||
|
@ -1338,12 +1332,12 @@ static int gameDbInit()
|
|||
for (patch_index = 0; patch_index < 1000; patch_index++) {
|
||||
snprintf(filename, sizeof(filename), "patch%03d.dat", patch_index);
|
||||
|
||||
if (access(filename, 0) == 0) {
|
||||
if (compat_access(filename, 0) == 0) {
|
||||
dbOpen(filename, 0, NULL, 1);
|
||||
}
|
||||
}
|
||||
|
||||
if (access("f2_res.dat", 0) == 0) {
|
||||
if (compat_access("f2_res.dat", 0) == 0) {
|
||||
dbOpen("f2_res.dat", 0, NULL, 1);
|
||||
}
|
||||
|
||||
|
|
|
@ -157,7 +157,7 @@ static int _gsound_speech_volume_get_set(int volume);
|
|||
static void speechPause();
|
||||
static void speechResume();
|
||||
static void _gsound_bkg_proc();
|
||||
static int gameSoundFileOpen(const char* fname, int* channels, int* sampleRate);
|
||||
static int gameSoundFileOpen(const char* fname, int* sampleRate);
|
||||
static long _gsound_write_();
|
||||
static long gameSoundFileTellNotImplemented(int handle);
|
||||
static int gameSoundFileWrite(int handle, const void* buf, unsigned int size);
|
||||
|
@ -1548,7 +1548,7 @@ void _gsound_bkg_proc()
|
|||
}
|
||||
|
||||
// 0x451A08
|
||||
int gameSoundFileOpen(const char* fname, int* channels, int* sampleRate)
|
||||
int gameSoundFileOpen(const char* fname, int* sampleRate)
|
||||
{
|
||||
File* stream = fileOpen(fname, "rb");
|
||||
if (stream == NULL) {
|
||||
|
|
24
src/input.cc
24
src/input.cc
|
@ -1026,24 +1026,24 @@ static void buildNormalizedQwertyKeys()
|
|||
keys[SDL_SCANCODE_F13] = -1;
|
||||
keys[SDL_SCANCODE_F14] = -1;
|
||||
keys[SDL_SCANCODE_F15] = -1;
|
||||
//keys[DIK_KANA] = -1;
|
||||
//keys[DIK_CONVERT] = -1;
|
||||
//keys[DIK_NOCONVERT] = -1;
|
||||
//keys[DIK_YEN] = -1;
|
||||
// keys[DIK_KANA] = -1;
|
||||
// keys[DIK_CONVERT] = -1;
|
||||
// keys[DIK_NOCONVERT] = -1;
|
||||
// keys[DIK_YEN] = -1;
|
||||
keys[SDL_SCANCODE_KP_EQUALS] = -1;
|
||||
//keys[DIK_PREVTRACK] = -1;
|
||||
//keys[DIK_AT] = -1;
|
||||
//keys[DIK_COLON] = -1;
|
||||
//keys[DIK_UNDERLINE] = -1;
|
||||
//keys[DIK_KANJI] = -1;
|
||||
// keys[DIK_PREVTRACK] = -1;
|
||||
// keys[DIK_AT] = -1;
|
||||
// keys[DIK_COLON] = -1;
|
||||
// keys[DIK_UNDERLINE] = -1;
|
||||
// keys[DIK_KANJI] = -1;
|
||||
keys[SDL_SCANCODE_STOP] = -1;
|
||||
//keys[DIK_AX] = -1;
|
||||
//keys[DIK_UNLABELED] = -1;
|
||||
// keys[DIK_AX] = -1;
|
||||
// keys[DIK_UNLABELED] = -1;
|
||||
keys[SDL_SCANCODE_KP_ENTER] = SDL_SCANCODE_KP_ENTER;
|
||||
keys[SDL_SCANCODE_RCTRL] = SDL_SCANCODE_RCTRL;
|
||||
keys[SDL_SCANCODE_KP_COMMA] = -1;
|
||||
keys[SDL_SCANCODE_KP_DIVIDE] = SDL_SCANCODE_KP_DIVIDE;
|
||||
//keys[DIK_SYSRQ] = 84;
|
||||
// keys[DIK_SYSRQ] = 84;
|
||||
keys[SDL_SCANCODE_RALT] = SDL_SCANCODE_RALT;
|
||||
keys[SDL_SCANCODE_HOME] = SDL_SCANCODE_HOME;
|
||||
keys[SDL_SCANCODE_UP] = SDL_SCANCODE_UP;
|
||||
|
|
|
@ -2694,7 +2694,7 @@ void inventoryOpenUseItemOn(Object* a1)
|
|||
inventoryWindowOpenContextMenu(keyCode, INVENTORY_WINDOW_TYPE_USE_ITEM_ON);
|
||||
} else {
|
||||
int inventoryItemIndex = _pud->length - (_stack_offset[_curr_stack] + keyCode - 1000 + 1);
|
||||
// SFALL: Fix crash when clicking on empty space in the inventory list
|
||||
// SFALL: Fix crash when clicking on empty space in the inventory list
|
||||
// opened by "Use Inventory Item On" (backpack) action icon
|
||||
if (inventoryItemIndex < _pud->length && inventoryItemIndex >= 0) {
|
||||
InventoryItem* inventoryItem = &(_pud->items[inventoryItemIndex]);
|
||||
|
|
40
src/kb.cc
40
src/kb.cc
|
@ -1400,11 +1400,11 @@ static void keyboardBuildFrenchConfiguration()
|
|||
gLogicalKeyEntries[SDL_SCANCODE_BACKSLASH].rmenu = -1;
|
||||
gLogicalKeyEntries[SDL_SCANCODE_BACKSLASH].ctrl = -1;
|
||||
|
||||
//gLogicalKeyEntries[DIK_OEM_102].unmodified = KEY_LESS;
|
||||
//gLogicalKeyEntries[DIK_OEM_102].shift = KEY_GREATER;
|
||||
//gLogicalKeyEntries[DIK_OEM_102].lmenu = -1;
|
||||
//gLogicalKeyEntries[DIK_OEM_102].rmenu = -1;
|
||||
//gLogicalKeyEntries[DIK_OEM_102].ctrl = -1;
|
||||
// gLogicalKeyEntries[DIK_OEM_102].unmodified = KEY_LESS;
|
||||
// gLogicalKeyEntries[DIK_OEM_102].shift = KEY_GREATER;
|
||||
// gLogicalKeyEntries[DIK_OEM_102].lmenu = -1;
|
||||
// gLogicalKeyEntries[DIK_OEM_102].rmenu = -1;
|
||||
// gLogicalKeyEntries[DIK_OEM_102].ctrl = -1;
|
||||
|
||||
switch (gKeyboardLayout) {
|
||||
case KEYBOARD_LAYOUT_QWERTY:
|
||||
|
@ -1583,11 +1583,11 @@ static void keyboardBuildGermanConfiguration()
|
|||
gLogicalKeyEntries[SDL_SCANCODE_BACKSLASH].rmenu = -1;
|
||||
gLogicalKeyEntries[SDL_SCANCODE_BACKSLASH].ctrl = -1;
|
||||
|
||||
//gLogicalKeyEntries[DIK_OEM_102].unmodified = KEY_LESS;
|
||||
//gLogicalKeyEntries[DIK_OEM_102].shift = KEY_GREATER;
|
||||
//gLogicalKeyEntries[DIK_OEM_102].lmenu = -1;
|
||||
//gLogicalKeyEntries[DIK_OEM_102].rmenu = KEY_166;
|
||||
//gLogicalKeyEntries[DIK_OEM_102].ctrl = -1;
|
||||
// gLogicalKeyEntries[DIK_OEM_102].unmodified = KEY_LESS;
|
||||
// gLogicalKeyEntries[DIK_OEM_102].shift = KEY_GREATER;
|
||||
// gLogicalKeyEntries[DIK_OEM_102].lmenu = -1;
|
||||
// gLogicalKeyEntries[DIK_OEM_102].rmenu = KEY_166;
|
||||
// gLogicalKeyEntries[DIK_OEM_102].ctrl = -1;
|
||||
|
||||
switch (gKeyboardLayout) {
|
||||
case KEYBOARD_LAYOUT_FRENCH:
|
||||
|
@ -1684,11 +1684,11 @@ static void keyboardBuildItalianConfiguration()
|
|||
gLogicalKeyEntries[SDL_SCANCODE_GRAVE].rmenu = -1;
|
||||
gLogicalKeyEntries[SDL_SCANCODE_GRAVE].ctrl = -1;
|
||||
|
||||
//gLogicalKeyEntries[DIK_OEM_102].unmodified = KEY_LESS;
|
||||
//gLogicalKeyEntries[DIK_OEM_102].shift = KEY_GREATER;
|
||||
//gLogicalKeyEntries[DIK_OEM_102].lmenu = -1;
|
||||
//gLogicalKeyEntries[DIK_OEM_102].rmenu = -1;
|
||||
//gLogicalKeyEntries[DIK_OEM_102].ctrl = -1;
|
||||
// gLogicalKeyEntries[DIK_OEM_102].unmodified = KEY_LESS;
|
||||
// gLogicalKeyEntries[DIK_OEM_102].shift = KEY_GREATER;
|
||||
// gLogicalKeyEntries[DIK_OEM_102].lmenu = -1;
|
||||
// gLogicalKeyEntries[DIK_OEM_102].rmenu = -1;
|
||||
// gLogicalKeyEntries[DIK_OEM_102].ctrl = -1;
|
||||
|
||||
gLogicalKeyEntries[SDL_SCANCODE_1].unmodified = KEY_1;
|
||||
gLogicalKeyEntries[SDL_SCANCODE_1].shift = KEY_EXCLAMATION;
|
||||
|
@ -1896,11 +1896,11 @@ static void keyboardBuildSpanishConfiguration()
|
|||
gLogicalKeyEntries[SDL_SCANCODE_RIGHTBRACKET].rmenu = KEY_BRACKET_RIGHT;
|
||||
gLogicalKeyEntries[SDL_SCANCODE_RIGHTBRACKET].ctrl = -1;
|
||||
|
||||
//gLogicalKeyEntries[DIK_OEM_102].unmodified = KEY_LESS;
|
||||
//gLogicalKeyEntries[DIK_OEM_102].shift = KEY_GREATER;
|
||||
//gLogicalKeyEntries[DIK_OEM_102].lmenu = -1;
|
||||
//gLogicalKeyEntries[DIK_OEM_102].rmenu = -1;
|
||||
//gLogicalKeyEntries[DIK_OEM_102].ctrl = -1;
|
||||
// gLogicalKeyEntries[DIK_OEM_102].unmodified = KEY_LESS;
|
||||
// gLogicalKeyEntries[DIK_OEM_102].shift = KEY_GREATER;
|
||||
// gLogicalKeyEntries[DIK_OEM_102].lmenu = -1;
|
||||
// gLogicalKeyEntries[DIK_OEM_102].rmenu = -1;
|
||||
// gLogicalKeyEntries[DIK_OEM_102].ctrl = -1;
|
||||
|
||||
gLogicalKeyEntries[SDL_SCANCODE_SEMICOLON].unmodified = KEY_241;
|
||||
gLogicalKeyEntries[SDL_SCANCODE_SEMICOLON].shift = KEY_209;
|
||||
|
|
|
@ -29,7 +29,7 @@ enum {
|
|||
OBJ_TYPE_COUNT,
|
||||
};
|
||||
|
||||
#define FID_TYPE(value) ((value) & 0xF000000) >> 24
|
||||
#define FID_TYPE(value) ((value)&0xF000000) >> 24
|
||||
#define PID_TYPE(value) (value) >> 24
|
||||
#define SID_TYPE(value) (value) >> 24
|
||||
|
||||
|
|
|
@ -12,6 +12,7 @@
|
|||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#else
|
||||
#include <dirent.h>
|
||||
#include <sys/stat.h>
|
||||
#include <unistd.h>
|
||||
#endif
|
||||
|
@ -204,6 +205,7 @@ int compat_mkdir(const char* path)
|
|||
char nativePath[COMPAT_MAX_PATH];
|
||||
strcpy(nativePath, path);
|
||||
compat_windows_path_to_native(nativePath);
|
||||
compat_resolve_path(nativePath);
|
||||
|
||||
#ifdef _WIN32
|
||||
return mkdir(nativePath);
|
||||
|
@ -228,6 +230,7 @@ FILE* compat_fopen(const char* path, const char* mode)
|
|||
char nativePath[COMPAT_MAX_PATH];
|
||||
strcpy(nativePath, path);
|
||||
compat_windows_path_to_native(nativePath);
|
||||
compat_resolve_path(nativePath);
|
||||
return fopen(nativePath, mode);
|
||||
}
|
||||
|
||||
|
@ -236,6 +239,7 @@ gzFile compat_gzopen(const char* path, const char* mode)
|
|||
char nativePath[COMPAT_MAX_PATH];
|
||||
strcpy(nativePath, path);
|
||||
compat_windows_path_to_native(nativePath);
|
||||
compat_resolve_path(nativePath);
|
||||
return gzopen(nativePath, mode);
|
||||
}
|
||||
|
||||
|
@ -274,6 +278,7 @@ int compat_remove(const char* path)
|
|||
char nativePath[COMPAT_MAX_PATH];
|
||||
strcpy(nativePath, path);
|
||||
compat_windows_path_to_native(nativePath);
|
||||
compat_resolve_path(nativePath);
|
||||
return remove(nativePath);
|
||||
}
|
||||
|
||||
|
@ -282,10 +287,12 @@ int compat_rename(const char* oldFileName, const char* newFileName)
|
|||
char nativeOldFileName[COMPAT_MAX_PATH];
|
||||
strcpy(nativeOldFileName, oldFileName);
|
||||
compat_windows_path_to_native(nativeOldFileName);
|
||||
compat_resolve_path(nativeOldFileName);
|
||||
|
||||
char nativeNewFileName[COMPAT_MAX_PATH];
|
||||
strcpy(nativeNewFileName, newFileName);
|
||||
compat_windows_path_to_native(nativeNewFileName);
|
||||
compat_resolve_path(nativeNewFileName);
|
||||
|
||||
return rename(nativeOldFileName, nativeNewFileName);
|
||||
}
|
||||
|
@ -303,6 +310,69 @@ void compat_windows_path_to_native(char* path)
|
|||
#endif
|
||||
}
|
||||
|
||||
void compat_resolve_path(char* path)
|
||||
{
|
||||
#ifndef _WIN32
|
||||
char* pch = path;
|
||||
|
||||
DIR *dir;
|
||||
if (pch[0] == '/') {
|
||||
dir = opendir("/");
|
||||
pch++;
|
||||
} else {
|
||||
dir = opendir(".");
|
||||
}
|
||||
|
||||
while (dir != NULL) {
|
||||
char* sep = strchr(pch, '/');
|
||||
size_t length;
|
||||
if (sep != NULL) {
|
||||
length = sep - pch;
|
||||
} else {
|
||||
length = strlen(pch);
|
||||
}
|
||||
|
||||
bool found = false;
|
||||
|
||||
struct dirent* entry = readdir(dir);
|
||||
while (entry != NULL) {
|
||||
if (strlen(entry->d_name) == length && compat_strnicmp(pch, entry->d_name, length) == 0) {
|
||||
strncpy(pch, entry->d_name, length);
|
||||
found = true;
|
||||
break;
|
||||
}
|
||||
entry = readdir(dir);
|
||||
}
|
||||
|
||||
closedir(dir);
|
||||
dir = NULL;
|
||||
|
||||
if (!found) {
|
||||
break;
|
||||
}
|
||||
|
||||
if (sep == NULL) {
|
||||
break;
|
||||
}
|
||||
|
||||
*sep = '\0';
|
||||
dir = opendir(path);
|
||||
*sep = '/';
|
||||
|
||||
pch = sep + 1;
|
||||
}
|
||||
#endif
|
||||
}
|
||||
|
||||
int compat_access(const char* path, int mode)
|
||||
{
|
||||
char nativePath[COMPAT_MAX_PATH];
|
||||
strcpy(nativePath, path);
|
||||
compat_windows_path_to_native(nativePath);
|
||||
compat_resolve_path(nativePath);
|
||||
return access(nativePath, mode);
|
||||
}
|
||||
|
||||
char* compat_strdup(const char* string)
|
||||
{
|
||||
return SDL_strdup(string);
|
||||
|
|
|
@ -40,6 +40,8 @@ char* compat_gzgets(gzFile stream, char* buffer, int maxCount);
|
|||
int compat_remove(const char* path);
|
||||
int compat_rename(const char* oldFileName, const char* newFileName);
|
||||
void compat_windows_path_to_native(char* path);
|
||||
void compat_resolve_path(char* path);
|
||||
int compat_access(const char* path, int mode);
|
||||
char* compat_strdup(const char* string);
|
||||
long getFileSize(FILE* stream);
|
||||
|
||||
|
|
|
@ -49,7 +49,7 @@ static long soundFileSize(int fileHandle);
|
|||
static long soundTellData(int fileHandle);
|
||||
static int soundWriteData(int fileHandle, const void* buf, unsigned int size);
|
||||
static int soundReadData(int fileHandle, void* buf, unsigned int size);
|
||||
static int soundOpenData(const char* filePath, int* channels, int* sampleRate);
|
||||
static int soundOpenData(const char* filePath, int* sampleRate);
|
||||
static long soundSeekData(int fileHandle, long offset, int origin);
|
||||
static int soundCloseData(int fileHandle);
|
||||
static char* soundFileManglerDefaultImpl(char* fname);
|
||||
|
@ -223,7 +223,7 @@ static int soundReadData(int fileHandle, void* buf, unsigned int size)
|
|||
}
|
||||
|
||||
// 0x4AC768
|
||||
static int soundOpenData(const char* filePath, int* channels, int* sampleRate)
|
||||
static int soundOpenData(const char* filePath, int* sampleRate)
|
||||
{
|
||||
int flags;
|
||||
|
||||
|
@ -616,7 +616,7 @@ int soundLoad(Sound* sound, char* filePath)
|
|||
return gSoundLastError;
|
||||
}
|
||||
|
||||
sound->io.fd = sound->io.open(gSoundFileNameMangler(filePath), &(sound->channels), &(sound->rate));
|
||||
sound->io.fd = sound->io.open(gSoundFileNameMangler(filePath), &(sound->rate));
|
||||
if (sound->io.fd == -1) {
|
||||
gSoundLastError = SOUND_FILE_NOT_FOUND;
|
||||
return gSoundLastError;
|
||||
|
|
|
@ -46,7 +46,7 @@ typedef enum SoundError {
|
|||
SOUND_ERR_COUNT,
|
||||
} SoundError;
|
||||
|
||||
typedef int SoundOpenProc(const char* filePath, int* channels, int* sampleRate);
|
||||
typedef int SoundOpenProc(const char* filePath, int* sampleRate);
|
||||
typedef int SoundCloseProc(int fileHandle);
|
||||
typedef int SoundReadProc(int fileHandle, void* buf, unsigned int size);
|
||||
typedef int SoundWriteProc(int fileHandle, const void* buf, unsigned int size);
|
||||
|
|
|
@ -154,7 +154,7 @@ void soundEffectsCacheFlush()
|
|||
|
||||
// sfxc_cached_open
|
||||
// 0x4A915C
|
||||
int soundEffectsCacheFileOpen(const char* fname, int* channels, int* sampleRate)
|
||||
int soundEffectsCacheFileOpen(const char* fname, int* sampleRate)
|
||||
{
|
||||
if (_sfxc_files_open >= SOUND_EFFECTS_MAX_COUNT) {
|
||||
return -1;
|
||||
|
|
|
@ -11,7 +11,7 @@ int soundEffectsCacheInit(int cache_size, const char* effectsPath);
|
|||
void soundEffectsCacheExit();
|
||||
int soundEffectsCacheInitialized();
|
||||
void soundEffectsCacheFlush();
|
||||
int soundEffectsCacheFileOpen(const char* fname, int* channels, int* sampleRate);
|
||||
int soundEffectsCacheFileOpen(const char* fname, int* sampleRate);
|
||||
int soundEffectsCacheFileClose(int handle);
|
||||
int soundEffectsCacheFileRead(int handle, void* buf, unsigned int size);
|
||||
int soundEffectsCacheFileWrite(int handle, const void* buf, unsigned int size);
|
||||
|
|
Loading…
Reference in New Issue