Skip to content
C_RFC_API.cpp 63.2 KiB
Newer Older
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/>.
 */

Luker's avatar
Luker committed
#include "RaptorQ/v1/wrapper/C_RFC_API.h"
#include "RaptorQ/v1/caches.hpp"
Luker's avatar
Luker committed
#include "RaptorQ/v1/RFC.hpp"
#include <chrono>
Luker's avatar
Luker committed
#include <future>
Luker's avatar
Luker committed
#include <memory>

Luker's avatar
Luker committed
struct RAPTORQ_LOCAL RFC6330_ptr
Luker's avatar
Luker committed
{
Luker's avatar
Luker committed
    void *const ptr;
    const RFC6330_type type;
Luker's avatar
Luker committed

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

Luker's avatar
Luker committed
struct RAPTORQ_LOCAL RFC6330_future
Luker's avatar
Luker committed
    std::future<std::pair<RFC6330__v1::Error, uint8_t>> f;
Luker's avatar
Luker committed
    RFC6330_future(){}
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!
////
////////////////////////

// precomputation caching
Luker's avatar
Luker committed
static RFC6330_Compress v1_supported_compressions();
static RFC6330_Compress v1_get_compression();
static bool v1_set_compression (const RFC6330_Compress compression);
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 RFC6330_ptr* v1_Encoder (RFC6330_type type,
Luker's avatar
Luker committed
                                              const void *data_from,
                                              const size_t size,
                                              const uint16_t min_subsymbol_size,
                                              const uint16_t symbol_size,
                                              const size_t max_memory);
Luker's avatar
Luker committed
static struct RFC6330_ptr* v1_Decoder (RFC6330_type type,
Luker's avatar
Luker committed
                              const RFC6330_OTI_Common_Data common,
                              const RFC6330_OTI_Scheme_Specific_Data scheme);
Luker's avatar
Luker committed
static struct RFC6330_ptr* v1_Decoder_raw (RFC6330_type type,
Luker's avatar
Luker committed
                                                    const uint64_t size,
                                                    const uint16_t symbol_size,
                                                    const uint16_t sub_blocks,
                                                    const uint8_t blocks,
                                                    const uint8_t alignment);
Luker's avatar
Luker committed
static bool v1_initialized (const struct RFC6330_ptr *ptr);
Luker's avatar
Luker committed


// common functions
Luker's avatar
Luker committed
static uint8_t  v1_blocks (const struct RFC6330_ptr *ptr);
static uint16_t v1_symbols (const struct RFC6330_ptr *ptr, const uint8_t sbn);
static size_t v1_symbol_size (const struct RFC6330_ptr *ptr);
static RaptorQ_Error v1_future_state (const struct RFC6330_future *f);
static RaptorQ_Error v1_future_wait_for (const struct RFC6330_future *f,
Luker's avatar
Luker committed
                                                const uint64_t time,
                                                const RFC6330_Unit_Time unit);
Luker's avatar
Luker committed
static void v1_future_wait (const struct RFC6330_future *f);
static void v1_future_free (struct RFC6330_future **f);
static struct RFC6330_Result v1_future_get (struct RFC6330_future *future);
static bool v1_set_thread_pool (const size_t threads,
Luker's avatar
Luker committed
                                const uint16_t max_block_concurrency,
                                const RFC6330_Work exit_type);
Luker's avatar
Luker committed
static struct RFC6330_future* v1_compute (const struct RFC6330_ptr *ptr,
Luker's avatar
Luker committed
                                                const RFC6330_Compute flags);
Luker's avatar
Luker committed
static void v1_free (struct RFC6330_ptr **ptr);
static void v1_free_block (const struct RFC6330_ptr *ptr, const uint8_t sbn);
Luker's avatar
Luker committed


// encoder-specific
Luker's avatar
Luker committed
static RFC6330_OTI_Common_Data v1_OTI_Common (const struct RFC6330_ptr *enc);
static RFC6330_OTI_Scheme_Specific_Data v1_OTI_Scheme_Specific (
Luker's avatar
Luker committed
                                                const struct RFC6330_ptr *enc);
Luker's avatar
Luker committed
static uint32_t v1_max_repair (const struct RFC6330_ptr *enc,
Luker's avatar
Luker committed
                                                            const uint8_t sbn);
Luker's avatar
Luker committed
static size_t v1_precompute_max_memory (const struct RFC6330_ptr *enc);
Luker's avatar
Luker committed

Luker's avatar
Luker committed
static size_t v1_encode_id (const struct RFC6330_ptr *enc, void **data,
Luker's avatar
Luker committed
                                                            const size_t size,
                                                            const uint32_t id);
Luker's avatar
Luker committed
static size_t v1_encode (const struct RFC6330_ptr *enc, void **data,
Luker's avatar
Luker committed
                                                            const size_t size,
                                                            const uint32_t esi,
                                                            const uint8_t sbn);
Luker's avatar
Luker committed
static uint32_t v1_id (const uint32_t esi, const uint8_t sbn);
Luker's avatar
Luker committed


// decoder-specific
Luker's avatar
Luker committed
static void v1_end_of_input (const struct RFC6330_ptr *dec);
static void v1_end_of_block_input (const struct RFC6330_ptr *dec,
Luker's avatar
Luker committed
                                                        const uint8_t block);
Luker's avatar
Luker committed
static uint64_t v1_bytes (const struct RFC6330_ptr *dec);
static RFC6330_Error v1_add_symbol_id (const struct RFC6330_ptr *dec,
                                                            void **data,
                                                            const uint32_t size,
                                                            const uint32_t id);
static RFC6330_Error v1_add_symbol (const struct RFC6330_ptr *dec, void **data,
                                                            const uint32_t size,
                                                            const uint32_t esi,
                                                            const uint8_t sbn);
Luker's avatar
Luker committed
static struct RFC6330_Dec_Result v1_decode_aligned (
Luker's avatar
Luker committed
                                                const struct RFC6330_ptr *dec,
                                                void **data,
                                                const uint64_t size,
                                                const uint8_t skip);
Luker's avatar
Luker committed
static struct RFC6330_Dec_Result v1_decode_block_aligned (
Luker's avatar
Luker committed
                                                const struct RFC6330_ptr *dec,
                                                void **data,
                                                const size_t size,
                                                const uint8_t skip,
                                                const uint8_t sbn);
Luker's avatar
Luker committed
static uint64_t v1_decode_bytes (const struct RFC6330_ptr *dec, void **data,
Luker's avatar
Luker committed
                                                            const uint64_t size,
                                                            const uint8_t skip);
Luker's avatar
Luker committed
static size_t v1_decode_block_bytes (const struct RFC6330_ptr *dec, void **data,
Luker's avatar
Luker committed
                                                            const size_t size,
                                                            const uint8_t skip,
                                                            const uint8_t sbn);



void RFC6330_free_api (struct RFC6330_base_api **api)
Luker's avatar
Luker committed
{
Luker's avatar
Luker committed
    if (api == nullptr || *api == nullptr)
Luker's avatar
Luker committed
        return;
Luker's avatar
Luker committed
    if ((*api)->version == 1) {
        delete reinterpret_cast<struct RFC6330_v1*> (*api);
    } // else it's all your fault anway
    *api = nullptr;
Luker's avatar
Luker committed
}

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

Luker's avatar
Luker committed
RFC6330_v1::RFC6330_v1()
    : base (1),
    // precomputation caching
    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),

    // constructors
    Encoder (&v1_Encoder),
    Decoder (&v1_Decoder),
    Decoder_raw (&v1_Decoder_raw),
    initialized (&v1_initialized),

    // common functions
    blocks (&v1_blocks),
    symbols (&v1_symbols),
    symbol_size (&v1_symbol_size),
    future_state (&v1_future_state),
    future_wait_for (&v1_future_wait_for),
    future_wait (&v1_future_wait),
    future_free (&v1_future_free),
    future_get (&v1_future_get),
    set_thread_pool (&v1_set_thread_pool),
    compute (&v1_compute),
    free (&v1_free),
    free_block (&v1_free_block),

    // encoder-specific functions
    OTI_Common (&v1_OTI_Common),
    OTI_Scheme_Specific (&v1_OTI_Scheme_Specific),
    max_repair (&v1_max_repair),
    precompute_max_memory (&v1_precompute_max_memory),
    encode_id (&v1_encode_id),
    encode (&v1_encode),
    id (&v1_id),

    // decoder-specific functions
    end_of_input (&v1_end_of_input),
    end_of_block_input (&v1_end_of_block_input),
    bytes (&v1_bytes),
    add_symbol_id (&v1_add_symbol_id),
    add_symbol (&v1_add_symbol),
