From c98958b4eeddc5d4742106410e23cce7bd9f5c27 Mon Sep 17 00:00:00 2001 From: MilesCranmer Date: Tue, 21 Nov 2023 01:54:34 +0000 Subject: [PATCH] Fix ambiguity in `div` --- src/math.jl | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/src/math.jl b/src/math.jl index 8922d307..e666d000 100644 --- a/src/math.jl +++ b/src/math.jl @@ -1,4 +1,5 @@ for (type, base_type, _) in ABSTRACT_QUANTITY_TYPES + div_base_type = type == AbstractGenericQuantity ? Number : base_type @eval begin function Base.:*(l::$type, r::$type) l, r = promote_except_value(l, r) @@ -20,7 +21,7 @@ for (type, base_type, _) in ABSTRACT_QUANTITY_TYPES function Base.:/(l::$type, r::$base_type) new_quantity(typeof(l), ustrip(l) / r, dimension(l)) end - function Base.div(x::$type, y::$base_type, r::RoundingMode=RoundToZero) + function Base.div(x::$type, y::$div_base_type, r::RoundingMode=RoundToZero) new_quantity(typeof(x), div(ustrip(x), y, r), dimension(x)) end @@ -30,7 +31,7 @@ for (type, base_type, _) in ABSTRACT_QUANTITY_TYPES function Base.:/(l::$base_type, r::$type) new_quantity(typeof(r), l / ustrip(r), inv(dimension(r))) end - function Base.div(x::$base_type, y::$type, r::RoundingMode=RoundToZero) + function Base.div(x::$div_base_type, y::$type, r::RoundingMode=RoundToZero) new_quantity(typeof(y), div(x, ustrip(y), r), inv(dimension(y))) end