xrfragment/dist/xrfragment.lua

1672 lines
45 KiB
Lua
Raw Normal View History

2023-03-09 19:58:08 +01:00
local _hx_hidden = {__id__=true, hx__closures=true, super=true, prototype=true, __fields__=true, __ifields__=true, __class__=true, __properties__=true, __fields__=true, __name__=true}
_hx_array_mt = {
__newindex = function(t,k,v)
local len = t.length
t.length = k >= len and (k + 1) or len
rawset(t,k,v)
end
}
function _hx_is_array(o)
return type(o) == "table"
and o.__enum__ == nil
and getmetatable(o) == _hx_array_mt
end
function _hx_tab_array(tab, length)
tab.length = length
return setmetatable(tab, _hx_array_mt)
end
function _hx_print_class(obj, depth)
local first = true
local result = ''
for k,v in pairs(obj) do
if _hx_hidden[k] == nil then
if first then
first = false
else
result = result .. ', '
end
if _hx_hidden[k] == nil then
result = result .. k .. ':' .. _hx_tostring(v, depth+1)
end
end
end
return '{ ' .. result .. ' }'
end
function _hx_print_enum(o, depth)
if o.length == 2 then
return o[0]
else
local str = o[0] .. "("
for i = 2, (o.length-1) do
if i ~= 2 then
str = str .. "," .. _hx_tostring(o[i], depth+1)
else
str = str .. _hx_tostring(o[i], depth+1)
end
end
return str .. ")"
end
end
function _hx_tostring(obj, depth)
if depth == nil then
depth = 0
elseif depth > 5 then
return "<...>"
end
local tstr = _G.type(obj)
if tstr == "string" then return obj
elseif tstr == "nil" then return "null"
elseif tstr == "number" then
if obj == _G.math.POSITIVE_INFINITY then return "Infinity"
elseif obj == _G.math.NEGATIVE_INFINITY then return "-Infinity"
elseif obj == 0 then return "0"
elseif obj ~= obj then return "NaN"
else return _G.tostring(obj)
end
elseif tstr == "boolean" then return _G.tostring(obj)
elseif tstr == "userdata" then
local mt = _G.getmetatable(obj)
if mt ~= nil and mt.__tostring ~= nil then
return _G.tostring(obj)
else
return "<userdata>"
end
elseif tstr == "function" then return "<function>"
elseif tstr == "thread" then return "<thread>"
elseif tstr == "table" then
if obj.__enum__ ~= nil then
return _hx_print_enum(obj, depth)
elseif obj.toString ~= nil and not _hx_is_array(obj) then return obj:toString()
elseif _hx_is_array(obj) then
if obj.length > 5 then
return "[...]"
else
local str = ""
for i=0, (obj.length-1) do
if i == 0 then
str = str .. _hx_tostring(obj[i], depth+1)
else
str = str .. "," .. _hx_tostring(obj[i], depth+1)
end
end
return "[" .. str .. "]"
end
elseif obj.__class__ ~= nil then
return _hx_print_class(obj, depth)
else
local buffer = {}
local ref = obj
if obj.__fields__ ~= nil then
ref = obj.__fields__
end
for k,v in pairs(ref) do
if _hx_hidden[k] == nil then
_G.table.insert(buffer, _hx_tostring(k, depth+1) .. ' : ' .. _hx_tostring(obj[k], depth+1))
end
end
return "{ " .. table.concat(buffer, ", ") .. " }"
end
else
_G.error("Unknown Lua type", 0)
return ""
end
end
function _hx_error(obj)
if obj.value then
_G.print("runtime error:\n " .. _hx_tostring(obj.value));
else
_G.print("runtime error:\n " .. tostring(obj));
end
if _G.debug and _G.debug.traceback then
_G.print(debug.traceback());
end
end
local function _hx_obj_newindex(t,k,v)
t.__fields__[k] = true
rawset(t,k,v)
end
local _hx_obj_mt = {__newindex=_hx_obj_newindex, __tostring=_hx_tostring}
local function _hx_a(...)
local __fields__ = {};
local ret = {__fields__ = __fields__};
local max = select('#',...);
local tab = {...};
local cur = 1;
while cur < max do
local v = tab[cur];
__fields__[v] = true;
ret[v] = tab[cur+1];
cur = cur + 2
end
return setmetatable(ret, _hx_obj_mt)
end
local function _hx_e()
return setmetatable({__fields__ = {}}, _hx_obj_mt)
end
local function _hx_o(obj)
return setmetatable(obj, _hx_obj_mt)
end
local function _hx_new(prototype)
return setmetatable({__fields__ = {}}, {__newindex=_hx_obj_newindex, __index=prototype, __tostring=_hx_tostring})
end
function _hx_field_arr(obj)
res = {}
idx = 0
if obj.__fields__ ~= nil then
obj = obj.__fields__
end
for k,v in pairs(obj) do
if _hx_hidden[k] == nil then
res[idx] = k
idx = idx + 1
end
end
return _hx_tab_array(res, idx)
end
local _hxClasses = {}
local Int = _hx_e();
local Dynamic = _hx_e();
local Float = _hx_e();
local Bool = _hx_e();
local Class = _hx_e();
local Enum = _hx_e();
local _hx_exports = _hx_exports or {}
_hx_exports["xrfragment"] = _hx_exports["xrfragment"] or _hx_e()
local Array = _hx_e()
__lua_lib_lrexlib_Rex = _G.require("rex_pcre")
__lua_lib_luautf8_Utf8 = _G.require("lua-utf8")
local EReg = _hx_e()
local Math = _hx_e()
local Reflect = _hx_e()
local String = _hx_e()
local Std = _hx_e()
__haxe_Exception = _hx_e()
__haxe_NativeStackTrace = _hx_e()
__haxe_ValueException = _hx_e()
__haxe_iterators_ArrayIterator = _hx_e()
__haxe_iterators_ArrayKeyValueIterator = _hx_e()
__lua_Boot = _hx_e()
__lua_UserData = _hx_e()
__lua_Thread = _hx_e()
__xrfragment_Query = _hx_e()
local _hx_bind, _hx_bit, _hx_staticToInstance, _hx_funcToField, _hx_maxn, _hx_print, _hx_apply_self, _hx_box_mr, _hx_bit_clamp, _hx_table, _hx_bit_raw
local _hx_pcall_default = {};
local _hx_pcall_break = {};
Array.new = function()
local self = _hx_new(Array.prototype)
Array.super(self)
return self
end
Array.super = function(self)
_hx_tab_array(self, 0);
end
2023-03-09 22:32:28 +01:00
Array.__name__ = true
2023-03-09 19:58:08 +01:00
Array.prototype = _hx_e();
Array.prototype.concat = function(self,a)
local _g = _hx_tab_array({}, 0);
local _g1 = 0;
local _g2 = self;
while (_g1 < _g2.length) do
local i = _g2[_g1];
_g1 = _g1 + 1;
_g:push(i);
end;
local ret = _g;
local _g = 0;
while (_g < a.length) do
local i = a[_g];
_g = _g + 1;
ret:push(i);
end;
do return ret end
end
Array.prototype.join = function(self,sep)
local tbl = ({});
local _g_current = 0;
local _g_array = self;
while (_g_current < _g_array.length) do
_g_current = _g_current + 1;
local i = _g_array[_g_current - 1];
_G.table.insert(tbl, Std.string(i));
end;
do return _G.table.concat(tbl, sep) end
end
Array.prototype.pop = function(self)
if (self.length == 0) then
do return nil end;
end;
local ret = self[self.length - 1];
self[self.length - 1] = nil;
self.length = self.length - 1;
do return ret end
end
Array.prototype.push = function(self,x)
self[self.length] = x;
do return self.length end
end
Array.prototype.reverse = function(self)
local tmp;
local i = 0;
while (i < Std.int(self.length / 2)) do
tmp = self[i];
self[i] = self[(self.length - i) - 1];
self[(self.length - i) - 1] = tmp;
i = i + 1;
end;
end
Array.prototype.shift = function(self)
if (self.length == 0) then
do return nil end;
end;
local ret = self[0];
if (self.length == 1) then
self[0] = nil;
else
if (self.length > 1) then
self[0] = self[1];
_G.table.remove(self, 1);
end;
end;
local tmp = self;
tmp.length = tmp.length - 1;
do return ret end
end
Array.prototype.slice = function(self,pos,_end)
if ((_end == nil) or (_end > self.length)) then
_end = self.length;
else
if (_end < 0) then
_end = _G.math.fmod((self.length - (_G.math.fmod(-_end, self.length))), self.length);
end;
end;
if (pos < 0) then
pos = _G.math.fmod((self.length - (_G.math.fmod(-pos, self.length))), self.length);
end;
if ((pos > _end) or (pos > self.length)) then
do return _hx_tab_array({}, 0) end;
end;
local ret = _hx_tab_array({}, 0);
local _g = pos;
local _g1 = _end;
while (_g < _g1) do
_g = _g + 1;
local i = _g - 1;
ret:push(self[i]);
end;
do return ret end
end
Array.prototype.sort = function(self,f)
local i = 0;
local l = self.length;
while (i < l) do
local swap = false;
local j = 0;
local max = (l - i) - 1;
while (j < max) do
if (f(self[j], self[j + 1]) > 0) then
local tmp = self[j + 1];
self[j + 1] = self[j];
self[j] = tmp;
swap = true;
end;
j = j + 1;
end;
if (not swap) then
break;
end;
i = i + 1;
end;
end
Array.prototype.splice = function(self,pos,len)
if ((len < 0) or (pos > self.length)) then
do return _hx_tab_array({}, 0) end;
else
if (pos < 0) then
pos = self.length - (_G.math.fmod(-pos, self.length));
end;
end;
len = Math.min(len, self.length - pos);
local ret = _hx_tab_array({}, 0);
local _g = pos;
local _g1 = pos + len;
while (_g < _g1) do
_g = _g + 1;
local i = _g - 1;
ret:push(self[i]);
self[i] = self[i + len];
end;
local _g = pos + len;
local _g1 = self.length;
while (_g < _g1) do
_g = _g + 1;
local i = _g - 1;
self[i] = self[i + len];
end;
local tmp = self;
tmp.length = tmp.length - len;
do return ret end
end
Array.prototype.toString = function(self)
local tbl = ({});
_G.table.insert(tbl, "[");
_G.table.insert(tbl, self:join(","));
_G.table.insert(tbl, "]");
do return _G.table.concat(tbl, "") end
end
Array.prototype.unshift = function(self,x)
local len = self.length;
local _g = 0;
local _g1 = len;
while (_g < _g1) do
_g = _g + 1;
local i = _g - 1;
self[len - i] = self[(len - i) - 1];
end;
self[0] = x;
end
Array.prototype.insert = function(self,pos,x)
if (pos > self.length) then
pos = self.length;
end;
if (pos < 0) then
pos = self.length + pos;
if (pos < 0) then
pos = 0;
end;
end;
local cur_len = self.length;
while (cur_len > pos) do
self[cur_len] = self[cur_len - 1];
cur_len = cur_len - 1;
end;
self[pos] = x;
end
Array.prototype.remove = function(self,x)
local _g = 0;
local _g1 = self.length;
while (_g < _g1) do
_g = _g + 1;
local i = _g - 1;
if (self[i] == x) then
local _g = i;
local _g1 = self.length - 1;
while (_g < _g1) do
_g = _g + 1;
local j = _g - 1;
self[j] = self[j + 1];
end;
self[self.length - 1] = nil;
self.length = self.length - 1;
do return true end;
end;
end;
do return false end
end
Array.prototype.contains = function(self,x)
local _g = 0;
local _g1 = self.length;
while (_g < _g1) do
_g = _g + 1;
local i = _g - 1;
if (self[i] == x) then
do return true end;
end;
end;
do return false end
end
Array.prototype.indexOf = function(self,x,fromIndex)
local _end = self.length;
if (fromIndex == nil) then
fromIndex = 0;
else
if (fromIndex < 0) then
fromIndex = self.length + fromIndex;
if (fromIndex < 0) then
fromIndex = 0;
end;
end;
end;
local _g = fromIndex;
local _g1 = _end;
while (_g < _g1) do
_g = _g + 1;
local i = _g - 1;
if (x == self[i]) then
do return i end;
end;
end;
do return -1 end
end
Array.prototype.lastIndexOf = function(self,x,fromIndex)
if ((fromIndex == nil) or (fromIndex >= self.length)) then
fromIndex = self.length - 1;
else
if (fromIndex < 0) then
fromIndex = self.length + fromIndex;
if (fromIndex < 0) then
do return -1 end;
end;
end;
end;
local i = fromIndex;
while (i >= 0) do
if (self[i] == x) then
do return i end;
else
i = i - 1;
end;
end;
do return -1 end
end
Array.prototype.copy = function(self)
local _g = _hx_tab_array({}, 0);
local _g1 = 0;
local _g2 = self;
while (_g1 < _g2.length) do
local i = _g2[_g1];
_g1 = _g1 + 1;
_g:push(i);
end;
do return _g end
end
Array.prototype.map = function(self,f)
local _g = _hx_tab_array({}, 0);
local _g1 = 0;
local _g2 = self;
while (_g1 < _g2.length) do
local i = _g2[_g1];
_g1 = _g1 + 1;
_g:push(f(i));
end;
do return _g end
end
Array.prototype.filter = function(self,f)
local _g = _hx_tab_array({}, 0);
local _g1 = 0;
local _g2 = self;
while (_g1 < _g2.length) do
local i = _g2[_g1];
_g1 = _g1 + 1;
if (f(i)) then
_g:push(i);
end;
end;
do return _g end
end
Array.prototype.iterator = function(self)
do return __haxe_iterators_ArrayIterator.new(self) end
end
Array.prototype.keyValueIterator = function(self)
do return __haxe_iterators_ArrayKeyValueIterator.new(self) end
end
Array.prototype.resize = function(self,len)
if (self.length < len) then
self.length = len;
else
if (self.length > len) then
local _g = len;
local _g1 = self.length;
while (_g < _g1) do
_g = _g + 1;
local i = _g - 1;
self[i] = nil;
end;
self.length = len;
end;
end;
end
Array.prototype.__class__ = Array
EReg.new = function(r,opt)
local self = _hx_new(EReg.prototype)
EReg.super(self,r,opt)
return self
end
EReg.super = function(self,r,opt)
local ropt = 0;
local _g = 0;
local _g1 = __lua_lib_luautf8_Utf8.len(opt);
while (_g < _g1) do
_g = _g + 1;
local i = _g - 1;
local _g = __lua_lib_luautf8_Utf8.sub(opt, i + 1, i + 1);
if (_g) == "g" then
self.global = true;
elseif (_g) == "i" then
ropt = _hx_bit.bor(ropt,EReg.FLAGS.CASELESS);
elseif (_g) == "m" then
ropt = _hx_bit.bor(ropt,EReg.FLAGS.MULTILINE);
elseif (_g) == "s" then
ropt = _hx_bit.bor(ropt,EReg.FLAGS.DOTALL);else end;
end;
ropt = _hx_bit.bor(ropt,EReg.FLAGS.UTF8);
ropt = _hx_bit.bor(ropt,EReg.FLAGS.UCP);
if (self.global == nil) then
self.global = false;
end;
self.r = __lua_lib_lrexlib_Rex.new(r, ropt);
end
2023-03-09 22:32:28 +01:00
EReg.__name__ = true
2023-03-09 19:58:08 +01:00
EReg.prototype = _hx_e();
EReg.prototype.match = function(self,s)
if (s == nil) then
do return false end;
else
self.m = _hx_table.pack(self.r:exec(s, 1));
self.s = s;
do return self.m[1] ~= nil end;
end;
end
2023-03-09 22:32:28 +01:00
EReg.prototype.__class__ = EReg
Math.new = {}
Math.__name__ = true
Math.isNaN = function(f)
do return f ~= f end;
end
Math.isFinite = function(f)
if (f > -_G.math.huge) then
do return f < _G.math.huge end;
else
2023-03-09 19:58:08 +01:00
do return false end;
end;
end
2023-03-09 22:32:28 +01:00
Math.min = function(a,b)
if (Math.isNaN(a) or Math.isNaN(b)) then
do return (0/0) end;
2023-03-09 19:58:08 +01:00
else
2023-03-09 22:32:28 +01:00
do return _G.math.min(a, b) end;
end;
end
Reflect.new = {}
Reflect.__name__ = true
Reflect.field = function(o,field)
if (_G.type(o) == "string") then
if (field == "length") then
do return _hx_wrap_if_string_field(o,'length') end;
2023-03-09 19:58:08 +01:00
else
2023-03-09 22:32:28 +01:00
do return String.prototype[field] end;
end;
else
local _hx_status, _hx_result = pcall(function()
do return o[field] end;
return _hx_pcall_default
end)
if not _hx_status and _hx_result == "_hx_pcall_break" then
elseif not _hx_status then
local _g = _hx_result;
do return nil end;
elseif _hx_result ~= _hx_pcall_default then
return _hx_result
2023-03-09 19:58:08 +01:00
end;
end;
end
2023-03-09 22:32:28 +01:00
Reflect.fields = function(o)
if (_G.type(o) == "string") then
do return Reflect.fields(String.prototype) end;
else
do return _hx_field_arr(o) end;
2023-03-09 19:58:08 +01:00
end;
end
2023-03-09 22:32:28 +01:00
String.new = function(string)
local self = _hx_new(String.prototype)
String.super(self,string)
self = string
return self
end
String.super = function(self,string)
2023-03-09 19:58:08 +01:00
end
2023-03-09 22:32:28 +01:00
String.__name__ = true
String.__index = function(s,k)
if (k == "length") then
do return __lua_lib_luautf8_Utf8.len(s) end;
else
local o = String.prototype;
local field = k;
if ((function()
local _hx_1
if ((_G.type(o) == "string") and ((String.prototype[field] ~= nil) or (field == "length"))) then
_hx_1 = true; elseif (o.__fields__ ~= nil) then
_hx_1 = o.__fields__[field] ~= nil; else
_hx_1 = o[field] ~= nil; end
return _hx_1
end )()) then
do return String.prototype[k] end;
else
if (String.__oldindex ~= nil) then
if (_G.type(String.__oldindex) == "function") then
do return String.__oldindex(s, k) end;
else
if (_G.type(String.__oldindex) == "table") then
do return String.__oldindex[k] end;
end;
end;
do return nil end;
else
do return nil end;
end;
end;
2023-03-09 19:58:08 +01:00
end;
end
2023-03-09 22:32:28 +01:00
String.indexOfEmpty = function(s,startIndex)
local length = __lua_lib_luautf8_Utf8.len(s);
if (startIndex < 0) then
startIndex = length + startIndex;
if (startIndex < 0) then
startIndex = 0;
end;
2023-03-09 19:58:08 +01:00
end;
2023-03-09 22:32:28 +01:00
if (startIndex > length) then
do return length end;
2023-03-09 19:58:08 +01:00
else
2023-03-09 22:32:28 +01:00
do return startIndex end;
2023-03-09 19:58:08 +01:00
end;
2023-03-09 22:32:28 +01:00
end
String.fromCharCode = function(code)
do return __lua_lib_luautf8_Utf8.char(code) end;
end
String.prototype = _hx_e();
String.prototype.toUpperCase = function(self)
do return __lua_lib_luautf8_Utf8.upper(self) end
end
String.prototype.toLowerCase = function(self)
do return __lua_lib_luautf8_Utf8.lower(self) end
end
String.prototype.indexOf = function(self,str,startIndex)
if (startIndex == nil) then
startIndex = 1;
else
startIndex = startIndex + 1;
2023-03-09 19:58:08 +01:00
end;
2023-03-09 22:32:28 +01:00
if (str == "") then
do return String.indexOfEmpty(self, startIndex - 1) end;
2023-03-09 19:58:08 +01:00
end;
2023-03-09 22:32:28 +01:00
local r = __lua_lib_luautf8_Utf8.find(self, str, startIndex, true);
if ((r ~= nil) and (r > 0)) then
do return r - 1 end;
2023-03-09 19:58:08 +01:00
else
2023-03-09 22:32:28 +01:00
do return -1 end;
2023-03-09 19:58:08 +01:00
end;
end
2023-03-09 22:32:28 +01:00
String.prototype.lastIndexOf = function(self,str,startIndex)
local ret = -1;
if (startIndex == nil) then
startIndex = __lua_lib_luautf8_Utf8.len(self);
end;
while (true) do
local startIndex1 = ret + 1;
if (startIndex1 == nil) then
startIndex1 = 1;
else
startIndex1 = startIndex1 + 1;
end;
local p;
if (str == "") then
p = String.indexOfEmpty(self, startIndex1 - 1);
else
local r = __lua_lib_luautf8_Utf8.find(self, str, startIndex1, true);
p = (function()
local _hx_1
if ((r ~= nil) and (r > 0)) then
_hx_1 = r - 1; else
_hx_1 = -1; end
return _hx_1
end )();
end;
if (((p == -1) or (p > startIndex)) or (p == ret)) then
break;
end;
ret = p;
2023-03-09 19:58:08 +01:00
end;
2023-03-09 22:32:28 +01:00
do return ret end
2023-03-09 19:58:08 +01:00
end
2023-03-09 22:32:28 +01:00
String.prototype.split = function(self,delimiter)
2023-03-09 19:58:08 +01:00
local idx = 1;
local ret = _hx_tab_array({}, 0);
while (idx ~= nil) do
local newidx = 0;
2023-03-09 22:32:28 +01:00
if (__lua_lib_luautf8_Utf8.len(delimiter) > 0) then
newidx = __lua_lib_luautf8_Utf8.find(self, delimiter, idx, true);
2023-03-09 19:58:08 +01:00
else
2023-03-09 22:32:28 +01:00
if (idx >= __lua_lib_luautf8_Utf8.len(self)) then
2023-03-09 19:58:08 +01:00
newidx = nil;
else
newidx = idx + 1;
end;
end;
if (newidx ~= nil) then
2023-03-09 22:32:28 +01:00
local match = __lua_lib_luautf8_Utf8.sub(self, idx, newidx - 1);
2023-03-09 19:58:08 +01:00
ret:push(match);
2023-03-09 22:32:28 +01:00
idx = newidx + __lua_lib_luautf8_Utf8.len(delimiter);
2023-03-09 19:58:08 +01:00
else
2023-03-09 22:32:28 +01:00
ret:push(__lua_lib_luautf8_Utf8.sub(self, idx, __lua_lib_luautf8_Utf8.len(self)));
2023-03-09 19:58:08 +01:00
idx = nil;
end;
end;
2023-03-09 22:32:28 +01:00
do return ret end
end
String.prototype.toString = function(self)
do return self end
end
String.prototype.substring = function(self,startIndex,endIndex)
if (endIndex == nil) then
endIndex = __lua_lib_luautf8_Utf8.len(self);
end;
if (endIndex < 0) then
endIndex = 0;
end;
if (startIndex < 0) then
startIndex = 0;
end;
if (endIndex < startIndex) then
do return __lua_lib_luautf8_Utf8.sub(self, endIndex + 1, startIndex) end;
else
do return __lua_lib_luautf8_Utf8.sub(self, startIndex + 1, endIndex) end;
2023-03-09 19:58:08 +01:00
end;
end
2023-03-09 22:32:28 +01:00
String.prototype.charAt = function(self,index)
do return __lua_lib_luautf8_Utf8.sub(self, index + 1, index + 1) end
end
String.prototype.charCodeAt = function(self,index)
do return __lua_lib_luautf8_Utf8.byte(self, index + 1) end
end
String.prototype.substr = function(self,pos,len)
if ((len == nil) or (len > (pos + __lua_lib_luautf8_Utf8.len(self)))) then
len = __lua_lib_luautf8_Utf8.len(self);
else
if (len < 0) then
len = __lua_lib_luautf8_Utf8.len(self) + len;
2023-03-09 19:58:08 +01:00
end;
end;
2023-03-09 22:32:28 +01:00
if (pos < 0) then
pos = __lua_lib_luautf8_Utf8.len(self) + pos;
end;
if (pos < 0) then
pos = 0;
2023-03-09 19:58:08 +01:00
end;
2023-03-09 22:32:28 +01:00
do return __lua_lib_luautf8_Utf8.sub(self, pos + 1, pos + len) end
2023-03-09 19:58:08 +01:00
end
2023-03-09 22:32:28 +01:00
String.prototype.__class__ = String
Std.new = {}
Std.__name__ = true
Std.string = function(s)
do return _hx_tostring(s, 0) end;
end
Std.int = function(x)
if (not Math.isFinite(x) or Math.isNaN(x)) then
do return 0 end;
else
do return _hx_bit_clamp(x) end;
end;
end
Std.parseInt = function(x)
if (x == nil) then
do return nil end;
2023-03-09 19:58:08 +01:00
end;
2023-03-09 22:32:28 +01:00
local hexMatch = _G.string.match(x, "^[ \t\r\n]*([%-+]*0[xX][%da-fA-F]*)");
if (hexMatch ~= nil) then
local sign;
local _g = __lua_lib_luautf8_Utf8.byte(hexMatch, 1);
if (_g) == 43 then
sign = 1;
elseif (_g) == 45 then
sign = -1;else
sign = 0; end;
local pos = (function()
local _hx_1
if (sign == 0) then
_hx_1 = 2; else
_hx_1 = 3; end
return _hx_1
end )();
2023-03-09 19:58:08 +01:00
local len = nil;
2023-03-09 22:32:28 +01:00
if ((len == nil) or (len > (pos + __lua_lib_luautf8_Utf8.len(hexMatch)))) then
len = __lua_lib_luautf8_Utf8.len(hexMatch);
2023-03-09 19:58:08 +01:00
else
if (len < 0) then
2023-03-09 22:32:28 +01:00
len = __lua_lib_luautf8_Utf8.len(hexMatch) + len;
2023-03-09 19:58:08 +01:00
end;
end;
if (pos < 0) then
2023-03-09 22:32:28 +01:00
pos = __lua_lib_luautf8_Utf8.len(hexMatch) + pos;
2023-03-09 19:58:08 +01:00
end;
if (pos < 0) then
pos = 0;
end;
2023-03-09 22:32:28 +01:00
do return (function()
local _hx_2
if (sign == -1) then
_hx_2 = -1; else
_hx_2 = 1; end
return _hx_2
end )() * _G.tonumber(__lua_lib_luautf8_Utf8.sub(hexMatch, pos + 1, pos + len), 16) end;
2023-03-09 19:58:08 +01:00
else
2023-03-09 22:32:28 +01:00
local intMatch = _G.string.match(x, "^ *[%-+]?%d*");
if (intMatch ~= nil) then
do return _G.tonumber(intMatch) end;
2023-03-09 19:58:08 +01:00
else
do return nil end;
end;
end;
end
2023-03-09 22:32:28 +01:00
__haxe_Exception.new = function(message,previous,native)
local self = _hx_new(__haxe_Exception.prototype)
__haxe_Exception.super(self,message,previous,native)
return self
2023-03-09 19:58:08 +01:00
end
2023-03-09 22:32:28 +01:00
__haxe_Exception.super = function(self,message,previous,native)
self.__skipStack = 0;
self.__exceptionMessage = message;
self.__previousException = previous;
if (native ~= nil) then
self.__nativeException = native;
self.__nativeStack = __haxe_NativeStackTrace.exceptionStack();
2023-03-09 19:58:08 +01:00
else
2023-03-09 22:32:28 +01:00
self.__nativeException = self;
self.__nativeStack = __haxe_NativeStackTrace.callStack();
self.__skipStack = 1;
2023-03-09 19:58:08 +01:00
end;
end
2023-03-09 22:32:28 +01:00
__haxe_Exception.__name__ = true
__haxe_Exception.thrown = function(value)
if (__lua_Boot.__instanceof(value, __haxe_Exception)) then
do return value:get_native() end;
2023-03-09 19:58:08 +01:00
else
2023-03-09 22:32:28 +01:00
local e = __haxe_ValueException.new(value);
e.__skipStack = e.__skipStack + 1;
do return e end;
2023-03-09 19:58:08 +01:00
end;
2023-03-09 22:32:28 +01:00
end
__haxe_Exception.prototype = _hx_e();
__haxe_Exception.prototype.get_native = function(self)
do return self.__nativeException end
2023-03-09 19:58:08 +01:00
end
2023-03-09 22:32:28 +01:00
__haxe_Exception.prototype.__class__ = __haxe_Exception
2023-03-09 19:58:08 +01:00
2023-03-09 22:32:28 +01:00
__haxe_NativeStackTrace.new = {}
__haxe_NativeStackTrace.__name__ = true
__haxe_NativeStackTrace.saveStack = function(exception)
2023-03-09 19:58:08 +01:00
end
2023-03-09 22:32:28 +01:00
__haxe_NativeStackTrace.callStack = function()
local _g = debug.traceback();
if (_g == nil) then
do return _hx_tab_array({}, 0) end;
else
local s = _g;
local idx = 1;
local ret = _hx_tab_array({}, 0);
while (idx ~= nil) do
local newidx = 0;
if (__lua_lib_luautf8_Utf8.len("\n") > 0) then
newidx = __lua_lib_luautf8_Utf8.find(s, "\n", idx, true);
else
if (idx >= __lua_lib_luautf8_Utf8.len(s)) then
newidx = nil;
else
newidx = idx + 1;
end;
end;
if (newidx ~= nil) then
local match = __lua_lib_luautf8_Utf8.sub(s, idx, newidx - 1);
ret:push(match);
idx = newidx + __lua_lib_luautf8_Utf8.len("\n");
else
ret:push(__lua_lib_luautf8_Utf8.sub(s, idx, __lua_lib_luautf8_Utf8.len(s)));
idx = nil;
end;
end;
do return ret:slice(3) end;
2023-03-09 19:58:08 +01:00
end;
end
2023-03-09 22:32:28 +01:00
__haxe_NativeStackTrace.exceptionStack = function()
do return _hx_tab_array({}, 0) end;
2023-03-09 19:58:08 +01:00
end
2023-03-09 22:32:28 +01:00
__haxe_ValueException.new = function(value,previous,native)
local self = _hx_new(__haxe_ValueException.prototype)
__haxe_ValueException.super(self,value,previous,native)
return self
2023-03-09 19:58:08 +01:00
end
2023-03-09 22:32:28 +01:00
__haxe_ValueException.super = function(self,value,previous,native)
__haxe_Exception.super(self,Std.string(value),previous,native);
self.value = value;
2023-03-09 19:58:08 +01:00
end
2023-03-09 22:32:28 +01:00
__haxe_ValueException.__name__ = true
__haxe_ValueException.prototype = _hx_e();
2023-03-09 19:58:08 +01:00
2023-03-09 22:32:28 +01:00
__haxe_ValueException.prototype.__class__ = __haxe_ValueException
__haxe_ValueException.__super__ = __haxe_Exception
setmetatable(__haxe_ValueException.prototype,{__index=__haxe_Exception.prototype})
2023-03-09 19:58:08 +01:00
2023-03-09 22:32:28 +01:00
__haxe_iterators_ArrayIterator.new = function(array)
local self = _hx_new(__haxe_iterators_ArrayIterator.prototype)
__haxe_iterators_ArrayIterator.super(self,array)
2023-03-09 19:58:08 +01:00
return self
end
2023-03-09 22:32:28 +01:00
__haxe_iterators_ArrayIterator.super = function(self,array)
self.current = 0;
self.array = array;
2023-03-09 19:58:08 +01:00
end
2023-03-09 22:32:28 +01:00
__haxe_iterators_ArrayIterator.__name__ = true
__haxe_iterators_ArrayIterator.prototype = _hx_e();
__haxe_iterators_ArrayIterator.prototype.hasNext = function(self)
do return self.current < self.array.length end
2023-03-09 19:58:08 +01:00
end
2023-03-09 22:32:28 +01:00
__haxe_iterators_ArrayIterator.prototype.next = function(self)
do return self.array[(function()
local _hx_obj = self;
local _hx_fld = 'current';
local _ = _hx_obj[_hx_fld];
_hx_obj[_hx_fld] = _hx_obj[_hx_fld] + 1;
return _;
end)()] end
2023-03-09 19:58:08 +01:00
end
2023-03-09 22:32:28 +01:00
__haxe_iterators_ArrayIterator.prototype.__class__ = __haxe_iterators_ArrayIterator
2023-03-09 19:58:08 +01:00
2023-03-09 22:32:28 +01:00
__haxe_iterators_ArrayKeyValueIterator.new = function(array)
local self = _hx_new(__haxe_iterators_ArrayKeyValueIterator.prototype)
__haxe_iterators_ArrayKeyValueIterator.super(self,array)
2023-03-09 19:58:08 +01:00
return self
end
2023-03-09 22:32:28 +01:00
__haxe_iterators_ArrayKeyValueIterator.super = function(self,array)
self.array = array;
2023-03-09 19:58:08 +01:00
end
2023-03-09 22:32:28 +01:00
__haxe_iterators_ArrayKeyValueIterator.__name__ = true
__haxe_iterators_ArrayKeyValueIterator.prototype = _hx_e();
__haxe_iterators_ArrayKeyValueIterator.prototype.__class__ = __haxe_iterators_ArrayKeyValueIterator
__lua_Boot.new = {}
__lua_Boot.__name__ = true
__lua_Boot.__instanceof = function(o,cl)
if (cl == nil) then
do return false end;
2023-03-09 19:58:08 +01:00
end;
2023-03-09 22:32:28 +01:00
local cl1 = cl;
if (cl1) == Array then
do return __lua_Boot.isArray(o) end;
elseif (cl1) == Bool then
do return _G.type(o) == "boolean" end;
elseif (cl1) == Dynamic then
do return o ~= nil end;
elseif (cl1) == Float then
do return _G.type(o) == "number" end;
elseif (cl1) == Int then
if (_G.type(o) == "number") then
do return _hx_bit_clamp(o) == o end;
else
do return false end;
end;
elseif (cl1) == String then
do return _G.type(o) == "string" end;
elseif (cl1) == _G.table then
do return _G.type(o) == "table" end;
elseif (cl1) == __lua_Thread then
do return _G.type(o) == "thread" end;
elseif (cl1) == __lua_UserData then
do return _G.type(o) == "userdata" end;else
if (((o ~= nil) and (_G.type(o) == "table")) and (_G.type(cl) == "table")) then
local tmp;
if (__lua_Boot.__instanceof(o, Array)) then
tmp = Array;
else
if (__lua_Boot.__instanceof(o, String)) then
tmp = String;
else
local cl = o.__class__;
tmp = (function()
local _hx_1
if (cl ~= nil) then
_hx_1 = cl; else
_hx_1 = nil; end
return _hx_1
end )();
2023-03-09 19:58:08 +01:00
end;
end;
2023-03-09 22:32:28 +01:00
if (__lua_Boot.extendsOrImplements(tmp, cl)) then
do return true end;
end;
if ((function()
local _hx_2
if (cl == Class) then
_hx_2 = o.__name__ ~= nil; else
_hx_2 = false; end
return _hx_2
end )()) then
do return true end;
end;
if ((function()
local _hx_3
if (cl == Enum) then
_hx_3 = o.__ename__ ~= nil; else
_hx_3 = false; end
return _hx_3
end )()) then
do return true end;
end;
do return o.__enum__ == cl end;
else
do return false end;
end; end;
2023-03-09 19:58:08 +01:00
end
2023-03-09 22:32:28 +01:00
__lua_Boot.isArray = function(o)
if (_G.type(o) == "table") then
if ((o.__enum__ == nil) and (_G.getmetatable(o) ~= nil)) then
do return _G.getmetatable(o).__index == Array.prototype end;
else
do return false end;
end;
else
do return false end;
2023-03-09 19:58:08 +01:00
end;
2023-03-09 22:32:28 +01:00
end
__lua_Boot.extendsOrImplements = function(cl1,cl2)
if ((cl1 == nil) or (cl2 == nil)) then
do return false end;
else
if (cl1 == cl2) then
do return true end;
else
if (cl1.__interfaces__ ~= nil) then
local intf = cl1.__interfaces__;
local _g = 1;
local _g1 = _hx_table.maxn(intf) + 1;
while (_g < _g1) do
_g = _g + 1;
local i = _g - 1;
if (__lua_Boot.extendsOrImplements(intf[i], cl2)) then
do return true end;
2023-03-09 19:58:08 +01:00
end;
end;
end;
end;
end;
2023-03-09 22:32:28 +01:00
do return __lua_Boot.extendsOrImplements(cl1.__super__, cl2) end;
2023-03-09 19:58:08 +01:00
end
2023-03-09 22:32:28 +01:00
__lua_UserData.new = {}
__lua_UserData.__name__ = true
2023-03-09 19:58:08 +01:00
2023-03-09 22:32:28 +01:00
__lua_Thread.new = {}
__lua_Thread.__name__ = true
2023-03-09 19:58:08 +01:00
__xrfragment_Query.new = function(str)
local self = _hx_new(__xrfragment_Query.prototype)
__xrfragment_Query.super(self,str)
return self
end
__xrfragment_Query.super = function(self,str)
self.preset = "";
self.accept = false;
self.exclude = Array.new();
self.include = Array.new();
self.q = _hx_e();
self.str = "";
if (str ~= nil) then
self:parse(str);
end;
end
_hx_exports["xrfragment"]["Query"] = __xrfragment_Query
2023-03-09 22:32:28 +01:00
__xrfragment_Query.__name__ = true
2023-03-09 19:58:08 +01:00
__xrfragment_Query.prototype = _hx_e();
__xrfragment_Query.prototype.toObject = function(self)
do return self.q end
end
__xrfragment_Query.prototype.qualify = function(self,nodename)
if (self.q.copy_all) then
self.accept = true;
end;
if (self.include:contains(nodename)) then
self.accept = true;
end;
if (self.exclude:contains(nodename)) then
self.accept = false;
end;
do return self.accept end
end
__xrfragment_Query.prototype.parse = function(self,str,recurse)
if (recurse == nil) then
recurse = false;
end;
local _gthis = self;
local copyAll;
if (recurse) then
copyAll = self.q.copy_all;
else
local copyAll1;
local pos = 0;
local len = 1;
if ((len == nil) or (len > (pos + __lua_lib_luautf8_Utf8.len(str)))) then
len = __lua_lib_luautf8_Utf8.len(str);
else
if (len < 0) then
len = __lua_lib_luautf8_Utf8.len(str) + len;
end;
end;
if (pos < 0) then
pos = __lua_lib_luautf8_Utf8.len(str) + pos;
end;
if (pos < 0) then
pos = 0;
end;
if (__lua_lib_luautf8_Utf8.sub(str, pos + 1, pos + len) ~= "-") then
local pos = 0;
local len = 1;
if ((len == nil) or (len > (pos + __lua_lib_luautf8_Utf8.len(str)))) then
len = __lua_lib_luautf8_Utf8.len(str);
else
if (len < 0) then
len = __lua_lib_luautf8_Utf8.len(str) + len;
end;
end;
if (pos < 0) then
pos = __lua_lib_luautf8_Utf8.len(str) + pos;
end;
if (pos < 0) then
pos = 0;
end;
copyAll1 = __lua_lib_luautf8_Utf8.sub(str, pos + 1, pos + len) == "?";
else
copyAll1 = true;
end;
copyAll = copyAll1 or (str == "");
end;
local isOr = EReg.new("^or$", "");
local isProp = EReg.new(".*:[><=!]?", "");
local isName = EReg.new("[^:/]", "");
local isExclude = EReg.new("^-", "");
local isInclude = EReg.new("^\\+", "");
local isPreset = EReg.new("^\\?", "");
local idx = 1;
local ret = _hx_tab_array({}, 0);
while (idx ~= nil) do
local newidx = 0;
if (__lua_lib_luautf8_Utf8.len(" ") > 0) then
newidx = __lua_lib_luautf8_Utf8.find(str, " ", idx, true);
else
if (idx >= __lua_lib_luautf8_Utf8.len(str)) then
newidx = nil;
else
newidx = idx + 1;
end;
end;
if (newidx ~= nil) then
local match = __lua_lib_luautf8_Utf8.sub(str, idx, newidx - 1);
ret:push(match);
idx = newidx + __lua_lib_luautf8_Utf8.len(" ");
else
ret:push(__lua_lib_luautf8_Utf8.sub(str, idx, __lua_lib_luautf8_Utf8.len(str)));
idx = nil;
end;
end;
local token = ret;
local ors = Array.new();
local q = _hx_e();
local composeQuery = function()
q = _hx_e();
local value = Array.new();
q.object = value;
local value = Array.new();
q["-object"] = value;
ors:push(q);
do return q end;
end;
composeQuery();
local match = nil;
match = function(str,prefix)
if (prefix == nil) then
prefix = "";
end;
if (isPreset:match(str) and not recurse) then
_gthis.preset = str;
do return end;
end;
if (isExclude:match(str) or isInclude:match(str)) then
local pos = 1;
local len = nil;
if ((len == nil) or (len > (pos + __lua_lib_luautf8_Utf8.len(str)))) then
len = __lua_lib_luautf8_Utf8.len(str);
else
if (len < 0) then
len = __lua_lib_luautf8_Utf8.len(str) + len;
end;
end;
if (pos < 0) then
pos = __lua_lib_luautf8_Utf8.len(str) + pos;
end;
if (pos < 0) then
pos = 0;
end;
local t = __lua_lib_luautf8_Utf8.sub(str, pos + 1, pos + len);
local pos = 0;
local len = 1;
if ((len == nil) or (len > (pos + __lua_lib_luautf8_Utf8.len(str)))) then
len = __lua_lib_luautf8_Utf8.len(str);
else
if (len < 0) then
len = __lua_lib_luautf8_Utf8.len(str) + len;
end;
end;
if (pos < 0) then
pos = __lua_lib_luautf8_Utf8.len(str) + pos;
end;
if (pos < 0) then
pos = 0;
end;
match(t, __lua_lib_luautf8_Utf8.sub(str, pos + 1, pos + len));
do return end;
end;
if (isProp:match(str)) then
local skip = 0;
local type = "=";
local startIndex = nil;
if (startIndex == nil) then
startIndex = 1;
else
startIndex = startIndex + 1;
end;
local r = __lua_lib_luautf8_Utf8.find(str, "*", startIndex, true);
if ((function()
local _hx_1
if ((r ~= nil) and (r > 0)) then
_hx_1 = r - 1; else
_hx_1 = -1; end
return _hx_1
end )() ~= -1) then
type = "*";
end;
local startIndex = nil;
if (startIndex == nil) then
startIndex = 1;
else
startIndex = startIndex + 1;
end;
local r = __lua_lib_luautf8_Utf8.find(str, ">", startIndex, true);
if ((function()
local _hx_2
if ((r ~= nil) and (r > 0)) then
_hx_2 = r - 1; else
_hx_2 = -1; end
return _hx_2
end )() ~= -1) then
type = ">";
end;
local startIndex = nil;
if (startIndex == nil) then
startIndex = 1;
else
startIndex = startIndex + 1;
end;
local r = __lua_lib_luautf8_Utf8.find(str, "<", startIndex, true);
if ((function()
local _hx_3
if ((r ~= nil) and (r > 0)) then
_hx_3 = r - 1; else
_hx_3 = -1; end
return _hx_3
end )() ~= -1) then
type = "<";
end;
local startIndex = nil;
if (startIndex == nil) then
startIndex = 1;
else
startIndex = startIndex + 1;
end;
local r = __lua_lib_luautf8_Utf8.find(str, "!=", startIndex, true);
if ((function()
local _hx_4
if ((r ~= nil) and (r > 0)) then
_hx_4 = r - 1; else
_hx_4 = -1; end
return _hx_4
end )() ~= -1) then
type = "!=";
end;
local startIndex = nil;
if (startIndex == nil) then
startIndex = 1;
else
startIndex = startIndex + 1;
end;
local r = __lua_lib_luautf8_Utf8.find(str, ">=", startIndex, true);
if ((function()
local _hx_5
if ((r ~= nil) and (r > 0)) then
_hx_5 = r - 1; else
_hx_5 = -1; end
return _hx_5
end )() ~= -1) then
type = ">=";
end;
local startIndex = nil;
if (startIndex == nil) then
startIndex = 1;
else
startIndex = startIndex + 1;
end;
local r = __lua_lib_luautf8_Utf8.find(str, "<=", startIndex, true);
if ((function()
local _hx_6
if ((r ~= nil) and (r > 0)) then
_hx_6 = r - 1; else
_hx_6 = -1; end
return _hx_6
end )() ~= -1) then
type = "<=";
end;
if (type ~= "=") then
skip = skip + __lua_lib_luautf8_Utf8.len(type);
end;
local idx = 1;
local ret = _hx_tab_array({}, 0);
while (idx ~= nil) do
local newidx = 0;
if (__lua_lib_luautf8_Utf8.len(":") > 0) then
newidx = __lua_lib_luautf8_Utf8.find(str, ":", idx, true);
else
if (idx >= __lua_lib_luautf8_Utf8.len(str)) then
newidx = nil;
else
newidx = idx + 1;
end;
end;
if (newidx ~= nil) then
local match = __lua_lib_luautf8_Utf8.sub(str, idx, newidx - 1);
ret:push(match);
idx = newidx + __lua_lib_luautf8_Utf8.len(":");
else
ret:push(__lua_lib_luautf8_Utf8.sub(str, idx, __lua_lib_luautf8_Utf8.len(str)));
idx = nil;
end;
end;
local property = ret[0];
local value;
if (Reflect.field(q, Std.string(prefix) .. Std.string(property))) then
value = Reflect.field(q, Std.string(prefix) .. Std.string(property));
else
value = _hx_e();
end;
local idx = 1;
local ret = _hx_tab_array({}, 0);
while (idx ~= nil) do
local newidx = 0;
if (__lua_lib_luautf8_Utf8.len(":") > 0) then
newidx = __lua_lib_luautf8_Utf8.find(str, ":", idx, true);
else
if (idx >= __lua_lib_luautf8_Utf8.len(str)) then
newidx = nil;
else
newidx = idx + 1;
end;
end;
if (newidx ~= nil) then
local match = __lua_lib_luautf8_Utf8.sub(str, idx, newidx - 1);
ret:push(match);
idx = newidx + __lua_lib_luautf8_Utf8.len(":");
else
ret:push(__lua_lib_luautf8_Utf8.sub(str, idx, __lua_lib_luautf8_Utf8.len(str)));
idx = nil;
end;
end;
local _this = ret[1];
local pos = skip;
local len = nil;
if ((len == nil) or (len > (pos + __lua_lib_luautf8_Utf8.len(_this)))) then
len = __lua_lib_luautf8_Utf8.len(_this);
else
if (len < 0) then
len = __lua_lib_luautf8_Utf8.len(_this) + len;
end;
end;
if (pos < 0) then
pos = __lua_lib_luautf8_Utf8.len(_this) + pos;
end;
if (pos < 0) then
pos = 0;
end;
local value1 = __lua_lib_luautf8_Utf8.sub(_this, pos + 1, pos + len);
value[type] = value1;
q[Std.string(prefix) .. Std.string(property)] = value;
do return end;
end;
if (isName:match(str)) then
if (prefix == "-") then
Reflect.field(q, "-object"):push(str);
while (Reflect.field(q, "object"):contains(str) == true) do
Reflect.field(q, "object"):remove(str);
end;
else
Reflect.field(q, "object"):push(str);
while (Reflect.field(q, "-object"):contains(str) == true) do
Reflect.field(q, "-object"):remove(str);
end;
end;
do return end;
end;
end;
local _g = 0;
local _g1 = token.length;
while (_g < _g1) do
_g = _g + 1;
local i = _g - 1;
if (isOr:match(token[i])) then
composeQuery();
else
match(token[i]);
end;
end;
local _g = 0;
local _g1 = ors.length;
while (_g < _g1) do
_g = _g + 1;
local i = _g - 1;
local _or = ors[i];
if (Reflect.field(_or, "object") ~= nil) then
self.include = self.include:concat(Reflect.field(_or, "object"));
end;
if (Reflect.field(_or, "-object") ~= nil) then
self.exclude = self.exclude:concat(Reflect.field(_or, "-object"));
end;
end;
self.q = _hx_o({__fields__={['or']=true,copy_all=true},['or']=ors,copy_all=copyAll});
do return self.q end
end
__xrfragment_Query.prototype.test = function(self,property,value)
if (self.preset == property) then
self:parse(value, true);
end;
local _g = 0;
local _g1 = _hx_wrap_if_string_field(self.q["or"],'length');
while (_g < _g1) do
_g = _g + 1;
local i = _g - 1;
local _or = self.q["or"][i];
local conds = _hx_tab_array({[0]=0}, 1);
local fails = _hx_tab_array({[0]=0}, 1);
local pass = 0;
local when = (function(fails,conds)
do return function(expr)
local conds = conds;
local when = 0;
conds[when] = conds[when] + 1;
local fails = fails;
local when = 0;
fails[when] = fails[when] + (function()
local _hx_1
if (expr) then
_hx_1 = 0; else
_hx_1 = 1; end
return _hx_1
end )();
do return expr end;
end end;
end)(fails, conds);
local _g = 0;
local _g1 = Reflect.fields(_or);
local _hx_continue_2 = false;
while (_g < _g1.length) do repeat
local k = _g1[_g];
_g = _g + 1;
local orval = Reflect.field(_or, k);
if (k ~= property) then
break;
end;
if ((Reflect.field(orval, "=") ~= nil) and when(value == Reflect.field(orval, "="))) then
pass = pass + 1;
end;
if ((Reflect.field(orval, "*") ~= nil) and when(value ~= nil)) then
pass = pass + 1;
end;
if ((Reflect.field(orval, ">") ~= nil) and when(value > Std.parseInt(Reflect.field(orval, ">")))) then
pass = pass + 1;
end;
if ((Reflect.field(orval, "<") ~= nil) and when(value < Std.parseInt(Reflect.field(orval, "<")))) then
pass = pass + 1;
end;
if ((Reflect.field(orval, ">=") ~= nil) and when(value >= Std.parseInt(Reflect.field(orval, ">=")))) then
pass = pass + 1;
end;
if ((Reflect.field(orval, "<=") ~= nil) and when(value >= Std.parseInt(Reflect.field(orval, "<=")))) then
pass = pass + 1;
end;
if ((Reflect.field(orval, "!=") ~= nil) and when(value ~= Std.parseInt(Reflect.field(orval, "!=")))) then
pass = pass + 1;
end;until true
if _hx_continue_2 then
_hx_continue_2 = false;
break;
end;
end;
if ((self.accept and (conds[0] > 0)) and (fails[0] > 0)) then
self.accept = false;
end;
if (((conds[0] > 0) and (pass > 0)) and (fails[0] == 0)) then
self.accept = true;
end;
end;
end
__xrfragment_Query.prototype.__class__ = __xrfragment_Query
-- require this for lua 5.1
pcall(require, 'bit')
if bit then
_hx_bit_raw = bit
_hx_bit = setmetatable({}, { __index = _hx_bit_raw });
else
_hx_bit_raw = _G.require('bit32')
_hx_bit = setmetatable({}, { __index = _hx_bit_raw });
-- lua 5.2 weirdness
_hx_bit.bnot = function(...) return _hx_bit_clamp(_hx_bit_raw.bnot(...)) end;
_hx_bit.bxor = function(...) return _hx_bit_clamp(_hx_bit_raw.bxor(...)) end;
end
-- see https://github.com/HaxeFoundation/haxe/issues/8849
_hx_bit.bor = function(...) return _hx_bit_clamp(_hx_bit_raw.bor(...)) end;
_hx_bit.band = function(...) return _hx_bit_clamp(_hx_bit_raw.band(...)) end;
_hx_bit.arshift = function(...) return _hx_bit_clamp(_hx_bit_raw.arshift(...)) end;
if _hx_bit_raw then
_hx_bit_clamp = function(v)
if v <= 2147483647 and v >= -2147483648 then
if v > 0 then return _G.math.floor(v)
else return _G.math.ceil(v)
end
end
if v > 2251798999999999 then v = v*2 end;
if (v ~= v or math.abs(v) == _G.math.huge) then return nil end
return _hx_bit_raw.band(v, 2147483647 ) - math.abs(_hx_bit_raw.band(v, 2147483648))
end
else
_hx_bit_clamp = function(v)
if v < -2147483648 then
return -2147483648
elseif v > 2147483647 then
return 2147483647
elseif v > 0 then
return _G.math.floor(v)
else
return _G.math.ceil(v)
end
end
end;
_hx_array_mt.__index = Array.prototype
local _hx_static_init = function()
if (__lua_lib_lrexlib_Rex == nil) then
_G.error(__haxe_Exception.thrown("Rex is missing. Please install lrexlib-pcre."),0);
end;
2023-03-09 22:32:28 +01:00
String.__name__ = true;
Array.__name__ = true;EReg.FLAGS = __lua_lib_lrexlib_Rex.flags();
2023-03-09 19:58:08 +01:00
end
_hx_table = {}
_hx_table.pack = _G.table.pack or function(...)
return {...}
end
_hx_table.unpack = _G.table.unpack or _G.unpack
_hx_table.maxn = _G.table.maxn or function(t)
local maxn=0;
for i in pairs(t) do
maxn=type(i)=='number'and i>maxn and i or maxn
end
return maxn
end;
_hx_wrap_if_string_field = function(o, fld)
if _G.type(o) == 'string' then
if fld == 'length' then
return _G.string.len(o)
else
return String.prototype[fld]
end
else
return o[fld]
end
end
_hx_static_init();
return _hx_exports