From 9c6feb3a354ce5f31181ab863fbf1a6d3a875208 Mon Sep 17 00:00:00 2001 From: SundaraRaman R Date: Wed, 8 Nov 2023 10:06:34 +0530 Subject: [PATCH] fix: doctests. add doctests for `zip_longest` too. --- docs/make.jl | 3 ++- docs/src/index.md | 6 ------ src/IterTools.jl | 31 +++++++++++++++++++++++++------ 3 files changed, 27 insertions(+), 13 deletions(-) diff --git a/docs/make.jl b/docs/make.jl index f2220f6..1e4dcbd 100644 --- a/docs/make.jl +++ b/docs/make.jl @@ -1,12 +1,13 @@ using Documenter, IterTools +DocMeta.setdocmeta!(IterTools, :DocTestSetup, :(using IterTools)) makedocs( modules = [IterTools], sitename = "IterTools", pages = [ "Docs" => "index.md", ], - doctest=false, + doctest=true, ) deploydocs( diff --git a/docs/src/index.md b/docs/src/index.md index 58559b1..189a45c 100644 --- a/docs/src/index.md +++ b/docs/src/index.md @@ -1,9 +1,3 @@ -```@meta -DocTestSetup = quote - using IterTools -end -``` - # IterTools ## Installation diff --git a/src/IterTools.jl b/src/IterTools.jl index 79895e9..216d4ee 100644 --- a/src/IterTools.jl +++ b/src/IterTools.jl @@ -1106,12 +1106,12 @@ Input: ```jldoctest julia> collect(interleaveby(1:2:5, 2:2:6)) 6-element Vector{Int64}: - 1 - 2 - 3 - 4 - 5 - 6 + 1 + 2 + 3 + 4 + 5 + 6 ``` If the predicate is `Base.isless` (the default) and both inputs are sorted, this produces the sorted output. @@ -1215,6 +1215,25 @@ _zip_longest_promote_shape(a, b) = promote_shape(a, b) For one or more iterable objects, return an iterable of tuples, where the `i`th tuple contains the `i`th component of each input iterable if it is not finished, and `default` otherwise. `default` can be a scalar, or a tuple with one default per iterable. + +```jldoctest +julia> for t in zip_longest(1:2, 5:8) + @show t + end +t = (1, 5) +t = (2, 6) +t = (nothing, 7) +t = (nothing, 8) + +julia> for t in zip_longest('a':'e', ['m', 'n']; default='x') + @show t + end +t = ('a', 'm') +t = ('b', 'n') +t = ('c', 'x') +t = ('d', 'x') +t = ('e', 'x') +``` """ zip_longest(its...; default=nothing) = ZipLongest(Tuple(_Padded.(its, default)))