summaryrefslogtreecommitdiff
path: root/tex/context/base/mult-ini.lua
blob: 1eee9a6569d6866c5586b625d6fa5f18fc391afc (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
if not modules then modules = { } end modules ['mult-ini'] = {
    version   = 1.001,
    comment   = "companion to mult-ini.tex",
    author    = "Hans Hagen, PRAGMA-ADE, Hasselt NL",
    copyright = "PRAGMA ADE / ConTeXt Development Team",
    license   = "see context related readme files"
}

local format, gmatch = string.format, string.gmatch

interfaces           = interfaces           or { }
interfaces.messages  = interfaces.messages  or { }
interfaces.constants = interfaces.constants or { }
interfaces.variables = interfaces.variables or { }

storage.register("interfaces/messages",  interfaces.messages,  "interfaces.messages" )
storage.register("interfaces/constants", interfaces.constants, "interfaces.constants")
storage.register("interfaces/variables", interfaces.variables, "interfaces.variables")

function interfaces.setmessages(category,str)
    local m = interfaces.messages[category] or { }
    for k, v in gmatch(str,"(%S+) *: *(.-) *[\n\r]") do
        m[k] = v:gsub("%-%-","%%s")
    end
    interfaces.messages[category] = m
end

function interfaces.setmessage(category,tag,message)
    local m = interfaces.messages[category]
    if not m then
        m = { }
        interfaces.messages[category] = m
    end
    m[tag] = message:gsub("%-%-","%%s")
end

function interfaces.getmessage(category,tag)
    local m = interfaces.messages[category]
    return (m and m[tag]) or "unknown message"
end

local messagesplitter = lpeg.splitat(",")

function interfaces.makemessage(category,tag,arguments)
    local m = interfaces.messages[category]
    m = (m and m[tag] ) or format("unknown message, category '%s', tag '%s'",category,tag)
    if not m then
        return m .. " " .. tag
    elseif not arguments then
        return m
    else
        return format(m,messagesplitter:match(arguments))
    end
end

function interfaces.showmessage(category,tag,arguments)
    local m = interfaces.messages[category]
    commands.writestatus((m and m.title) or "unknown title",interfaces.makemessage(category,tag,arguments))
end

function interfaces.setvariable(variable,given)
    interfaces.variables[given] = variable
end

function interfaces.setconstant(constant,given)
    interfaces.constants[given] = constant
end