From 9eeb22b4e3c36a8eb76b00ea7e294abc82c31a30 Mon Sep 17 00:00:00 2001 From: Oliver Schulz Date: Tue, 4 Apr 2023 09:07:49 +0200 Subject: [PATCH] Use weakdeps on Julia v1.9 --- Project.toml | 10 ++++++++++ ext/StructArraysGPUArraysCoreExt.jl | 19 +++++++++++++++++++ .../StructArraysStaticArraysCoreExt.jl | 11 +++++++++++ src/tables.jl => ext/StructArraysTablesExt.jl | 7 +++++++ src/StructArrays.jl | 19 ++++++------------- 5 files changed, 53 insertions(+), 13 deletions(-) create mode 100644 ext/StructArraysGPUArraysCoreExt.jl rename src/staticarrays_support.jl => ext/StructArraysStaticArraysCoreExt.jl (94%) rename src/tables.jl => ext/StructArraysTablesExt.jl (95%) diff --git a/Project.toml b/Project.toml index c672e08d..736130e4 100644 --- a/Project.toml +++ b/Project.toml @@ -9,6 +9,16 @@ GPUArraysCore = "46192b85-c4d5-4398-a991-12ede77f4527" StaticArraysCore = "1e83bf80-4336-4d27-bf5d-d5a4f845583c" Tables = "bd369af6-aec1-5ad0-b16a-f7cc5008161c" +[weakdeps] +GPUArraysCore = "46192b85-c4d5-4398-a991-12ede77f4527" +StaticArraysCore = "1e83bf80-4336-4d27-bf5d-d5a4f845583c" +Tables = "bd369af6-aec1-5ad0-b16a-f7cc5008161c" + +[extensions] +StructArraysGPUArraysCoreExt = "GPUArraysCore" +StructArraysStaticArraysCoreExt = "StaticArraysCore" +StructArraysTablesExt = "Tables" + [compat] Adapt = "1, 2, 3" DataAPI = "1" diff --git a/ext/StructArraysGPUArraysCoreExt.jl b/ext/StructArraysGPUArraysCoreExt.jl new file mode 100644 index 00000000..2393868e --- /dev/null +++ b/ext/StructArraysGPUArraysCoreExt.jl @@ -0,0 +1,19 @@ +module StructArraysGPUArraysCoreExt + + +using StructArrays +import GPUArraysCore + +# for GPU broadcast +import GPUArraysCore +function GPUArraysCore.backend(::Type{T}) where {T<:StructArray} + backends = map_params(GPUArraysCore.backend, array_types(T)) + backend, others = backends[1], tail(backends) + isconsistent = mapfoldl(isequal(backend), &, others; init=true) + isconsistent || throw(ArgumentError("all component arrays must have the same GPU backend")) + return backend +end +always_struct_broadcast(::GPUArraysCore.AbstractGPUArrayStyle) = true + + +end # module diff --git a/src/staticarrays_support.jl b/ext/StructArraysStaticArraysCoreExt.jl similarity index 94% rename from src/staticarrays_support.jl rename to ext/StructArraysStaticArraysCoreExt.jl index 1af186e8..f585beb0 100644 --- a/src/staticarrays_support.jl +++ b/ext/StructArraysStaticArraysCoreExt.jl @@ -1,3 +1,11 @@ +module StructArraysStaticArraysCoreExt + + +using StructArrays +using StructArrays: StructArrayStyle + +using Base.Broadcast: Broadcasted + using StaticArraysCore: StaticArray, FieldArray, tuple_prod """ @@ -66,3 +74,6 @@ end return map(Base.Fix2(getfield, i), x) end end + + +end # module diff --git a/src/tables.jl b/ext/StructArraysTablesExt.jl similarity index 95% rename from src/tables.jl rename to ext/StructArraysTablesExt.jl index d6ac2248..442f9a39 100644 --- a/src/tables.jl +++ b/ext/StructArraysTablesExt.jl @@ -1,3 +1,7 @@ +module StructArraysTablesExt + + +using StructArrays import Tables Tables.isrowtable(::Type{<:StructArray}) = true @@ -38,3 +42,6 @@ for (f, g) in zip((:append!, :prepend!), (:push!, :pushfirst!)) end end end + + +end # module diff --git a/src/StructArrays.jl b/src/StructArrays.jl index 129dcd82..7244e7ea 100644 --- a/src/StructArrays.jl +++ b/src/StructArrays.jl @@ -12,8 +12,12 @@ include("utils.jl") include("collect.jl") include("sort.jl") include("lazy.jl") -include("tables.jl") -include("staticarrays_support.jl") + +@static if !isdefined(Base, :get_extension) + include("../ext/StructArraysGPUArraysCoreExt.jl") + include("../ext/StructArraysTablesExt.jl") + include("../ext/StructArraysStaticArraysCoreExt.jl") +end # Implement refarray and refvalue to deal with pooled arrays and weakrefstrings effectively import DataAPI: refarray, refvalue @@ -29,15 +33,4 @@ end import Adapt Adapt.adapt_structure(to, s::StructArray) = replace_storage(x->Adapt.adapt(to, x), s) -# for GPU broadcast -import GPUArraysCore -function GPUArraysCore.backend(::Type{T}) where {T<:StructArray} - backends = map_params(GPUArraysCore.backend, array_types(T)) - backend, others = backends[1], tail(backends) - isconsistent = mapfoldl(isequal(backend), &, others; init=true) - isconsistent || throw(ArgumentError("all component arrays must have the same GPU backend")) - return backend -end -always_struct_broadcast(::GPUArraysCore.AbstractGPUArrayStyle) = true - end # module