Skip to content
C_RAW_API.cpp 61.8 KiB
Newer Older
Luker's avatar
Luker committed
/*
Luker's avatar
Luker committed
 * Copyright (c) 2015-2018, Luca Fulchir<luca@fulchir.it>, All rights reserved.
Luker's avatar
Luker committed
 *
 * This file is part of "libRaptorQ".
 *
 * libRaptorQ is free software: you can redistribute it and/or modify
 * it under the terms of the GNU Lesser General Public License as
 * published by the Free Software Foundation, either version 3
 * of the License, or (at your option) any later version.
 *
 * libRaptorQ is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * and a copy of the GNU Lesser General Public License
 * along with libRaptorQ.  If not, see <http://www.gnu.org/licenses/>.
 */


#include "RaptorQ/v1/wrapper/C_RAW_API.h"
#include "RaptorQ/v1/RaptorQ.hpp"
#include <future>
#include <utility>

struct RAPTORQ_LOCAL RaptorQ_ptr
{
Luker's avatar
Luker committed
    void *const ptr;
Luker's avatar
Luker committed
    const RaptorQ_type type;

Luker's avatar
Luker committed
    RaptorQ_ptr ()
        : ptr (nullptr), type (RaptorQ_type::RQ_NONE) {}
    RaptorQ_ptr (const RaptorQ_type _type, void *const _ptr)
        : ptr (_ptr), type (_type) {}
Luker's avatar
Luker committed
};


typedef enum {
Luker's avatar
Luker committed
    RQ_FUTURE_ENCODER = 1,
    RQ_FUTURE_DECODER = 2
Luker's avatar
Luker committed
} RAPTORQ_LOCAL RaptorQ_Future_Type;

struct RAPTORQ_LOCAL RaptorQ_future
{
    const RaptorQ_Future_Type type;
    RaptorQ_future (const RaptorQ_Future_Type t)
        :type (t) {}
};
Luker's avatar
Luker committed
struct RAPTORQ_LOCAL RaptorQ_future_enc
{
    const struct RaptorQ_future base;
Luker's avatar
Luker committed
    std::shared_future<RaptorQ__v1::Error> f;
Luker's avatar
Luker committed
    RaptorQ_future_enc ()
        :base (RaptorQ_Future_Type::RQ_FUTURE_ENCODER) {}
};
Luker's avatar
Luker committed
struct RAPTORQ_LOCAL RaptorQ_future_dec
{
    const struct RaptorQ_future base;
Luker's avatar
Luker committed
    std::future<struct RaptorQ__v1::Decoder_wait_res> f;
Luker's avatar
Luker committed
    RaptorQ_future_dec ()
        :base (RaptorQ_Future_Type::RQ_FUTURE_DECODER) {}
};


Luker's avatar
Luker committed
////////////////////////
////
//// For ease of development please keep the function declaration
//// and implementation in the same orders as defined in the structs!
////
////////////////////////

Luker's avatar
Luker committed
// precomputation caching
Luker's avatar
Luker committed
static RaptorQ_Compress v1_supported_compressions();
static RaptorQ_Compress v1_get_compression();
Luker's avatar
Luker committed
static bool v1_set_compression (const RaptorQ_Compress compression);
Luker's avatar
Luker committed
static size_t v1_local_cache_size (const size_t local_cache);
static size_t v1_get_local_cache_size ();
Luker's avatar
Luker committed
// constructors
Luker's avatar
Luker committed
static struct RaptorQ_ptr* v1_Encoder (RaptorQ_type type,
Luker's avatar
Luker committed
                                            const RaptorQ_Block_Size symbols,
Luker's avatar
Luker committed
                                            const size_t symbol_size);
Luker's avatar
Luker committed
static struct RaptorQ_ptr* v1_Decoder (RaptorQ_type type,
Luker's avatar
Luker committed
                                            const RaptorQ_Block_Size symbols,
                                            const size_t symbol_size,
Luker's avatar
Luker committed
                                            const RQ_Dec_Report report);
Luker's avatar
Luker committed
static bool v1_initialized (const RaptorQ_ptr *ptr);
Luker's avatar
Luker committed
// common functions
Luker's avatar
Luker committed
static uint16_t v1_symbols (const RaptorQ_ptr *ptr);
static size_t v1_symbol_size (const RaptorQ_ptr *ptr);
static void v1_stop (const RaptorQ_ptr *ptr);
Luker's avatar
Luker committed
static RaptorQ_Error v1_future_state (struct RaptorQ_future *const f);
static RaptorQ_Error v1_future_wait_for (struct RaptorQ_future *const f,
Luker's avatar
Luker committed
                                                const uint64_t time,
                                                const RaptorQ_Unit_Time unit);
Luker's avatar
Luker committed
static void v1_future_wait (struct RaptorQ_future *const f);
Luker's avatar
Luker committed
static void v1_future_free (struct RaptorQ_future **f);
static void v1_free (struct RaptorQ_ptr **ptr);
static bool v1_ready (const RaptorQ_ptr *ptr);
Luker's avatar
Luker committed

// encoder-specific
Luker's avatar
Luker committed
static uint32_t v1_max_repair  (const RaptorQ_ptr *enc);
Luker's avatar
Luker committed
static size_t v1_set_data (const RaptorQ_ptr *enc, void **from,
                                                            const size_t size);
Luker's avatar
Luker committed
static bool v1_has_data (const RaptorQ_ptr *enc);
Luker's avatar
Luker committed
static void v1_clear_data (const RaptorQ_ptr *ptr);
Luker's avatar
Luker committed
static bool v1_precompute_sync (const RaptorQ_ptr *enc);
static bool v1_compute_sync (const RaptorQ_ptr *enc);
static RaptorQ_future_enc* v1_precompute (const RaptorQ_ptr *enc);
static RaptorQ_future_enc* v1_compute (const RaptorQ_ptr *enc);
Luker's avatar
Luker committed
static RaptorQ_Error v1_enc_future_get (struct RaptorQ_future_enc *f);
static size_t v1_encode (const RaptorQ_ptr *enc, void **from, const size_t size,
                                                            const uint32_t id);
Luker's avatar
Luker committed

// decoder-specific
Luker's avatar
Luker committed
static RaptorQ_Error v1_add_symbol (const RaptorQ_ptr *dec, void **from,
                                                            const size_t size,
Luker's avatar
Luker committed
                                                            const uint32_t esi);
Luker's avatar
Luker committed
static bool v1_can_decode (const RaptorQ_ptr *dec);
static uint16_t v1_needed_symbols (const RaptorQ_ptr *dec);
Luker's avatar
Luker committed
static RaptorQ_Dec_wait_res v1_poll (const RaptorQ_ptr *dec);
static RaptorQ_Dec_wait_res v1_wait_sync (const RaptorQ_ptr *dec);
Luker's avatar
Luker committed
static RaptorQ_future_dec* v1_wait (const RaptorQ_ptr *dec);
Luker's avatar
Luker committed
static RaptorQ_Dec_wait_res v1_dec_future_get (struct RaptorQ_future_dec *f);
static struct RaptorQ_Byte_Tracker v1_end_of_input (struct RaptorQ_ptr *dec,
                                            const RaptorQ_Fill_With_Zeros fill);
