• Home
  • Features
  • Pricing
  • Docs
  • Announcements
  • Sign In

JuliaLang / julia / #37601

20 Aug 2023 01:36AM UTC coverage: 86.512% (+0.09%) from 86.427%
#37601

push

local

web-flow
Use rr-safe `nopl; rdtsc` sequence (#50975)

When running under `rr`, it needs to patch out `rdtsc` to record the
values returned. If this is not possible, `rr` falls back to an
expensive signal-based emulation. As of rr master, a specific `nopl;
rdtsc` sequence may be used to guarantee that `rdtsc` patching is always
possible. Use this sequence for uses of rdtsc in our runtime.

73270 of 84693 relevant lines covered (86.51%)

9871265.56 hits per line

Source File
Press 'n' to go to next uncovered line, 'b' for previous

84.31
/stdlib/Markdown/src/parse/parse.jl
1
# This file is a part of Julia. License is MIT: https://julialang.org/license
2

3
mutable struct MD
4
    content::Vector{Any}
5
    meta::Dict{Symbol, Any}
6

7
    MD(content::AbstractVector, meta::Dict = Dict()) =
35,539✔
8
        new(content, meta)
9
end
10

11
MD(xs...) = MD(vcat(xs...))
10,898✔
12

13
function MD(cfg::Config, xs...)
×
14
    md = MD(xs...)
10,647✔
15
    md.meta[:config] = cfg
10,647✔
16
    return md
10,647✔
17
end
18

19
config(md::MD) = md.meta[:config]::Config
44,896✔
20

21
# Forward some array methods
22

23
Base.push!(md::MD, x) = push!(md.content, x)
27,210✔
24
Base.getindex(md::MD, args...) = md.content[args...]
×
25
Base.setindex!(md::MD, args...) = setindex!(md.content, args...)
×
26
Base.lastindex(md::MD) = lastindex(md.content)
×
27
Base.firstindex(md::MD) = firstindex(md.content)
×
28
Base.length(md::MD) = length(md.content)
×
29
Base.isempty(md::MD) = isempty(md.content)
×
30
Base.copy(md::MD) = MD(copy(md.content), copy(md.meta))
×
31

32
==(a::MD, b::MD) = (html(a) == html(b))
9✔
33

34
# Parser functions:
35
#   md – should be modified appropriately
36
#   return – basically, true if parse was successful
37
#     false uses the next parser in the queue, true
38
#     goes back to the beginning
39
#
40
# Inner parsers:
41
#   return – element to use or nothing
42

43
# Inner parsing
44

45
function parseinline(stream::IO, md::MD, parsers::Vector{Function})
49,530✔
46
    for parser in parsers
49,530✔
47
        inner = parser(stream, md)
56,481✔
48
        inner ≡ nothing || return inner
101,846✔
49
    end
11,116✔
50
end
51

52
function parseinline(stream::IO, md::MD, config::Config)
26,042✔
53
    content = []
26,042✔
54
    buffer = IOBuffer()
26,042✔
55
    while !eof(stream)
1,861,438✔
56
        char = peek(stream, Char)
1,835,396✔
57
        if haskey(config.inner, char) &&
1,835,396✔
58
                (inner = parseinline(stream, md, config.inner[char])) !== nothing
59
            c = String(take!(buffer))
45,365✔
60
            !isempty(c) && push!(content, c)
45,365✔
61
            buffer = IOBuffer()
45,365✔
62
            push!(content, inner)
45,365✔
63
        else
64
            write(buffer, read(stream, Char))
1,790,031✔
65
        end
66
    end
1,835,396✔
67
    c = String(take!(buffer))
26,042✔
68
    !isempty(c) && push!(content, c)
26,042✔
69
    return content
26,042✔
70
end
71

72
parseinline(s::AbstractString, md::MD, c::Config) =
7,412✔
73
    parseinline(IOBuffer(s), md, c)
74

75
parseinline(s, md::MD) = parseinline(s, md, config(md))
26,042✔
76

77
# Block parsing
78

79
function parse(stream::IO, block::MD, config::Config; breaking = false)
116,034✔
80
    skipblank(stream)
58,017✔
81
    eof(stream) && return false
58,017✔
82
    for parser in (breaking ? config.breaking : [config.breaking; config.regular])
47,370✔
83
        parser(stream, block) && return true
363,645✔
84
    end
350,789✔
85
    return false
17,257✔
86
end
87

88
parse(stream::IO, block::MD; breaking = false) =
35,516✔
89
  parse(stream, block, config(block), breaking = breaking)
90

91
function parse(stream::IO; flavor = julia)
21,294✔
92
    isa(flavor, Symbol) && (flavor = flavors[flavor])
78✔
93
    markdown = MD(flavor)
10,647✔
94
    while parse(stream, markdown, flavor) end
69,871✔
95
    return markdown
10,647✔
96
end
STATUS · Troubleshooting · Open an Issue · Sales · Support · CAREERS · ENTERPRISE · START FREE · SCHEDULE DEMO
ANNOUNCEMENTS · TWITTER · TOS & SLA · Supported CI Services · What's a CI service? · Automated Testing

© 2026 Coveralls, Inc