diff options
author | ubq323 <ubq323@ubq323.website> | 2025-02-22 00:20:52 +0000 |
---|---|---|
committer | ubq323 <ubq323@ubq323.website> | 2025-02-22 00:20:52 +0000 |
commit | 989b6349b0c7e5a0d7ec06d2ca24d629c618fe12 (patch) | |
tree | c424e6eac3ee626db4b4993def6eda4b9292eb66 /xml_old.lua | |
parent | bf776624fb59d147b82d2a6a13c36292844a47b7 (diff) |
Diffstat (limited to 'xml_old.lua')
-rw-r--r-- | xml_old.lua | 48 |
1 files changed, 0 insertions, 48 deletions
diff --git a/xml_old.lua b/xml_old.lua deleted file mode 100644 index a63c0f7..0000000 --- a/xml_old.lua +++ /dev/null @@ -1,48 +0,0 @@ -function parseargs(s) - local arg = {} - string.gsub(s, "([%-%w]+)=([\"'])(.-)%2", function (w, _, a) - arg[w] = a - end) - return arg -end - -function collect(s) - local stack = {} - local top = {} - table.insert(stack, top) - local ni,c,label,xarg, empty - local i, j = 1, 1 - while true do - ni,j,c,label,xarg, empty = string.find(s, "<(%/?)([%w:]+)(.-)(%/?)>", i) - if not ni then break end - local text = string.sub(s, i, ni-1) - if not string.find(text, "^%s*$") then - table.insert(top, text) - end - if empty == "/" then -- empty element tag - table.insert(top, {label=label, xarg=parseargs(xarg), empty=1}) - elseif c == "" then -- start tag - top = {label=label, xarg=parseargs(xarg)} - table.insert(stack, top) -- new level - else -- end tag - local toclose = table.remove(stack) -- remove top - top = stack[#stack] - if #stack < 1 then - error("nothing to close with "..label) - end - if toclose.label ~= label then - error("trying to close "..toclose.label.." with "..label) - end - table.insert(top, toclose) - end - i = j+1 - end - local text = string.sub(s, i) - if not string.find(text, "^%s*$") then - table.insert(stack[#stack], text) - end - if #stack > 1 then - error("unclosed "..stack[#stack].label) - end - return stack[1] -end |