Luker's avatar
Luker committed
    decode_aligned (&v1_decode_aligned),
    decode_block_aligned (&v1_decode_block_aligned),
    decode_bytes (&v1_decode_bytes),
    decode_block_bytes (&v1_decode_block_bytes)
Luker's avatar
Luker committed
{}
Luker's avatar
Luker committed


Luker's avatar
Luker committed
///////////////////////////
// Precomputation caching
///////////////////////////

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

Luker's avatar
Luker committed
static RFC6330_Compress v1_get_compression()
    { return static_cast<RFC6330_Compress>(RaptorQ__v1::get_compression()); }
Luker's avatar
Luker committed
static bool v1_set_compression (const RFC6330_Compress compression)
Luker's avatar
Luker committed
    return static_cast<RFC6330_Compress> (RaptorQ__v1::set_compression (
Luker's avatar
Luker committed
                            static_cast<RaptorQ__v1::Compress> (compression)));
Luker's avatar
Luker committed
static size_t v1_local_cache_size (const size_t local_cache)
    { return RFC6330__v1::local_cache_size (local_cache); }

static size_t v1_get_local_cache_size ()
    { return RFC6330__v1::get_local_cache_size(); }




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

Luker's avatar
Luker committed
static struct RFC6330_ptr* v1_Encoder (RFC6330_type type,
Luker's avatar
Luker committed
                                              const void *data_from,
                                              const size_t size,
                                              const uint16_t min_subsymbol_size,
                                              const uint16_t symbol_size,
                                              const size_t max_memory)
Luker's avatar
Luker committed
    uint8_t *p_8;
    uint16_t *p_16;
    uint32_t *p_32;
    uint64_t *p_64;
    void *raw_ptr = nullptr;
    switch (type) {
    case RFC6330_type::RQ_ENC_8:
        p_8 = reinterpret_cast<uint8_t*> (const_cast<void*> (data_from));
        raw_ptr = reinterpret_cast<void *> (
                        new RFC6330__v1::Impl::Encoder<uint8_t*, uint8_t*> (
                                                p_8, p_8 + size,
                                                min_subsymbol_size, symbol_size,
                                                max_memory));
        break;
    case RFC6330_type::RQ_ENC_16:
        p_16 = reinterpret_cast<uint16_t*> (const_cast<void*> (data_from));
        raw_ptr = reinterpret_cast<void *> (
                        new RFC6330__v1::Impl::Encoder<uint16_t*, uint16_t*> (
                                                p_16, p_16 + size,
                                                min_subsymbol_size, symbol_size,
                                                max_memory));
        break;
    case RFC6330_type::RQ_ENC_32:
        p_32 = reinterpret_cast<uint32_t*> (const_cast<void*> (data_from));
        raw_ptr = reinterpret_cast<void *> (
                    new RFC6330__v1::Impl::Encoder<uint32_t*, uint32_t*> (
                                                p_32, p_32 + size,
                                                min_subsymbol_size, symbol_size,
                                                max_memory));
        break;
    case RFC6330_type::RQ_ENC_64:
        p_64 = reinterpret_cast<uint64_t*> (const_cast<void*> (data_from));
        raw_ptr = reinterpret_cast<void *> (
                    new RFC6330__v1::Impl::Encoder<uint64_t*, uint64_t*> (
                                                p_64, p_64 + size,
                                                min_subsymbol_size, symbol_size,
                                                max_memory));
        break;
    case RFC6330_type::RQ_DEC_8:
    case RFC6330_type::RQ_DEC_16:
    case RFC6330_type::RQ_DEC_32:
    case RFC6330_type::RQ_DEC_64:
    case RFC6330_type::RQ_NONE:
        return nullptr;
    }
    if (raw_ptr == nullptr)
        return nullptr;
    return new RFC6330_ptr (type, raw_ptr);
Luker's avatar
Luker committed
static struct RFC6330_ptr* v1_Decoder (RFC6330_type type,
Luker's avatar
Luker committed
                                  const RFC6330_OTI_Common_Data common,
                                  const RFC6330_OTI_Scheme_Specific_Data scheme)
Luker's avatar
Luker committed
{
Luker's avatar
Luker committed
    void *raw_ptr = nullptr;
    namespace RQ = RFC6330__v1::Impl;
    switch (type) {
    case RFC6330_type::RQ_DEC_8:
        raw_ptr = reinterpret_cast<void *> (
                        new RQ::Decoder<uint8_t*, uint8_t*> (common, scheme));
        break;
    case RFC6330_type::RQ_DEC_16:
        raw_ptr = reinterpret_cast<void *> (
                        new RQ::Decoder<uint16_t*, uint16_t*> (common, scheme));
        break;
    case RFC6330_type::RQ_DEC_32:
        raw_ptr = reinterpret_cast<void *> (
                        new RQ::Decoder<uint32_t*, uint32_t*> (common, scheme));
        break;
    case RFC6330_type::RQ_DEC_64:
        raw_ptr = reinterpret_cast<void *> (
                        new RQ::Decoder<uint64_t*, uint64_t*> (common, scheme));
        break;
    case RFC6330_type::RQ_ENC_8:
    case RFC6330_type::RQ_ENC_16:
    case RFC6330_type::RQ_ENC_32:
    case RFC6330_type::RQ_ENC_64:
    case RFC6330_type::RQ_NONE:
        return nullptr;
    }
    if (raw_ptr == nullptr)
        return nullptr;
    return new RFC6330_ptr (type, raw_ptr);
Luker's avatar
Luker committed
}

Luker's avatar
Luker committed
static struct RFC6330_ptr* v1_Decoder_raw (RFC6330_type type,
Luker's avatar
Luker committed
                                                  const uint64_t size,
                                                  const uint16_t symbol_size,
                                                  const uint16_t sub_blocks,
                                                  const uint8_t blocks,
                                                  const uint8_t alignment)
Luker's avatar
Luker committed
{
Luker's avatar
Luker committed
    void *raw_ptr = nullptr;
    namespace RQ = RFC6330__v1::Impl;
    switch (type) {
    case RFC6330_type::RQ_DEC_8:
        raw_ptr = reinterpret_cast<void *> (
                        new RQ::Decoder<uint8_t*, uint8_t*> (size, symbol_size,
                                                                sub_blocks,
                                                                blocks,
                                                                alignment));
        break;
    case RFC6330_type::RQ_DEC_16:
        raw_ptr = reinterpret_cast<void *> (
                        new RQ::Decoder<uint16_t*, uint16_t*> (size,symbol_size,
                                                                    sub_blocks,
                                                                    blocks,
                                                                    alignment));
        break;
    case RFC6330_type::RQ_DEC_32:
        raw_ptr = reinterpret_cast<void *> (
                        new RQ::Decoder<uint32_t*, uint32_t*> (size,symbol_size,
                                                                   sub_blocks,
                                                                   blocks,
                                                                   alignment));
        break;
    case RFC6330_type::RQ_DEC_64:
        raw_ptr = reinterpret_cast<void *> (
                        new RQ::Decoder<uint64_t*, uint64_t*> (size,symbol_size,
                                                                   sub_blocks,
                                                                   blocks,
                                                                   alignment));
        break;
    case RFC6330_type::RQ_ENC_8:
    case RFC6330_type::RQ_ENC_16:
    case RFC6330_type::RQ_ENC_32:
    case RFC6330_type::RQ_ENC_64:
    case RFC6330_type::RQ_NONE:
        return nullptr;
    }
    if (raw_ptr == nullptr)
        return nullptr;
    return new RFC6330_ptr (type, raw_ptr);
Luker's avatar
Luker committed
}

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

