From e5f1dacef2157df47ec96e09d9c204b276b36fe1 Mon Sep 17 00:00:00 2001 From: Charles Kawczynski Date: Thu, 10 Oct 2024 16:45:15 -0400 Subject: [PATCH] Try to fix Undefined Behavior in DataLayouts --- NEWS.md | 2 ++ src/DataLayouts/DataLayouts.jl | 25 +++++++++++++++++-------- 2 files changed, 19 insertions(+), 8 deletions(-) diff --git a/NEWS.md b/NEWS.md index 339b050ce2..3ce9189606 100644 --- a/NEWS.md +++ b/NEWS.md @@ -4,6 +4,8 @@ ClimaCore.jl Release Notes main ------- + - Fixed world-age issue on Julia 1.11 issue [Julia#54780](https://github.com/JuliaLang/julia/issues/54780), PR [#2034](https://github.com/CliMA/ClimaCore.jl/pull/2034). + v0.14.18 ------- diff --git a/src/DataLayouts/DataLayouts.jl b/src/DataLayouts/DataLayouts.jl index 18e9c05206..3410bc74e7 100644 --- a/src/DataLayouts/DataLayouts.jl +++ b/src/DataLayouts/DataLayouts.jl @@ -235,27 +235,29 @@ Base.similar(data::AbstractData{S}) where {S} = similar(data, S) typesize(eltype(parent(data)), S) end +@inline _getproperty(data::AbstractData, ::Val{Name}) where {Name} = + _getproperty(data, Val(Name), Name) + @generated function _getproperty( data::AbstractData{S}, ::Val{Name}, + name, ) where {S, Name} - errorstring = "Invalid field name $(Name) for type $(S)" i = findfirst(isequal(Name), fieldnames(S)) - if i === nothing - return :(error($errorstring)) - end static_idx = Val{i}() - return :(Base.@_inline_meta; DataLayouts._property_view(data, $static_idx)) + return :( + Base.@_inline_meta; DataLayouts._property_view(data, $static_idx, name) + ) end @inline function Base.getproperty(data::AbstractData{S}, name::Symbol) where {S} - _getproperty(data, Val{name}()) + _getproperty(data, Val{name}(), name) end @inline function Base.dotgetproperty( data::AbstractData{S}, name::Symbol, ) where {S} - _getproperty(data, Val{name}()) + _getproperty(data, Val{name}(), name) end Base.@propagate_inbounds function Base.getproperty( @@ -275,11 +277,18 @@ Base.@propagate_inbounds function Base.getproperty( union_all(data){SS, Base.tail(type_params(data))...}(dataview) end +@noinline _property_view( + data::AbstractData{S}, + ::Val{Nothing}, + name, +) where {S} = error("Invalid field name $name for type $(S)") + # In the past, we've sometimes needed a generated function # for inference and constant propagation: Base.@propagate_inbounds @generated function _property_view( data::AD, ::Val{Idx}, + name, ) where {S, Idx, AD <: AbstractData{S}} SS = fieldtype(S, Idx) T = eltype(parent_array_type(AD)) @@ -855,7 +864,7 @@ Base.lastindex(data::VF) = length(data) nlevels(::VF{S, Nv}) where {S, Nv} = Nv Base.@propagate_inbounds Base.getproperty(data::VF, i::Integer) = - _property_view(data, Val(i)) + _property_view(data, Val(i), i) Base.@propagate_inbounds column(data::VF, i, h) = column(data, i, 1, h)