Skip to content

Commit 2230f79

Browse files
authored
LazyString in interpolated error messages involving types (#54737)
These are often badly inferred, e.g. in: ```julia julia> @report_opt 2//2 ┌ Warning: skipping (::Base.var"#show_bound#661")(io::IO, b) @ Base show.jl:2777 to avoid parsing too much code └ @ Revise ~/.julia/packages/Revise/bAgL0/src/packagedef.jl:1092 ┌ Warning: skipping (::Base.var"#show_bound#661")(io::IO, b) @ Base show.jl:2777 to avoid parsing too much code └ @ Revise ~/.julia/packages/Revise/bAgL0/src/packagedef.jl:1092 ═════ 32 possible errors found ═════ ┌ //(n::Int64, d::Int64) @ Base ./rational.jl:84 │┌ Rational(n::Int64, d::Int64) @ Base ./rational.jl:48 ││┌ Rational{Int64}(num::Int64, den::Int64) @ Base ./rational.jl:32 │││┌ __throw_rational_argerror_zero(T::Type{Int64}) @ Base ./rational.jl:30 ││││┌ string(::String, ::Type{Int64}, ::String, ::Type{Int64}, ::String) @ Base ./strings/io.jl:189 │││││┌ print_to_string(::String, ::Type{Int64}, ::String, ::Type{Int64}, ::String) @ Base ./strings/io.jl:148 ││││││┌ print(io::IOBuffer, x::DataType) @ Base ./strings/io.jl:35 │││││││┌ show(io::IOBuffer, x::DataType) @ Base ./show.jl:970 ││││││││┌ _show_type(io::IOBuffer, x::Type) @ Base ./show.jl:975 │││││││││┌ show_typealias(io::IOBuffer, x::Type) @ Base ./show.jl:810 ││││││││││┌ make_typealias(x::Type) @ Base ./show.jl:620 │││││││││││┌ modulesof!(s::Set{Module}, x::Type) @ Base ./show.jl:595 ││││││││││││ runtime dispatch detected: Base.modulesof!(s::Set{Module}, %20::Any)::Any │││││││││││└──────────────────── │││││││││││┌ modulesof!(s::Set{Module}, x::Type) @ Base ./show.jl:596 ││││││││││││ runtime dispatch detected: Base.modulesof!(s::Set{Module}, %34::Any)::Any │││││││││││└──────────────────── │││││││││││┌ modulesof!(s::Set{Module}, x::TypeVar) @ Base ./show.jl:589 ││││││││││││ runtime dispatch detected: Base.modulesof!(s::Set{Module}, %1::Any)::Set{Module} │││││││││││└──────────────────── │││││││││┌ show_typealias(io::IOBuffer, x::Type) @ Base ./show.jl:813 ││││││││││┌ show_typealias(io::IOBuffer, name::GlobalRef, x::Type, env::Core.SimpleVector, wheres::Vector{TypeVar}) @ Base ./show.jl:760 │││││││││││┌ show_typeparams(io::IOContext{IOBuffer}, env::Core.SimpleVector, orig::Core.SimpleVector, wheres::Vector{TypeVar}) @ Base ./show.jl:724 ││││││││││││┌ show(io::IOContext{IOBuffer}, tv::TypeVar) @ Base ./show.jl:2788 │││││││││││││┌ (::Base.var"#show_bound#661")(io::IOContext{IOBuffer}, b::Any) @ Base ./show.jl:2780 ││││││││││││││ runtime dispatch detected: show(io::IOContext{IOBuffer}, b::Any)::Any │││││││││││││└──────────────────── │││││││││││┌ show_typeparams(io::IOContext{IOBuffer}, env::Core.SimpleVector, orig::Core.SimpleVector, wheres::Vector{TypeVar}) @ Base ./show.jl:719 ││││││││││││ runtime dispatch detected: show(io::IOContext{IOBuffer}, %252::Any)::Any │││││││││││└──────────────────── │││││││││││┌ show_typeparams(io::IOContext{IOBuffer}, env::Core.SimpleVector, orig::Core.SimpleVector, wheres::Vector{TypeVar}) @ Base ./show.jl:722 ││││││││││││ runtime dispatch detected: show(io::IOContext{IOBuffer}, %313::Any)::Any │││││││││││└──────────────────── │││││││││││┌ show_typeparams(io::IOContext{IOBuffer}, env::Core.SimpleVector, orig::Core.SimpleVector, wheres::Vector{TypeVar}) @ Base ./show.jl:727 ││││││││││││ runtime dispatch detected: show(io::IOContext{IOBuffer}, %191::Any)::Any │││││││││││└──────────────────── ││││││││┌ _show_type(io::IOBuffer, x::Type) @ Base ./show.jl:978 │││││││││┌ show_datatype(io::IOBuffer, x::DataType) @ Base ./show.jl:1094 ││││││││││┌ show_datatype(io::IOBuffer, x::DataType, wheres::Vector{TypeVar}) @ Base ./show.jl:1097 │││││││││││┌ maybe_kws_nt(x::DataType) @ Base ./show.jl:1085 ││││││││││││ runtime dispatch detected: eltype(%76::DataType)::Any │││││││││││└──────────────────── ││││││││││┌ show_datatype(io::IOBuffer, x::DataType, wheres::Vector{TypeVar}) @ Base ./show.jl:1186 │││││││││││┌ show_typeparams(io::IOBuffer, env::Core.SimpleVector, orig::Core.SimpleVector, wheres::Vector{TypeVar}) @ Base ./show.jl:724 ││││││││││││┌ show(io::IOBuffer, tv::TypeVar) @ Base ./show.jl:2788 │││││││││││││┌ (::Base.var"#show_bound#661")(io::IOBuffer, b::Any) @ Base ./show.jl:2780 ││││││││││││││ runtime dispatch detected: show(io::IOBuffer, b::Any)::Any │││││││││││││└──────────────────── │││││││││││┌ show_typeparams(io::IOBuffer, env::Core.SimpleVector, orig::Core.SimpleVector, wheres::Vector{TypeVar}) @ Base ./show.jl:719 ││││││││││││ runtime dispatch detected: show(io::IOBuffer, %250::Any)::Any │││││││││││└──────────────────── │││││││││││┌ show_typeparams(io::IOBuffer, env::Core.SimpleVector, orig::Core.SimpleVector, wheres::Vector{TypeVar}) @ Base ./show.jl:722 ││││││││││││ runtime dispatch detected: show(io::IOBuffer, %310::Any)::Any │││││││││││└──────────────────── │││││││││││┌ show_typeparams(io::IOBuffer, env::Core.SimpleVector, orig::Core.SimpleVector, wheres::Vector{TypeVar}) @ Base ./show.jl:727 ││││││││││││ runtime dispatch detected: show(io::IOBuffer, %190::Any)::Any │││││││││││└──────────────────── ││││││││││┌ show_datatype(io::IOBuffer, x::DataType, wheres::Vector{TypeVar}) @ Base ./show.jl:1157 │││││││││││ runtime dispatch detected: show(io::IOBuffer, %224::Any)::Any ││││││││││└──────────────────── ││││││││││┌ show_datatype(io::IOBuffer, x::DataType, wheres::Vector{TypeVar}) @ Base ./show.jl:1162 │││││││││││ runtime dispatch detected: show(io::IOBuffer, %54::Any)::Any ││││││││││└──────────────────── ││││││││││┌ show_datatype(io::IOBuffer, x::DataType, wheres::Vector{TypeVar}) @ Base ./show.jl:1148 │││││││││││ runtime dispatch detected: show(io::IOBuffer, %57::Any)::Any ││││││││││└──────────────────── ││││││││││┌ show_datatype(io::IOBuffer, x::DataType, wheres::Vector{TypeVar}) @ Base ./show.jl:1150 │││││││││││ runtime dispatch detected: show(io::IOBuffer, %54::Any)::Any ││││││││││└──────────────────── ││││││││││┌ show_datatype(io::IOBuffer, x::DataType, wheres::Vector{TypeVar}) @ Base ./show.jl:1172 │││││││││││ runtime dispatch detected: Base.show_at_namedtuple(io::IOBuffer, %329::Tuple, %328::DataType)::Any ││││││││││└──────────────────── ││││││││┌ _show_type(io::IOBuffer, x::Type) @ Base ./show.jl:981 │││││││││┌ show_unionaliases(io::IOBuffer, x::Union) @ Base ./show.jl:901 ││││││││││┌ make_typealiases(x::Union) @ Base ./show.jl:822 │││││││││││┌ modulesof!(s::Set{Module}, x::Union) @ Base ./show.jl:595 ││││││││││││ runtime dispatch detected: Base.modulesof!(s::Set{Module}, %3::Any)::Any │││││││││││└──────────────────── │││││││││││┌ modulesof!(s::Set{Module}, x::Union) @ Base ./show.jl:596 ││││││││││││ runtime dispatch detected: Base.modulesof!(s::Set{Module}, %17::Any)::Any │││││││││││└──────────────────── │││││││││┌ show_unionaliases(io::IOBuffer, x::Union) @ Base ./show.jl:914 ││││││││││ runtime dispatch detected: show(io::IOBuffer, %89::Any)::Any │││││││││└──────────────────── │││││││││┌ show_unionaliases(io::IOBuffer, x::Union) @ Base ./show.jl:920 ││││││││││ runtime dispatch detected: Base.show_typealias(io::IOBuffer, %206::Any, x::Union, %204::Core.SimpleVector, %205::Vector{TypeVar})::Any │││││││││└──────────────────── │││││││││┌ show_unionaliases(io::IOBuffer, x::Union) @ Base ./show.jl:928 ││││││││││ runtime dispatch detected: Base.show_typealias(io::IOBuffer, %269::Any, x::Union, %267::Core.SimpleVector, %268::Vector{TypeVar})::Any │││││││││└──────────────────── ││││││││┌ _show_type(io::IOBuffer, x::Type) @ Base ./show.jl:985 │││││││││┌ show_delim_array(io::IOBuffer, itr::Vector{Any}, op::Char, delim::Char, cl::Char, delim_one::Bool) @ Base ./show.jl:1392 ││││││││││┌ show_delim_array(io::IOBuffer, itr::Vector{Any}, op::Char, delim::Char, cl::Char, delim_one::Bool, i1::Int64, l::Int64) @ Base ./show.jl:1403 │││││││││││ runtime dispatch detected: show(%3::IOContext{IOBuffer}, %52::Any)::Any ││││││││││└──────────────────── ││││││││┌ _show_type(io::IOBuffer, x::Type) @ Base ./show.jl:1012 │││││││││┌ show_datatype(io::IOContext{IOBuffer}, x::DataType, wheres::Vector{TypeVar}) @ Base ./show.jl:1185 ││││││││││┌ show_type_name(io::IOContext{IOBuffer}, tn::Core.TypeName) @ Base ./show.jl:1059 │││││││││││ runtime dispatch detected: Base.isvisible(%29::Symbol, %86::Module, %80::Any)::Bool ││││││││││└──────────────────── │││││││││┌ show_datatype(io::IOContext{IOBuffer}, x::DataType, wheres::Vector{TypeVar}) @ Base ./show.jl:1157 ││││││││││ runtime dispatch detected: show(io::IOContext{IOBuffer}, %227::Any)::Any │││││││││└──────────────────── │││││││││┌ show_datatype(io::IOContext{IOBuffer}, x::DataType, wheres::Vector{TypeVar}) @ Base ./show.jl:1162 ││││││││││ runtime dispatch detected: show(io::IOContext{IOBuffer}, %55::Any)::Any │││││││││└──────────────────── │││││││││┌ show_datatype(io::IOContext{IOBuffer}, x::DataType, wheres::Vector{TypeVar}) @ Base ./show.jl:1148 ││││││││││ runtime dispatch detected: show(io::IOContext{IOBuffer}, %58::Any)::Any │││││││││└──────────────────── │││││││││┌ show_datatype(io::IOContext{IOBuffer}, x::DataType, wheres::Vector{TypeVar}) @ Base ./show.jl:1150 ││││││││││ runtime dispatch detected: show(io::IOContext{IOBuffer}, %55::Any)::Any │││││││││└──────────────────── │││││││││┌ show_datatype(io::IOContext{IOBuffer}, x::DataType, wheres::Vector{TypeVar}) @ Base ./show.jl:1172 ││││││││││ runtime dispatch detected: Base.show_at_namedtuple(io::IOContext{IOBuffer}, %338::Tuple, %337::DataType)::Any │││││││││└──────────────────── │││││││││┌ show_datatype(io::IOContext{IOBuffer}, x::DataType, wheres::Vector{TypeVar}) @ Base ./show.jl:1180 ││││││││││ runtime dispatch detected: Base.show_at_namedtuple(io::IOContext{IOBuffer}, %387::Tuple, %391::DataType)::Any │││││││││└──────────────────── ││││││││┌ _show_type(io::IOBuffer, x::Type) @ Base ./show.jl:1014 │││││││││ runtime dispatch detected: show(%98::IOContext{IOBuffer}, %99::Any)::Any ││││││││└──────────────────── │││││││┌ show(io::IOBuffer, x::DataType) @ Base ./show.jl:970 ││││││││ runtime dispatch detected: Base._show_type(io::IOBuffer, %1::Any)::Nothing │││││││└──────────────────── ``` I haven't looked through all instances thoroughly, just a quick `grep`. However, this PR should address several common cases.
1 parent ee651f4 commit 2230f79

13 files changed

+37
-33
lines changed

base/Enums.jl

+11-10
Original file line numberDiff line numberDiff line change
@@ -90,7 +90,7 @@ end
9090
# give Enum types scalar behavior in broadcasting
9191
Base.broadcastable(x::Enum) = Ref(x)
9292

93-
@noinline enum_argument_error(typename, x) = throw(ArgumentError(string("invalid value for Enum $(typename): $x")))
93+
@noinline enum_argument_error(typename, x) = throw(ArgumentError(LazyString("invalid value for Enum ", typename, ": ", x)))
9494

9595
"""
9696
@enum EnumName[::BaseType] value1[=x] value2[=y]
@@ -143,18 +143,19 @@ julia> Symbol(apple)
143143
"""
144144
macro enum(T::Union{Symbol,Expr}, syms...)
145145
if isempty(syms)
146-
throw(ArgumentError("no arguments given for Enum $T"))
146+
throw(ArgumentError(LazyString("no arguments given for Enum ", T)))
147147
end
148148
basetype = Int32
149149
typename = T
150150
if isa(T, Expr) && T.head === :(::) && length(T.args) == 2 && isa(T.args[1], Symbol)
151151
typename = T.args[1]
152152
basetype = Core.eval(__module__, T.args[2])
153153
if !isa(basetype, DataType) || !(basetype <: Integer) || !isbitstype(basetype)
154-
throw(ArgumentError("invalid base type for Enum $typename, $T=::$basetype; base type must be an integer primitive type"))
154+
throw(ArgumentError(
155+
LazyString("invalid base type for Enum ", typename, ", ", T, "=::", basetype, "; base type must be an integer primitive type")))
155156
end
156157
elseif !isa(T, Symbol)
157-
throw(ArgumentError("invalid type expression for enum $T"))
158+
throw(ArgumentError(LazyString("invalid type expression for enum ", T)))
158159
end
159160
values = Vector{basetype}()
160161
seen = Set{Symbol}()
@@ -169,32 +170,32 @@ macro enum(T::Union{Symbol,Expr}, syms...)
169170
s isa LineNumberNode && continue
170171
if isa(s, Symbol)
171172
if i == typemin(basetype) && !isempty(values)
172-
throw(ArgumentError("overflow in value \"$s\" of Enum $typename"))
173+
throw(ArgumentError(LazyString("overflow in value \"", s, "\" of Enum ", typename)))
173174
end
174175
elseif isa(s, Expr) &&
175176
(s.head === :(=) || s.head === :kw) &&
176177
length(s.args) == 2 && isa(s.args[1], Symbol)
177178
i = Core.eval(__module__, s.args[2]) # allow exprs, e.g. uint128"1"
178179
if !isa(i, Integer)
179-
throw(ArgumentError("invalid value for Enum $typename, $s; values must be integers"))
180+
throw(ArgumentError(LazyString("invalid value for Enum ", typename, ", ", s, "; values must be integers")))
180181
end
181182
i = convert(basetype, i)
182183
s = s.args[1]
183184
hasexpr = true
184185
else
185-
throw(ArgumentError(string("invalid argument for Enum ", typename, ": ", s)))
186+
throw(ArgumentError(LazyString("invalid argument for Enum ", typename, ": ", s)))
186187
end
187188
s = s::Symbol
188189
if !Base.isidentifier(s)
189-
throw(ArgumentError("invalid name for Enum $typename; \"$s\" is not a valid identifier"))
190+
throw(ArgumentError(LazyString("invalid name for Enum ", typename, "; \"", s, "\" is not a valid identifier")))
190191
end
191192
if hasexpr && haskey(namemap, i)
192-
throw(ArgumentError("both $s and $(namemap[i]) have value $i in Enum $typename; values must be unique"))
193+
throw(ArgumentError(LazyString("both ", s, " and ", namemap[i], " have value ", i, " in Enum ", typename, "; values must be unique")))
193194
end
194195
namemap[i] = s
195196
push!(values, i)
196197
if s in seen
197-
throw(ArgumentError("name \"$s\" in Enum $typename is not unique"))
198+
throw(ArgumentError(LazyString("name \"", s, "\" in Enum ", typename, " is not unique")))
198199
end
199200
push!(seen, s)
200201
if length(values) == 1

base/abstractarray.jl

+9-7
Original file line numberDiff line numberDiff line change
@@ -748,7 +748,7 @@ julia> checkindex(Bool, 1:20, 21)
748748
false
749749
```
750750
"""
751-
checkindex(::Type{Bool}, inds, i) = throw(ArgumentError("unable to check bounds for indices of type $(typeof(i))"))
751+
checkindex(::Type{Bool}, inds, i) = throw(ArgumentError(LazyString("unable to check bounds for indices of type ", typeof(i))))
752752
checkindex(::Type{Bool}, inds::AbstractUnitRange, i::Real) = (first(inds) <= i) & (i <= last(inds))
753753
checkindex(::Type{Bool}, inds::IdentityUnitRange, i::Real) = checkindex(Bool, inds.indices, i)
754754
checkindex(::Type{Bool}, inds::OneTo{T}, i::T) where {T<:BitInteger} = unsigned(i - one(i)) < unsigned(last(inds))
@@ -1541,12 +1541,14 @@ much more common case where aliasing does not occur. By default,
15411541
unaliascopy(A::Array) = copy(A)
15421542
unaliascopy(A::AbstractArray)::typeof(A) = (@noinline; _unaliascopy(A, copy(A)))
15431543
_unaliascopy(A::T, C::T) where {T} = C
1544-
_unaliascopy(A, C) = throw(ArgumentError("""
1545-
an array of type `$(typename(typeof(A)).wrapper)` shares memory with another argument
1546-
and must make a preventative copy of itself in order to maintain consistent semantics,
1547-
but `copy(::$(typeof(A)))` returns a new array of type `$(typeof(C))`.
1548-
To fix, implement:
1549-
`Base.unaliascopy(A::$(typename(typeof(A)).wrapper))::typeof(A)`"""))
1544+
function _unaliascopy(A, C)
1545+
Aw = typename(typeof(A)).wrapper
1546+
throw(ArgumentError(LazyString("an array of type `", Aw, "` shares memory with another argument ",
1547+
"and must make a preventative copy of itself in order to maintain consistent semantics, ",
1548+
"but `copy(::", typeof(A), ")` returns a new array of type `", typeof(C), "`.\n",
1549+
"""To fix, implement:
1550+
`Base.unaliascopy(A::""", Aw, ")::typeof(A)`")))
1551+
end
15501552
unaliascopy(A) = A
15511553

15521554
"""

base/c.jl

+1-1
Original file line numberDiff line numberDiff line change
@@ -344,7 +344,7 @@ function ccall_macro_lower(convention, func, rettype, types, args, nreq)
344344
check = quote
345345
if !isa(func, Ptr{Cvoid})
346346
name = $name
347-
throw(ArgumentError("interpolated function `$name` was not a Ptr{Cvoid}, but $(typeof(func))"))
347+
throw(ArgumentError(LazyString("interpolated function `", name, "` was not a Ptr{Cvoid}, but ", typeof(func))))
348348
end
349349
end
350350
push!(statements, check)

base/indices.jl

+2-2
Original file line numberDiff line numberDiff line change
@@ -310,9 +310,9 @@ to_index(I::AbstractArray{Bool}) = LogicalIndex(I)
310310
to_index(I::AbstractArray) = I
311311
to_index(I::AbstractArray{Union{}}) = I
312312
to_index(I::AbstractArray{<:Union{AbstractArray, Colon}}) =
313-
throw(ArgumentError("invalid index: $(limitrepr(I)) of type $(typeof(I))"))
313+
throw(ArgumentError(LazyString("invalid index: ", limitrepr(I), " of type ", typeof(I))))
314314
to_index(::Colon) = throw(ArgumentError("colons must be converted by to_indices(...)"))
315-
to_index(i) = throw(ArgumentError("invalid index: $(limitrepr(i)) of type $(typeof(i))"))
315+
to_index(i) = throw(ArgumentError(LazyString("invalid index: ", limitrepr(i), " of type ", typeof(i))))
316316

317317
# The general to_indices is mostly defined in multidimensional.jl, but this
318318
# definition is required for bootstrap:

base/intfuncs.jl

+2-2
Original file line numberDiff line numberDiff line change
@@ -956,7 +956,7 @@ julia> bitstring(2.2)
956956
```
957957
"""
958958
function bitstring(x::T) where {T}
959-
isprimitivetype(T) || throw(ArgumentError("$T not a primitive type"))
959+
isprimitivetype(T) || throw(ArgumentError(LazyString(T, " not a primitive type")))
960960
sz = sizeof(T) * 8
961961
str = StringMemory(sz)
962962
i = sz
@@ -1056,7 +1056,7 @@ julia> digits!([2, 2, 2, 2, 2, 2], 10, base = 2)
10561056
function digits!(a::AbstractVector{T}, n::Integer; base::Integer = 10) where T<:Integer
10571057
2 <= abs(base) || throw(DomainError(base, "base must be ≥ 2 or ≤ -2"))
10581058
hastypemax(T) && abs(base) - 1 > typemax(T) &&
1059-
throw(ArgumentError("type $T too small for base $base"))
1059+
throw(ArgumentError(LazyString("type ", T, " too small for base ", base)))
10601060
isempty(a) && return a
10611061

10621062
if base > 0

base/io.jl

+1-1
Original file line numberDiff line numberDiff line change
@@ -1426,7 +1426,7 @@ previously marked position. Throw an error if the stream is not marked.
14261426
See also [`mark`](@ref), [`unmark`](@ref), [`ismarked`](@ref).
14271427
"""
14281428
function reset(io::T) where T<:IO
1429-
ismarked(io) || throw(ArgumentError("$T not marked"))
1429+
ismarked(io) || throw(ArgumentError(LazyString(T, " not marked")))
14301430
m = io.mark
14311431
seek(io, m)
14321432
io.mark = -1 # must be after seek, or seek may fail

base/iterators.jl

+3-3
Original file line numberDiff line numberDiff line change
@@ -15,7 +15,7 @@ using .Base:
1515
AbstractRange, AbstractUnitRange, UnitRange, LinearIndices, TupleOrBottom,
1616
(:), |, +, -, *, !==, !, ==, !=, <=, <, >, >=, =>, missing,
1717
any, _counttuple, eachindex, ntuple, zero, prod, reduce, in, firstindex, lastindex,
18-
tail, fieldtypes, min, max, minimum, zero, oneunit, promote, promote_shape
18+
tail, fieldtypes, min, max, minimum, zero, oneunit, promote, promote_shape, LazyString
1919
using Core: @doc
2020

2121
if Base !== Core.Compiler
@@ -1097,15 +1097,15 @@ _prod_size(t::Tuple) = (_prod_size1(t[1], IteratorSize(t[1]))..., _prod_size(tai
10971097
_prod_size1(a, ::HasShape) = size(a)
10981098
_prod_size1(a, ::HasLength) = (length(a),)
10991099
_prod_size1(a, A) =
1100-
throw(ArgumentError("Cannot compute size for object of type $(typeof(a))"))
1100+
throw(ArgumentError(LazyString("Cannot compute size for object of type ", typeof(a))))
11011101

11021102
axes(P::ProductIterator) = _prod_indices(P.iterators)
11031103
_prod_indices(::Tuple{}) = ()
11041104
_prod_indices(t::Tuple) = (_prod_axes1(t[1], IteratorSize(t[1]))..., _prod_indices(tail(t))...)
11051105
_prod_axes1(a, ::HasShape) = axes(a)
11061106
_prod_axes1(a, ::HasLength) = (OneTo(length(a)),)
11071107
_prod_axes1(a, A) =
1108-
throw(ArgumentError("Cannot compute indices for object of type $(typeof(a))"))
1108+
throw(ArgumentError(LazyString("Cannot compute indices for object of type ", typeof(a))))
11091109

11101110
ndims(p::ProductIterator) = length(axes(p))
11111111
length(P::ProductIterator) = reduce(checked_mul, size(P); init=1)

base/multidimensional.jl

+1-1
Original file line numberDiff line numberDiff line change
@@ -592,7 +592,7 @@ module IteratorsMD
592592
else
593593
# Given the fact that StepRange 1:2:4 === 1:2:3, we lost the original size information
594594
# and thus cannot calculate the correct linear indices when the steps are not 1.
595-
throw(ArgumentError("LinearIndices for $(typeof(inds)) with non-1 step size is not yet supported."))
595+
throw(ArgumentError(LazyString("LinearIndices for ", typeof(inds), " with non-1 step size is not yet supported.")))
596596
end
597597
end
598598

base/parse.jl

+1-1
Original file line numberDiff line numberDiff line change
@@ -386,7 +386,7 @@ function tryparse_internal(::Type{T}, s::AbstractString, raise::Bool; kwargs...)
386386
return result
387387
end
388388
@noinline _parse_failure(T, s::AbstractString, startpos = firstindex(s), endpos = lastindex(s)) =
389-
throw(ArgumentError("cannot parse $(repr(s[startpos:endpos])) as $T"))
389+
throw(ArgumentError(LazyString("cannot parse ", repr(s[startpos:endpos]), " as ", T)))
390390

391391
tryparse_internal(::Type{T}, s::AbstractString, startpos::Int, endpos::Int, raise::Bool) where T<:Integer =
392392
tryparse_internal(T, s, startpos, endpos, 10, raise)

base/rational.jl

+1-1
Original file line numberDiff line numberDiff line change
@@ -27,7 +27,7 @@ end
2727
checked_den(num::T, den::T) where T<:Integer = checked_den(T, num, den)
2828
checked_den(num::Integer, den::Integer) = checked_den(promote(num, den)...)
2929

30-
@noinline __throw_rational_argerror_zero(T) = throw(ArgumentError("invalid rational: zero($T)//zero($T)"))
30+
@noinline __throw_rational_argerror_zero(T) = throw(ArgumentError(LazyString("invalid rational: zero(", T, ")//zero(", T, ")")))
3131
function Rational{T}(num::Integer, den::Integer) where T<:Integer
3232
iszero(den) && iszero(num) && __throw_rational_argerror_zero(T)
3333
if T <: Union{Unsigned, Bool}

base/sort.jl

+1-1
Original file line numberDiff line numberDiff line change
@@ -2478,7 +2478,7 @@ function _sort!(v::AbstractVector, a::Algorithm, o::Ordering, kw)
24782478
@getkw lo hi scratch legacy_dispatch_entry
24792479
if legacy_dispatch_entry === a
24802480
# This error prevents infinite recursion for unknown algorithms
2481-
throw(ArgumentError("Base.Sort._sort!(::$(typeof(v)), ::$(typeof(a)), ::$(typeof(o)), ::Any) is not defined"))
2481+
throw(ArgumentError(LazyString("Base.Sort._sort!(::", typeof(v), ", ::", typeof(a), ", ::", typeof(o), ", ::Any) is not defined")))
24822482
else
24832483
sort!(v, lo, hi, a, o)
24842484
scratch

base/subarray.jl

+3-2
Original file line numberDiff line numberDiff line change
@@ -437,7 +437,8 @@ substrides(strds::Tuple{}, ::Tuple{}) = ()
437437
substrides(strds::NTuple{N,Int}, I::Tuple{ScalarIndex, Vararg{Any}}) where N = (substrides(tail(strds), tail(I))...,)
438438
substrides(strds::NTuple{N,Int}, I::Tuple{Slice, Vararg{Any}}) where N = (first(strds), substrides(tail(strds), tail(I))...)
439439
substrides(strds::NTuple{N,Int}, I::Tuple{AbstractRange, Vararg{Any}}) where N = (first(strds)*step(I[1]), substrides(tail(strds), tail(I))...)
440-
substrides(strds, I::Tuple{Any, Vararg{Any}}) = throw(ArgumentError("strides is invalid for SubArrays with indices of type $(typeof(I[1]))"))
440+
substrides(strds, I::Tuple{Any, Vararg{Any}}) = throw(ArgumentError(
441+
LazyString("strides is invalid for SubArrays with indices of type ", typeof(I[1]))))
441442

442443
stride(V::SubArray, d::Integer) = d <= ndims(V) ? strides(V)[d] : strides(V)[end] * size(V)[end]
443444

@@ -449,7 +450,7 @@ compute_stride1(s, inds, I::Tuple{ScalarIndex, Vararg{Any}}) =
449450
(@inline; compute_stride1(s*length(inds[1]), tail(inds), tail(I)))
450451
compute_stride1(s, inds, I::Tuple{AbstractRange, Vararg{Any}}) = s*step(I[1])
451452
compute_stride1(s, inds, I::Tuple{Slice, Vararg{Any}}) = s
452-
compute_stride1(s, inds, I::Tuple{Any, Vararg{Any}}) = throw(ArgumentError("invalid strided index type $(typeof(I[1]))"))
453+
compute_stride1(s, inds, I::Tuple{Any, Vararg{Any}}) = throw(ArgumentError(LazyString("invalid strided index type ", typeof(I[1]))))
453454

454455
elsize(::Type{<:SubArray{<:Any,<:Any,P}}) where {P} = elsize(P)
455456

base/tuple.jl

+1-1
Original file line numberDiff line numberDiff line change
@@ -459,7 +459,7 @@ _totuple(::Type{Tuple{}}, itr, s...) = ()
459459

460460
function _totuple_err(@nospecialize T)
461461
@noinline
462-
throw(ArgumentError("too few elements for tuple type $T"))
462+
throw(ArgumentError(LazyString("too few elements for tuple type ", T)))
463463
end
464464

465465
function _totuple(::Type{T}, itr, s::Vararg{Any,N}) where {T,N}

0 commit comments

Comments
 (0)