Skip to content

Commit

Permalink
Make portaudio build on msvc
Browse files Browse the repository at this point in the history
  • Loading branch information
npostavs committed Jan 24, 2021
1 parent e4ce3a9 commit a702953
Showing 1 changed file with 67 additions and 42 deletions.
109 changes: 67 additions & 42 deletions Jamulus.pro
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,14 @@ CONFIG += qt \
lrelease \
release

CONFIG += portaudio
# default to use portaudio in Windows
win32 {
CONFIG += portaudio
}
CONFIG (noportaudio) {
CONFIG -= portaudio
}


QT += network \
xml \
Expand Down Expand Up @@ -55,33 +62,40 @@ DEFINES += APP_VERSION=\\\"$$VERSION\\\" \
CUSTOM_MODES \
_REENTRANT

# msvc uses a different options syntax for adding libraries.
defineReplace(libnames) {
libopts =
names = $$1
for(libname, names) {
win32-msvc* {
libopts += $${libname}.lib
} else {
libopts += -l$${libname}
}
}
return($$libopts)
}

win32 {
DEFINES -= UNICODE # fixes issue with ASIO SDK (asiolist.cpp is not unicode compatible)
!CONFIG(portaudio) {
DEFINES += NOMINMAX # solves a compiler error in qdatetime.h (Qt5), breaks portaudio wasapi&wdmks though
HEADERS += windows/sound.h
SOURCES += windows/sound.cpp
}
win32-msvc* {
DEFINES += NOMINMAX # solves a compiler error in qdatetime.h (Qt5) when compiling with MSVC, breaks portaudio build under mingw
}

SOURCES += windows/ASIOSDK2/common/asio.cpp \
windows/ASIOSDK2/host/asiodrivers.cpp \
windows/ASIOSDK2/host/pc/asiolist.cpp
RC_FILE = windows/mainicon.rc
INCLUDEPATH += windows/ASIOSDK2/common \
windows/ASIOSDK2/host \
windows/ASIOSDK2/host/pc
mingw* {
LIBS += -lole32 \
-luser32 \
-ladvapi32 \
-lwinmm \
-lws2_32
} else {
LIBS += $$libnames(ole32 user32 advapi32 winmm ws2_32)
win32-msvc* {
QMAKE_LFLAGS += /DYNAMICBASE:NO # fixes crash with libjack64.dll, see https://github.com/corrados/jamulus/issues/93
LIBS += ole32.lib \
user32.lib \
advapi32.lib \
winmm.lib \
ws2_32.lib
}

# replace ASIO with jack if requested
Expand Down Expand Up @@ -691,28 +705,36 @@ win32 {
$$files(libs/portaudio/src/hostapi/wmme/*.c) \
$$files(libs/portaudio/src/hostapi/wasapi/*.c)
SOURCES_CXX_PORTAUDIO += $$files(libs/portaudio/src/hostapi/asio/*.cpp)
# Adapter for C++ compiler-specific calling convention not needed for msvc
win32-msvc* {
SOURCES_CXX_PORTAUDIO -= libs/portaudio/src/hostapi/asio/iasiothiscallresolver.cpp
}
} else:unix {
# FIXME: also some hostapi files, probably.
SOURCES_PORTAUDIO += $$files(libs/portaudio/src/os/unix/*.c)
}

# Suppress warnings from portaudio sources, with -w
# NOTE: we set portaudio(cc|cxx).variable_out to OBJECTS down near the
# bottom depending on the configuration.
# See also
# - https://wiki.qt.io/Undocumented_QMake#Custom_tools
# - https://stackoverflow.com/questions/27683777/how-to-specify-compiler-flag-to-a-single-source-file-with-qmake
portaudiocc.name = portaudiocc
portaudiocc.input = SOURCES_PORTAUDIO
portaudiocc.dependency_type = TYPE_C
portaudiocc.output = ${QMAKE_VAR_OBJECTS_DIR}${QMAKE_FILE_IN_BASE}$${first(QMAKE_EXT_OBJ)}
portaudiocc.commands = ${CC} $(CFLAGS) -w $(INCPATH) -c ${QMAKE_FILE_IN} -o ${QMAKE_FILE_OUT}
portaudiocxx.name = portaudiocxx
portaudiocxx.input = SOURCES_CXX_PORTAUDIO
portaudiocxx.dependency_type = TYPE_C
portaudiocxx.output = ${QMAKE_VAR_OBJECTS_DIR}${QMAKE_FILE_IN_BASE}$${first(QMAKE_EXT_OBJ)}
portaudiocxx.commands = ${CXX} $(CXXFLAGS) -w $(INCPATH) -c ${QMAKE_FILE_IN} -o ${QMAKE_FILE_OUT}

# I can't figure out how to make the custom compiler stuff work for
# msvc, we'll have to live with portaudio compile warnings in that
# build.
!win32-msvc* {
# Suppress warnings from portaudio sources, with -w
# NOTE: we set portaudio(cc|cxx).variable_out to OBJECTS down near the
# bottom depending on the configuration.
# See also
# - https://wiki.qt.io/Undocumented_QMake#Custom_tools
# - https://stackoverflow.com/questions/27683777/how-to-specify-compiler-flag-to-a-single-source-file-with-qmake
portaudiocc.name = portaudiocc
portaudiocc.input = SOURCES_PORTAUDIO
portaudiocc.dependency_type = TYPE_C
portaudiocc.output = ${QMAKE_VAR_OBJECTS_DIR}${QMAKE_FILE_IN_BASE}$${first(QMAKE_EXT_OBJ)}
portaudiocc.commands = ${CC} $(CFLAGS) -w $(INCPATH) -c ${QMAKE_FILE_IN} -o ${QMAKE_FILE_OUT}
portaudiocxx.name = portaudiocxx
portaudiocxx.input = SOURCES_CXX_PORTAUDIO
portaudiocxx.dependency_type = TYPE_C
portaudiocxx.output = ${QMAKE_VAR_OBJECTS_DIR}${QMAKE_FILE_IN_BASE}$${first(QMAKE_EXT_OBJ)}
portaudiocxx.commands = ${CXX} $(CXXFLAGS) -w $(INCPATH) -c ${QMAKE_FILE_IN} -o ${QMAKE_FILE_OUT}
}

DISTFILES += ChangeLog \
COPYING \
Expand Down Expand Up @@ -1108,24 +1130,25 @@ CONFIG(portaudio) {
DEFINES += USE_PORTAUDIO
HEADERS += src/portaudiosound.h
SOURCES += src/portaudiosound.cpp
mingw* {
win32 {
CONFIG(portaudio_shared_lib) {
LIBS += -lportaudio
LIBS += $$libnames(portaudio)
} else {
DEFINES += PA_USE_ASIO=1
INCLUDEPATH += $$INCLUDEPATH_PORTAUDIO
HEADERS += $$HEADERS_PORTAUDIO
portaudiocxx.variable_out = OBJECTS
portaudiocc.variable_out = OBJECTS
QMAKE_EXTRA_COMPILERS += portaudiocc portaudiocxx
mingw {
portaudiocxx.variable_out = OBJECTS
portaudiocc.variable_out = OBJECTS
QMAKE_EXTRA_COMPILERS += portaudiocc portaudiocxx
} else {
SOURCES += $$SOURCES_PORTAUDIO $$SOURCES_CXX_PORTAUDIO
}
DISTFILES += $$DISTFILES_PORTAUDIO
}
LIBS += -lwinmm \
-lole32 \
-luuid \
-lsetupapi
LIBS += $$libnames(winmm ole32 uuid setupapi)
} else {
error( "portaudio only tested on mingw for now" )
error( "portaudio only tested on win32 for now" )
}
}

Expand All @@ -1138,5 +1161,7 @@ contains(CONFIG, "disable_version_check") {
ANDROID_ABIS = armeabi-v7a arm64-v8a x86 x86_64

CONFIG += silent
QMAKE_CXXFLAGS += -Wno-deprecated-declarations
!win32-msvc* {
QMAKE_CXXFLAGS += -Wno-deprecated-declarations
}

0 comments on commit a702953

Please sign in to comment.