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

sile-typesetter / sile / 14684598788

26 Apr 2025 07:55PM UTC coverage: 29.023% (-36.3%) from 65.328%
14684598788

push

github

alerque
test(fonts): Update test to work on new ICU instead of old

5840 of 20122 relevant lines covered (29.02%)

379.34 hits per line

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

72.13
/inputters/xml.lua
1
local base = require("inputters.base")
8✔
2
local lxp = require("lxp")
8✔
3

4
local inputter = pl.class(base)
8✔
5
inputter._name = "xml"
8✔
6

7
inputter.order = 2
8✔
8

9
local function startcommand (parser, command, options)
10
   -- Discard list values (non-key/value), stuffed by LXP/expat to make it possible to deduce the order of keys in
11
   -- the source. We're not using it, so we don't care and it is clutter in the AST that makes it different from
12
   -- ASTs generated from SIL inputs.
13
   for i = 1, #options do
1✔
14
      options[i] = nil
×
15
   end
16
   local stack = parser:getcallbacks().stack
1✔
17
   local lno, col, pos = parser:pos()
1✔
18
   local position = { lno = lno, col = col, pos = pos }
1✔
19
   -- create an empty command which content will be filled on closing tag
20
   local element = SU.ast.createCommand(command, options, nil, position)
1✔
21
   table.insert(stack, element)
1✔
22
end
23

24
local function endcommand (parser, command)
25
   local stack = parser:getcallbacks().stack
1✔
26
   local element = table.remove(stack)
1✔
27
   assert(element.command == command)
1✔
28
   local level = #stack
1✔
29
   table.insert(stack[level], element)
1✔
30
end
31

32
local function text (parser, msg)
33
   local stack = parser:getcallbacks().stack
1✔
34
   local element = stack[#stack]
1✔
35
   local n = #element
1✔
36
   if type(element[n]) == "string" then
1✔
37
      element[n] = element[n] .. msg
×
38
   else
39
      table.insert(element, msg)
1✔
40
   end
41
end
42

43
local function parse (doc)
44
   local content = {
1✔
45
      StartElement = startcommand,
1✔
46
      EndElement = endcommand,
1✔
47
      CharacterData = text,
1✔
48
      _nonstrict = true,
49
      stack = { {} },
1✔
50
   }
51
   local parser = lxp.new(content)
1✔
52
   local status, err
53
   if type(doc) == "string" then
1✔
54
      status, err = parser:parse(doc)
1✔
55
      if not status then
1✔
56
         return nil, err
×
57
      end
58
   else
59
      for element in pairs(doc) do
×
60
         status, err = parser:parse(element)
×
61
         if not status then
×
62
            return nil, err
×
63
         end
64
      end
65
   end
66
   status, err = parser:parse()
1✔
67
   if not status then
1✔
68
      return nil, err
×
69
   end
70
   parser:close()
1✔
71
   return content.stack[1][1]
1✔
72
end
73

74
function inputter.appropriate (round, filename, doc)
8✔
75
   if round == 1 then
8✔
76
      return filename:match(".xml$")
8✔
77
   elseif round == 2 then
×
78
      local sniff = doc:sub(1, 100):gsub("begin.*", "") or ""
×
79
      local promising = sniff:match("<")
×
80
      return promising and inputter.appropriate(3, filename, doc)
×
81
   elseif round == 3 then
×
82
      local _, err = parse(doc)
×
83
      return not err
×
84
   end
85
end
86

87
function inputter:parse (doc)
8✔
88
   local tree, err = parse(doc)
1✔
89
   if not tree then
1✔
90
      SU.error(err)
×
91
   end
92
   -- XML documents can have any root element, and it should be up to the class
93
   -- to supply handling far whatever that element that is in a specific format.
94
   -- Hence we wrap the actual DOM in an extra element of our own if and only if
95
   -- it doesn't look like a native SILE one already.
96
   local rootelement = tree.command
1✔
97
   if rootelement ~= "sile" and rootelement ~= "document" then
1✔
98
      tree = SU.ast.createCommand("document", {}, tree)
×
99
   end
100
   return { tree }
1✔
101
end
102

103
return inputter
8✔
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

© 2025 Coveralls, Inc