WhereIsMyDocstring.jl

Helping you find and include docstrings in julia
Author thofma
Popularity
5 Stars
Updated Last
3 Months Ago
Started In
August 2024

WhereIsMyDocstring.jl


Dude, where is my docstring?


  • Have you ever wondered, which docstring is included in a ```@docs``` block when writing the documentation?
  • Are you tired of finding the magic syntax to include the right docstring of a method?

Enter: WhereIsMyDocstring.jl

Status

Build Status Coverage Pkg Eval

Installation

Since WhereIsMyDocstring.jl is a registered package, it can be simply installed as follows:

julia> using Pkg; Pkg.install("WhereIsMyDocstring")

Usage

The package provides the @docmatch macro, which allows one to simulate the behaviour of ```@docs``` blocks interactively. This is helpful in case a function has many different methods and docstrings, and one wants to include a specific one. In particular in the presence of type parameters, this can be a frustrating experience due to JuliaLang/julia#29437. Here is a simple example:

julia> using WhereIsMyDocstring

julia> @docmatch sin
2-element Vector{WhereIsMyDocstring.DocStr}:
 Base.sin
  Content:
    sin(x) [...]
  Signature type:
    Tuple{Number}
  Include in ```@docs``` block:
    Base.sin(::Number)
  Source:
   math.jl:490
====================================================================================

 Base.sin
  Content:
    sin(A::AbstractMatrix) [...]
  Signature type:
    Tuple{AbstractMatrix{<:Real}}
  Include in ```@docs``` block:
    Base.sin(::AbstractMatrix{<:Real})
  Source:
   /usr/share/julia/stdlib/v1.10/LinearAlgebra/src/dense.jl:956
====================================================================================

The macro returns the docstrings (including metadata). In view of ```@docs ``` blocks, the most imporant information is the "Include in ..." field. This provides the right invocation to include the specific docstring. For example, if we want to include the second docstring, in our documentation markdown source we would write:

```@docs
Base.sin(::AbstractMatrix{<:Real})
```

A more complicated example is:

julia> "blub"
       function foo(x::Vector{S}, z::Matrix{T} = 1; y::Number = 2) where {S, T <: S}
       end

julia> @docmatch foo
1-element Vector{WhereIsMyDocstring.DocStr}:
 foo
  Content:
    blub [...]
  Signature type:
    Union{Tuple{Vector{S}}, Tuple{T}, Tuple{S}, Tuple{Vector{S}, Matrix{T}}} where {S, T<:S}
  Include in ```@docs``` block:
    foo(::Union{Tuple{Vector{S}}, Tuple{T}, Tuple{S}, Tuple{Vector{S}, Matrix{T}}} where {S, T<:S})
    try the following:
    foo(::Array{S, 1}, ::Array{T, 2}) where {S, T<:S}
  Source:
   REPL[2]:1

Note that the type of the signature is garbled due to JuliaLang/julia#29437. This also messes up the lookup. Here we are warned about this and a suggested way to fix it is provided via foo(::Array{S, 1}, ::Array{T, 2}) where {S, T<:S}.

Used By Packages

No packages found.