static RaptorQ_Decoder_Result v1_decode_once (struct RaptorQ_ptr *dec);
Luker's avatar
Luker committed
static RaptorQ_Error v1_decode_symbol (struct RaptorQ_ptr *dec, void** start,
                                        const size_t size, const uint16_t esi);
static RaptorQ_Dec_Written v1_decode_bytes (struct RaptorQ_ptr *dec,
                                                        void **start,
                                                        const size_t size,
                                                        const size_t from_byte,
                                                        const size_t skip);
Luker's avatar
Luker committed
void RaptorQ_free_api (struct RaptorQ_base_api **api)
{
    if (api == nullptr || *api == nullptr)
        return;
    if ((*api)->version == 1) {
        delete reinterpret_cast<struct RaptorQ_v1*> (*api);
    } // else it's all your fault anway
    *api = nullptr;
}
Luker's avatar
Luker committed

Luker's avatar
Luker committed
struct RaptorQ_base_api* RaptorQ_api (uint32_t version)
Luker's avatar
Luker committed
{
    if (version != 1)
        return nullptr;
Luker's avatar
Luker committed
    return reinterpret_cast<RaptorQ_base_api*> (new RaptorQ_v1());
}

RaptorQ_v1::RaptorQ_v1()
    : base (1),
Luker's avatar
Luker committed

    // precomputation caching
Luker's avatar
Luker committed
    supported_compressions (&v1_supported_compressions),
    get_compression (&v1_get_compression),
    set_compression (&v1_set_compression),
    local_cache_size (&v1_local_cache_size),
    get_local_cache_size (&v1_get_local_cache_size),
Luker's avatar
Luker committed

    // constructors
Luker's avatar
Luker committed
    Encoder (&v1_Encoder),
    Decoder (&v1_Decoder),
    initialized (&v1_initialized),
Luker's avatar
Luker committed

    // common functions
Luker's avatar
Luker committed
    symbols (&v1_symbols),
    symbol_size (&v1_symbol_size),
    stop (&v1_stop),
    future_state (&v1_future_state),
    future_wait_for (&v1_future_wait_for),
    future_wait (&v1_future_wait),
    future_free (&v1_future_free),
    free (&v1_free),
    ready (&v1_ready),
Luker's avatar
Luker committed

    // encoder-specific functions
Luker's avatar
Luker committed
    max_repair (&v1_max_repair),
    set_data (&v1_set_data),
    has_data (&v1_has_data),
    clear_data (&v1_clear_data),
    precompute_sync (&v1_precompute_sync),
    compute_sync (&v1_compute_sync),
    precompute (&v1_precompute),
    compute (&v1_compute),
    enc_future_get (&v1_enc_future_get),
    encode (&v1_encode),
Luker's avatar
Luker committed

    // decoder-specific functions
Luker's avatar
Luker committed
    add_symbol (&v1_add_symbol),
    can_decode (&v1_can_decode),
    needed_symbols (&v1_needed_symbols),
    poll (&v1_poll),
    wait_sync (&v1_wait_sync),
    wait (&v1_wait),
Luker's avatar
Luker committed
    dec_future_get (&v1_dec_future_get),
    end_of_input (&v1_end_of_input),
    decode_once (&v1_decode_once),
Luker's avatar
Luker committed
    decode_symbol (&v1_decode_symbol),
    decode_bytes (&v1_decode_bytes)
Luker's avatar
Luker committed
{}
Luker's avatar
Luker committed

///////////////////////////
// Precomputation caching
///////////////////////////

static RaptorQ_Compress v1_supported_compressions()
{
Luker's avatar
Luker committed
    return static_cast<RaptorQ_Compress>(RaptorQ__v1::supported_compressions());
Luker's avatar
Luker committed
}

static RaptorQ_Compress v1_get_compression()
    { return static_cast<RaptorQ_Compress>(RaptorQ__v1::get_compression()); }

static bool v1_set_compression (const RaptorQ_Compress compression)
{
Luker's avatar
Luker committed
    return static_cast<RaptorQ_Compress> (RaptorQ__v1::set_compression (
                            static_cast<RaptorQ__v1::Compress> (compression)));
Luker's avatar
Luker committed
}

static size_t v1_local_cache_size (const size_t local_cache)
    { return RaptorQ__v1::local_cache_size (local_cache); }

static size_t v1_get_local_cache_size ()
Luker's avatar
Luker committed
    { return RFC6330__v1::get_local_cache_size(); }
Luker's avatar
Luker committed


/////////////////////
// Constructors
/////////////////////

Luker's avatar
Luker committed
static struct RaptorQ_ptr* v1_Encoder (RaptorQ_type type,
Luker's avatar
Luker committed
                                            const RaptorQ_Block_Size symbols,
Luker's avatar
Luker committed
                                            const size_t symbol_size)
{
Luker's avatar
Luker committed
    void *raw_ptr = nullptr;
Luker's avatar
Luker committed
    switch (type) {
Luker's avatar
Luker committed
    case RaptorQ_type::RQ_ENC_8:
Luker's avatar
Luker committed
        raw_ptr = reinterpret_cast<void *> (
Luker's avatar
Luker committed
                    new RaptorQ__v1::Impl::Encoder<uint8_t*, uint8_t*> (
Luker's avatar
Luker committed
                                static_cast<RaptorQ__v1::Block_Size>(symbols),
Luker's avatar
Luker committed
                                                                symbol_size));
Luker's avatar
Luker committed
        break;
    case RaptorQ_type::RQ_ENC_16:
Luker's avatar
Luker committed
        raw_ptr = reinterpret_cast<void *> (
Luker's avatar
Luker committed
                    new RaptorQ__v1::Impl::Encoder<uint16_t*, uint16_t*> (
Luker's avatar
Luker committed
                                static_cast<RaptorQ__v1::Block_Size>(symbols),
Luker's avatar
Luker committed
                                                                symbol_size));
Luker's avatar
Luker committed
        break;
    case RaptorQ_type::RQ_ENC_32:
Luker's avatar
Luker committed
        raw_ptr = reinterpret_cast<void *> (
Luker's avatar
Luker committed
                    new RaptorQ__v1::Impl::Encoder<uint32_t*, uint32_t*> (
Luker's avatar
Luker committed
                                static_cast<RaptorQ__v1::Block_Size>(symbols),
Luker's avatar
Luker committed
                                                                symbol_size));
Luker's avatar
Luker committed
        break;
    case RaptorQ_type::RQ_ENC_64:
Luker's avatar
Luker committed
        raw_ptr = reinterpret_cast<void *> (
Luker's avatar
Luker committed
                    new RaptorQ__v1::Impl::Encoder<uint64_t*, uint64_t*> (
Luker's avatar
Luker committed
                                static_cast<RaptorQ__v1::Block_Size>(symbols),
Luker's avatar
Luker committed
                                                                symbol_size));
Luker's avatar
Luker committed
        break;
    case RaptorQ_type::RQ_DEC_8:
    case RaptorQ_type::RQ_DEC_16:
    case RaptorQ_type::RQ_DEC_32:
    case RaptorQ_type::RQ_DEC_64:
    case RaptorQ_type::RQ_NONE:
Luker's avatar
Luker committed
        return nullptr;
Luker's avatar
Luker committed
    }
Luker's avatar
Luker committed
    if (raw_ptr == nullptr)
Luker's avatar
Luker committed
        return nullptr;
Luker's avatar
Luker committed
    return new RaptorQ_ptr (type, raw_ptr);
Luker's avatar
Luker committed
}

