Skip to content

Commit

Permalink
Rename `similar_dims to WithDims, same for units
Browse files Browse the repository at this point in the history
  • Loading branch information
RomeoV committed Nov 20, 2023
1 parent 74a73d1 commit bd9126e
Show file tree
Hide file tree
Showing 2 changed files with 14 additions and 14 deletions.
24 changes: 12 additions & 12 deletions src/utils.jl
Original file line number Diff line number Diff line change
Expand Up @@ -244,47 +244,47 @@ struct DimensionError <: Exception
end

"""
similar_dims(q::Quantity)
similar_dims(u::Units)
WithDims(q::Quantity)
WithDims(u::Units)
Returns a type of [`Unitful.Quantity`](@ref) with the dimensions contrained to the
dimension of `q` or `u`.
Useful to build unitful interfaces that don't contrain the numeric type of the specific unit.
Examples:
```jldoctest
julia> circumference_of_square(side::similar_dims(u"m")) = 4*side;
julia> circumference_of_square(side::WithDims(u"m")) = 4*side;
julia> circumference_of_square((1//2)m) # works
2//1 m
julia> circumference_of_square((1//2)km) # also works
2//1 km
```
See also [`Unitful.similar_units`](@ref).
See also [`Unitful.WithUnits`](@ref).
"""
similar_dims(q::Quantity) = Quantity{T, dimension(q), U} where {T<:Real, U<:Unitlike}
similar_dims(u::Units) = Quantity{T, dimension(u), U} where {T<:Real, U<:Unitlike}
WithDims(q::Quantity) = Quantity{T, dimension(q), U} where {T<:Real, U<:Unitlike}
WithDims(u::Units) = Quantity{T, dimension(u), U} where {T<:Real, U<:Unitlike}

"""
similar_units(q::Quantity)
similar_units(u::Units)
WithUnits(q::Quantity)
WithUnits(u::Units)
Returns a type of [`Unitful.Quantity`](@ref) with the dimensions and units contrained to the
dimension and units of `q` or `u`.
Useful to build unitful interfaces that don't contrain the numeric type.
Examples:
```jldoctest
julia> circumference_of_square(side::similar_units(u"m")) = 4*side;
julia> circumference_of_square(side::WithUnits(u"m")) = 4*side;
julia> circumference_of_square((1//2)m) # works
2//1 m
julia> # circumference_of_square((1//2)km) # doesn't work, constrained to exactly meters
```
See also [`Unitful.similar_dims`](@ref).
See also [`Unitful.WithDims`](@ref).
"""
similar_units(q::Quantity) = Quantity{T, dimension(q), unit(q)} where {T<:Real}
similar_units(u::Units) = Quantity{T, dimension(u), typeof(u)} where {T<:Real}
WithUnits(q::Quantity) = Quantity{T, dimension(q), unit(q)} where {T<:Real}
WithUnits(u::Units) = Quantity{T, dimension(u), typeof(u)} where {T<:Real}

Base.showerror(io::IO, e::DimensionError) =
print(io, "DimensionError: $(e.x) and $(e.y) are not dimensionally compatible.");
Expand Down
4 changes: 2 additions & 2 deletions test/runtests.jl
Original file line number Diff line number Diff line change
Expand Up @@ -2080,8 +2080,8 @@ Base.OrderStyle(::Type{Num}) = Base.Unordered()
# Test that @generated functions work with Quantities + custom types (#231)
@test uconvert(u"°C", Num(373.15)u"K") == Num(100)u"°C"
end
area_of_circle(radius::similar_dims(u"m")) = pi*radius^2
area_of_square(side::similar_units(u"m")) = side^2
area_of_circle(radius::WithDims(u"m")) = pi*radius^2
area_of_square(side::WithUnits(u"m")) = side^2

@testset "Unitful interfaces" begin
@test area_of_circle(Num(1.0)u"m") pi*m^2
Expand Down

0 comments on commit bd9126e

Please sign in to comment.