X-Git-Url: https://git.jsancho.org/?a=blobdiff_plain;f=makefile;h=54b17068223753cde0f8a529d93f6e62eba12472;hb=04b5ba806de1bc772da574a8cacad0c2d2f001cf;hp=8672d2e2431c6de718b73e442dbc7d24d2a39238;hpb=d72054c5ab036810ee8a09ce57950aa977fcab06;p=lugaru.git diff --git a/makefile b/makefile index 8672d2e..54b1706 100644 --- a/makefile +++ b/makefile @@ -1,6 +1,7 @@ macosx := false use_devil := false +use_fmod := false BINDIR := bin RUNDIR := run @@ -9,32 +10,45 @@ SDLDIR := SDL12 LIBPNGDIR := libpng-1.2.8 JPEGLIBDIR := jpeg-6b ZLIBDIR := zlib-1.2.3 +OPENALDIR := OpenAL +GLUDIR := GLU +LIBOGGDIR := libogg-1.0 +LIBVORBISDIR := libvorbis-1.0.1 -EXE := $(RUNDIR)/lugaru-bin -CXX := ccache g++ -CC := ccache gcc -#CXX := g++ -#CC := gcc -LD := g++ +ifeq ($(strip $(macosx_arch)),) + macosx_arch := i386 +endif -OPT := -O0 -#OPT := -O3 -fno-strict-aliasing -falign-loops=16 -fno-math-errno -#OPT := -Os -fno-strict-aliasing +ifeq ($(strip $(macosx)),true) + EXEEXT := $(macosx_arch) +else + EXEEXT := bin +endif + +EXE := $(RUNDIR)/lugaru-$(EXEEXT) -# always use this on the Mac, even in debug builds, since we aren't building -# a dylib at this point. ifeq ($(strip $(macosx)),true) - OPT += -mdynamic-no-pic + CXX := g++-4.0 + CC := gcc-4.0 + LD := g++-4.0 +else + CXX := /opt/crosstool/gcc-4.1.2-glibc-2.3.6/i686-unknown-linux-gnu/i686-unknown-linux-gnu/bin/g++ + CC := /opt/crosstool/gcc-4.1.2-glibc-2.3.6/i686-unknown-linux-gnu/i686-unknown-linux-gnu/bin/gcc + LD := /opt/crosstool/gcc-4.1.2-glibc-2.3.6/i686-unknown-linux-gnu/i686-unknown-linux-gnu/bin/g++ endif +#OPT := -O0 +OPT := -O3 -fno-strict-aliasing -falign-loops=16 -fno-math-errno +#OPT := -Os -fno-strict-aliasing + DEFINES := \ -DPLATFORM_UNIX=1 \ - -DPLATFORM_LINUX=1 \ -DUSE_SDL=1 \ -DTRUE=1 \ -DFALSE=0 \ -Dstricmp=strcasecmp \ + -DBinIO_STDINT_HEADER="" \ INCLUDES := \ -I$(SRCDIR) \ @@ -44,28 +58,43 @@ INCLUDES := \ ifeq ($(strip $(use_devil)),true) DEFINES += -DUSE_DEVIL=1 - INCLUDES += -I$(SRCDIR)/devil/include + INCLUDES += -I$(SRCDIR)/devil/include else DEFINES += -DZ_PREFIX=1 INCLUDES += -I$(ZLIBDIR) -I$(LIBPNGDIR) -I$(JPEGLIBDIR) endif -CFLAGS := -g -c $(OPT) $(INCLUDES) $(DEFINES) -fsigned-char +ifeq ($(strip $(use_fmod)),false) + DEFINES += -DUSE_OPENAL=1 + INCLUDES += -I$(OPENALDIR)/include -I$(LIBOGGDIR)/include -I$(LIBVORBISDIR)/include +endif + + +CFLAGS := -g -c $(OPT) $(INCLUDES) $(DEFINES) -fsigned-char -pipe CFLAGS += -w ifeq ($(strip $(macosx)),true) - CFLAGS += -fpascal-strings -faltivec -fasm -force_cpusubtype_ALL -Wno-long-double -mdynamic-no-pic - CFLAGS += -DPLATFORM_BIGENDIAN=1 -DMACOSX=1 -DPLATFORM_MACOSX=1 - LDFLAGS := -framework Cocoa -framework OpenGL -framework IOKit -framework CoreFoundation -framework Carbon - APPLDFLAGS := $(SDLDIR)/lib/libSDL-1.2.0.dylib $(SDLDIR)/lib/libSDLmain-osx.a + CFLAGS += -mdynamic-no-pic + LDFLAGS := -framework Cocoa -framework OpenGL -framework IOKit -framework CoreFoundation -framework Carbon -framework OpenAL + APPLDFLAGS := ./libSDL-1.2.0.dylib ./libSDLmain-osx.a + ifneq ($(strip $(macosx_arch)),) + CFLAGS += -arch $(macosx_arch) + LDFLAGS += -arch $(macosx_arch) + APPLDFLAGS += -arch $(macosx_arch) + endif else CFLAGS += -DPLATFORM_LINUX=1 - #CFLAGS += -msse -mmmx - LDFLAGS := ./libSDL-1.2.so.0 -lGL -lGLU ./libfmod.so + LDFLAGS := ./libSDL-1.2.so.0 -Wl,-rpath,\$$ORIGIN ifeq ($(strip $(use_devil)),true) LDFLAGS += ./libIL.so.1 ./libILU.so.1 ./libILUT.so.1 endif + + ifeq ($(strip $(use_fmod)),true) + POSTLDFLAGS += -lpthread ./libfmod-linux-x86.a + else + LDFLAGS += ./libopenal.so.1 + endif endif CXXFLAGS := $(CFLAGS) @@ -96,14 +125,18 @@ SRCS := \ Weapons.cpp \ MacCompatibility.cpp \ logger/logger.cpp \ - DRIVER.CC \ - MD5.CC \ WinInput.cpp \ OpenGL_Windows.cpp \ + openal_wrapper.cpp \ SRCS := $(foreach f,$(SRCS),$(SRCDIR)/$(f)) +UNUSED_SRCS := \ + DRIVER.CC \ + MD5.CC \ + + PNGSRCS := \ png.c \ pngerror.c \ @@ -192,10 +225,65 @@ ZLIBSRCS = \ ZLIBSRCS := $(foreach f,$(ZLIBSRCS),$(ZLIBDIR)/$(f)) -ifneq ($(strip $(use_devil)),true) +GLUSRCS := \ + dict.c \ + geom.c \ + memalloc.c \ + mesh.c \ + mipmap.c \ + normal.c \ + priorityq.c \ + render.c \ + sweep.c \ + tess.c \ + tessmono.c \ + util.c \ + +GLUSRCS := $(foreach f,$(GLUSRCS),$(GLUDIR)/$(f)) + + +OGGSRCS := \ + bitwise.o \ + framing.o + +OGGSRCS := $(foreach f,$(OGGSRCS),$(LIBOGGDIR)/src/$(f)) + +VORBISSRCS := \ + analysis.o \ + bitrate.o \ + block.o \ + codebook.o \ + envelope.o \ + floor0.o \ + floor1.o \ + info.o \ + lpc.o \ + lsp.o \ + mapping0.o \ + mdct.o \ + psy.o \ + registry.o \ + res0.o \ + sharedbook.o \ + smallft.o \ + synthesis.o \ + vorbisfile.o \ + window.o + +VORBISSRCS := $(foreach f,$(VORBISSRCS),$(LIBVORBISDIR)/lib/$(f)) + +ifeq ($(strip $(macosx)),false) + SRCS += $(GLUSRCS) +endif + +ifeq ($(strip $(use_devil)),false) SRCS += $(PNGSRCS) $(JPEGSRCS) $(ZLIBSRCS) endif +ifeq ($(strip $(use_fmod)),false) + SRCS += $(OGGSRCS) $(VORBISSRCS) +endif + OBJS := $(SRCS:.CC=.o) OBJS := $(OBJS:.cc=.o) OBJS := $(OBJS:.cpp=.o) @@ -209,34 +297,39 @@ OBJS := $(foreach f,$(OBJS),$(BINDIR)/$(f)) all : $(EXE) $(BINDIR)/%.o : %.cpp + @mkdir -p $(dir $@) $(CXX) -o $@ $(CXXFLAGS) $< $(BINDIR)/%.o : %.CC - $(CXX) -o $@ $(CXXFLAGS) $< + @mkdir -p $(dir $@) + $(CXX) -x c++ -o $@ $(CXXFLAGS) $< $(BINDIR)/%.o : %.cc + @mkdir -p $(dir $@) $(CXX) -o $@ $(CXXFLAGS) $< $(BINDIR)/%.o : %.m + @mkdir -p $(dir $@) $(CC) -o $@ $(CFLAGS) $< $(BINDIR)/%.o : %.c + @mkdir -p $(dir $@) $(CC) -o $@ $(CFLAGS) $< $(EXE) : $(OBJS) $(APPOBJS) -ifeq ($(strip $(macosx)),true) - ranlib $(SDLDIR)/lib/libSDLmain-osx.a - ranlib $(FREETYPEDIR)/lib/libfreetype-osx.a -endif - $(LD) -o $@ $(APPLDFLAGS) $(LDFLAGS) $(OBJS) $(APPOBJS) + @mkdir -p $(dir $@) + $(LD) -o $@ $(APPLDFLAGS) $(LDFLAGS) $(OBJS) $(APPOBJS) $(POSTLDFLAGS) clean: rm -f $(BINDIR)/*.o rm -f $(BINDIR)/$(SRCDIR)/*.o rm -f $(BINDIR)/$(SRCDIR)/logger/*.o + rm -f $(BINDIR)/$(GLUDIR)/*.o rm -f $(BINDIR)/$(LIBPNGDIR)/*.o - rm -f $(BINDIR)/$(JPEGLIB)/*.o + rm -f $(BINDIR)/$(JPEGLIBDIR)/*.o rm -f $(BINDIR)/$(ZLIBDIR)/*.o + rm -f $(BINDIR)/$(LIBOGGDIR)/src/*.o + rm -f $(BINDIR)/$(LIBVORBISDIR)/lib/*.o rm -f $(EXE) # end of makefile ...