[med-svn] [Git][med-team/libbioparser-dev][upstream] New upstream version 3.1.0
Michael R. Crusoe (@crusoe)
gitlab at salsa.debian.org
Fri Mar 22 16:20:57 GMT 2024
Michael R. Crusoe pushed to branch upstream at Debian Med / libbioparser-dev
Commits:
b9a7fc37 by Michael R. Crusoe at 2024-03-21T14:31:03+01:00
New upstream version 3.1.0
- - - - -
17 changed files:
- .github/workflows/bioparser.yml
- .gitignore
- CMakeLists.txt
- README.md
- + include/meson.build
- + meson.build
- + meson_options.txt
- + subprojects/biosoup.wrap
- + subprojects/gtest.wrap
- + subprojects/zlib.wrap
- + test/bioparser_test_config.h.in
- test/fasta_parser_test.cpp
- test/fastq_parser_test.cpp
- + test/meson.build
- test/mhap_parser_test.cpp
- test/paf_parser_test.cpp
- test/sam_parser_test.cpp
Changes:
=====================================
.github/workflows/bioparser.yml
=====================================
@@ -14,38 +14,53 @@ jobs:
strategy:
matrix:
compiler:
+ - g++-7
- g++
- - g++-4.8
+ - clang++-6.0
- clang++
- - clang++-4.0
- runs-on: ubuntu-18.04
+ runs-on: ubuntu-20.04
steps:
- - uses: actions/checkout at v2
+ - uses: actions/checkout at v3
- - if: ${{ matrix.compiler == 'g++-4.8' }}
+ - if: ${{ contains(matrix.compiler, '-') }}
+ name: Get compiler version
+ id: get-compiler-version
+ run: |
+ version=$(echo ${{ matrix.compiler }} | cut -d- -f2)
+ echo "version=$version" >> $GITHUB_OUTPUT
+
+ - if: ${{ startsWith(matrix.compiler, 'g++-') }}
name: Setup GCC
uses: egor-tensin/setup-gcc at v1
with:
- version: "4.8"
+ version: "${{ steps.get-compiler-version.outputs.version }}"
platform: x64
- - if: ${{ matrix.compiler == 'clang++-4.0' }}
+ - if: ${{ startsWith(matrix.compiler, 'clang++-') }}
name: Setup Clang
uses: egor-tensin/setup-clang at v1
with:
- version: "4.0"
+ version: "${{ steps.get-compiler-version.outputs.version }}"
platform: x64
- name: Configure CMake
- run: cmake -B ${{ github.workspace }}/build -DCMAKE_BUILD_TYPE=${{ env.BUILD_TYPE }}
+ run: |
+ cmake -B ${{ github.workspace }}/build_cmake -DCMAKE_BUILD_TYPE=${{ env.BUILD_TYPE }}
+ cmake --build ${{ github.workspace }}/build_cmake
env:
CXX: ${{ matrix.compiler }}
- - name: Build
- run: cmake --build ${{ github.workspace }}/build --config ${{ env.BUILD_TYPE }}
+ - name: Configure Meson
+ uses: BSFishy/meson-build at v1.0.3
+ with:
+ action: build
+ directory: build_meson
+ meson-version: 0.60.0
- name: Test
- working-directory: ${{ github.workspace }}/build
- run: bin/bioparser_test
+ working-directory: ${{ github.workspace }}
+ run: |
+ build_cmake/bin/bioparser_test
+ build_meson/test/bioparser_test
=====================================
.gitignore
=====================================
@@ -1,2 +1,5 @@
# Compiled Object files
build/
+
+/subprojects/*
+!/subprojects/*.wrap
=====================================
CMakeLists.txt
=====================================
@@ -1,6 +1,6 @@
cmake_minimum_required(VERSION 3.11)
-project(bioparser VERSION 3.0.15
+project(bioparser VERSION 3.1.0
LANGUAGES CXX
DESCRIPTION "Bioparser is a c++ header only parsing library for several formats in bioinformatics (FASTA/Q, MHAP/PAF/SAM), with support for zlib compressed files.")
@@ -22,7 +22,7 @@ option(bioparser_build_tests "Build unit tests" ${bioparser_main_project})
find_package(ZLIB 1.2.8 REQUIRED)
if (bioparser_build_tests)
- find_package(biosoup 0.10.0 QUIET)
+ find_package(biosoup 0.11.0 QUIET)
find_package(GTest 1.10.0 QUIET)
if (NOT biosoup_FOUND)
@@ -31,7 +31,7 @@ if (bioparser_build_tests)
FetchContent_Declare(
biosoup
GIT_REPOSITORY https://github.com/rvaser/biosoup
- GIT_TAG 0.10.0)
+ GIT_TAG 0.11.0)
FetchContent_GetProperties(biosoup)
if (NOT biosoup_POPULATED)
@@ -102,6 +102,9 @@ if (bioparser_install)
endif ()
if (bioparser_build_tests)
+ set(BIOPARSER_TEST_DATA "${PROJECT_SOURCE_DIR}/test/data/")
+ configure_file(test/bioparser_test_config.h.in bioparser_test_config.h)
+
add_executable(bioparser_test
test/parser_test.cpp
test/fasta_parser_test.cpp
@@ -115,6 +118,6 @@ if (bioparser_build_tests)
biosoup::biosoup
GTest::Main)
- target_compile_definitions(bioparser_test
- PRIVATE TEST_DATA="${PROJECT_SOURCE_DIR}/test/data/")
+ target_include_directories(bioparser_test PUBLIC
+ $<BUILD_INTERFACE:${CMAKE_CURRENT_BINARY_DIR}>)
endif ()
=====================================
README.md
=====================================
@@ -5,41 +5,42 @@
Bioparser is a c++ header only parsing library for several bioinformatics formats (FASTA/Q, MHAP/PAF/SAM), with support for zlib compressed files.
-## Usage
+## Build
+
+### Dependencies
+
+- gcc 4.8+ | clang 3.5+
+- zlib 1.2.8+
+
+#### Hidden
+
+- (bioparser_test) rvaser/biosoup 0.11.0
+- (bioparser_test) google/googletest 1.10.0
+
+### CMake (3.11+)
-To build bioparser run the following commands:
```bash
-git clone https://github.com/rvaser/bioparser && cd bioparser && mkdir build && cd build
-cmake -DCMAKE_BUILD_TYPE=Release .. && make
-```
-which will create install targets and unit tests. Running `make install` will create a package on your system that can be searched and linked with:
-```cmake
-find_package(bioparser)
-target_link_libraries(<target> bioparser::bioparser)
+git clone https://github.com/rvaser/bioparser && cd bioparser
+cmake -B build -DCMAKE_BUILD_TYPE=Release
+make -C build
```
-On the other hand, you can include bioparser as a submodule and add it to your project with the following:
-```cmake
-if (NOT TARGET bioparser)
- add_subdirectory(<path_to_submodules>/bioparser EXCLUDE_FROM_ALL)
-endif ()
-target_link_libraries(<target> bioparser::bioparser)
-```
-
-If you are not using CMake, include the appropriate header file directly to your project and link with zlib.
-#### Build options
+#### Options
- `bioparser_install`: generate install target
- `bioparser_build_tests`: build unit tests
-#### Dependencies
-- gcc 4.8+ | clang 3.5+
-- zlib 1.2.8+
-- (optional) cmake 3.11+
+### Meson (0.60.0+)
-###### Hidden
-- (bioparser_test) rvaser/biosoup 0.10.0
-- (bioparser_test) google/googletest 1.10.0
+```bash
+git clone https://github.com/rvaser/bioparser && cd bioparser
+meson setup build
+ninja -C build
+```
+
+#### Options
+
+- `tests`: build unit tests
## Examples
=====================================
include/meson.build
=====================================
@@ -0,0 +1,20 @@
+###########
+# Headers #
+###########
+
+bioparser_include_directories = include_directories(['.'])
+
+if meson.is_subproject()
+ subdir_done()
+endif
+
+install_headers(
+ files([
+ 'bioparser/fasta_parser.hpp',
+ 'bioparser/fastq_parser.hpp',
+ 'bioparser/mhap_parser.hpp',
+ 'bioparser/paf_parser.hpp',
+ 'bioparser/parser.hpp',
+ 'bioparser/sam_parser.hpp',
+ ]),
+ subdir : 'bioparser')
=====================================
meson.build
=====================================
@@ -0,0 +1,61 @@
+project(
+ 'bioparser',
+ ['cpp'],
+ version : '3.1.0',
+ default_options : [
+ 'buildtype=release',
+ 'warning_level=3',
+ 'cpp_std=c++11',
+ 'b_ndebug=if-release'],
+ license : 'MIT',
+ meson_version : '>=0.60.0'
+)
+
+################
+# Dependencies #
+################
+
+# zlib
+bioparser_zlib_dep = dependency('zlib', include_type : 'system', fallback : ['zlib', 'zlib_dep'])
+
+bioparser_lib_deps = [
+ bioparser_zlib_dep,
+]
+
+###########
+# Headers #
+###########
+
+subdir('include')
+
+#########
+# Tests #
+#########
+
+if (not meson.is_subproject()) and get_option('tests')
+ # biosoup
+ bioparser_biosoup_dep = dependency('biosoup', version : '>= 0.11.0', fallback : ['biosoup', 'biosoup_dep'])
+
+ # gtest
+ bioparser_gtest_dep = dependency('gtest', version : '>= 1.10.0', main : true, fallback : ['gtest', 'gtest_main_dep'])
+
+ subdir('test')
+endif
+
+###################
+# Dependency info #
+###################
+
+if (not meson.is_subproject())
+ import('pkgconfig').generate(
+ name : 'bioparser',
+ version : meson.project_version(),
+ filebase : 'bioparser',
+ description : 'C++ header only parsing library for bioinformatics formats (FASTA/Q, MHAP/PAF/SAM), with support for zlib compressed files.')
+endif
+
+bioparser_dep = declare_dependency(
+ include_directories : bioparser_include_directories,
+ dependencies : bioparser_lib_deps,
+ version : meson.project_version()
+)
=====================================
meson_options.txt
=====================================
@@ -0,0 +1,8 @@
+#########
+# Tests #
+#########
+
+option('tests',
+ type : 'boolean',
+ value : true,
+ description : 'Enable dependencies required for testing')
=====================================
subprojects/biosoup.wrap
=====================================
@@ -0,0 +1,5 @@
+[wrap-git]
+directory = biosoup
+
+url = https://github.com/rvaser/biosoup
+revision = 0.11.0
=====================================
subprojects/gtest.wrap
=====================================
@@ -0,0 +1,16 @@
+[wrap-file]
+directory = googletest-release-1.10.0
+
+source_url = https://github.com/google/googletest/archive/release-1.10.0.zip
+source_filename = gtest-1.10.0.zip
+source_hash = 94c634d499558a76fa649edb13721dce6e98fb1e7018dfaeba3cd7a083945e91
+
+patch_url = https://wrapdb.mesonbuild.com/v2/gtest_1.10.0-1/get_patch
+patch_filename = gtest-1.10.0-1-wrap.zip
+patch_hash = 04ff14e8880e4e465f6260221e9dfd56fea6bc7cce4c4aff0dc528e4a2c8f514
+
+wrapdb_version = 1.10.0-1
+
+[provide]
+gtest = gtest_dep
+gtest_main = gtest_main_dep
=====================================
subprojects/zlib.wrap
=====================================
@@ -0,0 +1,15 @@
+[wrap-file]
+directory = zlib-1.2.8
+
+source_url = http://zlib.net/fossils/zlib-1.2.8.tar.gz
+source_filename = zlib-1.2.8.tar.gz
+source_hash = 36658cb768a54c1d4dec43c3116c27ed893e88b02ecfcb44f2166f9c0b7f2a0d
+
+patch_url = https://wrapdb.mesonbuild.com/v2/zlib_1.2.8-8/get_patch
+patch_filename = zlib-1.2.8-8-wrap.zip
+patch_hash = 17c52a0e0c59ce926d3959005d5cd8178c6c7e2c9a4a1304279a8320c955ac60
+
+wrapdb_version = 1.2.8-8
+
+[provide]
+zlib = zlib_dep
=====================================
test/bioparser_test_config.h.in
=====================================
@@ -0,0 +1,14 @@
+// Copyright (c) 2023 Robert Vaser
+
+#ifndef BIOPARSER_TEST_CONFIG_H_
+#define BIOPARSER_TEST_CONFIG_H_
+
+namespace bioparser {
+namespace test {
+
+constexpr char BIOPARSER_TEST_DATA[] = "@BIOPARSER_TEST_DATA@";
+
+} // namespace test
+} // namespace bioparser
+
+#endif // BIOPARSER_TEST_CONFIG_H_
=====================================
test/fasta_parser_test.cpp
=====================================
@@ -7,6 +7,8 @@
#include "biosoup/sequence.hpp"
#include "gtest/gtest.h"
+#include "bioparser_test_config.h"
+
std::atomic<std::uint32_t> biosoup::Sequence::num_objects{0};
namespace bioparser {
@@ -15,7 +17,7 @@ namespace test {
class BioparserFastaTest: public ::testing::Test {
public:
void Setup(const std::string& file) {
- p = Parser<biosoup::Sequence>::Create<FastaParser>(TEST_DATA + file);
+ p = Parser<biosoup::Sequence>::Create<FastaParser>(BIOPARSER_TEST_DATA + file);
}
void Check(bool is_trimmed = true) {
=====================================
test/fastq_parser_test.cpp
=====================================
@@ -7,13 +7,15 @@
#include "biosoup/sequence.hpp"
#include "gtest/gtest.h"
+#include "bioparser_test_config.h"
+
namespace bioparser {
namespace test {
class BioparserFastqTest: public ::testing::Test {
public:
void Setup(const std::string& file) {
- p = Parser<biosoup::Sequence>::Create<FastqParser>(TEST_DATA + file);
+ p = Parser<biosoup::Sequence>::Create<FastqParser>(BIOPARSER_TEST_DATA + file);
}
void Check() {
=====================================
test/meson.build
=====================================
@@ -0,0 +1,35 @@
+bioparser_test_config = configuration_data()
+bioparser_test_config.set('BIOPARSER_TEST_DATA', meson.project_source_root() + '/test/data/')
+
+###########
+# Sources #
+###########
+
+bioparser_test_config_headers = [
+ configure_file(
+ input : 'bioparser_test_config.h.in',
+ output : 'bioparser_test_config.h',
+ configuration : bioparser_test_config)
+]
+
+bioparser_test_sources = files([
+ 'fasta_parser_test.cpp',
+ 'fastq_parser_test.cpp',
+ 'mhap_parser_test.cpp',
+ 'paf_parser_test.cpp',
+ 'parser_test.cpp',
+ 'sam_parser_test.cpp',
+]) + bioparser_test_config_headers
+
+bioparser_test = executable(
+ 'bioparser_test',
+ bioparser_test_sources,
+ dependencies : [bioparser_lib_deps, bioparser_biosoup_dep, bioparser_gtest_dep],
+ include_directories : bioparser_include_directories,
+ install : false)
+
+#########
+# Tests #
+#########
+
+test('bioparser gtest unit tests', bioparser_test)
=====================================
test/mhap_parser_test.cpp
=====================================
@@ -8,6 +8,8 @@
#include "biosoup/overlap.hpp"
#include "gtest/gtest.h"
+#include "bioparser_test_config.h"
+
namespace bioparser {
namespace test {
@@ -43,7 +45,7 @@ struct MhapOverlap: public biosoup::Overlap {
class BioparserMhapTest: public ::testing::Test {
public:
void Setup(const std::string& file) {
- p = Parser<MhapOverlap>::Create<MhapParser>(TEST_DATA + file);
+ p = Parser<MhapOverlap>::Create<MhapParser>(BIOPARSER_TEST_DATA + file);
}
void Check() {
=====================================
test/paf_parser_test.cpp
=====================================
@@ -8,6 +8,8 @@
#include "biosoup/overlap.hpp"
#include "gtest/gtest.h"
+#include "bioparser_test_config.h"
+
namespace bioparser {
namespace test {
@@ -49,7 +51,7 @@ struct PafOverlap: public biosoup::Overlap {
class BioparserPafTest: public ::testing::Test {
public:
void Setup(const std::string& file) {
- p = Parser<PafOverlap>::Create<PafParser>(TEST_DATA + file);
+ p = Parser<PafOverlap>::Create<PafParser>(BIOPARSER_TEST_DATA + file);
}
void Check() {
=====================================
test/sam_parser_test.cpp
=====================================
@@ -8,6 +8,8 @@
#include "biosoup/overlap.hpp"
#include "gtest/gtest.h"
+#include "bioparser_test_config.h"
+
namespace bioparser {
namespace test {
@@ -54,7 +56,7 @@ struct SamOverlap: public biosoup::Overlap {
class BioparserSamTest: public ::testing::Test {
public:
void Setup(const std::string& file) {
- p = Parser<SamOverlap>::Create<SamParser>(TEST_DATA + file);
+ p = Parser<SamOverlap>::Create<SamParser>(BIOPARSER_TEST_DATA + file);
}
void Check() {
View it on GitLab: https://salsa.debian.org/med-team/libbioparser-dev/-/commit/b9a7fc37f5966c04b893790f8d04cb92711e66c1
--
View it on GitLab: https://salsa.debian.org/med-team/libbioparser-dev/-/commit/b9a7fc37f5966c04b893790f8d04cb92711e66c1
You're receiving this email because of your account on salsa.debian.org.
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://alioth-lists.debian.net/pipermail/debian-med-commit/attachments/20240322/7c434545/attachment-0001.htm>
More information about the debian-med-commit
mailing list