mirror of
https://github.com/logos-storage/logos-storage-nim.git
synced 2026-01-05 06:53:06 +00:00
Needs to be proved out by doing a port of leopard's benchmark tool to Nim, i.e. there are still some questions re: parameter types
33 lines
998 B
Nim
33 lines
998 B
Nim
type
|
|
LeopardResult* {.pure.} = enum
|
|
Leopard_CallInitialize = -7.cint
|
|
Leopard_Platform = -6.cint
|
|
Leopard_InvalidInput = -5.cint
|
|
Leopard_InvalidCounts = -4.cint
|
|
Leopard_InvalidSize = -3.cint
|
|
Leopard_TooMuchData = -2.cint
|
|
Leopard_NeedMoreData = -1.cint
|
|
Leopard_Success = 0.cint
|
|
|
|
const
|
|
header = "leopard.h"
|
|
|
|
{.pragma: leo, cdecl, header: header, importCpp.}
|
|
|
|
proc leo_init*(): cint {.leo.}
|
|
|
|
func leo_result_string*(res: LeopardResult): cstring {.leo.}
|
|
|
|
func leo_encode_work_count*(original_count, recovery_count: cuint): cuint
|
|
{.leo.}
|
|
|
|
proc leo_encode*(buffer_bytes: uint64, original_count, recovery_count,
|
|
work_count: cuint, original_data, work_data: pointer): LeopardResult {.leo.}
|
|
|
|
func leo_decode_work_count*(original_count, recovery_count: cuint): cuint
|
|
{.leo.}
|
|
|
|
proc leo_decode*(buffer_bytes: uint64, original_count, recovery_count,
|
|
work_count: cuint, original_data, recovery_data, work_data: pointer):
|
|
LeopardResult {.leo.}
|