From ec35e2f651960e21bda0ae07bc84493dcb60951e Mon Sep 17 00:00:00 2001 From: Simon Byrne Date: Wed, 1 Nov 2023 13:15:50 -0700 Subject: [PATCH] fix variable length strings as attributes --- src/attributes.jl | 9 +++++++-- test/attributes.jl | 11 +++++++++++ 2 files changed, 18 insertions(+), 2 deletions(-) diff --git a/src/attributes.jl b/src/attributes.jl index 0c683224a..9af867dd1 100644 --- a/src/attributes.jl +++ b/src/attributes.jl @@ -173,8 +173,13 @@ end function write_attribute(attr::Attribute, memtype::Datatype, str::AbstractString) strbuf = Base.cconvert(Cstring, str) GC.@preserve strbuf begin - buf = Base.unsafe_convert(Ptr{UInt8}, strbuf) - write_attribute(attr, memtype, buf) + if API.h5t_is_variable_str(memtype) + ptr = Base.unsafe_convert(Cstring, strbuf) + write_attribute(attr, memtype, Ref(ptr)) + else + ptr = Base.unsafe_convert(Ptr{UInt8}, strbuf) + write_attribute(attr, memtype, ptr) + end end end function write_attribute( diff --git a/test/attributes.jl b/test/attributes.jl index b2a710289..f94b97cf9 100644 --- a/test/attributes.jl +++ b/test/attributes.jl @@ -69,3 +69,14 @@ end close(f) end end + + +@testset "variable length strings" begin + filename = tempname() + h5open(filename, "w") do f + # https://github.com/JuliaIO/HDF5.jl/issues/1129 + attr = create_attribute(f, "attr-name", datatype(String), dataspace(String)) + write_attribute(attr, datatype(String), "attr-value") + @test attrs(f)["attr-name"] == "attr-value" + end +end \ No newline at end of file