Make Qt4 work
authorSam Moore <matches@ucc.asn.au>
Mon, 18 Aug 2014 05:18:39 +0000 (13:18 +0800)
committerSam Moore <matches@ucc.asn.au>
Mon, 18 Aug 2014 05:18:39 +0000 (13:18 +0800)
Needed to generate a special "moc" cpp file from the header file

src/Makefile
src/controlpanel.h

index 067cc61..26edd62 100644 (file)
@@ -3,10 +3,10 @@ ARCH := $(shell uname -m)
 # TODO: stb_truetype doesn't compile with some of these warnings.
 CXX = g++ -std=gnu++0x -g -Wall -Werror -Wshadow -pedantic -rdynamic
 MAIN = main.o
 # TODO: stb_truetype doesn't compile with some of these warnings.
 CXX = g++ -std=gnu++0x -g -Wall -Werror -Wshadow -pedantic -rdynamic
 MAIN = main.o
-OBJ = log.o real.o bezier.o document.o objectrenderer.o view.o screen.o vfpu.o quadtree.o graphicsbuffer.o framebuffer.o shaderprogram.o stb_truetype.o gl_core44.o add_digits_asm.o sub_digits_asm.o mul_digits_asm.o div_digits_asm.o arbint.o controlpanel.o
+OBJ = log.o real.o bezier.o document.o objectrenderer.o view.o screen.o vfpu.o quadtree.o graphicsbuffer.o framebuffer.o shaderprogram.o stb_truetype.o gl_core44.o add_digits_asm.o sub_digits_asm.o mul_digits_asm.o div_digits_asm.o arbint.o moc_controlpanel.o controlpanel.o
 
 QT_INCLUDE := -I/usr/share/qt4/mkspecs/linux-g++-64 -I. -I/usr/include/qt4/QtCore -I/usr/include/qt4/QtGui -I/usr/include/qt4 -I. -Itests -I.
 
 QT_INCLUDE := -I/usr/share/qt4/mkspecs/linux-g++-64 -I. -I/usr/include/qt4/QtCore -I/usr/include/qt4/QtGui -I/usr/include/qt4 -I. -Itests -I.
-
+QT_DEF := -DQT_NO_DEBUG -DQT_GUI_LIB -DQT_CORE_LIB
 QT_LIB :=  -L/usr/lib/x86_64-linux-gnu -lQtGui -lQtCore -lpthread 
 
 LIB_x86_64 = ../contrib/lib/libSDL2-2.0.so.0 -lGL -lgmp $(QT_LIB)
 QT_LIB :=  -L/usr/lib/x86_64-linux-gnu -lQtGui -lQtCore -lpthread 
 
 LIB_x86_64 = ../contrib/lib/libSDL2-2.0.so.0 -lGL -lgmp $(QT_LIB)
@@ -49,6 +49,8 @@ double : $(BIN)
 
 DEF = -DREAL=$(REALTYPE) -DQUADTREE_DISABLED
 
 
 DEF = -DREAL=$(REALTYPE) -DQUADTREE_DISABLED
 
+CFLAGS := $(CFLAGS) $(QT_DEF)
+
 demo : $(BIN) ../tools/stream_plot.py
        mkdir -p ../data/
        $(RM) ../data/performance.dat
 demo : $(BIN) ../tools/stream_plot.py
        mkdir -p ../data/
        $(RM) ../data/performance.dat
@@ -79,6 +81,9 @@ $(BIN) : $(LINKOBJ) ../obj/$(MAIN)
 
 -include $(DEPS)
 
 
 -include $(DEPS)
 
+moc_controlpanel.cpp : controlpanel.cpp controlpanel.h
+       moc $(DEF) controlpanel.h -o moc_controlpanel.cpp
+
 ../obj/%.o : %.cpp main.h
        @mkdir -p $(dir $@)
        $(CXX) $(CFLAGS) $(DEF) -c -MMD -o $@ $<
 ../obj/%.o : %.cpp main.h
        @mkdir -p $(dir $@)
        $(CXX) $(CFLAGS) $(DEF) -c -MMD -o $@ $<
index 3e8eb9a..f799375 100644 (file)
@@ -32,7 +32,7 @@ namespace IPDF
         */
        class ControlPanel : public QMainWindow
        {       
         */
        class ControlPanel : public QMainWindow
        {       
-               //Q_OBJECT // Having this causes shit about undefined vtables
+               Q_OBJECT // Having this causes shit about undefined vtables
                                // Not having it means things break
                                // Apparently you need "qmake" to build qt applications
                                // Or some bullshit -_-
                                // Not having it means things break
                                // Apparently you need "qmake" to build qt applications
                                // Or some bullshit -_-

UCC git Repository :: git.ucc.asn.au