Luker's avatar
Luker committed
static struct RaptorQ_ptr* v1_Decoder (RaptorQ_type type,
Luker's avatar
Luker committed
                                            const RaptorQ_Block_Size symbols,
                                            const size_t symbol_size,
Luker's avatar
Luker committed
                                            const RQ_Dec_Report report)
Luker's avatar
Luker committed
{
    const auto _report = static_cast<RFC6330_Compute> (report);
    if (_report != RQ_COMPUTE_PARTIAL_FROM_BEGINNING &&
        _report != RQ_COMPUTE_PARTIAL_ANY &&
        _report != RQ_COMPUTE_COMPLETE) {
Luker's avatar
Luker committed
        return nullptr;
    }

Luker's avatar
Luker committed
    void *raw_ptr = nullptr;
Luker's avatar
Luker committed
    namespace RQ = RaptorQ__v1::Impl;
    switch (type) {
Luker's avatar
Luker committed
    case RaptorQ_type::RQ_DEC_8:
Luker's avatar
Luker committed
        raw_ptr = reinterpret_cast<void *> (
                            new RQ::Decoder<uint8_t*, uint8_t*> (
                                static_cast<RaptorQ__v1::Block_Size>(symbols),
                                symbol_size,
Luker's avatar
Luker committed
                                static_cast<RaptorQ__v1::Dec_Report> (report)));
Luker's avatar
Luker committed
        break;
    case RaptorQ_type::RQ_DEC_16:
Luker's avatar
Luker committed
        raw_ptr = reinterpret_cast<void *> (
                            new RQ::Decoder<uint16_t*, uint16_t*> (
                                static_cast<RaptorQ__v1::Block_Size>(symbols),
                                symbol_size,
Luker's avatar
Luker committed
                                static_cast<RaptorQ__v1::Dec_Report> (report)));
Luker's avatar
Luker committed
        break;
    case RaptorQ_type::RQ_DEC_32:
Luker's avatar
Luker committed
        raw_ptr = reinterpret_cast<void *> (
                            new RQ::Decoder<uint32_t*, uint32_t*> (
                                static_cast<RaptorQ__v1::Block_Size>(symbols),
                                symbol_size,
Luker's avatar
Luker committed
                                static_cast<RaptorQ__v1::Dec_Report> (report)));
Luker's avatar
Luker committed
        break;
    case RaptorQ_type::RQ_DEC_64:
Luker's avatar
Luker committed
        raw_ptr = reinterpret_cast<void *> (
                            new RQ::Decoder<uint64_t*, uint64_t*> (
                                static_cast<RaptorQ__v1::Block_Size>(symbols),
                                symbol_size,
Luker's avatar
Luker committed
                                static_cast<RaptorQ__v1::Dec_Report> (report)));
Luker's avatar
Luker committed
        break;
    case RaptorQ_type::RQ_ENC_8:
    case RaptorQ_type::RQ_ENC_16:
    case RaptorQ_type::RQ_ENC_32:
    case RaptorQ_type::RQ_ENC_64:
    case RaptorQ_type::RQ_NONE:
Luker's avatar
Luker committed
        return nullptr;
Luker's avatar
Luker committed
    }
Luker's avatar
Luker committed
    if (raw_ptr == nullptr)
Luker's avatar
Luker committed
        return nullptr;
Luker's avatar
Luker committed
    return new RaptorQ_ptr (type, raw_ptr);
Luker's avatar
Luker committed
}

