summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--cmake/Modules/FindCodec2.cmake12
-rw-r--r--gr-vocoder/include/gnuradio/vocoder/freedv_api.h5
2 files changed, 14 insertions, 3 deletions
diff --git a/cmake/Modules/FindCodec2.cmake b/cmake/Modules/FindCodec2.cmake
index 0c94ad0a0a..f33de4dcde 100644
--- a/cmake/Modules/FindCodec2.cmake
+++ b/cmake/Modules/FindCodec2.cmake
@@ -61,6 +61,18 @@ if(LIBCODEC2_INCLUDE_DIR AND LIBCODEC2_LIBRARIES)
else()
set(LIBCODEC2_HAS_FREEDV_API false)
endif()
+
+ # we need to discover if codec2 < 0.9
+ # moreover, codec2 < 0.8 doesn't provide codec2/version.h
+ if(EXISTS "${LIBCODEC2_INCLUDE_DIRS}/version.h")
+ file(READ "${LIBCODEC2_INCLUDE_DIRS}/version.h" _CODEC2_VERSION_H_CONTENTS)
+ string(REGEX MATCH "CODEC2_VERSION_MAJOR ([0-9]+)(.*)CODEC2_VERSION_MINOR ([0-9]+)" _CODEC2_TMP_MATCH " ${_CODEC2_VERSION_H_CONTENTS}")
+ if((CMAKE_MATCH_1 EQUAL 0) AND (CMAKE_MATCH_3 LESS 9))
+ add_definitions(-DCODEC2_LEGACY)
+ endif()
+ else()
+ add_definitions(-DCODEC2_LEGACY)
+ endif()
endif(LIBCODEC2_INCLUDE_DIR AND LIBCODEC2_LIBRARIES)
FIND_PACKAGE_HANDLE_STANDARD_ARGS(LIBCODEC2 DEFAULT_MSG LIBCODEC2_LIBRARIES LIBCODEC2_INCLUDE_DIRS)
diff --git a/gr-vocoder/include/gnuradio/vocoder/freedv_api.h b/gr-vocoder/include/gnuradio/vocoder/freedv_api.h
index 04c768bcb7..c025432c5d 100644
--- a/gr-vocoder/include/gnuradio/vocoder/freedv_api.h
+++ b/gr-vocoder/include/gnuradio/vocoder/freedv_api.h
@@ -27,14 +27,13 @@
// version >=0.9.1 contains fixes that doesn't require "extern C"
// between 0.8.1 and 0.9.1 the build fail
-#include <codec2/version.h>
-#if CODEC2_VERSION_MAJOR == 0 && CODEC2_VERSION_MINOR < 9
+#ifdef CODEC2_LEGACY
extern "C" {
#endif
#include <codec2/codec2.h>
#include <codec2/freedv_api.h>
#include <codec2/modem_stats.h>
-#if CODEC2_VERSION_MAJOR == 0 && CODEC2_VERSION_MINOR < 9
+#ifdef CODEC2_LEGACY
}
#endif