diff --git a/base/nullable.jl b/base/nullable.jl index dfcec4f68dd3e..cece014371893 100644 --- a/base/nullable.jl +++ b/base/nullable.jl @@ -46,10 +46,10 @@ function show{T}(io::IO, x::Nullable{T}) end """ - get(x::Nullable[, y]) + get(x::Nullable, y) Attempt to access the value of `x`. Returns the value if it is present; -otherwise, returns `y` if provided, or throws a `NullException` if not. +otherwise, returns `y`. """ @inline function get{S,T}(x::Nullable{S}, y::T) if isbits(S) @@ -59,7 +59,22 @@ otherwise, returns `y` if provided, or throws a `NullException` if not. end end -get(x::Nullable) = isnull(x) ? throw(NullException()) : x.value +""" + getindex(x::Nullable) + +Attempt to access the value of `x`. Throw a `NullException` if the value is not +present. Usually, this is written as `x[]`. +""" +getindex(x::Nullable) = isnull(x) ? throw(NullException()) : x.value + +""" + get(x::Nullable) + +Attempt to access the value of `x`. Throw a `NullException` if the value is not +present. Equivalent to `getindex(x::Nullable)`, which can alternatively be +written as `x[]`. +""" +get(x::Nullable) = x[] """ unsafe_get(x) diff --git a/doc/stdlib/base.rst b/doc/stdlib/base.rst index 435c662775994..c56991bb9ebc5 100644 --- a/doc/stdlib/base.rst +++ b/doc/stdlib/base.rst @@ -822,11 +822,17 @@ Nullables Wrap value ``x`` in an object of type ``Nullable``\ , which indicates whether a value is present. ``Nullable(x)`` yields a non-empty wrapper, and ``Nullable{T}()`` yields an empty instance of a wrapper that might contain a value of type ``T``\ . -.. function:: get(x::Nullable[, y]) +.. function:: get(x::Nullable, y) .. Docstring generated from Julia source - Attempt to access the value of ``x``\ . Returns the value if it is present; otherwise, returns ``y`` if provided, or throws a ``NullException`` if not. + Attempt to access the value of ``x``\ . Returns the value if it is present; otherwise, returns ``y``\ . + +.. function:: getindex(x::Nullable) + + .. Docstring generated from Julia source + + Attempt to access the value of ``x``\ . Throw a ``NullException`` if the value is not present. Usually, this is written as ``x[]``\ . .. function:: isnull(x) diff --git a/test/nullable.jl b/test/nullable.jl index 819cd4a5871ce..cb1f83c7ff37f 100644 --- a/test/nullable.jl +++ b/test/nullable.jl @@ -140,11 +140,13 @@ for T in types x3 = Nullable(one(T)) @test_throws NullException get(x1) - @test get(x2) === zero(T) - @test get(x3) === one(T) + @test_throws NullException x1[] + @test get(x2) === x2[] === zero(T) + @test get(x3) === x3[] === one(T) end @test_throws NullException get(Nullable()) +@test_throws NullException Nullable()[] # get{S, T}(x::Nullable{S}, y::T) for T in types