Skip to content

Commit

Permalink
Merge pull request #16449 from felipenoris/fn/new-docstrings
Browse files Browse the repository at this point in the history
docstring for @inferred
  • Loading branch information
StefanKarpinski committed May 20, 2016
2 parents bfb0ac6 + 78d703f commit bf1debc
Show file tree
Hide file tree
Showing 2 changed files with 84 additions and 0 deletions.
43 changes: 43 additions & 0 deletions base/test.jl
Original file line number Diff line number Diff line change
Expand Up @@ -782,6 +782,49 @@ macro test_approx_eq(a, b)
:(test_approx_eq($(esc(a)), $(esc(b)), $(string(a)), $(string(b))))
end

"""
@inferred f(x)
Tests that the call expression `f(x)` returns a value of the same type
inferred by the compiler. It's useful to check for type stability.
`f(x)` can be any call expression, except a call for a generated function.
Returns the result of `f(x)` if the types match, and an `Error` `Result` if
it finds different types.
```jldoctest
julia> using Base.Test
julia> f(a,b,c) = b > 1 ? 1 : 1.0
f (generic function with 1 method)
julia> typeof(f(1,2,3))
Int64
julia> @code_warntype f(1,2,3)
Variables:
#self#::#f
a::Int64
b::Int64
c::Int64
Body:
begin # REPL[2], line 1:
unless (Base.slt_int)(1,b::Int64)::Bool goto 4
return 1
4:
return 1.0
end::Union{Float64,Int64}
julia> @inferred f(1,2,3)
ERROR: return type Int64 does not match inferred return type Union{Float64,Int64}
in error(::String) at ./error.jl:21
in eval(::Module, ::Any) at ./boot.jl:226
julia> @inferred max(1,2)
2
```
"""
macro inferred(ex)
ex.head == :call || error("@inferred requires a call expression")
Base.remove_linenums!(quote
Expand Down
41 changes: 41 additions & 0 deletions doc/stdlib/test.rst
Original file line number Diff line number Diff line change
Expand Up @@ -244,6 +244,47 @@ writing new tests.
Test two floating point numbers ``a`` and ``b`` for equality taking in account a margin of tolerance given by ``tol``\ .

.. function:: @inferred f(x)

.. Docstring generated from Julia source
Tests that the call expression ``f(x)`` returns a value of the same type inferred by the compiler. It's useful to check for type stability.

``f(x)`` can be any call expression, except a call for a generated function. Returns the result of ``f(x)`` if the types match, and an ``Error`` ``Result`` if it finds different types.

.. doctest::

julia> using Base.Test

julia> f(a,b,c) = b > 1 ? 1 : 1.0
f (generic function with 1 method)

julia> typeof(f(1,2,3))
Int64

julia> @code_warntype f(1,2,3)
Variables:
#self#::#f
a::Int64
b::Int64
c::Int64

Body:
begin # REPL[2], line 1:
unless (Base.slt_int)(1,b::Int64)::Bool goto 4
return 1
4:
return 1.0
end::Union{Float64,Int64}

julia> @inferred f(1,2,3)
ERROR: return type Int64 does not match inferred return type Union{Float64,Int64}
in error(::String) at ./error.jl:21
in eval(::Module, ::Any) at ./boot.jl:226

julia> @inferred max(1,2)
2

Creating Custom ``AbstractTestSet`` Types
-----------------------------------------

Expand Down

0 comments on commit bf1debc

Please sign in to comment.