mirror of
https://github.com/ValveSoftware/Proton.git
synced 2025-01-27 14:08:18 +03:00
Support building for Mac
Patch by Aric
This commit is contained in:
parent
b272ddb88f
commit
e217e277c4
@ -7,14 +7,20 @@ set -e
|
|||||||
#./dist/ <-- proton build, ready to distribute
|
#./dist/ <-- proton build, ready to distribute
|
||||||
|
|
||||||
TOP="$PWD"
|
TOP="$PWD"
|
||||||
RUNTIME_PATH="$TOP/../../runtime/steam-runtime-both/"
|
|
||||||
AMD64_WRAPPER="schroot --chroot steamrt_scout_beta_amd64 --"
|
|
||||||
I386_WRAPPER="schroot --chroot steamrt_scout_beta_i386 --"
|
|
||||||
DST_DIR="$TOP/build/dist"
|
|
||||||
TOOLS_DIR64="$TOP/build/tools.win64"
|
|
||||||
TOOLS_DIR32="$TOP/build/tools.win32"
|
|
||||||
|
|
||||||
STRIPFLAGS='-s'
|
PLATFORM=$(uname)
|
||||||
|
if [ "$PLATFORM" == "Darwin" ]; then
|
||||||
|
CC="ccache clang -g"
|
||||||
|
STRIPFLAGS=''
|
||||||
|
AMD64_WRAPPER=""
|
||||||
|
I386_WRAPPER=""
|
||||||
|
else
|
||||||
|
CC="ccache gcc -g"
|
||||||
|
STRIPFLAGS='-s'
|
||||||
|
AMD64_WRAPPER="schroot --chroot steamrt_scout_beta_amd64 --"
|
||||||
|
I386_WRAPPER="schroot --chroot steamrt_scout_beta_i386 --"
|
||||||
|
fi
|
||||||
|
|
||||||
STRIP='strip'
|
STRIP='strip'
|
||||||
if [ "$1" == "--debug" ]; then
|
if [ "$1" == "--debug" ]; then
|
||||||
#don't strip
|
#don't strip
|
||||||
@ -22,11 +28,15 @@ if [ "$1" == "--debug" ]; then
|
|||||||
STRIP=''
|
STRIP=''
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
DST_DIR="$TOP/build/dist"
|
||||||
|
TOOLS_DIR64="$TOP/build/tools.win64"
|
||||||
|
TOOLS_DIR32="$TOP/build/tools.win32"
|
||||||
|
|
||||||
mkdir -p dist "$DST_DIR"/bin build/wine.win32 build/dist.win32 build/wine.win64
|
mkdir -p dist "$DST_DIR"/bin build/wine.win32 build/dist.win32 build/wine.win64
|
||||||
|
|
||||||
#build wine64
|
#build wine64
|
||||||
cd "$TOP"/build/wine.win64
|
cd "$TOP"/build/wine.win64
|
||||||
CC="ccache gcc" $AMD64_WRAPPER "$TOP"/wine/configure --enable-win64 --disable-tests --prefix="$DST_DIR"
|
CC="$CC" $AMD64_WRAPPER "$TOP"/wine/configure --enable-win64 --disable-tests --prefix="$DST_DIR"
|
||||||
$AMD64_WRAPPER make -j5
|
$AMD64_WRAPPER make -j5
|
||||||
INSTALL_PROGRAM_FLAGS="$STRIPFLAGS" $AMD64_WRAPPER make install-lib
|
INSTALL_PROGRAM_FLAGS="$STRIPFLAGS" $AMD64_WRAPPER make install-lib
|
||||||
INSTALL_PROGRAM_FLAGS="$STRIPFLAGS" $AMD64_WRAPPER make prefix="$TOOLS_DIR64" libdir="$TOOLS_DIR64/lib64" dlldir="$TOOLS_DIR64/lib64/wine" install-dev install-lib
|
INSTALL_PROGRAM_FLAGS="$STRIPFLAGS" $AMD64_WRAPPER make prefix="$TOOLS_DIR64" libdir="$TOOLS_DIR64/lib64" dlldir="$TOOLS_DIR64/lib64/wine" install-dev install-lib
|
||||||
@ -35,7 +45,7 @@ rm -rf "$DST_DIR/share/man/"
|
|||||||
|
|
||||||
#build wine32
|
#build wine32
|
||||||
cd "$TOP"/build/wine.win32
|
cd "$TOP"/build/wine.win32
|
||||||
CC="ccache gcc" $I386_WRAPPER "$TOP"/wine/configure --disable-tests --prefix="$TOP/build/dist.win32/"
|
CC="$CC" $I386_WRAPPER "$TOP"/wine/configure --disable-tests --prefix="$TOP/build/dist.win32/"
|
||||||
$I386_WRAPPER make -j5
|
$I386_WRAPPER make -j5
|
||||||
INSTALL_PROGRAM_FLAGS="$STRIPFLAGS" $I386_WRAPPER make install-lib
|
INSTALL_PROGRAM_FLAGS="$STRIPFLAGS" $I386_WRAPPER make install-lib
|
||||||
INSTALL_PROGRAM_FLAGS="$STRIPFLAGS" $I386_WRAPPER make prefix="$TOOLS_DIR32" libdir="$TOOLS_DIR32/lib" dlldir="$TOOLS_DIR32/lib/wine" install-dev install-lib
|
INSTALL_PROGRAM_FLAGS="$STRIPFLAGS" $I386_WRAPPER make prefix="$TOOLS_DIR32" libdir="$TOOLS_DIR32/lib" dlldir="$TOOLS_DIR32/lib/wine" install-dev install-lib
|
||||||
@ -45,7 +55,9 @@ INSTALL_PROGRAM_FLAGS="$STRIPFLAGS" $I386_WRAPPER make prefix="$TOOLS_DIR32" lib
|
|||||||
cd "$TOP"/build/dist.win32/
|
cd "$TOP"/build/dist.win32/
|
||||||
cp -a lib "$DST_DIR"/
|
cp -a lib "$DST_DIR"/
|
||||||
cp -a bin/wine "$DST_DIR"/bin/
|
cp -a bin/wine "$DST_DIR"/bin/
|
||||||
cp -a bin/wine-preloader "$DST_DIR"/bin/
|
if [ "$PLATFORM" != "Darwin" ]; then
|
||||||
|
cp -a bin/wine-preloader "$DST_DIR"/bin/
|
||||||
|
fi
|
||||||
cp -a bin/wineserver "$DST_DIR"/bin/wineserver32
|
cp -a bin/wineserver "$DST_DIR"/bin/wineserver32
|
||||||
|
|
||||||
#build 64-bit lsteamclient
|
#build 64-bit lsteamclient
|
||||||
|
@ -19,13 +19,22 @@
|
|||||||
/* Copied from dlls/msvcrt/cxx.h */
|
/* Copied from dlls/msvcrt/cxx.h */
|
||||||
#undef __thiscall
|
#undef __thiscall
|
||||||
|
|
||||||
#define __ASM_NAME(name) name
|
#ifdef __APPLE__
|
||||||
#define __ASM_DEFINE_FUNC(name,suffix,code) asm(".text\n\t.align 4\n\t.globl " #name suffix "\n\t.type " #name suffix ",@function\n" #name suffix ":\n\t.cfi_startproc\n\t" code "\n\t.cfi_endproc\n\t.previous");
|
# define __ASM_NAME(name) "_" name
|
||||||
#define __ASM_GLOBAL_FUNC(name,code) __ASM_DEFINE_FUNC(name,"",code)
|
#else
|
||||||
#define __ASM_STDCALL(args) ""
|
# define __ASM_NAME(name) name
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef __i386__ /* thiscall functions are i386-specific */
|
#ifdef __i386__ /* thiscall functions are i386-specific */
|
||||||
|
|
||||||
|
#ifdef __APPLE__
|
||||||
|
# define __ASM_DEFINE_FUNC(name,suffix,code) asm(".text\n\t.align 4\n\t.globl _" #name suffix "\n\t\n_" #name suffix ":\n\t.cfi_startproc\n\t" code "\n\t.cfi_endproc\n\t.previous");
|
||||||
|
#else
|
||||||
|
# define __ASM_DEFINE_FUNC(name,suffix,code) asm(".text\n\t.align 4\n\t.globl " #name suffix "\n\t.type " #name suffix ",@function\n" #name suffix ":\n\t.cfi_startproc\n\t" code "\n\t.cfi_endproc\n\t.previous");
|
||||||
|
#endif
|
||||||
|
#define __ASM_GLOBAL_FUNC(name,code) __ASM_DEFINE_FUNC(name,"",code)
|
||||||
|
#define __ASM_STDCALL(args) ""
|
||||||
|
|
||||||
#define THISCALL(func) __thiscall_ ## func
|
#define THISCALL(func) __thiscall_ ## func
|
||||||
#define THISCALL_NAME(func) __ASM_NAME("__thiscall_" #func)
|
#define THISCALL_NAME(func) __ASM_NAME("__thiscall_" #func)
|
||||||
#define __thiscall __stdcall
|
#define __thiscall __stdcall
|
||||||
|
@ -1,7 +1,9 @@
|
|||||||
typedef int EHTMLMouseButton, EHTMLKeyModifiers;
|
typedef int EHTMLMouseButton, EHTMLKeyModifiers;
|
||||||
|
|
||||||
#ifndef __cplusplus
|
#ifndef __cplusplus
|
||||||
|
#ifndef bool
|
||||||
typedef char bool; /* 1 byte on modern visual studio c++ */
|
typedef char bool; /* 1 byte on modern visual studio c++ */
|
||||||
|
#endif
|
||||||
|
|
||||||
typedef int EAccountType;
|
typedef int EAccountType;
|
||||||
typedef int EUniverse;
|
typedef int EUniverse;
|
||||||
|
@ -19,13 +19,22 @@
|
|||||||
/* Copied from dlls/msvcrt/cxx.h */
|
/* Copied from dlls/msvcrt/cxx.h */
|
||||||
#undef __thiscall
|
#undef __thiscall
|
||||||
|
|
||||||
#define __ASM_NAME(name) name
|
#ifdef __APPLE__
|
||||||
#define __ASM_DEFINE_FUNC(name,suffix,code) asm(".text\n\t.align 4\n\t.globl " #name suffix "\n\t.type " #name suffix ",@function\n" #name suffix ":\n\t.cfi_startproc\n\t" code "\n\t.cfi_endproc\n\t.previous");
|
# define __ASM_NAME(name) "_" name
|
||||||
#define __ASM_GLOBAL_FUNC(name,code) __ASM_DEFINE_FUNC(name,"",code)
|
#else
|
||||||
#define __ASM_STDCALL(args) ""
|
# define __ASM_NAME(name) name
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef __i386__ /* thiscall functions are i386-specific */
|
#ifdef __i386__ /* thiscall functions are i386-specific */
|
||||||
|
|
||||||
|
#ifdef __APPLE__
|
||||||
|
# define __ASM_DEFINE_FUNC(name,suffix,code) asm(".text\n\t.align 4\n\t.globl _" #name suffix "\n\t\n_" #name suffix ":\n\t.cfi_startproc\n\t" code "\n\t.cfi_endproc\n\t.previous");
|
||||||
|
#else
|
||||||
|
# define __ASM_DEFINE_FUNC(name,suffix,code) asm(".text\n\t.align 4\n\t.globl " #name suffix "\n\t.type " #name suffix ",@function\n" #name suffix ":\n\t.cfi_startproc\n\t" code "\n\t.cfi_endproc\n\t.previous");
|
||||||
|
#endif
|
||||||
|
#define __ASM_GLOBAL_FUNC(name,code) __ASM_DEFINE_FUNC(name,"",code)
|
||||||
|
#define __ASM_STDCALL(args) ""
|
||||||
|
|
||||||
#define THISCALL(func) __thiscall_ ## func
|
#define THISCALL(func) __thiscall_ ## func
|
||||||
#define THISCALL_NAME(func) __ASM_NAME("__thiscall_" #func)
|
#define THISCALL_NAME(func) __ASM_NAME("__thiscall_" #func)
|
||||||
#define __thiscall __stdcall
|
#define __thiscall __stdcall
|
||||||
|
Loading…
x
Reference in New Issue
Block a user