mirror of
https://github.com/RetroDECK/Supermodel.git
synced 2024-11-25 23:25:40 +00:00
Modified Windows Makefile to fix conditional compiling and also to allow building of 64-bit version of emulator.
This commit is contained in:
parent
e8782b98fa
commit
9297c5b8d2
|
@ -35,89 +35,144 @@
|
||||||
###############################################################################
|
###############################################################################
|
||||||
|
|
||||||
#
|
#
|
||||||
# Bitness of build
|
# Bitness of build ('32' or '64')
|
||||||
#
|
#
|
||||||
BITS = 32 # '32' or '64' only
|
BITS = 32
|
||||||
|
|
||||||
#
|
#
|
||||||
# Experimental sound code (32-bit builds only)
|
# Experimental sound code ('yes' on 32-bit builds only or 'no')
|
||||||
#
|
#
|
||||||
ENABLE_SOUND = no # 'yes' or 'no' only
|
ENABLE_SOUND = no
|
||||||
|
|
||||||
|
|
||||||
|
###############################################################################
|
||||||
|
# 32/64-Bit SDK Directories and Options
|
||||||
|
#
|
||||||
|
# Edit these paths as necessary.
|
||||||
|
# The following environment variables are used:
|
||||||
|
# VSINSTALLDIR is Visual Studio installation directory.
|
||||||
|
# WindowsSdkDir is Windows SDK installation directory.
|
||||||
|
###############################################################################
|
||||||
|
|
||||||
|
ifeq ($(strip $(BITS)),64)
|
||||||
|
ARCH = x64
|
||||||
|
VC_BIN = $(VSINSTALLDIR)\vc\bin\amd64
|
||||||
|
ARCH_LIBS = /LIBPATH:"$(VSINSTALLDIR)\vc\lib\amd64" /LIBPATH:"$(WindowsSdkDir)\lib\x64"
|
||||||
|
else
|
||||||
|
ARCH = x86
|
||||||
|
VC_BIN = $(VSINSTALLDIR)\vc\bin
|
||||||
|
ARCH_LIBS =
|
||||||
|
endif
|
||||||
|
|
||||||
|
|
||||||
###############################################################################
|
###############################################################################
|
||||||
# Required Libraries
|
# Required Libraries
|
||||||
#
|
#
|
||||||
# Edit these paths as necessary.
|
# Edit these paths as necessary.
|
||||||
|
# The following environment variables are used:
|
||||||
|
# DXSDK_DIR is Direct X installation directory.
|
||||||
###############################################################################
|
###############################################################################
|
||||||
|
|
||||||
#
|
#
|
||||||
# SDL
|
# SDL
|
||||||
#
|
#
|
||||||
SDL_LIBPATH = c:\Code\SDL-1.2.14\lib\\
|
SDL_LIBPATH = Libraries\SDL-1.2.14\lib-$(ARCH)-MT
|
||||||
SDL_INCLUDEPATH = c:\Code\SDL-1.2.14\include\\
|
SDL_INCLUDEPATH = Libraries\SDL-1.2.14\include
|
||||||
|
|
||||||
|
#
|
||||||
|
# ZLib
|
||||||
|
#
|
||||||
|
ZLIB_LIBPATH = Libraries\zlib-1.2.4\lib-$(ARCH)-MT
|
||||||
|
ZLIB_INCLUDEPATH = Libraries\zlib-1.2.4\include
|
||||||
|
|
||||||
|
#
|
||||||
|
# DirectX
|
||||||
|
#
|
||||||
|
DIRECTX_LIBPATH = $(DXSDK_DIR)\Lib\$(ARCH)
|
||||||
|
DIRECTX_INCLUDEPATH = $(DXSDK_DIR)\Include
|
||||||
|
|
||||||
|
|
||||||
###############################################################################
|
###############################################################################
|
||||||
# Outputs
|
# Outputs
|
||||||
###############################################################################
|
###############################################################################
|
||||||
|
|
||||||
OUTFILE = Supermodel.exe
|
ifeq ($(strip $(BITS)),64)
|
||||||
OBJ_DIR = obj
|
OBJ_DIR = obj64
|
||||||
|
BIN_DIR = bin64
|
||||||
|
else
|
||||||
|
OBJ_DIR = obj
|
||||||
|
BIN_DIR = bin
|
||||||
|
endif
|
||||||
|
|
||||||
|
OUTFILE = $(BIN_DIR)\Supermodel.exe
|
||||||
|
|
||||||
###############################################################################
|
###############################################################################
|
||||||
# Compiler and Linker
|
# Compiler and Linker
|
||||||
###############################################################################
|
###############################################################################
|
||||||
|
|
||||||
CC = cl
|
CC = "$(VC_BIN)\cl.exe"
|
||||||
LD = link
|
LD = "$(VC_BIN)\link.exe"
|
||||||
COMPILER_FLAGS = /I "$(DXSDK_DIR)\Include" /I "$(SDL_INCLUDEPATH)" /I "Src\\" /I "Src\OSD\SDL\\" /Ox /D "SUPERMODEL_WIN32" /D "GLEW_STATIC" /D "_MBCS" /D "_CRT_SECURE_NO_WARNINGS" /MT /Gy /W3 /nologo /c /Zi /GL
|
COMPILER_FLAGS = /I "$(SDL_INCLUDEPATH)" /I "$(ZLIB_INCLUDEPATH)" /I "$(DIRECTX_INCLUDEPATH)" /I "Src\\" /I "Src\OSD\SDL\\" /Ox \
|
||||||
|
/D "SUPERMODEL_WIN32" /D "GLEW_STATIC" /D "_MBCS" /D "_CRT_SECURE_NO_WARNINGS" /MT /Gy /W3 /nologo /c /Zi /GL
|
||||||
CFLAGS = $(COMPILER_FLAGS) /TC
|
CFLAGS = $(COMPILER_FLAGS) /TC
|
||||||
CPPFLAGS = $(COMPILER_FLAGS) /TP /EHsc
|
CPPFLAGS = $(COMPILER_FLAGS) /TP /EHsc
|
||||||
LFLAGS = /LIBPATH:"$(DXSDK_DIR)\Lib\x86" /LIBPATH:"$(SDL_LIBPATH)" /OUT:"$(OUTFILE)" /MANIFEST:NO /SUBSYSTEM:CONSOLE /NOLOGO /OPT:REF /OPT:ICF /DYNAMICBASE /NXCOMPAT /MACHINE:X86 /LTCG #/DEBUG
|
LFLAGS = /MACHINE:$(ARCH) $(ARCH_LIBS) /LIBPATH:"$(SDL_LIBPATH)" /LIBPATH:"$(ZLIB_LIBPATH)" /LIBPATH:"$(DIRECTX_LIBPATH)" /OUT:"$(OUTFILE)" \
|
||||||
OBJ_LIBS = kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib OpenGL32.lib GLu32.lib SDL.lib SDLmain.lib zlib.lib dinput8.lib dxguid.lib
|
/MANIFEST:NO /SUBSYSTEM:CONSOLE /NOLOGO /OPT:REF /OPT:ICF /DYNAMICBASE /NXCOMPAT /LTCG #/DEBUG
|
||||||
|
OBJ_LIBS = kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib \
|
||||||
|
odbc32.lib odbccp32.lib OpenGL32.lib GLu32.lib SDL.lib SDLmain.lib zlib.lib dinput8.lib dxguid.lib
|
||||||
|
|
||||||
#
|
#
|
||||||
# Build options...
|
# Build options...
|
||||||
#
|
#
|
||||||
##ifdef ($(BITS),32) # build type must be 32 bits for sound to be included
|
|
||||||
# ifeq ($(ENABLE_SOUND),yes)
|
# Ensure options are consistent
|
||||||
COMPILER_FLAGS += /D "SUPERMODEL_SOUND"
|
# (ie build type must be 32 bits for sound to be included)
|
||||||
# endif
|
ifneq ($(strip $(BITS)),32)
|
||||||
#endif
|
ENABLE_SOUND = no
|
||||||
|
endif
|
||||||
|
|
||||||
|
# Add compiler flags for various options
|
||||||
|
ifeq ($(strip $(ENABLE_SOUND)),yes)
|
||||||
|
COMPILER_FLAGS += /D "SUPERMODEL_SOUND"
|
||||||
|
endif
|
||||||
|
|
||||||
|
|
||||||
###############################################################################
|
###############################################################################
|
||||||
# Build Instructions
|
# Build Instructions
|
||||||
###############################################################################
|
###############################################################################
|
||||||
|
|
||||||
#
|
|
||||||
# Ensure build options are consistent
|
|
||||||
#
|
|
||||||
ifneq ($(BITS),32)
|
|
||||||
ENABLE_SOUND = no
|
|
||||||
endif
|
|
||||||
|
|
||||||
#
|
#
|
||||||
# Objects and Dependencies
|
# Objects and Dependencies
|
||||||
#
|
#
|
||||||
HEADERS = Src/Supermodel.h Src/OSD/SDL/Types.h
|
HEADERS = Src/Supermodel.h Src/OSD/SDL/Types.h
|
||||||
OBJ = $(OBJ_DIR)/PPCDisasm.obj $(OBJ_DIR)/Games.obj $(OBJ_DIR)/INIFile.obj $(OBJ_DIR)/BlockFile.obj $(OBJ_DIR)/93C46.obj $(OBJ_DIR)/ROMLoad.obj $(OBJ_DIR)/unzip.obj $(OBJ_DIR)/ioapi.obj $(OBJ_DIR)/Error.obj $(OBJ_DIR)/glew.obj $(OBJ_DIR)/Shader.obj $(OBJ_DIR)/Real3D.obj $(OBJ_DIR)/Render3D.obj $(OBJ_DIR)/Models.obj $(OBJ_DIR)/Render2D.obj $(OBJ_DIR)/TileGen.obj $(OBJ_DIR)/Model3.obj $(OBJ_DIR)/ppc.obj $(OBJ_DIR)/Main.obj $(OBJ_DIR)/SoundBoard.obj $(OBJ_DIR)/SCSP.obj $(OBJ_DIR)/SCSPDSP.obj $(OBJ_DIR)/IRQ.obj $(OBJ_DIR)/53C810.obj $(OBJ_DIR)/PCI.obj $(OBJ_DIR)/RTC72421.obj $(OBJ_DIR)/MPC10x.obj $(OBJ_DIR)/Input.obj $(OBJ_DIR)/Inputs.obj $(OBJ_DIR)/InputSource.obj $(OBJ_DIR)/InputSystem.obj $(OBJ_DIR)/InputTypes.obj $(OBJ_DIR)/MultiInputSource.obj $(OBJ_DIR)/SDLInputSystem.obj $(OBJ_DIR)/DirectInputSystem.obj
|
OBJ = $(OBJ_DIR)/PPCDisasm.obj $(OBJ_DIR)/Games.obj $(OBJ_DIR)/INIFile.obj $(OBJ_DIR)/BlockFile.obj $(OBJ_DIR)/93C46.obj \
|
||||||
|
$(OBJ_DIR)/ROMLoad.obj $(OBJ_DIR)/unzip.obj $(OBJ_DIR)/ioapi.obj $(OBJ_DIR)/Error.obj $(OBJ_DIR)/glew.obj $(OBJ_DIR)/Shader.obj \
|
||||||
|
$(OBJ_DIR)/Real3D.obj $(OBJ_DIR)/Render3D.obj $(OBJ_DIR)/Models.obj $(OBJ_DIR)/Render2D.obj $(OBJ_DIR)/TileGen.obj \
|
||||||
|
$(OBJ_DIR)/Model3.obj $(OBJ_DIR)/ppc.obj $(OBJ_DIR)/Main.obj $(OBJ_DIR)/SoundBoard.obj \
|
||||||
|
$(OBJ_DIR)/IRQ.obj $(OBJ_DIR)/53C810.obj $(OBJ_DIR)/PCI.obj $(OBJ_DIR)/RTC72421.obj $(OBJ_DIR)/MPC10x.obj \
|
||||||
|
$(OBJ_DIR)/Input.obj $(OBJ_DIR)/Inputs.obj $(OBJ_DIR)/InputSource.obj $(OBJ_DIR)/InputSystem.obj $(OBJ_DIR)/InputTypes.obj \
|
||||||
|
$(OBJ_DIR)/MultiInputSource.obj $(OBJ_DIR)/SDLInputSystem.obj $(OBJ_DIR)/DirectInputSystem.obj
|
||||||
|
|
||||||
#ifeq ($(BITS),32) # if sound enabled and 32-bit build, include Turbo68K
|
# If sound enabled, include Turbo68K and SCSP code
|
||||||
# ifeq ($(ENABLE_SOUND),yes)
|
ifeq ($(strip $(ENABLE_SOUND)),yes)
|
||||||
OBJ += $(OBJ_DIR)/Turbo68K.obj
|
OBJ += $(OBJ_DIR)/Turbo68K.obj $(OBJ_DIR)/SCSP.obj $(OBJ_DIR)/SCSPDSP.obj
|
||||||
# endif
|
endif
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
#
|
#
|
||||||
# Targets
|
# Targets
|
||||||
#
|
#
|
||||||
all: $(OBJ_DIR) $(OBJ)
|
all: $(OUTFILE) $(BIN_DIR)/SDL.dll
|
||||||
$(LD) $(LFLAGS) $(OBJ_LIBS) $(OBJ)
|
|
||||||
|
|
||||||
|
$(OUTFILE): $(BIN_DIR) $(OBJ_DIR) $(OBJ)
|
||||||
|
$(LD) $(LFLAGS) $(OBJ_LIBS) $(OBJ)
|
||||||
|
|
||||||
|
$(BIN_DIR)/SDL.dll: $(SDL_LIBPATH)/SDL.dll
|
||||||
|
xcopy /D /Y $(SDL_LIBPATH)\SDL.dll $(BIN_DIR)
|
||||||
|
|
||||||
|
$(BIN_DIR):
|
||||||
|
mkdir $(BIN_DIR)
|
||||||
|
|
||||||
$(OBJ_DIR):
|
$(OBJ_DIR):
|
||||||
mkdir $(OBJ_DIR)
|
mkdir $(OBJ_DIR)
|
||||||
|
|
||||||
|
@ -155,13 +210,13 @@ $(OBJ_DIR)/%.obj: Src/Graphics/%.cpp Src/Graphics/%.h $(HEADERS) Src/Graphics/Sh
|
||||||
|
|
||||||
$(OBJ_DIR)/%.obj: Src/Graphics/%.cpp $(HEADERS)
|
$(OBJ_DIR)/%.obj: Src/Graphics/%.cpp $(HEADERS)
|
||||||
$(CC) $< $(CPPFLAGS) /Fo$(OBJ_DIR)/$(*F).obj
|
$(CC) $< $(CPPFLAGS) /Fo$(OBJ_DIR)/$(*F).obj
|
||||||
|
|
||||||
$(OBJ_DIR)/%.obj: Src/Sound/%.cpp Src/Sound/%.h $(HEADERS)
|
$(OBJ_DIR)/%.obj: Src/Sound/%.cpp Src/Sound/%.h $(HEADERS)
|
||||||
$(CC) $< $(CPPFLAGS) /Fo$(OBJ_DIR)/$(*F).obj
|
$(CC) $< $(CPPFLAGS) /Fo$(OBJ_DIR)/$(*F).obj
|
||||||
|
|
||||||
$(OBJ_DIR)/%.obj: Src/Sound/%.cpp $(HEADERS)
|
$(OBJ_DIR)/%.obj: Src/Sound/%.cpp $(HEADERS)
|
||||||
$(CC) $< $(CPPFLAGS) /Fo$(OBJ_DIR)/$(*F).obj
|
$(CC) $< $(CPPFLAGS) /Fo$(OBJ_DIR)/$(*F).obj
|
||||||
|
|
||||||
$(OBJ_DIR)/%.obj: Src/CPU/PowerPC/%.cpp Src/CPU/PowerPC/%.h Src/CPU/PowerPC/ppc603.c Src/CPU/PowerPC/ppc_ops.c $(HEADERS)
|
$(OBJ_DIR)/%.obj: Src/CPU/PowerPC/%.cpp Src/CPU/PowerPC/%.h Src/CPU/PowerPC/ppc603.c Src/CPU/PowerPC/ppc_ops.c $(HEADERS)
|
||||||
$(CC) $< $(CPPFLAGS) /Fo$(OBJ_DIR)/$(*F).obj
|
$(CC) $< $(CPPFLAGS) /Fo$(OBJ_DIR)/$(*F).obj
|
||||||
|
|
||||||
|
@ -182,4 +237,3 @@ $(OBJ_DIR)/%.obj: Src/Pkgs/%.c Src/Pkgs/%.h
|
||||||
|
|
||||||
$(OBJ_DIR)/%.obj: Src/Pkgs/*.c
|
$(OBJ_DIR)/%.obj: Src/Pkgs/*.c
|
||||||
$(CC) $< $(CFLAGS) /Fo$(OBJ_DIR)/$(*F).obj
|
$(CC) $< $(CFLAGS) /Fo$(OBJ_DIR)/$(*F).obj
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue