summaryrefslogtreecommitdiff
path: root/tex/context/base/verb-tex.lua
blob: ad72fb2115f5e633e934941d4b013e91a1cda8f4 (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
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
-- filename : type-tex.lua
-- comment  : companion to core-buf.tex
-- author   : Hans Hagen, PRAGMA-ADE, Hasselt NL
-- copyright: PRAGMA ADE / ConTeXt Development Team
-- license  : see context related readme files

if not buffers                 then buffers                 = { } end
if not buffers.visualizers     then buffers.visualizers     = { } end
if not buffers.visualizers.tex then buffers.visualizers.tex = { } end

buffers.visualizers.tex.colors = {
    "prettytwo",
    "prettyone",
    "prettythree",
    "prettyfour"
}

buffers.visualizers.tex.states = {
    ['$']=2, ['{']=2, ['}']=2,
    ['[']=3, [']']=3, ['(']=3, [')']=3, ['<']=3, ['>']=3, ['#']=3, ['=']=3, ['"']=3,
    ['/']=4, ['^']=4, ['_']=4, ['-']=4, ['&']=4, ['+']=4, ["'"]=4, ['`']=4, ['|']=4, ['%']=4
}

-- using a table to store the result does not make sense here (actually,
-- it's substantial slower since we're flushing lines on the fly)
--
-- we could use a special catcode regime: only \ { }

function buffers.visualizers.tex.flush_line(str,nested)
    local result, state = { }, 0
    local first, escaping = false, false
    local byte, find = utf.byte, utf.find
    local finish, change = buffers.finish_state, buffers.change_state
    buffers.currentcolors = buffers.visualizers.tex.colors
    for c in str:utfcharacters() do
        if c == " " then
            if escaping then
                result[#result+1] = " "
            else
                state = finish(state, result)
                result[#result+1] = "\\obs "
            end
            escaping, first = false, false
        elseif c == "\t" then
            if escaping then
                result[#result+1] = " "
            else
                state = finish(state, result)
                result[#result+1] = "\\obs "
            end
            if buffers.visualizers.enabletab then
                result[#result+1] = string.rep("\\obs ",i%buffers.visualizers.tablength)
            end
            escaping, first = false, false
        elseif buffers.visualizers.enableescape and (c == buffers.visualizers.escapetoken) then
            if escaping then
                if first then
                    if find(c,"^[%a%!%?%@]$") then
                        result[#result+1] =c
                    else
                        result[#result+1] ="\\char" .. byte(c) .. " "
                    end
                    first = false
                else
                    result[#result+1] = "\\"
                    first = true
                end
            else
                state = finish(state, result)
                result[#result+1] = "\\"
                escaping, first = true, true
            end
        elseif escaping then
            if find(c,"^[%a%!%?%@]$") then
                result[#result+1] = c
            else
                result[#result+1] = "\\char" .. byte(c) .. " "
            end
            first = false
        elseif first then
            state = 1
            if find(c,"^[%a%!%?%@]$") then
                result[#result+1] = c
            else
                result[#result+1] = "\\char" .. byte(c) .. " "
                state = finish(state, result)
            end
            first = false
        elseif state == 1 then
            if find(c,"^[%a%!%?%@]$") then
                result[#result+1] = c
                first = false
            elseif c == "\\" then
                state = change(1, state, result)
                result[#result+1] = "\\char" .. byte(c) .. " "
                first = true
            else
                state = change(buffers.visualizers.tex.states[c], state, result)
                if state == 0 then
                    result[#result+1] = c
                else
                    result[#result+1] = "\\char" .. byte(c) .. " "
                end
                first = false
            end
        elseif c == "\\" then
            first = true
            state = change(1, state, result)
            result[#result+1] = "\\char" .. byte(c) .. " "
        else
            state = change(buffers.visualizers.tex.states[c], state, result)
            if state == 0 then
                result[#result+1] = c
            else
                result[#result+1] = "\\char" .. byte(c) .. " "
            end
            first = false
        end
    end
    state = finish(state, result)
    buffers.flush_result(result,nested)
end