From 68349aa20ec93b0ef8e75b65dc95fcbbaae1129f Mon Sep 17 00:00:00 2001 From: Max Horn Date: Mon, 25 Nov 2024 00:15:14 +0100 Subject: [PATCH] Remove convert method to OrderedDict The generic one in Julia stdlib does the job, except for the deprecation warning shown when converting from an unordered dict (such as `Base.Dict`) to an `OrderedDict{K,V}` type. This avoids potential invalidations in packages. There also is no explanation as to why it makes sense to forbids such conversions. --- src/ordered_dict.jl | 18 ------------------ 1 file changed, 18 deletions(-) diff --git a/src/ordered_dict.jl b/src/ordered_dict.jl index d08e715..e847c4f 100644 --- a/src/ordered_dict.jl +++ b/src/ordered_dict.jl @@ -95,24 +95,6 @@ defined order (such as `OrderedDict` and `SortedDict`), and `false` otherwise. isordered(::Type{T}) where {T<:AbstractDict} = false isordered(::Type{T}) where {T<:OrderedDict} = true -# conversion between OrderedDict types -function convert(::Type{OrderedDict{K,V}}, d::AbstractDict) where {K,V} - d isa OrderedDict{K, V} && return d - if !isordered(typeof(d)) - Base.depwarn("Conversion to OrderedDict is deprecated for unordered associative containers (in this case, $(typeof(d))). Use an ordered or sorted associative type, such as SortedDict and OrderedDict.", :convert) - end - h = OrderedDict{K,V}() - for (k,v) in d - ck = convert(K,k) - if !haskey(h,ck) - h[ck] = convert(V,v) - else - error("key collision during dictionary conversion") - end - end - return h -end - isslotempty(slot_value::Integer) = slot_value == 0 isslotfilled(slot_value::Integer) = slot_value > 0 isslotmissing(slot_value::Integer) = slot_value < 0