mirror of
https://github.com/tursodatabase/libsql.git
synced 2025-06-17 11:29:49 +00:00
.cargo
.github
bindings
bottomless
bottomless-cli
docker-compose
docs
libsql
libsql-ffi
libsql-hrana
libsql-replication
libsql-server
libsql-shell
libsql-sqlite3
art
autoconf
contrib
crates
doc
ext
async
crr
expert
fts3
fts5
icu
jni
libsql-wasi
lsm1
lsm-test
test
tool
Makefile
Makefile.msc
lsm.h
lsmInt.h
lsm_ckpt.c
lsm_file.c
lsm_log.c
lsm_main.c
lsm_mem.c
lsm_mutex.c
lsm_shared.c
lsm_sorted.c
lsm_str.c
lsm_tree.c
lsm_unix.c
lsm_varint.c
lsm_vtab.c
lsm_win32.c
misc
rbu
recover
repair
rtree
session
udf
userauth
vwal
wasi
wasm
README.md
mptest
src
test
tool
vsixtest
.gitignore
Dockerfile-wasm-udf
LIBSQL_VERSION
LICENSE.md
Makefile.in
Makefile.linux-gcc
Makefile.msc
README-SQLite.md
VERSION
aclocal.m4
config.guess
config.sub
configure
configure.ac
install-sh
libsql.pc.in
ltmain.sh
magic.txt
main.mk
manifest
manifest.uuid
spec.template
sqlite.pc.in
sqlite3.1
sqlite3.pc.in
sqlite_cfg.h.in
libsql-sys
tools
vendored
xtask
.dockerignore
.env
.gitignore
.gitmodules
CODE_OF_CONDUCT.md
Cargo.lock
Cargo.toml
Dockerfile
Dockerfile.dev
LICENSE.md
README-libsql.md
README.md
docker-entrypoint.sh
fly.toml
rust-toolchain.toml
105 lines
2.3 KiB
C
105 lines
2.3 KiB
C
/*
|
|
** 2011-08-18
|
|
**
|
|
** The author disclaims copyright to this source code. In place of
|
|
** a legal notice, here is a blessing:
|
|
**
|
|
** May you do good and not evil.
|
|
** May you find forgiveness for yourself and forgive others.
|
|
** May you share freely, never taking more than you give.
|
|
**
|
|
*************************************************************************
|
|
**
|
|
** Helper routines for memory allocation.
|
|
*/
|
|
#include "lsmInt.h"
|
|
|
|
/*
|
|
** The following routines are called internally by LSM sub-routines. In
|
|
** this case a valid environment pointer must be supplied.
|
|
*/
|
|
void *lsmMalloc(lsm_env *pEnv, size_t N){
|
|
assert( pEnv );
|
|
return pEnv->xMalloc(pEnv, N);
|
|
}
|
|
void lsmFree(lsm_env *pEnv, void *p){
|
|
assert( pEnv );
|
|
pEnv->xFree(pEnv, p);
|
|
}
|
|
void *lsmRealloc(lsm_env *pEnv, void *p, size_t N){
|
|
assert( pEnv );
|
|
return pEnv->xRealloc(pEnv, p, N);
|
|
}
|
|
|
|
/*
|
|
** Core memory allocation routines for LSM.
|
|
*/
|
|
void *lsm_malloc(lsm_env *pEnv, size_t N){
|
|
return lsmMalloc(pEnv ? pEnv : lsm_default_env(), N);
|
|
}
|
|
void lsm_free(lsm_env *pEnv, void *p){
|
|
lsmFree(pEnv ? pEnv : lsm_default_env(), p);
|
|
}
|
|
void *lsm_realloc(lsm_env *pEnv, void *p, size_t N){
|
|
return lsmRealloc(pEnv ? pEnv : lsm_default_env(), p, N);
|
|
}
|
|
|
|
void *lsmMallocZero(lsm_env *pEnv, size_t N){
|
|
void *pRet;
|
|
assert( pEnv );
|
|
pRet = lsmMalloc(pEnv, N);
|
|
if( pRet ) memset(pRet, 0, N);
|
|
return pRet;
|
|
}
|
|
|
|
void *lsmMallocRc(lsm_env *pEnv, size_t N, int *pRc){
|
|
void *pRet = 0;
|
|
if( *pRc==LSM_OK ){
|
|
pRet = lsmMalloc(pEnv, N);
|
|
if( pRet==0 ){
|
|
*pRc = LSM_NOMEM_BKPT;
|
|
}
|
|
}
|
|
return pRet;
|
|
}
|
|
|
|
void *lsmMallocZeroRc(lsm_env *pEnv, size_t N, int *pRc){
|
|
void *pRet = 0;
|
|
if( *pRc==LSM_OK ){
|
|
pRet = lsmMallocZero(pEnv, N);
|
|
if( pRet==0 ){
|
|
*pRc = LSM_NOMEM_BKPT;
|
|
}
|
|
}
|
|
return pRet;
|
|
}
|
|
|
|
void *lsmReallocOrFree(lsm_env *pEnv, void *p, size_t N){
|
|
void *pNew;
|
|
pNew = lsm_realloc(pEnv, p, N);
|
|
if( !pNew ) lsm_free(pEnv, p);
|
|
return pNew;
|
|
}
|
|
|
|
void *lsmReallocOrFreeRc(lsm_env *pEnv, void *p, size_t N, int *pRc){
|
|
void *pRet = 0;
|
|
if( *pRc ){
|
|
lsmFree(pEnv, p);
|
|
}else{
|
|
pRet = lsmReallocOrFree(pEnv, p, N);
|
|
if( !pRet ) *pRc = LSM_NOMEM_BKPT;
|
|
}
|
|
return pRet;
|
|
}
|
|
|
|
char *lsmMallocStrdup(lsm_env *pEnv, const char *zIn){
|
|
int nByte;
|
|
char *zRet;
|
|
nByte = strlen(zIn);
|
|
zRet = lsmMalloc(pEnv, nByte+1);
|
|
if( zRet ){
|
|
memcpy(zRet, zIn, nByte+1);
|
|
}
|
|
return zRet;
|
|
}
|