Luker's avatar
Luker committed

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

Luker's avatar
Luker committed
static uint8_t v1_blocks (const struct RFC6330_ptr *ptr)
Luker's avatar
Luker committed
{
    if (ptr == nullptr || ptr->ptr == nullptr)
        return 0;
    switch (ptr->type) {
    case RFC6330_type::RQ_ENC_8:
        return (reinterpret_cast<const
                            RFC6330__v1::Impl::Encoder<uint8_t*, uint8_t*>*> (
                                                        ptr->ptr))->blocks();
    case RFC6330_type::RQ_ENC_16:
        return (reinterpret_cast<const
                            RFC6330__v1::Impl::Encoder<uint16_t*, uint16_t*>*> (
                                                        ptr->ptr))->blocks();
    case RFC6330_type::RQ_ENC_32:
        return (reinterpret_cast<const
                            RFC6330__v1::Impl::Encoder<uint32_t*, uint32_t*>*> (
                                                        ptr->ptr))->blocks();
    case RFC6330_type::RQ_ENC_64:
        return (reinterpret_cast<const
                            RFC6330__v1::Impl::Encoder<uint64_t*, uint64_t*>*> (
                                                        ptr->ptr))->blocks();
    case RFC6330_type::RQ_DEC_8:
        return (reinterpret_cast<const
                            RFC6330__v1::Impl::Decoder<uint8_t*, uint8_t*>*> (
                                                        ptr->ptr))->blocks();
    case RFC6330_type::RQ_DEC_16:
        return (reinterpret_cast<const
                            RFC6330__v1::Impl::Decoder<uint16_t*, uint16_t*>*> (
                                                        ptr->ptr))->blocks();
    case RFC6330_type::RQ_DEC_32:
        return (reinterpret_cast<const
                            RFC6330__v1::Impl::Decoder<uint32_t*, uint32_t*>*> (
                                                        ptr->ptr))->blocks();
    case RFC6330_type::RQ_DEC_64:
        return (reinterpret_cast<const
                            RFC6330__v1::Impl::Decoder<uint64_t*, uint64_t*>*> (
                                                        ptr->ptr))->blocks();
    case RFC6330_type::RQ_NONE:
        break;
    }
    return 0;
}
Luker's avatar
Luker committed
static uint16_t v1_symbols (const struct RFC6330_ptr *ptr, const uint8_t sbn)
Luker's avatar
Luker committed
    if (ptr == nullptr || ptr->ptr == nullptr)
        return 0;
    switch (ptr->type) {
    case RFC6330_type::RQ_ENC_8:
        return (reinterpret_cast<const
                            RFC6330__v1::Impl::Encoder<uint8_t*, uint8_t*>*> (
                                                    ptr->ptr))->symbols (sbn);
    case RFC6330_type::RQ_ENC_16:
        return (reinterpret_cast<const
                            RFC6330__v1::Impl::Encoder<uint16_t*, uint16_t*>*> (
                                                    ptr->ptr))->symbols (sbn);
    case RFC6330_type::RQ_ENC_32:
        return (reinterpret_cast<const
                            RFC6330__v1::Impl::Encoder<uint32_t*, uint32_t*>*> (
                                                    ptr->ptr))->symbols (sbn);
    case RFC6330_type::RQ_ENC_64:
        return (reinterpret_cast<const
                            RFC6330__v1::Impl::Encoder<uint64_t*, uint64_t*>*> (
                                                    ptr->ptr))->symbols (sbn);
    case RFC6330_type::RQ_DEC_8:
        return (reinterpret_cast<const
                            RFC6330__v1::Impl::Decoder<uint8_t*, uint8_t*>*> (
                                                    ptr->ptr))->symbols (sbn);
    case RFC6330_type::RQ_DEC_16:
        return (reinterpret_cast<const
                            RFC6330__v1::Impl::Decoder<uint16_t*, uint16_t*>*> (
                                                    ptr->ptr))->symbols (sbn);
    case RFC6330_type::RQ_DEC_32:
        return (reinterpret_cast<const
                            RFC6330__v1::Impl::Decoder<uint32_t*, uint32_t*>*> (
                                                    ptr->ptr))->symbols (sbn);
    case RFC6330_type::RQ_DEC_64:
        return (reinterpret_cast<const
                            RFC6330__v1::Impl::Decoder<uint64_t*, uint64_t*>*> (
                                                    ptr->ptr))->symbols (sbn);
    case RFC6330_type::RQ_NONE:
        break;
    }
    return 0;
