TARGET = IESample
-HEADERS = src/*.h
-SOURCES = src/*.cxx
+SAMPLESROOT = $$quote($$(CSF_OCCTSamplesPath)/qt)
-INCLUDEPATH = $(CASROOT) $(CASROOT)/inc $(QTDIR)/include/QtCore \
- $(QTDIR)/include/QtGui $(QTDIR)/include
+HEADERS = $${SAMPLESROOT}/Common/src/*.h \
+ $${SAMPLESROOT}/Interface/src/*.h
-TS_FILES = ./src/Common-icon.ts \
- ./src/Common-string.ts \
- ./src/Interface-string.ts
+SOURCES = src/*.cxx \
+ $${SAMPLESROOT}/Common/src/*.cxx \
+ $${SAMPLESROOT}/Interface/src/*.cxx
-DEFINES = CSFDB
+TS_FILES = $${SAMPLESROOT}/Common/src/Common-icon.ts \
+ $${SAMPLESROOT}/Common/src/Common-string.ts \
+ $${SAMPLESROOT}/Interface/src/Interface-string.ts
+
+RES_FILES = $${SAMPLESROOT}/Common/res/*
+
+RES_DIR = $$quote($$(RES_DIR))
+
+INCLUDEPATH += $$quote($${SAMPLESROOT}/Common/src)
+INCLUDEPATH += $$quote($${SAMPLESROOT}/Interface/src)
+INCLUDEPATH += $$quote($$(CSF_OCCTIncludePath))
+
+OCCT_DEFINES = $$(CSF_DEFINES)
+
+DEFINES = $$split(OCCT_DEFINES, ;)
unix {
+ UNAME = $$system(uname -s)
+ LIBLIST = $$(LD_LIBRARY_PATH)
+ LIBPATHS = $$split(LIBLIST,":")
+ for(lib, LIBPATHS):LIBS += -L$${lib}
+
CONFIG(debug, debug|release) {
- DESTDIR = ./Linux/bind
- OBJECTS_DIR = ./Linux/objd
- MOC_DIR = ./Linux/srcd
+ DESTDIR = ./$$UNAME/bind
+ OBJECTS_DIR = ./$$UNAME/objd
+ MOC_DIR = ./$$UNAME/mocd
} else {
- DESTDIR = ./Linux/bin
- OBJECTS_DIR = ./Linux/obj
- MOC_DIR = ./Linux/src
- }
- INCLUDEPATH += $$QMAKE_INCDIR_X11 $$QMAKE_INCDIR_OPENGL $$QMAKE_INCDIR_THREAD
- DEFINES += LIN LININTEL OCC_CONVERT_SIGNALS HAVE_CONFIG_H HAVE_WOK_CONFIG_H QT_NO_STL
- LIBS = -L$(CASROOT)/Linux/lib -L$$QMAKE_LIBDIR_X11 $$QMAKE_LIBS_X11 -L$$QMAKE_LIBDIR_OPENGL $$QMAKE_LIBS_OPENGL $$QMAKE_LIBS_THREAD
- FREEIMAGE_DIR = $$(FREEIMAGEDIR)
- exists($$FREEIMAGE_DIR) {
- LIBS += -L$(FREEIMAGEDIR)/lib -lfreeimageplus
- }
- TBB_LIB = $$(TBBLIB)
- exists($$TBB_LIB) {
- LIBS += -L$(TBBLIB) -ltbb -ltbbmalloc
+ DESTDIR = ./$$UNAME/bin
+ OBJECTS_DIR = ./$$UNAME/obj
+ MOC_DIR = ./$$UNAME/moc
}
+
+ MACOSX_USE_GLX = $$(MACOSX_USE_GLX)
+
+ !macx | equals(MACOSX_USE_GLX, true): INCLUDEPATH += $$QMAKE_INCDIR_X11 $$QMAKE_INCDIR_OPENGL $$QMAKE_INCDIR_THREAD
+ equals(MACOSX_USE_GLX, true): DEFINES += MACOSX_USE_GLX
+ DEFINES += OCC_CONVERT_SIGNALS QT_NO_STL
+ !macx | equals(MACOSX_USE_GLX, true): LIBS += -L$$QMAKE_LIBDIR_X11 $$QMAKE_LIBS_X11 -L$$QMAKE_LIBDIR_OPENGL $$QMAKE_LIBS_OPENGL $$QMAKE_LIBS_THREAD
+ LIBS += -lfreeimageplus
+ LIBS += -ltbb -ltbbmalloc
+ QMAKE_CXXFLAGS += -std=gnu++11
}
win32 {
CONFIG(debug, debug|release) {
- DEFINES += _DEBUG
- !contains(QMAKE_HOST.arch, x86_64) {
- contains(QMAKE_COMPILER_DEFINES, _MSC_VER=1310) {
- DESTDIR = ./win32/vc7/bind
- OBJECTS_DIR = ./win32/vc7/objd
- MOC_DIR = ./win32/vc7/srcd
- LIBS = -L$(CASROOT)/win32/vc7/libd
- }
- contains(QMAKE_COMPILER_DEFINES, _MSC_VER=1400) {
- DESTDIR = ./win32/vc8/bind
- OBJECTS_DIR = ./win32/vc8/objd
- MOC_DIR = ./win32/vc8/srcd
- LIBS = -L$(CASROOT)/win32/vc8/libd
- }
- contains(QMAKE_COMPILER_DEFINES, _MSC_VER=1500) {
- DESTDIR = ./win32/vc9/bind
- OBJECTS_DIR = ./win32/vc9/objd
- MOC_DIR = ./win32/vc9/srcd
- LIBS = -L$(CASROOT)/win32/vc9/libd
- }
- contains(QMAKE_COMPILER_DEFINES, _MSC_VER=1600) {
- DESTDIR = ./win32/vc10/bind
- OBJECTS_DIR = ./win32/vc10/objd
- MOC_DIR = ./win32/vc10/srcd
- LIBS = -L$(CASROOT)/win32/vc10/libd
- }
- } else {
- contains(QMAKE_COMPILER_DEFINES, _MSC_VER=1400) {
- DESTDIR = ./win64/vc8/bind
- OBJECTS_DIR = ./win64/vc8/objd
- MOC_DIR = ./win64/vc8/srcd
- LIBS = -L$(CASROOT)/win64/vc8/libd
- }
- contains(QMAKE_COMPILER_DEFINES, _MSC_VER=1500) {
- DESTDIR = ./win64/vc9/bind
- OBJECTS_DIR = ./win64/vc9/objd
- MOC_DIR = ./win64/vc9/srcd
- LIBS = -L$(CASROOT)/win64/vc9/libd
- }
- contains(QMAKE_COMPILER_DEFINES, _MSC_VER=1600) {
- DESTDIR = ./win64/vc10/bind
- OBJECTS_DIR = ./win64/vc10/objd
- MOC_DIR = ./win64/vc10/srcd
- LIBS = -L$(CASROOT)/win64/vc10/libd
- }
- }
+ DEFINES += _DEBUG
+ DESTDIR = ./win$(ARCH)/$(VCVER)/bind
+ OBJECTS_DIR = ./win$(ARCH)/$(VCVER)/objd
+ MOC_DIR = ./win$(ARCH)/$(VCVER)/mocd
} else {
- DEFINES += NDEBUG
- !contains(QMAKE_HOST.arch, x86_64) {
- contains(QMAKE_COMPILER_DEFINES, _MSC_VER=1310) {
- DESTDIR = ./win32/vc7/bin
- OBJECTS_DIR = ./win32/vc7/obj
- MOC_DIR = ./win32/vc7/src
- LIBS = -L$(CASROOT)/win32/vc7/lib
- }
- contains(QMAKE_COMPILER_DEFINES, _MSC_VER=1400) {
- DESTDIR = ./win32/vc8/bin
- OBJECTS_DIR = ./win32/vc8/obj
- MOC_DIR = ./win32/vc8/src
- LIBS = -L$(CASROOT)/win32/vc8/lib
- }
- contains(QMAKE_COMPILER_DEFINES, _MSC_VER=1500) {
- DESTDIR = ./win32/vc9/bin
- OBJECTS_DIR = ./win32/vc9/obj
- MOC_DIR = ./win32/vc9/src
- LIBS = -L$(CASROOT)/win32/vc9/lib
- }
- contains(QMAKE_COMPILER_DEFINES, _MSC_VER=1600) {
- DESTDIR = ./win32/vc10/bin
- OBJECTS_DIR = ./win32/vc10/obj
- MOC_DIR = ./win32/vc10/src
- LIBS = -L$(CASROOT)/win32/vc10/lib
- }
- } else {
- contains(QMAKE_COMPILER_DEFINES, _MSC_VER=1400) {
- DESTDIR = ./win64/vc8/bin
- OBJECTS_DIR = ./win64/vc8/obj
- MOC_DIR = ./win64/vc8/src
- LIBS = -L$(CASROOT)/win64/vc8/lib
- }
- contains(QMAKE_COMPILER_DEFINES, _MSC_VER=1500) {
- DESTDIR = ./win64/vc9/bin
- OBJECTS_DIR = ./win64/vc9/obj
- MOC_DIR = ./win64/vc9/src
- LIBS = -L$(CASROOT)/win64/vc9/lib
- }
- contains(QMAKE_COMPILER_DEFINES, _MSC_VER=1600) {
- DESTDIR = ./win64/vc10/bin
- OBJECTS_DIR = ./win64/vc10/obj
- MOC_DIR = ./win64/vc10/src
- LIBS = -L$(CASROOT)/win64/vc10/lib
- }
- }
+ DEFINES += NDEBUG
+ DESTDIR = ./win$(ARCH)/$(VCVER)/bin
+ OBJECTS_DIR = ./win$(ARCH)/$(VCVER)/obj
+ MOC_DIR = ./win$(ARCH)/$(VCVER)/moc
}
- DEFINES +=WNT WIN32 NO_COMMONSAMPLE_EXPORTS NO_IESAMPLE_EXPORTS
+ LIBS = -L$$(QTDIR)/lib;$$(CSF_OCCTLibPath)
+ DEFINES += NO_COMMONSAMPLE_EXPORTS NO_IESAMPLE_EXPORTS
}
-LIBS += -lTKernel -lPTKernel -lTKMath -lTKService -lTKV3d -lTKV2d \
+LIBS += -lTKernel -lTKMath -lTKService -lTKV3d -lTKOpenGl \
-lTKBRep -lTKIGES -lTKSTL -lTKVRML -lTKSTEP -lTKSTEPAttr -lTKSTEP209 \
- -lTKSTEPBase -lTKShapeSchema -lTKGeomBase -lTKGeomAlgo -lTKG3d -lTKG2d \
- -lTKXSBase -lTKPShape -lTKShHealing -lTKHLR -lTKTopAlgo -lTKMesh -lTKPrim \
- -lTKCDF -lTKBool -lTKBO -lTKFillet -lTKOffset \
- -L$(QTDIR)/lib -lQtCore -lQtGui
-
-lrelease.name = LRELASE ${QMAKE_FILE_IN}
-lrelease.commands = $(QTDIR)/bin/lrelease ${QMAKE_FILE_IN} -qm ./res/${QMAKE_FILE_BASE}.qm
-lrelease.output = ./res/${QMAKE_FILE_BASE}.qm
+ -lTKSTEPBase -lTKGeomBase -lTKGeomAlgo -lTKG3d -lTKG2d \
+ -lTKXSBase -lTKShHealing -lTKHLR -lTKTopAlgo -lTKMesh -lTKPrim \
+ -lTKCDF -lTKBool -lTKBO -lTKFillet -lTKOffset -lTKLCAF \
+
+!exists($${RES_DIR}) {
+ win32 {
+ system(mkdir $${RES_DIR})
+ } else {
+ system(mkdir -p $${RES_DIR})
+ }
+}
+
+lrelease.name = LRELEASE ${QMAKE_FILE_IN}
+lrelease.commands = lrelease ${QMAKE_FILE_IN} -qm $${RES_DIR}/${QMAKE_FILE_BASE}.qm
+lrelease.output = ${QMAKE_FILE_BASE}.qm
lrelease.input = TS_FILES
-lrelease.clean = ./res/${QMAKE_FILE_BASE}.qm
+lrelease.clean = $${RES_DIR}/${QMAKE_FILE_BASE}.qm
lrelease.CONFIG += no_link target_predeps
QMAKE_EXTRA_COMPILERS += lrelease
+
+copy_res.name = Copy resource ${QMAKE_FILE_IN}
+copy_res.output = ${QMAKE_FILE_BASE}${QMAKE_FILE_EXT}
+copy_res.clean = $${RES_DIR}/${QMAKE_FILE_BASE}${QMAKE_FILE_EXT}
+copy_res.input = RES_FILES
+copy_res.CONFIG += no_link target_predeps
+win32: copy_res.commands = type ${QMAKE_FILE_IN} > $${RES_DIR}/${QMAKE_FILE_BASE}${QMAKE_FILE_EXT}
+unix: copy_res.commands = cp -f ${QMAKE_FILE_IN} $${RES_DIR}
+QMAKE_EXTRA_COMPILERS += copy_res
+#QMAKE_CXXFLAGS += /wd4996
+
+greaterThan(QT_MAJOR_VERSION, 4) {
+ QT += widgets
+}