summaryrefslogtreecommitdiff
path: root/tex/context/base/mkiv/meta-nod.lua
blob: 422b4ee14d27232f3ec7a519ccd46c7a45b2e8d6 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
if not modules then modules = { } end modules ['meta-nod'] = {
    version   = 1.001,
    comment   = "companion to meta-nod.mkiv",
    author    = "Hans Hagen, PRAGMA-ADE, Hasselt NL",
    copyright = "PRAGMA ADE / ConTeXt Development Team",
    license   = "see context related readme files"
}

local tonumber = tonumber
local P, R, Cs, lpegmatch = lpeg.P, lpeg.R, lpeg.Cs, lpeg.match

local references = { }
local trace      = false
local report     = logs.reporter("metapost","nodes")

local context    = context
local implement  = interfaces.implement

trackers.register("metapost.nodes", function(v) trace = v end)

local word     = R("AZ","az","__")^1

local pattern = Cs (
    (
        word / function(s) return references[s] or s end
      + P("{") / "["
      + P("}") / "]"
      + P(1)
    )^1
)

implement {
    name    = "grph_nodes_initialize",
    actions = function()
        references = { }
    end
}

implement {
    name    = "grph_nodes_reset",
    actions = function()
        references = { }
    end
}

implement {
    name      = "grph_nodes_register",
    arguments = { "string", "integer" },
    actions   = function(s,r)
        if not tonumber(s) then
            if trace then
                report("register %i as %a",t,s)
            end
            references[s] = r
        end
    end
}

implement {
    name      = "grph_nodes_resolve",
    arguments = "string",
    actions   = function(s)
        local r = references[s]
        if r then
            if trace then
                report("resolve %a to %i",s,r)
            end
            context(r)
            return
        end
        local n = lpegmatch(pattern,s)
        if s ~= n then
            if trace then
                report("resolve '%s' to %s",s,n)
            end
            context(n)
            return
        end
        context(s)
    end
}