File: GLib-Markup.lua

package info (click to toggle)
lua-lgi 0.9.2-7
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 1,388 kB
  • sloc: ansic: 5,082; makefile: 169; sh: 31
file content (112 lines) | stat: -rw-r--r-- 3,742 bytes parent folder | download | duplicates (6)
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
-------------------------------------------------------------------------------
--
-- LGI GLib MarkupParser support implementation.
--
-- Copyright (c) 2013 Pavel Holejsovsky
-- Licensed under the MIT license:
-- http://www.opensource.org/licenses/mit-license.php
--
-------------------------------------------------------------------------------

local pairs, ipairs, setmetatable, select =
   pairs, ipairs, setmetatable, select

local lgi = require 'lgi'
local core = require 'lgi.core'
local record = require 'lgi.record'
local component = require 'lgi.component'
local ffi = require 'lgi.ffi'
local ti = ffi.types

local MarkupParser = lgi.GLib.MarkupParser
local MarkupParseContext = lgi.GLib.MarkupParseContext

local parser_guard = setmetatable({}, { __mode = 'k' })
local parser_field = MarkupParser._field
MarkupParser._field = nil
MarkupParser._attribute = {}
MarkupParser._allow = true

-- Replace fields with function pointers with attributes which actually
-- convert Lua target into C callback.
for name, def in pairs {
   start_element = {
      signature = {
	 name = 'start_element', throws = true, ret = ti.void,
	 MarkupParseContext, ti.utf8, ti.GStrv, ti.GStrv, ti.ptr
      },
      override = function(start_element)
	 return function(context, element, attr_names, attr_values, user_data)
	    -- Convert attribute lists to table.
	    local attrs = {}
	    for i = 1, #attr_names do
	       attrs[attr_names[i]] = attr_values[i]
	    end
	    start_element(context, element, attrs, user_data)
	 end
      end,
   },
   end_element = {},
   passthrough = {},
   text = {},
   error = {},
} do
   MarkupParser._attribute[name] = { set = function(parser, target)
      -- Prepare guards table for this parser
      local guards = parser_guard[parser]
      if not guards then
	 guards = {}
	 parser_guard[parser] = guards
      end

      -- Generate real function pointer and guard for the target
      local cbk_type = def.signature or parser_field[name].typeinfo.interface
      if def.override then
	 target = def.override(target)
      end
      local guard, funcptr = core.marshal.callback(cbk_type, target)
      guards[name] = guard
      core.record.field(parser, parser_field[name], funcptr)
   end }
end

-- ParseContext helper overrides.
if not MarkupParseContext._gtype then
   -- Note that older glib/gobject-introspection combos did not mark
   -- MarkupParseContext as boxed.  This means that we have to teach
   -- lgi how to free context and also new(), because in this case
   -- new() is marked as introspectable="0".
   MarkupParseContext._free = core.gi.GLib.resolve.g_markup_parse_context_free
   MarkupParseContext._method.new = core.callable.new {
      name = 'GLib.MarkupParseContext.new',
      addr = core.gi.GLib.resolve.g_markup_parse_context_new,
      ret = { MarkupParseContext, xfer = true },
      MarkupParser, lgi.GLib.MarkupParseFlags, ti.ptr, ti.ptr,
      ti.GDestroyNotify,
   }
end

function MarkupParseContext.new(parser, flags, user_data)
   -- DestroyNotify is required (allow-none) annotation is missing, so
   -- provide dummy one.
   return MarkupParseContext._method.new(parser, flags, user_data,
					 function() end)
end
function MarkupParseContext._new(typetable, parser, flags)
   return MarkupParseContext.new(parser, flags)
end

function MarkupParseContext:parse(text, len)
   return MarkupParseContext._method.parse(self,  text, len or -1)
end

MarkupParseContext._method.pop = core.callable.new {
   name = 'GLib.MarkupParseContext.pop',
   addr = core.gi.GLib.resolve.g_markup_parse_context_pop,
   ret = ti.ptr, MarkupParseContext
}

local escape_text = lgi.GLib.markup_escape_text
function lgi.GLib.markup_escape_text(text)
   return escape_text(text, -1)
end