diff options
author | dzaima <dzaimagit@gmail.com> | 2023-01-04 20:15:09 +0200 |
---|---|---|
committer | dzaima <dzaimagit@gmail.com> | 2023-01-04 20:41:21 +0200 |
commit | 18459482c9effa334bfbeb6e444a2a2830ead7c9 (patch) | |
tree | 8921e91dd4c82a2cc58b7308c4e65fba17a1b8c5 | |
parent | 32f0a2f8fc152a38595cf8ae610ab4fe6f3e7cd1 (diff) |
some cleanup of bqnffi.h comments
-rw-r--r-- | include/bqnffi.h | 57 |
1 files changed, 36 insertions, 21 deletions
diff --git a/include/bqnffi.h b/include/bqnffi.h index bee7dbc2..fdcfd13b 100644 --- a/include/bqnffi.h +++ b/include/bqnffi.h @@ -2,8 +2,9 @@ #include<stdint.h> #include<stdbool.h> /* - FFI interface for interfacing with BQN implementations - In general, the functions assume the argument(s) are of the expected type (if applicable), and cause undefined behavior if not + FFI interface for interfacing with BQN implementations. + In general, the functions assume the argument(s) are of the expected type (if applicable), and cause undefined behavior if not. + Functions, unless otherwise specified, don't free their arguments. */ typedef uint64_t BQNV; @@ -11,17 +12,17 @@ typedef uint64_t BQNV; extern "C" { #endif -void bqn_init(void); +void bqn_init(void); // must be called at least once before any of the below functions are used; can safely be called multiple times -void bqn_free(BQNV v); -BQNV bqn_copy(BQNV v); // create a BQNV equivalent in value to `v`, which can be freed separately from `v` +void bqn_free(BQNV v); // free a previously obtained BQNV value, making it illegal to use it further +BQNV bqn_copy(BQNV v); // create a BQNV with a value equivalent to `v`, which can be freed separately from `v` double bqn_toF64 (BQNV v); // includes bqn_free(v) uint32_t bqn_toChar(BQNV v); // includes bqn_free(v) double bqn_readF64 (BQNV v); // doesn't include bqn_free(v) uint32_t bqn_readChar(BQNV v); // doesn't include bqn_free(v) -int bqn_type(BQNV v); // equivalent of BQN •Type +int bqn_type(BQNV v); // equivalent of BQN `•Type` // Invoke BQN function; f can be any BQN object other than modifiers BQNV bqn_call1(BQNV f, BQNV x); @@ -33,15 +34,16 @@ BQNV bqn_evalCStr(const char* str); // evaluates the null-terminated UTF8-encode // Read array data -size_t bqn_bound(BQNV a); // aka product of shape, aka "×´≢a" -size_t bqn_rank(BQNV a); // "=a" +size_t bqn_bound(BQNV a); // aka product of shape, aka `×´≢a` +size_t bqn_rank(BQNV a); // `=a` void bqn_shape(BQNV a, size_t* buf); // writes bqn_rank(a) items in buf BQNV bqn_pick(BQNV a, size_t pos); // pos⊑⥊a -// Functions for reading all elements of `a` into a pre-allocated buffer (whose count must be at least `bqn_bound(a)`). -// Defined if and only if the input `a` consists of elements whose types exactly fit in the wanted type. -// e.g. bqn_readObjArr is always defined (assuming `a` is an array and `buf` isn't null and has enough slots) -// but bqn_readI8Arr is illegal to invoke on `⟨1.2,3.4⟩` or `⟨200,201⟩` +// Functions for reading all elements of an array `a` in deshape order into a pre-allocated buffer. +// Behavior is defined if and only if the input `a` consists of elements whose values losslessly fit in the wanted type. +// e.g. bqn_readObjArr is always defined (assuming `buf` is a valid buffer pointer, and `a` is an array), +// but bqn_readI8Arr is illegal to invoke on `⟨1.2,3.4⟩` or `⟨200,201⟩`, as those overflow a signed 8-bit integer. +// (internal representation of `a` does not matter - e.g. bqn_readI8Arr must succeed on all arrays whose value equals `1‿2‿3`) void bqn_readI8Arr (BQNV a, int8_t* buf); void bqn_readI16Arr(BQNV a, int16_t* buf); void bqn_readI32Arr(BQNV a, int32_t* buf); @@ -51,12 +53,20 @@ void bqn_readC16Arr(BQNV a, uint16_t* buf); void bqn_readC32Arr(BQNV a, uint32_t* buf); void bqn_readObjArr(BQNV a, BQNV* buf); -bool bqn_hasField(BQNV ns, BQNV name); // test if the namespace has the wanted field (result is unspecified if `name` isn't lowercase or has underscores) +bool bqn_hasField(BQNV ns, BQNV name); // test if the namespace has the wanted field BQNV bqn_getField(BQNV ns, BQNV name); // gives the value of the field with the requested name. Assumes the field exists in the namespace. +// The result of bqn_hasField is implementation-defined if `name` has underscores or isn't lowercase, but +// a result of `true` still should always result in a corresponding bqn_getField call succeeding. -// Create objects + + +// Create new BQN objects BQNV bqn_makeF64(double d); BQNV bqn_makeChar(uint32_t c); + +// `shape` must point to `rank` elements; `data` must have `×´shape` readable items. +// The result will contain `data` in deshape order. +// The implementation will copy both buffers, so they can be temporary ones that are freed right after the call. BQNV bqn_makeI8Arr (size_t rank, const size_t* shape, const int8_t* data); BQNV bqn_makeI16Arr(size_t rank, const size_t* shape, const int16_t* data); BQNV bqn_makeI32Arr(size_t rank, const size_t* shape, const int32_t* data); @@ -66,6 +76,7 @@ BQNV bqn_makeC16Arr(size_t rank, const size_t* shape, const uint16_t* data); BQNV bqn_makeC32Arr(size_t rank, const size_t* shape, const uint32_t* data); BQNV bqn_makeObjArr(size_t rank, const size_t* shape, const BQNV* data); // frees the taken elements of data +// Create a vector with length `len`; equivalent to the corresponding bqn_make*Arr function with `rank` 1, and `shape` being a pointer to `len` BQNV bqn_makeI8Vec (size_t len, const int8_t* data); BQNV bqn_makeI16Vec(size_t len, const int16_t* data); BQNV bqn_makeI32Vec(size_t len, const int32_t* data); @@ -74,27 +85,31 @@ BQNV bqn_makeC8Vec (size_t len, const uint8_t* data); BQNV bqn_makeC16Vec(size_t len, const uint16_t* data); BQNV bqn_makeC32Vec(size_t len, const uint32_t* data); BQNV bqn_makeObjVec(size_t len, const BQNV* data); // frees the taken elements of data -BQNV bqn_makeUTF8Str(size_t len, const char* str); // len is the number of chars in str; result item count will be lower if str contains non-ASCII characters +BQNV bqn_makeUTF8Str(size_t len, const char* str); // len is the number of bytes (`char`s) in `str`; result item count will be smaller than `len` if `str` contains non-ASCII characters + + typedef BQNV (*bqn_boundFn1)(BQNV obj, BQNV x); typedef BQNV (*bqn_boundFn2)(BQNV obj, BQNV w, BQNV x); -// When the result is called, the first arg given to `f` will be `obj`, and the rest will be the corresponding BQN arguments +// Creates a BQN function object, which, when called, calls `f` with the first argument being (a copy of) the original `obj` argument, +// and further arguments being the passed ones. The provided `f` is responsible for freeing all its arguments when they're done being used. +// Behavior when calling bqn_makeBoundFn1's result dyadically, or bqn_makeBoundFn2's - monadically - is undefined. BQNV bqn_makeBoundFn1(bqn_boundFn1 f, BQNV obj); BQNV bqn_makeBoundFn2(bqn_boundFn2 f, BQNV obj); -// Direct (zero copy) array item access +// Direct (zero-copy) array item access typedef enum { elt_unk, elt_i8, elt_i16, elt_i32, elt_f64, elt_c8, elt_c16, elt_c32 } BQNElType; // note that more types may be added in the future BQNElType bqn_directArrType(BQNV a); -// A valid implementation of bqn_directArrType would be to always return elt_unk, thus disallowing the use of direct access entirely. +// Note that a valid implementation of bqn_directArrType would be to always return elt_unk, thus disallowing the use of direct access entirely. -// The functions below can only be used if if bqn_directArrType returns the exact equivalent type. -// Mutating the result, or using it after `a` is freed, results in undefined behavior. +// The functions below can only be used only if bqn_directArrType returns the exact type. +// Mutating the result, or reading from it after `a` is freed, results in undefined behavior. // Doing other FFI invocations between a direct access request and the last read from the result is currently allowed in CBQN, -// but that may not be true for an implementation which has a compacting garbage collector. +// but that may not be true for an implementation which has a compacting garbage collector without pinning. const int8_t* bqn_directI8 (BQNV a); const int16_t* bqn_directI16(BQNV a); const int32_t* bqn_directI32(BQNV a); |