From 489ae0a56ea002a90ed5345a84905fee78a7d825 Mon Sep 17 00:00:00 2001 From: Jameson Nash Date: Mon, 21 Sep 2020 16:55:55 -0400 Subject: [PATCH] Revert "Improve typesubtract for tuples (#35600)" (#37562) This reverts commit cf0c3e03eaa16c22a4d371c273a05d88a8a23dbd. (cherry picked from commit b18647edda608d473b049ef2c7a40a9d481f0e2d) --- base/compiler/typeutils.jl | 9 --------- test/compiler/inference.jl | 41 -------------------------------------- 2 files changed, 50 deletions(-) diff --git a/base/compiler/typeutils.jl b/base/compiler/typeutils.jl index d6eb7305b1c8d..ebb06a33a2d74 100644 --- a/base/compiler/typeutils.jl +++ b/base/compiler/typeutils.jl @@ -70,15 +70,6 @@ function typesubtract(@nospecialize(a), @nospecialize(b)) if isa(a, Union) return Union{typesubtract(a.a, b), typesubtract(a.b, b)} - elseif a isa DataType - if b isa DataType - if a.name === b.name === Tuple.name && length(a.types) == length(b.types) - ta = switchtupleunion(a) - if length(ta) > 1 - return typesubtract(Union{ta...}, b) - end - end - end end return a # TODO: improve this bound? end diff --git a/test/compiler/inference.jl b/test/compiler/inference.jl index 4fd9a020252b9..ea74feb0369f8 100644 --- a/test/compiler/inference.jl +++ b/test/compiler/inference.jl @@ -2562,47 +2562,6 @@ end @test map(>:, [Int], [Int]) == [true] -# issue 35566 -module Issue35566 -function step(acc, x) - xs, = acc - y = x > 0.0 ? x : missing - if y isa eltype(xs) - ys = push!(xs, y) - else - ys = vcat(xs, [y]) - end - return (ys,) -end - -function probe(y) - if y isa Tuple{Vector{Missing}} - return Val(:missing) - else - return Val(:expected) - end -end - -function _foldl_iter(rf, val::T, iter, state) where {T} - while true - ret = iterate(iter, state) - ret === nothing && break - x, state = ret - y = rf(val, x) - if y isa T - val = y - else - return probe(y) - end - end - return Val(:expected) -end - -f() = _foldl_iter(step, (Missing[],), [0.0], 1) -end -@test Core.Compiler.typesubtract(Tuple{Union{Int,Char}}, Tuple{Char}) == Tuple{Int} -@test Base.return_types(Issue35566.f) == [Val{:expected}] - # constant prop through keyword arguments _unstable_kw(;x=1,y=2) = x == 1 ? 0 : "" _use_unstable_kw_1() = _unstable_kw(x = 2)