mirror of
https://github.com/ggerganov/llama.cpp
synced 2026-03-05 14:49:45 +01:00
The C API in llama.h claims users can implement `llama_sampler_i` to create custom `llama_sampler`. The sampler chain takes ownership and calls `llama_sampler_free` on them. However, `llama_sampler_free` is hard-coded to use `delete`. This is undefined behavior if the object wasn't also allocated via `new` from libllama's C++ runtime. Callers in C and C-compatible languages do not use C++'s `new` operator. C++ callers may not be sharing the same heap as libllama. |
||
|---|---|---|
| .. | ||
| llama-cpp.h | ||
| llama.h | ||