Luker's avatar
Luker committed
static size_t v1_symbol_size (const struct RFC6330_ptr *ptr)
Luker's avatar
Luker committed
    if (ptr == nullptr || ptr->ptr == nullptr)
        return 0;
    switch (ptr->type) {
    case RFC6330_type::RQ_ENC_8:
        return (reinterpret_cast<const
                            RFC6330__v1::Impl::Encoder<uint8_t*, uint8_t*>*> (
                                                    ptr->ptr))->symbol_size();
    case RFC6330_type::RQ_ENC_16:
        return (reinterpret_cast<const
                            RFC6330__v1::Impl::Encoder<uint16_t*, uint16_t*>*> (
                                                    ptr->ptr))->symbol_size();
    case RFC6330_type::RQ_ENC_32:
        return (reinterpret_cast<const
                            RFC6330__v1::Impl::Encoder<uint32_t*, uint32_t*>*> (
                                                    ptr->ptr))->symbol_size();
    case RFC6330_type::RQ_ENC_64:
        return (reinterpret_cast<const
                            RFC6330__v1::Impl::Encoder<uint64_t*, uint64_t*>*> (
                                                    ptr->ptr))->symbol_size();
    case RFC6330_type::RQ_DEC_8:
        return (reinterpret_cast<const
                            RFC6330__v1::Impl::Decoder<uint8_t*, uint8_t*>*> (
                                                    ptr->ptr))->symbol_size();
    case RFC6330_type::RQ_DEC_16:
        return (reinterpret_cast<const
                            RFC6330__v1::Impl::Decoder<uint16_t*, uint16_t*>*> (
                                                    ptr->ptr))->symbol_size();
    case RFC6330_type::RQ_DEC_32:
        return (reinterpret_cast<const
                            RFC6330__v1::Impl::Decoder<uint32_t*, uint32_t*>*> (
                                                    ptr->ptr))->symbol_size();
    case RFC6330_type::RQ_DEC_64:
        return (reinterpret_cast<const
                            RFC6330__v1::Impl::Decoder<uint64_t*, uint64_t*>*> (
                                                    ptr->ptr))->symbol_size();
    case RFC6330_type::RQ_NONE:
        break;
    }
    return 0;
Luker's avatar
Luker committed
static RaptorQ_Error v1_future_state (const struct RFC6330_future *f)
Luker's avatar
Luker committed
{
    if (f == nullptr)
        return RFC6330_Error::RQ_ERR_WRONG_INPUT;

    if (f->f.valid())
        return RFC6330_Error::RQ_ERR_WORKING;
    return RaptorQ_Error::RQ_ERR_NOT_NEEDED;
}

Luker's avatar
Luker committed
static RaptorQ_Error v1_future_wait_for (const struct RFC6330_future *f,
Luker's avatar
Luker committed
                                                const uint64_t time,
Luker's avatar
Luker committed
                                                const RFC6330_Unit_Time unit)
Luker's avatar
Luker committed
    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
        status = f->f.wait_for (std::chrono::nanoseconds (time));
Luker's avatar
Luker committed
        break;
    case RQ_TIME_MICROSEC:
Luker's avatar
Luker committed
        status = f->f.wait_for (std::chrono::microseconds (time));
Luker's avatar
Luker committed
        break;
    case RQ_TIME_MILLISEC:
Luker's avatar
Luker committed
        status = f->f.wait_for (std::chrono::milliseconds (time));
Luker's avatar
Luker committed
        break;
    case RQ_TIME_SEC:
Luker's avatar
Luker committed
        status = f->f.wait_for (std::chrono::seconds (time));
Luker's avatar
Luker committed
        break;
    case RQ_TIME_MIN:
Luker's avatar
Luker committed
        status = f->f.wait_for (std::chrono::minutes (time));
Luker's avatar
Luker committed
        break;
    case RQ_TIME_HOUR:
Luker's avatar
Luker committed
        status = f->f.wait_for (std::chrono::hours (time));
Luker's avatar
Luker committed
        break;
    }
    if (status == std::future_status::ready)
Luker's avatar
Luker committed
        return RaptorQ_Error::RQ_ERR_NONE;
    return RaptorQ_Error::RQ_ERR_WORKING;
Luker's avatar
Luker committed
static void v1_future_wait (const struct RFC6330_future *f)
Luker's avatar
Luker committed
    if (f == nullptr)
Luker's avatar
Luker committed
        return;
Luker's avatar
Luker committed
    f->f.wait();
Luker's avatar
Luker committed
static void v1_future_free (struct RFC6330_future **f)
Luker's avatar
Luker committed
    if (f == nullptr || *f == nullptr)
        return;

    delete *f;
    *f = nullptr;
}