Luker's avatar
Luker committed
static bool v1_initialized (const RaptorQ_ptr *ptr)
Luker's avatar
Luker committed
{
    if (ptr == nullptr || ptr->ptr == nullptr)
Luker's avatar
Luker committed
        return false;
Luker's avatar
Luker committed
    switch (ptr->type) {
    case RaptorQ_type::RQ_ENC_8:
Luker's avatar
Luker committed
        return static_cast<bool> (*reinterpret_cast<const
Luker's avatar
Luker committed
                            RaptorQ__v1::Impl::Encoder<uint8_t*, uint8_t*>*> (
                                                                    ptr->ptr));
    case RaptorQ_type::RQ_ENC_16:
Luker's avatar
Luker committed
        return static_cast<bool> (*reinterpret_cast<const
Luker's avatar
Luker committed
                            RaptorQ__v1::Impl::Encoder<uint16_t*, uint16_t*>*> (
                                                                    ptr->ptr));
    case RaptorQ_type::RQ_ENC_32:
Luker's avatar
Luker committed
        return static_cast<bool> (*reinterpret_cast<const
Luker's avatar
Luker committed
                            RaptorQ__v1::Impl::Encoder<uint32_t*, uint32_t*>*> (
                                                                    ptr->ptr));
    case RaptorQ_type::RQ_ENC_64:
Luker's avatar
Luker committed
        return static_cast<bool> (*reinterpret_cast<const
Luker's avatar
Luker committed
                            RaptorQ__v1::Impl::Encoder<uint64_t*, uint64_t*>*> (
                                                                    ptr->ptr));
    case RaptorQ_type::RQ_DEC_8:
Luker's avatar
Luker committed
        return static_cast<bool> (*reinterpret_cast<const
Luker's avatar
Luker committed
                            RaptorQ__v1::Impl::Decoder<uint8_t*, uint8_t*>*> (
                                                                    ptr->ptr));
    case RaptorQ_type::RQ_DEC_16:
Luker's avatar
Luker committed
        return static_cast<bool> (*reinterpret_cast<const
Luker's avatar
Luker committed
                            RaptorQ__v1::Impl::Decoder<uint16_t*, uint16_t*>*> (
                                                                    ptr->ptr));
    case RaptorQ_type::RQ_DEC_32:
Luker's avatar
Luker committed
        return static_cast<bool> (*reinterpret_cast<const
Luker's avatar
Luker committed
                            RaptorQ__v1::Impl::Decoder<uint32_t*, uint32_t*>*> (
                                                                    ptr->ptr));
    case RaptorQ_type::RQ_DEC_64:
Luker's avatar
Luker committed
        return static_cast<bool> (*reinterpret_cast<const
Luker's avatar
Luker committed
                            RaptorQ__v1::Impl::Decoder<uint64_t*, uint64_t*>*> (
                                                                    ptr->ptr));
    case RaptorQ_type::RQ_NONE:
        break;
    }
Luker's avatar
Luker committed
    return false;
Luker's avatar
Luker committed

/////////////////////
// Common functions
/////////////////////


static uint16_t v1_symbols (const RaptorQ_ptr *ptr)
{
    if (ptr == nullptr || ptr->ptr == nullptr)
Luker's avatar
Luker committed
        return 0;
    switch (ptr->type) {
    case RaptorQ_type::RQ_ENC_8:
Luker's avatar
Luker committed
        return (reinterpret_cast<const
Luker's avatar
Luker committed
                            RaptorQ__v1::Impl::Encoder<uint8_t*, uint8_t*>*> (
                                                        ptr->ptr))->symbols();
Luker's avatar
Luker committed
    case RaptorQ_type::RQ_ENC_16:
Luker's avatar
Luker committed
        return (reinterpret_cast<const
Luker's avatar
Luker committed
                            RaptorQ__v1::Impl::Encoder<uint16_t*, uint16_t*>*> (
                                                        ptr->ptr))->symbols();
Luker's avatar
Luker committed
    case RaptorQ_type::RQ_ENC_32:
Luker's avatar
Luker committed
        return (reinterpret_cast<const
Luker's avatar
Luker committed
                            RaptorQ__v1::Impl::Encoder<uint32_t*, uint32_t*>*> (
                                                        ptr->ptr))->symbols();
Luker's avatar
Luker committed
    case RaptorQ_type::RQ_ENC_64:
Luker's avatar
Luker committed
        return (reinterpret_cast<const
Luker's avatar
Luker committed
                            RaptorQ__v1::Impl::Encoder<uint64_t*, uint64_t*>*> (
                                                        ptr->ptr))->symbols();
Luker's avatar
Luker committed
    case RaptorQ_type::RQ_DEC_8:
Luker's avatar
Luker committed
        return (reinterpret_cast<const
Luker's avatar
Luker committed
                            RaptorQ__v1::Impl::Decoder<uint8_t*, uint8_t*>*> (
                                                        ptr->ptr))->symbols();
Luker's avatar
Luker committed
    case RaptorQ_type::RQ_DEC_16:
Luker's avatar
Luker committed
        return (reinterpret_cast<const
Luker's avatar
Luker committed
                            RaptorQ__v1::Impl::Decoder<uint16_t*, uint16_t*>*> (
                                                        ptr->ptr))->symbols();
Luker's avatar
Luker committed
    case RaptorQ_type::RQ_DEC_32:
Luker's avatar
Luker committed
        return (reinterpret_cast<const
Luker's avatar
Luker committed
                            RaptorQ__v1::Impl::Decoder<uint32_t*, uint32_t*>*> (
                                                        ptr->ptr))->symbols();
Luker's avatar
Luker committed
    case RaptorQ_type::RQ_DEC_64:
Luker's avatar
Luker committed
        return (reinterpret_cast<const
Luker's avatar
Luker committed
                            RaptorQ__v1::Impl::Decoder<uint64_t*, uint64_t*>*> (
                                                        ptr->ptr))->symbols();
Luker's avatar
Luker committed
    case RaptorQ_type::RQ_NONE:
Luker's avatar
Luker committed
        break;
Luker's avatar
Luker committed
    }
Luker's avatar
Luker committed
    return 0;
}

static size_t v1_symbol_size (const RaptorQ_ptr *ptr)
{
    if (ptr == nullptr || ptr->ptr == nullptr)
Luker's avatar
Luker committed
        return 0;
    switch (ptr->type) {
    case RaptorQ_type::RQ_ENC_8:
Luker's avatar
Luker committed
        return (reinterpret_cast<const
Luker's avatar
Luker committed
                            RaptorQ__v1::Impl::Encoder<uint8_t*, uint8_t*>*> (
                                                    ptr->ptr))->symbol_size();
Luker's avatar
Luker committed
    case RaptorQ_type::RQ_ENC_16:
Luker's avatar
Luker committed
        return (reinterpret_cast<const
Luker's avatar
Luker committed
                            RaptorQ__v1::Impl::Encoder<uint16_t*, uint16_t*>*> (
                                                    ptr->ptr))->symbol_size();
Luker's avatar
Luker committed
    case RaptorQ_type::RQ_ENC_32:
Luker's avatar
Luker committed
        return (reinterpret_cast<const
Luker's avatar
Luker committed
                            RaptorQ__v1::Impl::Encoder<uint32_t*, uint32_t*>*> (
                                                    ptr->ptr))->symbol_size();
Luker's avatar
Luker committed
    case RaptorQ_type::RQ_ENC_64:
Luker's avatar
Luker committed
        return (reinterpret_cast<const
Luker's avatar
Luker committed
                            RaptorQ__v1::Impl::Encoder<uint64_t*, uint64_t*>*> (
                                                    ptr->ptr))->symbol_size();
Luker's avatar
Luker committed
    case RaptorQ_type::RQ_DEC_8:
Luker's avatar
Luker committed
        return (reinterpret_cast<const
Luker's avatar
Luker committed
                            RaptorQ__v1::Impl::Decoder<uint8_t*, uint8_t*>*> (
                                                    ptr->ptr))->symbol_size();
Luker's avatar
Luker committed
    case RaptorQ_type::RQ_DEC_16:
Luker's avatar
Luker committed
        return (reinterpret_cast<const
Luker's avatar
Luker committed
                            RaptorQ__v1::Impl::Decoder<uint16_t*, uint16_t*>*> (
                                                    ptr->ptr))->symbol_size();
Luker's avatar
Luker committed
    case RaptorQ_type::RQ_DEC_32:
Luker's avatar
Luker committed
        return (reinterpret_cast<const
Luker's avatar
Luker committed
                            RaptorQ__v1::Impl::Decoder<uint32_t*, uint32_t*>*> (
                                                    ptr->ptr))->symbol_size();
Luker's avatar
Luker committed
    case RaptorQ_type::RQ_DEC_64:
Luker's avatar
Luker committed
        return (reinterpret_cast<const
Luker's avatar
Luker committed
                            RaptorQ__v1::Impl::Decoder<uint64_t*, uint64_t*>*> (
                                                    ptr->ptr))->symbol_size();
Luker's avatar
Luker committed
    case RaptorQ_type::RQ_NONE:
Luker's avatar
Luker committed
        break;
Luker's avatar
Luker committed
    }
Luker's avatar
Luker committed
    return 0;
}

static void v1_stop (const RaptorQ_ptr *ptr)
{
    if (ptr == nullptr || ptr->ptr == nullptr)
        return;
    switch (ptr->type) {
    case RaptorQ_type::RQ_ENC_8:
        return (reinterpret_cast<
                            RaptorQ__v1::Impl::Encoder<uint8_t*, uint8_t*>*> (
                                                            ptr->ptr))->stop();
    case RaptorQ_type::RQ_ENC_16:
        return (reinterpret_cast<
                            RaptorQ__v1::Impl::Encoder<uint16_t*, uint16_t*>*> (
                                                            ptr->ptr))->stop();
    case RaptorQ_type::RQ_ENC_32:
        return (reinterpret_cast<
                            RaptorQ__v1::Impl::Encoder<uint32_t*, uint32_t*>*> (
                                                            ptr->ptr))->stop();
    case RaptorQ_type::RQ_ENC_64:
        return (reinterpret_cast<
                            RaptorQ__v1::Impl::Encoder<uint64_t*, uint64_t*>*> (
                                                            ptr->ptr))->stop();
    case RaptorQ_type::RQ_DEC_8:
        return (reinterpret_cast<
                            RaptorQ__v1::Impl::Decoder<uint8_t*, uint8_t*>*> (
                                                            ptr->ptr))->stop();
    case RaptorQ_type::RQ_DEC_16:
        return (reinterpret_cast<
                            RaptorQ__v1::Impl::Decoder<uint16_t*, uint16_t*>*> (
                                                            ptr->ptr))->stop();
    case RaptorQ_type::RQ_DEC_32:
        return (reinterpret_cast<
                            RaptorQ__v1::Impl::Decoder<uint32_t*, uint32_t*>*> (
                                                            ptr->ptr))->stop();
    case RaptorQ_type::RQ_DEC_64:
        return (reinterpret_cast<
                            RaptorQ__v1::Impl::Decoder<uint64_t*, uint64_t*>*> (
                                                            ptr->ptr))->stop();
    case RaptorQ_type::RQ_NONE:
        break;
    }
}

Luker's avatar
Luker committed
static RaptorQ_Error v1_future_state (struct RaptorQ_future *const f)
Luker's avatar
Luker committed
{
    if (f == nullptr)
Luker's avatar
Luker committed
        return RaptorQ_Error::RQ_ERR_WRONG_INPUT;
Luker's avatar
Luker committed
    switch (f->type)
    {
    case RaptorQ_Future_Type::RQ_FUTURE_ENCODER:
Luker's avatar
Luker committed
        if (reinterpret_cast<const RaptorQ_future_enc*> (f)->f.valid()) {
            if (reinterpret_cast<const RaptorQ_future_enc*>(f)->f.wait_for (
                                            std::chrono::milliseconds (0)) ==
                                                std::future_status::ready) {
                return RaptorQ_Error::RQ_ERR_NONE; // ready
            }
            return RaptorQ_Error::RQ_ERR_WORKING; // still working
        }
Luker's avatar
Luker committed
        break;
    case RaptorQ_Future_Type::RQ_FUTURE_DECODER:
Luker's avatar
Luker committed
        if (reinterpret_cast<const RaptorQ_future_dec*> (f)->f.valid()) {
            if (reinterpret_cast<const RaptorQ_future_dec*>(f)->f.wait_for (
                                            std::chrono::milliseconds (0)) ==
                                                std::future_status::ready) {
                return RaptorQ_Error::RQ_ERR_NONE; // ready
            }
            return RaptorQ_Error::RQ_ERR_WORKING; // still working
        }
Luker's avatar
Luker committed
    }
Luker's avatar
Luker committed
    // future not valid
Luker's avatar
Luker committed
    return RaptorQ_Error::RQ_ERR_NOT_NEEDED;
Luker's avatar
Luker committed
}

Luker's avatar
Luker committed
static RaptorQ_Error v1_future_wait_for (struct RaptorQ_future *const f,
Luker's avatar
Luker committed
                                                const uint64_t time,
                                                const RaptorQ_Unit_Time unit)
{
    if (f == nullptr)
Luker's avatar
Luker committed
        return RQ_ERR_WRONG_INPUT;
    std::future_status status = std::future_status::timeout;
    switch (unit) {
    case RQ_TIME_NANOSEC:
Luker's avatar
Luker committed
        switch (f->type)
        {
        case RaptorQ_Future_Type::RQ_FUTURE_ENCODER:
Luker's avatar
Luker committed
            status = reinterpret_cast<const RaptorQ_future_enc*>(f)->f.wait_for (
Luker's avatar
Luker committed
                                            std::chrono::nanoseconds (time));
            break;
        case RaptorQ_Future_Type::RQ_FUTURE_DECODER:
Luker's avatar
Luker committed
            status = reinterpret_cast<const RaptorQ_future_dec*>(f)->f.wait_for (
Luker's avatar
Luker committed
                                            std::chrono::nanoseconds (time));
        }
Luker's avatar
Luker committed
        break;
    case RQ_TIME_MICROSEC:
Luker's avatar
Luker committed
        switch (f->type)
        {
        case RaptorQ_Future_Type::RQ_FUTURE_ENCODER:
Luker's avatar
Luker committed
            status = reinterpret_cast<const RaptorQ_future_enc*>(f)->f.wait_for (
Luker's avatar
Luker committed
                                            std::chrono::microseconds (time));
            break;
        case RaptorQ_Future_Type::RQ_FUTURE_DECODER:
Luker's avatar
Luker committed
            status = reinterpret_cast<const RaptorQ_future_dec*>(f)->f.wait_for (
Luker's avatar
Luker committed
                                            std::chrono::microseconds (time));
        }
Luker's avatar
Luker committed
        break;
    case RQ_TIME_MILLISEC:
Luker's avatar
Luker committed
        switch (f->type)
        {
        case RaptorQ_Future_Type::RQ_FUTURE_ENCODER:
Luker's avatar
Luker committed
            status = reinterpret_cast<const RaptorQ_future_enc*>(f)->f.wait_for (
Luker's avatar
Luker committed
                                            std::chrono::milliseconds (time));
            break;
        case RaptorQ_Future_Type::RQ_FUTURE_DECODER:
Luker's avatar
Luker committed
            status = reinterpret_cast<const RaptorQ_future_dec*>(f)->f.wait_for (
Luker's avatar
Luker committed
                                            std::chrono::milliseconds (time));
        }
Luker's avatar
Luker committed
        break;
    case RQ_TIME_SEC:
Luker's avatar
Luker committed
        switch (f->type)
        {
        case RaptorQ_Future_Type::RQ_FUTURE_ENCODER:
Luker's avatar
Luker committed
            status = reinterpret_cast<const RaptorQ_future_enc*>(f)->f.wait_for (
Luker's avatar
Luker committed
                                                std::chrono::seconds (time));
            break;
        case RaptorQ_Future_Type::RQ_FUTURE_DECODER:
Luker's avatar
Luker committed
            status = reinterpret_cast<const RaptorQ_future_dec*>(f)->f.wait_for (
Luker's avatar
Luker committed
                                                std::chrono::seconds (time));
        }
Luker's avatar
Luker committed
        break;
    case RQ_TIME_MIN:
Luker's avatar
Luker committed
        switch (f->type)
        {
        case RaptorQ_Future_Type::RQ_FUTURE_ENCODER:
Luker's avatar
Luker committed
            status = reinterpret_cast<const RaptorQ_future_enc*>(f)->f.wait_for (
Luker's avatar
Luker committed
                                                std::chrono::minutes (time));
            break;
        case RaptorQ_Future_Type::RQ_FUTURE_DECODER:
Luker's avatar
Luker committed
            status = reinterpret_cast<const RaptorQ_future_dec*>(f)->f.wait_for (
Luker's avatar
Luker committed
                                                std::chrono::minutes (time));
        }
Luker's avatar
Luker committed
        break;
    case RQ_TIME_HOUR:
Luker's avatar
Luker committed
        switch (f->type)
        {
        case RaptorQ_Future_Type::RQ_FUTURE_ENCODER:
Luker's avatar
Luker committed
            status = reinterpret_cast<const RaptorQ_future_enc*>(f)->f.wait_for (
Luker's avatar
Luker committed
                                                    std::chrono::hours (time));
            break;
        case RaptorQ_Future_Type::RQ_FUTURE_DECODER:
Luker's avatar
Luker committed
            status = reinterpret_cast<const RaptorQ_future_dec*>(f)->f.wait_for (
Luker's avatar
Luker committed
                                                    std::chrono::hours (time));
        }
Luker's avatar
Luker committed
        break;
    }
    if (status == std::future_status::ready)
        return RaptorQ_Error::RQ_ERR_NONE;
    return RaptorQ_Error::RQ_ERR_WORKING;
Luker's avatar
Luker committed
}

Luker's avatar
Luker committed
static void v1_future_wait (struct RaptorQ_future *const f)
Luker's avatar
Luker committed
{
    if (f == nullptr)
Luker's avatar
Luker committed
        return;
Luker's avatar
Luker committed
    switch (f->type)
    {
    case RaptorQ_Future_Type::RQ_FUTURE_ENCODER:
Luker's avatar
Luker committed
        reinterpret_cast<const RaptorQ_future_enc*>(f)->f.wait();
Luker's avatar
Luker committed
        break;
    case RaptorQ_Future_Type::RQ_FUTURE_DECODER:
Luker's avatar
Luker committed
        reinterpret_cast<const RaptorQ_future_dec*>(f)->f.wait();
Luker's avatar
Luker committed
    }
}

static void v1_future_free (struct RaptorQ_future **f)
{
    if (f == nullptr || *f == nullptr)
Luker's avatar
Luker committed
        return;
Luker's avatar
Luker committed
    switch ((*f)->type) {
    case RaptorQ_Future_Type::RQ_FUTURE_ENCODER:
        delete reinterpret_cast<RaptorQ_future_enc*>(*f);
        break;
    case RaptorQ_Future_Type::RQ_FUTURE_DECODER:
        delete reinterpret_cast<RaptorQ_future_dec*>(*f);
    }
Luker's avatar
Luker committed
    *f = nullptr;
Luker's avatar
Luker committed
}

Luker's avatar
Luker committed
static void v1_free (struct RaptorQ_ptr **ptr)
{
    if (ptr == nullptr || *ptr == nullptr)
        return;
    if ((*ptr)->ptr == nullptr) {
        delete *ptr;
Luker's avatar
Luker committed
        *ptr = nullptr;
Luker's avatar
Luker committed
        return;
    }
    switch ((*ptr)->type) {
    case RaptorQ_type::RQ_ENC_8:
        delete reinterpret_cast<
                RaptorQ__v1::Impl::Encoder<uint8_t*, uint8_t*>*> ((*ptr)->ptr);
        break;
    case RaptorQ_type::RQ_ENC_16:
        delete reinterpret_cast<
                RaptorQ__v1::Impl::Encoder<uint16_t*, uint16_t*>*>((*ptr)->ptr);
        break;
    case RaptorQ_type::RQ_ENC_32:
        delete reinterpret_cast<
                RaptorQ__v1::Impl::Encoder<uint32_t*, uint32_t*>*>((*ptr)->ptr);
        break;
    case RaptorQ_type::RQ_ENC_64:
        delete reinterpret_cast<
                RaptorQ__v1::Impl::Encoder<uint64_t*, uint64_t*>*>((*ptr)->ptr);
        break;
    case RaptorQ_type::RQ_DEC_8:
        delete reinterpret_cast<
                RaptorQ__v1::Impl::Decoder<uint8_t*, uint8_t*>*> ((*ptr)->ptr);
        break;
    case RaptorQ_type::RQ_DEC_16:
        delete reinterpret_cast<
                RaptorQ__v1::Impl::Decoder<uint16_t*, uint16_t*>*>((*ptr)->ptr);
        break;
    case RaptorQ_type::RQ_DEC_32:
        delete reinterpret_cast<
                RaptorQ__v1::Impl::Decoder<uint32_t*, uint32_t*>*>((*ptr)->ptr);
        break;
    case RaptorQ_type::RQ_DEC_64:
        delete reinterpret_cast<
                RaptorQ__v1::Impl::Decoder<uint64_t*, uint64_t*>*>((*ptr)->ptr);
        break;
    case RaptorQ_type::RQ_NONE:
        break;
    }
Luker's avatar
Luker committed
    delete *ptr;
    *ptr = nullptr;
Luker's avatar
Luker committed
}

static bool v1_ready (const RaptorQ_ptr *ptr)
{
    if (ptr == nullptr || ptr->ptr == nullptr)
        return false;
    switch (ptr->type) {
    case RaptorQ_type::RQ_ENC_8:
        return static_cast<bool> (reinterpret_cast<const
                            RaptorQ__v1::Impl::Encoder<uint8_t*, uint8_t*>*> (
                                                            ptr->ptr)->ready());
    case RaptorQ_type::RQ_ENC_16:
        return static_cast<bool> (reinterpret_cast<const
                            RaptorQ__v1::Impl::Encoder<uint16_t*, uint16_t*>*> (
                                                            ptr->ptr)->ready());
    case RaptorQ_type::RQ_ENC_32:
        return static_cast<bool> (reinterpret_cast<const
                            RaptorQ__v1::Impl::Encoder<uint32_t*, uint32_t*>*> (
                                                            ptr->ptr)->ready());
    case RaptorQ_type::RQ_ENC_64:
        return static_cast<bool> (reinterpret_cast<const
                            RaptorQ__v1::Impl::Encoder<uint64_t*, uint64_t*>*> (
                                                            ptr->ptr)->ready());
    case RaptorQ_type::RQ_DEC_8:
        return static_cast<bool> (reinterpret_cast<const
                            RaptorQ__v1::Impl::Decoder<uint8_t*, uint8_t*>*> (
                                                            ptr->ptr)->ready());
    case RaptorQ_type::RQ_DEC_16:
        return static_cast<bool> (reinterpret_cast<const
                            RaptorQ__v1::Impl::Decoder<uint16_t*, uint16_t*>*> (
                                                            ptr->ptr)->ready());
    case RaptorQ_type::RQ_DEC_32:
        return static_cast<bool> (reinterpret_cast<const
                            RaptorQ__v1::Impl::Decoder<uint32_t*, uint32_t*>*> (
                                                            ptr->ptr)->ready());
    case RaptorQ_type::RQ_DEC_64:
        return static_cast<bool> (reinterpret_cast<const
                            RaptorQ__v1::Impl::Decoder<uint64_t*, uint64_t*>*> (
                                                            ptr->ptr)->ready());
    case RaptorQ_type::RQ_NONE:
        break;
    }
    return false;
}

Luker's avatar
Luker committed
//////////////////////////////
// Encoder-specific functions
//////////////////////////////

static uint32_t v1_max_repair  (const RaptorQ_ptr *enc)
{
    if (enc == nullptr || enc->ptr == nullptr)
Luker's avatar
Luker committed
        return 0;
Luker's avatar
Luker committed
    switch (enc->type) {
Luker's avatar
Luker committed
    case RaptorQ_type::RQ_ENC_8:
Luker's avatar
Luker committed
        return (reinterpret_cast<const
Luker's avatar
Luker committed
                            RaptorQ__v1::Impl::Encoder<uint8_t*, uint8_t*>*> (
                                                    enc->ptr))->max_repair();
Luker's avatar
Luker committed
    case RaptorQ_type::RQ_ENC_16:
Luker's avatar
Luker committed
        return (reinterpret_cast<const
Luker's avatar
Luker committed
                            RaptorQ__v1::Impl::Encoder<uint16_t*, uint16_t*>*> (
                                                    enc->ptr))->max_repair();
Luker's avatar
Luker committed
    case RaptorQ_type::RQ_ENC_32:
Luker's avatar
Luker committed
        return (reinterpret_cast<const
Luker's avatar
Luker committed
                            RaptorQ__v1::Impl::Encoder<uint32_t*, uint32_t*>*> (
                                                    enc->ptr))->max_repair();
Luker's avatar
Luker committed
    case RaptorQ_type::RQ_ENC_64:
Luker's avatar
Luker committed
        return (reinterpret_cast<const
Luker's avatar
Luker committed
                            RaptorQ__v1::Impl::Encoder<uint64_t*, uint64_t*>*> (
                                                    enc->ptr))->max_repair();
Luker's avatar
Luker committed
    case RaptorQ_type::RQ_DEC_8:
    case RaptorQ_type::RQ_DEC_16:
    case RaptorQ_type::RQ_DEC_32:
    case RaptorQ_type::RQ_DEC_64:
    case RaptorQ_type::RQ_NONE:
Luker's avatar
Luker committed
        break;
Luker's avatar
Luker committed
    }
Luker's avatar
Luker committed
    return 0;
}

Luker's avatar
Luker committed
static size_t v1_set_data (const RaptorQ_ptr *enc, void **from,
                                                            const size_t size)
Luker's avatar
Luker committed
{
Luker's avatar
Luker committed
    if (enc == nullptr || enc->ptr == nullptr ||
                                        from == nullptr || *from == nullptr) {
Luker's avatar
Luker committed
        return 0;
Luker's avatar
Luker committed
    uint8_t *f_8 = reinterpret_cast<uint8_t*> (*from);
    uint16_t *f_16 = reinterpret_cast<uint16_t*> (*from);
    uint32_t *f_32 = reinterpret_cast<uint32_t*> (*from);
    uint64_t *f_64= reinterpret_cast<uint64_t*> (*from);
Luker's avatar
Luker committed
    size_t ret;
    switch (enc->type) {
Luker's avatar
Luker committed
    case RaptorQ_type::RQ_ENC_8:
        ret = reinterpret_cast<
Luker's avatar
Luker committed
                            RaptorQ__v1::Impl::Encoder<uint8_t*, uint8_t*>*> (
Luker's avatar
Luker committed
                                                enc->ptr)->set_data (f_8,
Luker's avatar
Luker committed
                                                                f_8 + size);
        *from = reinterpret_cast<void*> (f_8);
Luker's avatar
Luker committed
        return ret;
Luker's avatar
Luker committed
    case RaptorQ_type::RQ_ENC_16:
        ret = reinterpret_cast<
Luker's avatar
Luker committed
                            RaptorQ__v1::Impl::Encoder<uint16_t*, uint16_t*>*> (
Luker's avatar
Luker committed
                                                enc->ptr)->set_data (f_16,
Luker's avatar
Luker committed
                                                                f_16 + size);
        *from = reinterpret_cast<void*> (f_16);
Luker's avatar
Luker committed
        return ret;
Luker's avatar
Luker committed
    case RaptorQ_type::RQ_ENC_32:
        ret = reinterpret_cast<
Luker's avatar
Luker committed
                            RaptorQ__v1::Impl::Encoder<uint32_t*, uint32_t*>*> (
Luker's avatar
Luker committed
                                                enc->ptr)->set_data (f_32,
Luker's avatar
Luker committed
                                                                f_32 + size);
        *from = reinterpret_cast<void*> (f_32);
Luker's avatar
Luker committed
        return ret;
Luker's avatar
Luker committed
    case RaptorQ_type::RQ_ENC_64:
Luker's avatar
Luker committed
        ret = reinterpret_cast<
                            RaptorQ__v1::Impl::Encoder<uint64_t*, uint64_t*>*> (
Luker's avatar
Luker committed
                                                enc->ptr)->set_data (f_64,
Luker's avatar
Luker committed
                                                                f_64 + size);
        *from = reinterpret_cast<void*> (f_64);
Luker's avatar
Luker committed
        return ret;
Luker's avatar
Luker committed
    case RaptorQ_type::RQ_DEC_8:
    case RaptorQ_type::RQ_DEC_16:
    case RaptorQ_type::RQ_DEC_32:
    case RaptorQ_type::RQ_DEC_64:
    case RaptorQ_type::RQ_NONE:
Luker's avatar
Luker committed
        break;
Luker's avatar
Luker committed
    }
Luker's avatar
Luker committed
    return 0;
}

Luker's avatar
Luker committed
static bool v1_has_data (const RaptorQ_ptr *enc)
{
    if (enc == nullptr || enc->ptr == nullptr)
        return false;
    switch (enc->type) {
    case RaptorQ_type::RQ_ENC_8:
Luker's avatar
Luker committed
        return (reinterpret_cast<const
Luker's avatar
Luker committed
                            RaptorQ__v1::Impl::Encoder<uint8_t*, uint8_t*>*> (
                                                        enc->ptr))->has_data();
    case RaptorQ_type::RQ_ENC_16:
Luker's avatar
Luker committed
        return (reinterpret_cast<const
Luker's avatar
Luker committed
                            RaptorQ__v1::Impl::Encoder<uint16_t*, uint16_t*>*> (
                                                        enc->ptr))->has_data();
    case RaptorQ_type::RQ_ENC_32:
Luker's avatar
Luker committed
        return (reinterpret_cast<const
Luker's avatar
Luker committed
                            RaptorQ__v1::Impl::Encoder<uint32_t*, uint32_t*>*> (
                                                        enc->ptr))->has_data();
    case RaptorQ_type::RQ_ENC_64:
Luker's avatar
Luker committed
        return (reinterpret_cast<const
Luker's avatar
Luker committed
                            RaptorQ__v1::Impl::Encoder<uint64_t*, uint64_t*>*> (
                                                        enc->ptr))->has_data();
    case RaptorQ_type::RQ_DEC_8:
    case RaptorQ_type::RQ_DEC_16:
    case RaptorQ_type::RQ_DEC_32:
    case RaptorQ_type::RQ_DEC_64:
    case RaptorQ_type::RQ_NONE:
        break;
    }
    return false;
}

Luker's avatar
Luker committed
static void v1_clear_data (const RaptorQ_ptr *ptr)
Luker's avatar
Luker committed
{
Luker's avatar
Luker committed
    if (ptr == nullptr || ptr->ptr == nullptr)
Luker's avatar
Luker committed
        return;
Luker's avatar
Luker committed
    switch (ptr->type) {
Luker's avatar
Luker committed
    case RaptorQ_type::RQ_ENC_8:
        return (reinterpret_cast<
Luker's avatar
Luker committed
                            RaptorQ__v1::Impl::Encoder<uint8_t*, uint8_t*>*> (
Luker's avatar
Luker committed
                                                    ptr->ptr))->clear_data();
Luker's avatar
Luker committed
    case RaptorQ_type::RQ_ENC_16:
        return (reinterpret_cast<
Luker's avatar
Luker committed
                            RaptorQ__v1::Impl::Encoder<uint16_t*, uint16_t*>*> (
Luker's avatar
Luker committed
                                                    ptr->ptr))->clear_data();
Luker's avatar
Luker committed
    case RaptorQ_type::RQ_ENC_32:
        return (reinterpret_cast<
Luker's avatar
Luker committed
                            RaptorQ__v1::Impl::Encoder<uint32_t*, uint32_t*>*> (
Luker's avatar
Luker committed
                                                    ptr->ptr))->clear_data();
Luker's avatar
Luker committed
    case RaptorQ_type::RQ_ENC_64:
Luker's avatar
Luker committed
        return (reinterpret_cast<
                            RaptorQ__v1::Impl::Encoder<uint64_t*, uint64_t*>*> (
Luker's avatar
Luker committed
                                                    ptr->ptr))->clear_data();
Luker's avatar
Luker committed
    case RaptorQ_type::RQ_DEC_8:
Luker's avatar
Luker committed
        return (reinterpret_cast<
                            RaptorQ__v1::Impl::Decoder<uint8_t*, uint8_t*>*> (
                                                    ptr->ptr))->clear_data();
Luker's avatar
Luker committed
    case RaptorQ_type::RQ_DEC_16:
Luker's avatar
Luker committed
        return (reinterpret_cast<
                            RaptorQ__v1::Impl::Decoder<uint16_t*, uint16_t*>*> (
                                                    ptr->ptr))->clear_data();
Luker's avatar
Luker committed
    case RaptorQ_type::RQ_DEC_32:
Luker's avatar
Luker committed
        return (reinterpret_cast<
                            RaptorQ__v1::Impl::Decoder<uint32_t*, uint32_t*>*> (
                                                    ptr->ptr))->clear_data();
Luker's avatar
Luker committed
    case RaptorQ_type::RQ_DEC_64:
Luker's avatar
Luker committed
        return (reinterpret_cast<
                            RaptorQ__v1::Impl::Decoder<uint64_t*, uint64_t*>*> (
                                                    ptr->ptr))->clear_data();
Luker's avatar
Luker committed
    case RaptorQ_type::RQ_NONE:
        return;
    }
Luker's avatar
Luker committed
}

Luker's avatar
Luker committed
static bool v1_precompute_sync (const RaptorQ_ptr *enc)
Luker's avatar
Luker committed
{
    if (enc == nullptr || enc->ptr == nullptr)
Luker's avatar
Luker committed
        return false;
Luker's avatar
Luker committed
    switch (enc->type) {
Luker's avatar
Luker committed
    case RaptorQ_type::RQ_ENC_8:
        return (reinterpret_cast<
Luker's avatar
Luker committed
                            RaptorQ__v1::Impl::Encoder<uint8_t*, uint8_t*>*> (
Luker's avatar
Luker committed
                                                enc->ptr))->precompute_sync();
Luker's avatar
Luker committed
    case RaptorQ_type::RQ_ENC_16:
        return (reinterpret_cast<
Luker's avatar
Luker committed
                            RaptorQ__v1::Impl::Encoder<uint16_t*, uint16_t*>*> (
Luker's avatar
Luker committed
                                                enc->ptr))->precompute_sync();
Luker's avatar
Luker committed
    case RaptorQ_type::RQ_ENC_32:
        return (reinterpret_cast<
Luker's avatar
Luker committed
                            RaptorQ__v1::Impl::Encoder<uint32_t*, uint32_t*>*> (
Luker's avatar
Luker committed
                                                enc->ptr))->precompute_sync();
Luker's avatar
Luker committed
    case RaptorQ_type::RQ_ENC_64:
Luker's avatar
Luker committed
        return (reinterpret_cast<
                            RaptorQ__v1::Impl::Encoder<uint64_t*, uint64_t*>*> (
Luker's avatar
Luker committed
                                                enc->ptr))->precompute_sync();
Luker's avatar
Luker committed
    case RaptorQ_type::RQ_DEC_8:
    case RaptorQ_type::RQ_DEC_16:
    case RaptorQ_type::RQ_DEC_32:
    case RaptorQ_type::RQ_DEC_64:
    case RaptorQ_type::RQ_NONE:
Luker's avatar
Luker committed
        break;
Luker's avatar
Luker committed
    }
Luker's avatar
Luker committed
    return false;
Luker's avatar
Luker committed
}

static bool v1_compute_sync (const RaptorQ_ptr *enc)
{
    if (enc == nullptr || enc->ptr == nullptr)
Luker's avatar
Luker committed
        return false;
Luker's avatar
Luker committed
    switch (enc->type) {
Luker's avatar
Luker committed
    case RaptorQ_type::RQ_ENC_8:
        return (reinterpret_cast<
Luker's avatar
Luker committed
                            RaptorQ__v1::Impl::Encoder<uint8_t*, uint8_t*>*> (
                                                    enc->ptr))->compute_sync();
Luker's avatar
Luker committed
    case RaptorQ_type::RQ_ENC_16:
        return (reinterpret_cast<
Luker's avatar
Luker committed
                            RaptorQ__v1::Impl::Encoder<uint16_t*, uint16_t*>*> (
                                                    enc->ptr))->compute_sync();
Luker's avatar
Luker committed
    case RaptorQ_type::RQ_ENC_32:
        return (reinterpret_cast<
Luker's avatar
Luker committed
                            RaptorQ__v1::Impl::Encoder<uint32_t*, uint32_t*>*> (
                                                    enc->ptr))->compute_sync();
Luker's avatar
Luker committed
    case RaptorQ_type::RQ_ENC_64:
Luker's avatar
Luker committed
        return (reinterpret_cast<
                            RaptorQ__v1::Impl::Encoder<uint64_t*, uint64_t*>*> (
                                                    enc->ptr))->compute_sync();
Luker's avatar
Luker committed
    case RaptorQ_type::RQ_DEC_8:
    case RaptorQ_type::RQ_DEC_16:
    case RaptorQ_type::RQ_DEC_32:
    case RaptorQ_type::RQ_DEC_64:
    case RaptorQ_type::RQ_NONE:
Luker's avatar
Luker committed
        break;
Luker's avatar
Luker committed
    }
Luker's avatar
Luker committed
    return false;
}

Luker's avatar
Luker committed
static RaptorQ_future_enc* v1_precompute (const RaptorQ_ptr *enc)
{
    if (enc == nullptr || enc->ptr == nullptr)
        return nullptr;
    RaptorQ_future_enc *fut = new RaptorQ_future_enc();
    switch (enc->type) {
    case RaptorQ_type::RQ_ENC_8:
        fut->f = reinterpret_cast<
                            RaptorQ__v1::Impl::Encoder<uint8_t*, uint8_t*>*> (
                                                        enc->ptr)->precompute();
        break;
    case RaptorQ_type::RQ_ENC_16:
        fut->f = reinterpret_cast<
                            RaptorQ__v1::Impl::Encoder<uint16_t*, uint16_t*>*> (
                                                        enc->ptr)->precompute();
        break;
    case RaptorQ_type::RQ_ENC_32:
        fut->f = reinterpret_cast<
                            RaptorQ__v1::Impl::Encoder<uint32_t*, uint32_t*>*> (
                                                        enc->ptr)->precompute();
        break;
    case RaptorQ_type::RQ_ENC_64:
        fut->f = reinterpret_cast<
                            RaptorQ__v1::Impl::Encoder<uint64_t*, uint64_t*>*> (
                                                        enc->ptr)->precompute();
        break;
    case RaptorQ_type::RQ_DEC_8:
    case RaptorQ_type::RQ_DEC_16:
    case RaptorQ_type::RQ_DEC_32:
    case RaptorQ_type::RQ_DEC_64:
    case RaptorQ_type::RQ_NONE: