From 419adaebbd6e18d97fb19d428736736b61fec141 Mon Sep 17 00:00:00 2001 From: Neven Sajko Date: Tue, 23 Apr 2024 23:11:23 +0200 Subject: [PATCH] implement `Base.elsize` for the strided arrays interface Makes `pointer(::FixedSizeArray, ::Int)` work. Fixes #25 --- src/FixedSizeArrays.jl | 6 ++++++ test/runtests.jl | 14 ++++++++++++++ 2 files changed, 20 insertions(+) diff --git a/src/FixedSizeArrays.jl b/src/FixedSizeArrays.jl index 68bea35..5395820 100644 --- a/src/FixedSizeArrays.jl +++ b/src/FixedSizeArrays.jl @@ -76,6 +76,8 @@ end # helper functions +parent_type(::Type{<:FixedSizeArray{T}}) where {T} = Memory{T} + memory_of(m::Memory) = m memory_of(f::FixedSizeArray) = f.mem @@ -143,4 +145,8 @@ Base.@propagate_inbounds Base.copyto!(dst::Memory , src::FixedSizeArray) Base.unsafe_convert(::Type{Ptr{T}}, a::FixedSizeArray{T}) where {T} = Base.unsafe_convert(Ptr{T}, a.mem) +# `elsize`: part of the strided arrays interface, used for `pointer` + +Base.elsize(::Type{A}) where {A<:FixedSizeArray} = Base.elsize(parent_type(A)) + end # module FixedSizeArrays diff --git a/test/runtests.jl b/test/runtests.jl index 7d16cea..dbee5fa 100644 --- a/test/runtests.jl +++ b/test/runtests.jl @@ -237,4 +237,18 @@ end @test M_mul ≈ M * M end end + + @testset "`pointer`" begin + for elem_type ∈ (Int8, Int16, Int32, Int64) + for dim_count ∈ 0:4 + siz = ntuple(Returns(2), dim_count) + arr = FixedSizeArray{elem_type, dim_count}(undef, siz) + @test pointer(arr) === pointer(arr, 1) === pointer(arr, 2) - sizeof(elem_type) + @test (@inferred pointer(arr)) isa Ptr{elem_type} + @test (@inferred pointer(arr, 1)) isa Ptr{elem_type} + @test iszero(allocated(pointer, arr)) + @test iszero(allocated(pointer, arr, 1)) + end + end + end end