Luker's avatar
Luker committed
static struct RFC6330_Result v1_future_get (struct RFC6330_future *const future)
Luker's avatar
Luker committed
{
    RFC6330_Result res = {RQ_ERR_WRONG_INPUT, 0 };
    if (future != nullptr && future->f.valid()) {
        const auto cpp_res = future->f.get();
        return RFC6330_Result {static_cast<RFC6330_Error> (cpp_res.first),
                                                                cpp_res.second};
    }
Luker's avatar
Luker committed
    return res;
Luker's avatar
Luker committed
static bool v1_set_thread_pool (const size_t threads,
Luker's avatar
Luker committed
                                        const uint16_t max_block_concurrency,
                                        const RFC6330_Work exit_type)
Luker's avatar
Luker committed
    return RFC6330__v1::set_thread_pool(threads, max_block_concurrency,
                            static_cast<RaptorQ__v1::Work_State> (exit_type));
Luker's avatar
Luker committed

Luker's avatar
Luker committed
static struct RFC6330_future* v1_compute (const struct RFC6330_ptr *ptr,
Luker's avatar
Luker committed
                                                 const RFC6330_Compute flags)
Luker's avatar
Luker committed
    if (ptr == nullptr || ptr->ptr == nullptr)
Luker's avatar
Luker committed
        return nullptr;
Luker's avatar
Luker committed
    std::unique_ptr<RFC6330_future> ret = std::unique_ptr<RFC6330_future> (
                                                        new RFC6330_future());
Luker's avatar
Luker committed
    switch (ptr->type) {
Luker's avatar
Luker committed
    case RFC6330_type::RQ_ENC_8:
        ret->f = (reinterpret_cast<
                            RFC6330__v1::Impl::Encoder<uint8_t*, uint8_t*>*> (
                ptr->ptr))->compute(static_cast<RFC6330__v1::Compute> (flags));
        return ret.release();
    case RFC6330_type::RQ_ENC_16:
        ret->f = (reinterpret_cast<
                            RFC6330__v1::Impl::Encoder<uint16_t*, uint16_t*>*> (
                ptr->ptr))->compute(static_cast<RFC6330__v1::Compute> (flags));
        return ret.release();
    case RFC6330_type::RQ_ENC_32:
        ret->f = (reinterpret_cast<
                            RFC6330__v1::Impl::Encoder<uint32_t*, uint32_t*>*> (
                ptr->ptr))->compute(static_cast<RFC6330__v1::Compute> (flags));
        return ret.release();
    case RFC6330_type::RQ_ENC_64:
        ret->f = (reinterpret_cast<
                            RFC6330__v1::Impl::Encoder<uint64_t*, uint64_t*>*> (
                ptr->ptr))->compute(static_cast<RFC6330__v1::Compute> (flags));
        return ret.release();
    case RFC6330_type::RQ_DEC_8:
        ret->f = (reinterpret_cast<
                            RFC6330__v1::Impl::Decoder<uint8_t*, uint8_t*>*> (
                ptr->ptr))->compute(static_cast<RFC6330__v1::Compute> (flags));
        return ret.release();
    case RFC6330_type::RQ_DEC_16:
        ret->f = (reinterpret_cast<
                            RFC6330__v1::Impl::Decoder<uint16_t*, uint16_t*>*> (
                ptr->ptr))->compute(static_cast<RFC6330__v1::Compute> (flags));
        return ret.release();
    case RFC6330_type::RQ_DEC_32:
        ret->f = (reinterpret_cast<
                            RFC6330__v1::Impl::Decoder<uint32_t*, uint32_t*>*> (
                ptr->ptr))->compute(static_cast<RFC6330__v1::Compute> (flags));
        return ret.release();
    case RFC6330_type::RQ_DEC_64:
        ret->f = (reinterpret_cast<
                            RFC6330__v1::Impl::Decoder<uint64_t*, uint64_t*>*> (
                ptr->ptr))->compute(static_cast<RFC6330__v1::Compute> (flags));
        return ret.release();
    case RFC6330_type::RQ_NONE:
Luker's avatar
Luker committed
        break;
Luker's avatar
Luker committed
    }
    return nullptr;
}

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

