libcorrect: add package

Adds the libcorrect package. Libcorrect by default builds a shared
library, so require shared libraries. We add a patch to make sure
-Wpedantic is only used if supported by the C compiler (gcc < 4.8
didn't support it).

Signed-off-by: Joel Carlson <JoelsonCarl@gmail.com>
[Thomas: add a patch to use -Wpedantic only if available, instead of
depending on gcc >= 4.8.]
Signed-off-by: Thomas Petazzoni <thomas.petazzoni@bootlin.com>
This commit is contained in:
Joel Carlson 2018-10-09 17:46:49 -06:00 committed by Thomas Petazzoni
parent 81496de675
commit abbf2f4e5d
6 changed files with 72 additions and 0 deletions

View File

@ -1073,6 +1073,7 @@ N: Joel Carlson <JoelsonCarl@gmail.com>
F: package/capnproto/ F: package/capnproto/
F: package/cmocka/ F: package/cmocka/
F: package/flatcc/ F: package/flatcc/
F: package/libcorrect/
N: Joel Stanley <joel@jms.id.au> N: Joel Stanley <joel@jms.id.au>
F: package/pdbg/ F: package/pdbg/

View File

@ -1609,6 +1609,7 @@ menu "Other"
source "package/libcap-ng/Config.in" source "package/libcap-ng/Config.in"
source "package/libcgroup/Config.in" source "package/libcgroup/Config.in"
source "package/libcofi/Config.in" source "package/libcofi/Config.in"
source "package/libcorrect/Config.in"
source "package/libcroco/Config.in" source "package/libcroco/Config.in"
source "package/libcrossguid/Config.in" source "package/libcrossguid/Config.in"
source "package/libcsv/Config.in" source "package/libcsv/Config.in"

View File

@ -0,0 +1,42 @@
From 8fc28b4c4c01581b25220fdbc1eeda196e399256 Mon Sep 17 00:00:00 2001
From: Thomas Petazzoni <thomas.petazzoni@bootlin.com>
Date: Wed, 10 Oct 2018 09:28:00 +0200
Subject: [PATCH] CMakeLists.txt: conditionally use -Wpedantic
-Wpedantic is only provided by gcc >= 4.8. Since showing pedantic
warnings is not really mandatory, let's only use this option when the
compiler supports it.
Signed-off-by: Thomas Petazzoni <thomas.petazzoni@bootlin.com>
Upstream: https://github.com/quiet/libcorrect/pull/25
---
CMakeLists.txt | 7 ++++++-
1 file changed, 6 insertions(+), 1 deletion(-)
diff --git a/CMakeLists.txt b/CMakeLists.txt
index 193f311..e570198 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -3,13 +3,18 @@ project(Correct C)
include(CheckLibraryExists)
include(CheckIncludeFiles)
include(CheckCSourceCompiles)
+include(CheckCCompilerFlag)
if(MSVC)
set(LIBM "")
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} /W4")
else(MSVC)
set(LIBM "m")
-set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -fPIC -std=c99 -Wpedantic -Wall")
+set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -fPIC -std=c99 -Wall")
+check_c_compiler_flag(-Wpedantic COMPILER_SUPPORTS_WPEDANTIC)
+if(COMPILER_SUPPORTS_WPEDANTIC)
+set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wpedantic")
+endif()
if(CMAKE_BUILD_TYPE STREQUAL "Debug")
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -g3 -O0 -fsanitize=address")
set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} -Wl,-no_pie,")
--
2.14.4

View File

@ -0,0 +1,12 @@
config BR2_PACKAGE_LIBCORRECT
bool "libcorrect"
depends on !BR2_STATIC_LIBS
help
A C library for Forward Error Correction, providing
convolutional codes and Reed-Solomon codes. It is part
of the Quiet Modem Project.
https://github.com/quiet/libcorrect
comment "libcorrect needs a toolchain w/ dynamic library"
depends on BR2_STATIC_LIBS

View File

@ -0,0 +1,3 @@
# Locally calculated
sha256 79861750540fb3a1cc501ee217cb4d1febc4855f3fb82e5eb60906eec5379890 libcorrect-ce6c17f1f988765ae3695315d7cce1f2a2e6cf0d.tar.gz
sha256 135138cd4304aa637836758dc5edfb5f21b7d09ecc637d25288d206b151a5768 LICENSE

View File

@ -0,0 +1,13 @@
################################################################################
#
# libcorrect
#
################################################################################
LIBCORRECT_VERSION = ce6c17f1f988765ae3695315d7cce1f2a2e6cf0d
LIBCORRECT_SITE = $(call github,quiet,libcorrect,$(LIBCORRECT_VERSION))
LIBCORRECT_LICENSE = BSD-3-Clause
LIBCORRECT_LICENSE_FILES = LICENSE
LIBCORRECT_INSTALL_STAGING = YES
$(eval $(cmake-package))