]> Shamusworld >> Repos - virtualjaguar/blobdiff - Makefile.win32
New experimental pipelined core
[virtualjaguar] / Makefile.win32
index e83eb3fb240a4d9be22a3fb41425e8b9ddeaeb3c..299860c759a93401f8406d092add0d081fda2568 100644 (file)
@@ -1,73 +1,89 @@
-CC = gcc
-LD = gcc 
-NASM = nasm
+#
+# Makefile for Virtual Jaguar GCC/SDL Portable Jaguar Emulator
+#
+
+# Uncomment the following lines to compile for Win32
+
+SYSTYPE   = __GCCWIN32__
+EXESUFFIX = .exe
+GLLIB     = opengl32
+
+# Uncomment the following lines to compile for *nix
+
+#SYSTYPE   = __GCCUNIX__
+#EXESUFFIX =
+#GLLIB     = GL
+
+CC        = gcc
+LD        = gcc
+TARGET    = vj
 
-CFLAGS  = -Wall -O3 -D__PORT__ -D__GCCWIN32__ -Dstricmp="strcasecmp" \
+CFLAGS  = -Wall -Wno-switch -O3 -D$(SYSTYPE) -Dstricmp="strcasecmp" \
                        -fomit-frame-pointer `sdl-config --cflags`
 #                      -fomit-frame-pointer `sdl-config --cflags` -DLOG_UNMAPPED_MEMORY_ACCESSES
-#                      -fomit-frame-pointer `sdl-config --cflags` -DTOM_DEBUG
 
 LDFLAGS = $(CFLAGS)
 
-TARGET = vj
+LIBS = -L/usr/local/lib `sdl-config --libs` -lstdc++ -lz -l$(GLLIB)
+
+INCS = -I. -Isrc -Isrc/include -I/usr/local/include
+
+THECC = $(CC) $(CFLAGS) $(INCS)
 
 OBJS = \
-       obj/version.o \
-       obj/pcm.o \
-       obj/objectp.o \
-       obj/memory.o \
-       obj/log.o \
-       obj/jerry.o \
-       obj/jaguar.o \
-       obj/jagdasm.o \
-       obj/eeprom.o \
-       obj/dsound_dummy.o \
-       obj/crc32.o \
-       obj/clock.o \
-       obj/cdrom.o \
-       obj/cdi.o \
-       obj/cdbios.o \
-       obj/blitter.o \
        obj/anajoy.o \
-       obj/tom.o \
-       obj/joystick.o \
-       obj/gpu.o \
+       obj/blitter.o \
+       obj/cdbios.o \
+       obj/cdi.o \
+       obj/cdrom.o \
+       obj/clock.o \
+       obj/crc32.o \
+       obj/dac.o \
        obj/dsp.o \
-       obj/blitter2.o \
-       obj/vj.o \
-       obj/unzip.o \
+       obj/eeprom.o \
+       obj/gpu.o \
+       obj/gui.o \
+       obj/jagdasm.o \
+       obj/jaguar.o \
+       obj/jerry.o \
+       obj/joystick.o \
+       obj/log.o \
        obj/m68kcpu.o obj/m68kops.o obj/m68kopac.o obj/m68kopdm.o obj/m68kopnz.o \
-       obj/m68kdasm.o
-#      obj/m68kdasmAG.o \
-#      obj/gpu2.o \
-
-LIBS = `sdl-config --libs` -lstdc++ -lz
-
-INCS = -I. -Isrc -Isrc/include `sdl-config --cflags`
-
-THECC = $(CC) $(CFLAGS) $(INCS)
+       obj/m68kdasm.o \
+       obj/memory.o \
+       obj/objectp.o \
+       obj/sdlemu_config.o \
+       obj/sdlemu_opengl.o \
+       obj/settings.o \
+       obj/tom.o \
+       obj/unzip.o \
+       obj/version.o \
+       obj/video.o \
+       obj/vj.o
 
 all: obj $(TARGET)
 
 clean:
        rm -rf obj
-       rm -f vj.exe
+       rm -f ./vj$(EXESUFFIX)
 
 obj:
        mkdir obj
 
-obj/%.o: src/%.asm
-       $(NASM) -f win32 -o $@ $<
-
 obj/%.o: src/%.c
        $(THECC) -c $< -o $@
 
 obj/%.o: src/%.cpp
        $(THECC) -c $< -o $@
 
-vj: $(OBJS) 
+vj: $(OBJS)
        $(LD) $(LDFLAGS) -o $@ $(OBJS) $(LIBS)
-#      upx -9 vj.exe
+#      upx -9 vj$(EXESUFFIX)
+
+# Other stuff that has unusual dependencies
+
+obj/gui.o: src/gui.cpp src/include/gui.h src/include/font1.h
+       $(THECC) -c src/gui.cpp -o obj/gui.o
 
 #
 # Musashi specific stuffola
@@ -76,23 +92,23 @@ vj: $(OBJS)
 obj/m68kcpu.o: obj/m68kops.h src/m68k.h src/m68kconf.h
        $(CC) $(CFLAGS) -Iobj -c src/m68kcpu.c -o obj/m68kcpu.o
 
-obj/m68kops.o: obj/m68kmake.exe obj/m68kops.h obj/m68kops.c src/m68k.h src/m68kconf.h
+obj/m68kops.o: obj/m68kmake$(EXESUFFIX) obj/m68kops.h obj/m68kops.c src/m68k.h src/m68kconf.h
        $(CC) $(CFLAGS) -Isrc -c obj/m68kops.c -o obj/m68kops.o
 
-obj/m68kopac.o: obj/m68kmake.exe obj/m68kops.h obj/m68kopac.c src/m68k.h src/m68kconf.h
+obj/m68kopac.o: obj/m68kmake$(EXESUFFIX) obj/m68kops.h obj/m68kopac.c src/m68k.h src/m68kconf.h
        $(CC) $(CFLAGS) -Isrc -c obj/m68kopac.c -o obj/m68kopac.o
 
-obj/m68kopdm.o: obj/m68kmake.exe obj/m68kops.h obj/m68kopdm.c src/m68k.h src/m68kconf.h
+obj/m68kopdm.o: obj/m68kmake$(EXESUFFIX) obj/m68kops.h obj/m68kopdm.c src/m68k.h src/m68kconf.h
        $(CC) $(CFLAGS) -Isrc -c obj/m68kopdm.c -o obj/m68kopdm.o
 
-obj/m68kopnz.o: obj/m68kmake.exe obj/m68kops.h obj/m68kopnz.c src/m68k.h src/m68kconf.h
+obj/m68kopnz.o: obj/m68kmake$(EXESUFFIX) obj/m68kops.h obj/m68kopnz.c src/m68k.h src/m68kconf.h
        $(CC) $(CFLAGS) -Isrc -c obj/m68kopnz.c -o obj/m68kopnz.o
 
 obj/m68kdasm.o: src/m68kdasm.c src/m68k.h src/m68kconf.h
        $(CC) $(CFLAGS) -Isrc -c src/m68kdasm.c -o obj/m68kdasm.o
 
-obj/m68kops.h: obj/m68kmake.exe
+obj/m68kops.h: obj/m68kmake$(EXESUFFIX)
        obj/m68kmake obj src/m68k_in.c
 
-obj/m68kmake.exe: src/m68kmake.c src/m68k_in.c
-       $(CC) $(WARNINGS) src/m68kmake.c -o obj/m68kmake.exe
+obj/m68kmake$(EXESUFFIX): src/m68kmake.c src/m68k_in.c
+       $(CC) $(WARNINGS) src/m68kmake.c -o obj/m68kmake$(EXESUFFIX)