X-Git-Url: https://git.zerfleddert.de/cgi-bin/gitweb.cgi/proxmark3-svn/blobdiff_plain/91c38cf715f2bbd668cb13f4acfed0cb01293912..985ef1c31561626dae17750741c49f3b9cca85b6:/client/Makefile?ds=sidebyside diff --git a/client/Makefile b/client/Makefile index d0978a98..364070e8 100644 --- a/client/Makefile +++ b/client/Makefile @@ -1,80 +1,109 @@ +#----------------------------------------------------------------------------- +# This code is licensed to you under the terms of the GNU GPL, version 2 or, +# at your option, any later version. See the LICENSE.txt file for the text of +# the license. +#----------------------------------------------------------------------------- +include ../common/Makefile.common + CC=gcc +CXX=g++ #COMMON_FLAGS = -m32 VPATH = ../common +OBJDIR = obj LDLIBS = -L/opt/local/lib -L/usr/local/lib -lusb -lreadline -lpthread LDFLAGS = $(COMMON_FLAGS) -CFLAGS = -std=gnu99 -I. -I../include -I../common -I/opt/local/include -Wall -Wno-unused-function $(COMMON_FLAGS) -g3 - -WINLIBS = -lgdi32 -lsetupapi -CXXFLAGS = $(shell pkg-config --cflags QtCore QtGui 2>/dev/null) -Wall +CFLAGS = -std=gnu99 -I. -I../include -I../common -I/opt/local/include -Wall -Wno-unused-function $(COMMON_FLAGS) -g -O3 + +ifneq (,$(findstring MINGW,$(platform))) +CXXFLAGS = -I$(QTDIR)/include -I$(QTDIR)/include/QtCore -I$(QTDIR)/include/QtGui +QTLDLIBS = -L$(QTDIR)/lib -lQtCore4 -lQtGui4 +MOC = $(QTDIR)/moc +#################################################### +# Disabled gui for Windows, can someone with more +# knowledge about QT fix this problem?? +#################################################### +QTLDLIBS= +else ifeq ($(platform),Darwin) +CXXFLAGS = -I/Library/Frameworks/QtGui.framework/Versions/Current/Headers -I/Library/Frameworks/QtCore.framework/Versions/Current/Headers +QTLDLIBS = -framework QtGui -framework QtCore +MOC = moc +else +CXXFLAGS = $(shell pkg-config --cflags QtCore QtGui 2>/dev/null) -Wall -O3 QTLDLIBS = $(shell pkg-config --libs QtCore QtGui 2>/dev/null) +MOC = $(shell pkg-config --variable=moc_location QtCore) +endif + + +ifneq ($(QTLDLIBS),) +QTGUI = $(OBJDIR)/proxgui.o $(OBJDIR)/proxguiqt.o $(OBJDIR)/proxguiqt.moc.o +CFLAGS += -DHAVE_GUI +LINK.o = $(LINK.cpp) +else +QTGUI = guidummy.o +endif CMDSRCS = \ + nonce2key/crapto1.c\ + nonce2key/crypto1.c\ + nonce2key/nonce2key.c\ + mifarehost.c\ crc16.c \ iso14443crc.c \ + iso15693tools.c \ data.c \ graph.c \ ui.c \ + util.c \ cmddata.c \ cmdhf.c \ cmdhf14a.c \ cmdhf14b.c \ cmdhf15.c \ + cmdhfepa.c \ cmdhflegic.c \ + cmdhficlass.c \ + cmdhfmf.c \ cmdhw.c \ cmdlf.c \ cmdlfem4x.c \ cmdlfhid.c \ + cmdlfhitag.c \ cmdlfti.c \ cmdparser.c \ - cmdmain.c - -CMDOBJS = $(CMDSRCS:.c=.o) - -ifeq ($(shell echo ""),) + cmdmain.c \ + uart.c -ifeq ($(shell uname),Darwin) -CXXFLAGS = -I/Library/Frameworks/QtGui.framework/Versions/Current/Headers -I/Library/Frameworks/QtCore.framework/Versions/Current/Headers -QTLDLIBS = -framework QtGui -framework QtCore -MOC = moc -endif - -ifneq ($(QTLDLIBS),) -QTGUI = proxgui.o proxguiqt.o proxguiqt.moc.o -CFLAGS += -DHAVE_GUI -MOC ?= $(shell pkg-config --variable=moc_location QtCore) -LINK.o = $(LINK.cpp) -else -QTGUI = guidummy.o -endif +CMDOBJS = $(CMDSRCS:%.c=$(OBJDIR)/%.o) RM = rm -f -BINS = proxmark3 snooper cli flasher -CLEAN = cli flasher proxmark3 snooper *.o $(CMDOBJS) *.moc.cpp -else -RM = del -BINS = prox.exe -CLEAN = prox.exe -endif +BINS = proxmark3 flasher #snooper cli +CLEAN = cli cli.exe flasher flasher.exe proxmark3 proxmark3.exe snooper snooper.exe $(CMDOBJS) $(OBJDIR)/*.o *.o *.moc.cpp all: $(BINS) all-static: LDLIBS:=-static $(LDLIBS) all-static: snooper cli flasher - -prox.exe: prox.o wingui.o $(CMDOBJS) flash.o - $(CC) $(CFLAGS) $(DEFINES) -o prox.exe prox.o wingui.o $(CMDOBJS) flash.c $(WINLIBS) proxmark3: LDLIBS+=$(QTLDLIBS) -proxmark3: proxmark3.o $(CMDOBJS) proxusb.o $(QTGUI) +proxmark3: $(OBJDIR)/proxmark3.o $(CMDOBJS) $(OBJDIR)/proxusb.o $(QTGUI) + $(CXX) $(CXXFLAGS) $^ $(LDLIBS) -o $@ + +snooper: $(OBJDIR)/snooper.o $(CMDOBJS) $(OBJDIR)/proxusb.o $(OBJDIR)/guidummy.o + $(CXX) $(CXXFLAGS) $^ $(LDLIBS) -o $@ -snooper: snooper.o $(CMDOBJS) proxusb.o guidummy.o +cli: $(OBJDIR)/cli.o $(CMDOBJS) $(OBJDIR)/proxusb.o $(OBJDIR)/guidummy.o + $(CXX) $(CXXFLAGS) $^ $(LDLIBS) -o $@ -cli: cli.o $(CMDOBJS) proxusb.o guidummy.o +flasher: $(OBJDIR)/flash.o $(OBJDIR)/flasher.o $(OBJDIR)/proxusb.o + $(CXX) $(CXXFLAGS) $^ $(LDLIBS) -o $@ -flasher: flash.o flasher.o proxusb.o +$(OBJDIR)/%.o: %.c + $(CC) $(CFLAGS) -c -o $@ $< + +$(OBJDIR)/%.o: %.cpp + $(CXX) $(CXXFLAGS) -c -o $@ $< proxguiqt.moc.cpp: proxguiqt.h $(MOC) -o$@ $^ @@ -82,6 +111,9 @@ proxguiqt.moc.cpp: proxguiqt.h clean: $(RM) $(CLEAN) +tarbin: $(BINS) + $(TAR) $(TARFLAGS) ../proxmark3-$(platform)-bin.tar $(BINS:%=client/%) + # must be run as root install_kext: Info.plist mkdir -p /System/Library/Extensions/Proxmark3.kext/Contents