Luker's avatar
Luker committed
static void v1_free_block (const struct RFC6330_ptr *ptr, const uint8_t sbn)
Luker's avatar
Luker committed
{
    if (ptr == nullptr || ptr->ptr == nullptr)
        return;
    switch (ptr->type) {
    case RFC6330_type::RQ_ENC_8:
        return (reinterpret_cast<
                            RFC6330__v1::Impl::Encoder<uint8_t*, uint8_t*>*> (
                                                        ptr->ptr))->free (sbn);
    case RFC6330_type::RQ_ENC_16:
        return (reinterpret_cast<
                            RFC6330__v1::Impl::Encoder<uint16_t*, uint16_t*>*> (
                                                        ptr->ptr))->free (sbn);
    case RFC6330_type::RQ_ENC_32:
        return (reinterpret_cast<
                            RFC6330__v1::Impl::Encoder<uint32_t*, uint32_t*>*> (
                                                        ptr->ptr))->free (sbn);
    case RFC6330_type::RQ_ENC_64:
        return (reinterpret_cast<
                            RFC6330__v1::Impl::Encoder<uint64_t*, uint64_t*>*> (
                                                        ptr->ptr))->free (sbn);
    case RFC6330_type::RQ_DEC_8:
        return (reinterpret_cast<
                            RFC6330__v1::Impl::Decoder<uint8_t*, uint8_t*>*> (
                                                        ptr->ptr))->free (sbn);
    case RFC6330_type::RQ_DEC_16:
        return (reinterpret_cast<
                            RFC6330__v1::Impl::Decoder<uint16_t*, uint16_t*>*> (
                                                        ptr->ptr))->free (sbn);
    case RFC6330_type::RQ_DEC_32:
        return (reinterpret_cast<
                            RFC6330__v1::Impl::Decoder<uint32_t*, uint32_t*>*> (
                                                        ptr->ptr))->free (sbn);
    case RFC6330_type::RQ_DEC_64:
        return (reinterpret_cast<
                            RFC6330__v1::Impl::Decoder<uint64_t*, uint64_t*>*> (
                                                        ptr->ptr))->free (sbn);
    case RFC6330_type::RQ_NONE:
        break;
    }
    return;
Luker's avatar
Luker committed

/////////////
Luker's avatar
Luker committed
// Encoding
Luker's avatar
Luker committed
/////////////

Luker's avatar
Luker committed

Luker's avatar
Luker committed
static RFC6330_OTI_Common_Data v1_OTI_Common (const struct RFC6330_ptr *enc)
Luker's avatar
Luker committed
{
Luker's avatar
Luker committed
    if (enc == nullptr || enc->ptr == nullptr)
Luker's avatar
Luker committed
        return 0;
    switch (enc->type) {
Luker's avatar
Luker committed
    case RFC6330_type::RQ_ENC_8:
        return (reinterpret_cast<
                            RFC6330__v1::Impl::Encoder<uint8_t*, uint8_t*>*> (
Luker's avatar
Luker committed
                                                    enc->ptr))->OTI_Common();
Luker's avatar
Luker committed
    case RFC6330_type::RQ_ENC_16:
        return (reinterpret_cast<
                            RFC6330__v1::Impl::Encoder<uint16_t*, uint16_t*>*> (
Luker's avatar
Luker committed
                                                    enc->ptr))->OTI_Common();
Luker's avatar
Luker committed
    case RFC6330_type::RQ_ENC_32:
        return (reinterpret_cast<
                            RFC6330__v1::Impl::Encoder<uint32_t*, uint32_t*>*> (
Luker's avatar
Luker committed
                                                    enc->ptr))->OTI_Common();
Luker's avatar
Luker committed
    case RFC6330_type::RQ_ENC_64:
        return (reinterpret_cast<
                            RFC6330__v1::Impl::Encoder<uint64_t*, uint64_t*>*> (
Luker's avatar
Luker committed
                                                    enc->ptr))->OTI_Common();
Luker's avatar
Luker committed
    case RFC6330_type::RQ_DEC_8:
    case RFC6330_type::RQ_DEC_16:
    case RFC6330_type::RQ_DEC_32:
    case RFC6330_type::RQ_DEC_64:
    case RFC6330_type::RQ_NONE:
        break;
Luker's avatar
Luker committed
    }
    return 0;
Luker's avatar
Luker committed
}

Luker's avatar
Luker committed
static RFC6330_OTI_Scheme_Specific_Data v1_OTI_Scheme_Specific (
Luker's avatar
Luker committed
                                                const struct RFC6330_ptr *enc)
Luker's avatar
Luker committed
{
Luker's avatar
Luker committed
    if (enc == nullptr || enc->ptr == nullptr)
Luker's avatar
Luker committed
        return 0;
    switch (enc->type) {
Luker's avatar
Luker committed
    case RFC6330_type::RQ_ENC_8:
        return (reinterpret_cast<
                            RFC6330__v1::Impl::Encoder<uint8_t*, uint8_t*>*> (
Luker's avatar
Luker committed
                                            enc->ptr))->OTI_Scheme_Specific();
Luker's avatar
Luker committed
    case RFC6330_type::RQ_ENC_16:
        return (reinterpret_cast<
                            RFC6330__v1::Impl::Encoder<uint16_t*, uint16_t*>*> (
Luker's avatar
Luker committed
                                            enc->ptr))->OTI_Scheme_Specific();
Luker's avatar
Luker committed
    case RFC6330_type::RQ_ENC_32:
        return (reinterpret_cast<
                            RFC6330__v1::Impl::Encoder<uint32_t*, uint32_t*>*> (
Luker's avatar
Luker committed
                                            enc->ptr))->OTI_Scheme_Specific();
Luker's avatar
Luker committed
    case RFC6330_type::RQ_ENC_64:
        return (reinterpret_cast<
                            RFC6330__v1::Impl::Encoder<uint64_t*, uint64_t*>*> (
Luker's avatar
Luker committed
                                            enc->ptr))->OTI_Scheme_Specific();
Luker's avatar
Luker committed
    case RFC6330_type::RQ_DEC_8:
    case RFC6330_type::RQ_DEC_16:
    case RFC6330_type::RQ_DEC_32:
    case RFC6330_type::RQ_DEC_64:
    case RFC6330_type::RQ_NONE:
        break;
Luker's avatar
Luker committed
    }
    return 0;
Luker's avatar
Luker committed
}

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

Luker's avatar
Luker committed
static size_t v1_precompute_max_memory (const struct RFC6330_ptr *enc)
Luker's avatar
Luker committed
{
Luker's avatar
Luker committed
    if (enc == nullptr || enc->ptr == nullptr)
Luker's avatar
Luker committed
        return 0;
    switch (enc->type) {
Luker's avatar
Luker committed
    case RFC6330_type::RQ_ENC_8:
        return (reinterpret_cast<
                            RFC6330__v1::Impl::Encoder<uint8_t*, uint8_t*>*> (
Luker's avatar
Luker committed
                                            enc->ptr))->precompute_max_memory();
Luker's avatar
Luker committed
    case RFC6330_type::RQ_ENC_16:
        return (reinterpret_cast<
                            RFC6330__v1::Impl::Encoder<uint16_t*, uint16_t*>*> (
Luker's avatar
Luker committed
                                            enc->ptr))->precompute_max_memory();
Luker's avatar
Luker committed
    case RFC6330_type::RQ_ENC_32:
        return (reinterpret_cast<
                            RFC6330__v1::Impl::Encoder<uint32_t*, uint32_t*>*> (
Luker's avatar
Luker committed
                                            enc->ptr))->precompute_max_memory();
Luker's avatar
Luker committed
    case RFC6330_type::RQ_ENC_64:
        return (reinterpret_cast<
                            RFC6330__v1::Impl::Encoder<uint64_t*, uint64_t*>*> (
Luker's avatar
Luker committed
                                            enc->ptr))->precompute_max_memory();
Luker's avatar
Luker committed
    case RFC6330_type::RQ_DEC_8:
    case RFC6330_type::RQ_DEC_16:
    case RFC6330_type::RQ_DEC_32:
    case RFC6330_type::RQ_DEC_64:
    case RFC6330_type::RQ_NONE:
        break;
Luker's avatar
Luker committed
    }
    return 0;
Luker's avatar
Luker committed
}

Luker's avatar
Luker committed
static size_t v1_encode_id (const struct RFC6330_ptr *enc, void **data,
Luker's avatar
Luker committed
                                                            const size_t size,
Luker's avatar
Luker committed
                                                            const uint32_t id)
Luker's avatar
Luker committed
{
Luker's avatar
Luker committed
    if (enc == nullptr || enc->ptr == nullptr || data == nullptr)
        return 0;
    uint8_t *p_8;
    uint16_t *p_16;
    uint32_t *p_32;
    uint64_t *p_64;
    size_t ret;
    switch (enc->type) {
    case RFC6330_type::RQ_ENC_8:
        p_8 = reinterpret_cast<uint8_t*> (*data);
        ret = (reinterpret_cast<
                            RFC6330__v1::Impl::Encoder<uint8_t*, uint8_t*>*> (
                                                    enc->ptr))->encode (
                                                        p_8, p_8 + size,id);
        *data = p_8;
        return ret;
    case RFC6330_type::RQ_ENC_16:
        p_16 = reinterpret_cast<uint16_t*> (*data);
        ret = (reinterpret_cast<
                            RFC6330__v1::Impl::Encoder<uint16_t*, uint16_t*>*> (
                                                    enc->ptr))->encode (
                                                        p_16, p_16 + size,id);
        *data = p_16;
        return ret;
    case RFC6330_type::RQ_ENC_32:
        p_32 = reinterpret_cast<uint32_t*> (*data);
        ret = (reinterpret_cast<
                            RFC6330__v1::Impl::Encoder<uint32_t*, uint32_t*>*> (
                                                    enc->ptr))->encode (
                                                        p_32, p_32 + size,id);
        *data = p_32;
        return ret;
    case RFC6330_type::RQ_ENC_64:
        p_64 = reinterpret_cast<uint64_t*> (*data);
        ret = (reinterpret_cast<
                            RFC6330__v1::Impl::Encoder<uint64_t*, uint64_t*>*> (
                                                    enc->ptr))->encode (
                                                        p_64, p_64 + size,id);
        *data = p_64;
        return ret;
    case RFC6330_type::RQ_DEC_8:
    case RFC6330_type::RQ_DEC_16:
    case RFC6330_type::RQ_DEC_32:
    case RFC6330_type::RQ_DEC_64:
    case RFC6330_type::RQ_NONE:
        break;
    }
    return 0;
Luker's avatar
Luker committed
}

Luker's avatar
Luker committed
static size_t v1_encode (const struct RFC6330_ptr *enc, void **data,
                                                            const size_t size,
Luker's avatar
Luker committed
                                                            const uint32_t esi,
                                                            const uint8_t sbn)
Luker's avatar
Luker committed
{
Luker's avatar
Luker committed
    if (enc == nullptr || enc->ptr == nullptr || data == nullptr)
Luker's avatar
Luker committed
        return 0;
    uint8_t *p_8;
    uint16_t *p_16;
    uint32_t *p_32;
    uint64_t *p_64;
Luker's avatar
Luker committed
    size_t ret;
Luker's avatar
Luker committed
    switch (enc->type) {
Luker's avatar
Luker committed
    case RFC6330_type::RQ_ENC_8:
Luker's avatar
Luker committed
        p_8 = reinterpret_cast<uint8_t*> (*data);
Luker's avatar
Luker committed
        ret = (reinterpret_cast<
                            RFC6330__v1::Impl::Encoder<uint8_t*, uint8_t*>*> (
                                                        enc->ptr))->encode (
                                                                p_8, p_8 + size,
                                                                    esi, sbn);
        *data = p_8;
        return ret;
    case RFC6330_type::RQ_ENC_16:
Luker's avatar
Luker committed
        p_16 = reinterpret_cast<uint16_t*> (*data);
Luker's avatar
Luker committed
        ret = (reinterpret_cast<
                            RFC6330__v1::Impl::Encoder<uint16_t*, uint16_t*>*> (