Skip to content

Commit

Permalink
Add the get!(d::LMDBDict, key, default), `get(f::Function, d::LMDBD…
Browse files Browse the repository at this point in the history
…ict, key)`, and `get!(f::Function, d::LMDBDict, key)` methods
  • Loading branch information
DilumAluthge committed Sep 1, 2022
1 parent 94f4542 commit fd893b2
Show file tree
Hide file tree
Showing 2 changed files with 83 additions and 1 deletion.
52 changes: 52 additions & 0 deletions src/dicts.jl
Original file line number Diff line number Diff line change
Expand Up @@ -117,6 +117,58 @@ function Base.get(d::LMDBDict{K,V}, key, default) where {K,V}
end
end

function Base.get!(d::LMDBDict{K,V}, key, default) where {K,V}
txn_dbi_do(d, readonly = true) do txn, dbi
mdb_key_ref = Ref(MDBValue(toref(convert(K,key))))
mdb_val_ref = Ref(MDBValue())
# Get value
ret = _mdb_get(txn.handle, dbi.handle, mdb_key_ref, mdb_val_ref)
if ret == MDB_NOTFOUND
d[key] = default
return default
elseif ret == Cint(0)
return mbd_unpack(V, mdb_val_ref)
else
throw(LMDB.LMDBError(ret))
end
end
end

function Base.get(f::F, d::LMDBDict{K,V}, key) where {K,V,F<:Union{Function, Type}}
txn_dbi_do(d, readonly = true) do txn, dbi
mdb_key_ref = Ref(MDBValue(toref(convert(K,key))))
mdb_val_ref = Ref(MDBValue())
# Get value
ret = _mdb_get(txn.handle, dbi.handle, mdb_key_ref, mdb_val_ref)
if ret == MDB_NOTFOUND
default = f()
return default
elseif ret == Cint(0)
return mbd_unpack(V, mdb_val_ref)
else
throw(LMDB.LMDBError(ret))
end
end
end

function Base.get!(f::F, d::LMDBDict{K,V}, key) where {K,V,F<:Union{Function, Type}}
txn_dbi_do(d, readonly = true) do txn, dbi
mdb_key_ref = Ref(MDBValue(toref(convert(K,key))))
mdb_val_ref = Ref(MDBValue())
# Get value
ret = _mdb_get(txn.handle, dbi.handle, mdb_key_ref, mdb_val_ref)
if ret == MDB_NOTFOUND
default = f()
d[key] = default
return default
elseif ret == Cint(0)
return mbd_unpack(V, mdb_val_ref)
else
throw(LMDB.LMDBError(ret))
end
end
end

function Base.setindex!(d::LMDBDict{K,V},v,k) where {K,V}
txn_dbi_do(d) do txn, dbi
LMDB.put!(txn,dbi,convert(K,k),convert(V,v))
Expand Down
32 changes: 31 additions & 1 deletion test/dict.jl
Original file line number Diff line number Diff line change
Expand Up @@ -49,4 +49,34 @@ d["b"] = [0,0,0]
@test LMDB.list_dirs(d) == ["aa/", "b"]
@test LMDB.list_dirs(d,prefix="aa/") == ["aa/a", "aa/b", "aa/c"]
@test LMDB.valuesize(d,prefix="aa/") == sizeof(Float32)*18
end

@testset "Tests for get and get!" begin
mktempdir() do dir
d = LMDBDict{String, String}(dir)
@test !haskey(d, "foo")
@test get(d, "foo", "bar") == "bar"
@test !haskey(d, "foo")
@test get!(d, "foo", "bar") == "bar"
@test haskey(d, "foo")
@test d["foo"] == "bar"
@test get(d, "foo", "hello") == "bar"
@test d["foo"] == "bar"
@test get!(d, "foo", "hello") == "bar"
@test d["foo"] == "bar"
end
mktempdir() do dir
d = LMDBDict{String, String}(dir)
@test !haskey(d, "foo")
@test get(() -> "bar", d, "foo") == "bar"
@test !haskey(d, "foo")
@test get!(() -> "bar", d, "foo") == "bar"
@test haskey(d, "foo")
@test d["foo"] == "bar"
@test get(() -> "hello", d, "foo") == "bar"
@test d["foo"] == "bar"
@test get!(() -> "hello", d, "foo") == "bar"
@test d["foo"] == "bar"
end
end

end

0 comments on commit fd893b2

Please sign in to comment.