2018-01-26 11:37:49 +00:00
|
|
|
local PASTEBIN_URL = 'http://pastebin.com/raw'
|
|
|
|
local GIT_URL = 'https://raw.githubusercontent.com'
|
2018-12-30 11:50:59 +00:00
|
|
|
|
|
|
|
local function split(str, pattern)
|
|
|
|
local t = { }
|
|
|
|
local function helper(line) table.insert(t, line) return "" end
|
|
|
|
helper((str:gsub(pattern, helper)))
|
|
|
|
return t
|
|
|
|
end
|
|
|
|
|
|
|
|
local luaPaths = package and package.path and split(package.path, '(.-);') or { }
|
|
|
|
for i = 1, #luaPaths do
|
|
|
|
if luaPaths[i] == '?' or luaPaths[i] == '?.lua' then
|
|
|
|
luaPaths[i] = nil
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2019-01-27 03:58:02 +00:00
|
|
|
table.insert(luaPaths, 1, '?.lua')
|
|
|
|
table.insert(luaPaths, 2, '?/init.lua')
|
|
|
|
table.insert(luaPaths, 3, '/usr/apis/?.lua')
|
|
|
|
table.insert(luaPaths, 4, '/usr/apis/?/init.lua')
|
|
|
|
table.insert(luaPaths, 5, '/sys/apis/?.lua')
|
|
|
|
table.insert(luaPaths, 6, '/sys/apis/?/init.lua')
|
2018-12-30 11:50:59 +00:00
|
|
|
|
|
|
|
local DEFAULT_PATH = table.concat(luaPaths, ';')
|
2018-12-27 08:05:12 +00:00
|
|
|
local DEFAULT_BRANCH = _ENV.OPUS_BRANCH or _G.OPUS_BRANCH or 'develop-1.8'
|
2018-01-26 11:37:49 +00:00
|
|
|
local DEFAULT_UPATH = GIT_URL .. '/kepler155c/opus/' .. DEFAULT_BRANCH .. '/sys/apis'
|
2016-12-23 04:22:04 +00:00
|
|
|
|
2018-12-23 22:32:06 +00:00
|
|
|
local fs = _G.fs
|
|
|
|
local http = _G.http
|
|
|
|
local os = _G.os
|
|
|
|
local string = _G.string
|
2017-10-08 21:45:01 +00:00
|
|
|
|
2017-10-09 00:03:01 +00:00
|
|
|
if not http._patched then
|
2018-01-24 22:39:38 +00:00
|
|
|
-- fix broken http get
|
|
|
|
local syncLocks = { }
|
|
|
|
|
|
|
|
local function sync(obj, fn)
|
|
|
|
local key = tostring(obj)
|
|
|
|
if syncLocks[key] then
|
|
|
|
local cos = tostring(coroutine.running())
|
|
|
|
table.insert(syncLocks[key], cos)
|
|
|
|
repeat
|
|
|
|
local _, co = os.pullEvent('sync_lock')
|
|
|
|
until co == cos
|
|
|
|
else
|
|
|
|
syncLocks[key] = { }
|
|
|
|
end
|
|
|
|
fn()
|
|
|
|
local co = table.remove(syncLocks[key], 1)
|
|
|
|
if co then
|
|
|
|
os.queueEvent('sync_lock', co)
|
|
|
|
else
|
|
|
|
syncLocks[key] = nil
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
-- todo -- completely replace http.get with function that
|
|
|
|
-- checks for success on permanent redirects (minecraft 1.75 bug)
|
|
|
|
|
|
|
|
http._patched = http.get
|
|
|
|
function http.get(url, headers)
|
|
|
|
local s, m
|
|
|
|
sync(url, function()
|
|
|
|
s, m = http._patched(url, headers)
|
|
|
|
end)
|
|
|
|
return s, m
|
|
|
|
end
|
2016-12-18 19:38:48 +00:00
|
|
|
end
|
2016-12-11 19:24:52 +00:00
|
|
|
|
2016-12-18 19:38:48 +00:00
|
|
|
local function loadUrl(url)
|
2018-01-24 22:39:38 +00:00
|
|
|
local c
|
|
|
|
local h = http.get(url)
|
|
|
|
if h then
|
|
|
|
c = h.readAll()
|
|
|
|
h.close()
|
|
|
|
end
|
|
|
|
if c and #c > 0 then
|
|
|
|
return c
|
|
|
|
end
|
2016-12-11 19:24:52 +00:00
|
|
|
end
|
|
|
|
|
2018-01-20 12:18:13 +00:00
|
|
|
-- Add require and package to the environment
|
2018-12-23 22:32:06 +00:00
|
|
|
return function(env)
|
2019-01-27 03:58:02 +00:00
|
|
|
local function preloadSearcher(modname)
|
2019-01-13 00:51:56 +00:00
|
|
|
if env.package.preload[modname] then
|
|
|
|
return function()
|
|
|
|
return env.package.preload[modname](modname, env)
|
|
|
|
end
|
|
|
|
end
|
2018-01-24 22:39:38 +00:00
|
|
|
end
|
|
|
|
|
2019-01-27 03:58:02 +00:00
|
|
|
local function loadedSearcher(modname)
|
|
|
|
if env.package.loaded[modname] then
|
|
|
|
return function()
|
|
|
|
return env.package.loaded[modname]
|
2018-01-24 22:39:38 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
local function pathSearcher(modname)
|
2018-12-17 03:17:19 +00:00
|
|
|
local fname = modname:gsub('%.', '/')
|
2018-01-24 22:39:38 +00:00
|
|
|
|
2018-12-17 03:17:19 +00:00
|
|
|
for pattern in string.gmatch(env.package.path, "[^;]+") do
|
|
|
|
local sPath = string.gsub(pattern, "%?", fname)
|
2019-01-27 03:58:02 +00:00
|
|
|
-- TODO: if there's no shell, we should not be checking relative paths below
|
|
|
|
-- as they will resolve to root directory
|
|
|
|
if env.shell and type(env.shell.getRunningProgram) == 'function' and sPath:sub(1, 1) ~= "/" then
|
2019-01-27 05:26:41 +00:00
|
|
|
sPath = fs.combine(fs.getDir(env.shell.getRunningProgram() or ''), sPath)
|
2018-12-17 03:17:19 +00:00
|
|
|
end
|
|
|
|
if fs.exists(sPath) and not fs.isDir(sPath) then
|
|
|
|
return loadfile(sPath, env)
|
|
|
|
end
|
|
|
|
end
|
2018-01-24 22:39:38 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
-- require('BniCQPVf')
|
|
|
|
local function pastebinSearcher(modname)
|
|
|
|
if #modname == 8 and not modname:match('%W') then
|
|
|
|
local url = PASTEBIN_URL .. '/' .. modname
|
|
|
|
local c = loadUrl(url)
|
|
|
|
if c then
|
|
|
|
return load(c, modname, nil, env)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
-- require('kepler155c.opus.master.sys.apis.util')
|
|
|
|
local function gitSearcher(modname)
|
|
|
|
local fname = modname:gsub('%.', '/') .. '.lua'
|
|
|
|
local _, count = fname:gsub("/", "")
|
|
|
|
if count >= 3 then
|
|
|
|
local url = GIT_URL .. '/' .. fname
|
|
|
|
local c = loadUrl(url)
|
|
|
|
if c then
|
|
|
|
return load(c, modname, nil, env)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
local function urlSearcher(modname)
|
|
|
|
local fname = modname:gsub('%.', '/') .. '.lua'
|
|
|
|
|
|
|
|
if fname:sub(1, 1) ~= '/' then
|
|
|
|
for entry in string.gmatch(env.package.upath, "[^;]+") do
|
|
|
|
local url = entry .. '/' .. fname
|
|
|
|
local c = loadUrl(url)
|
|
|
|
if c then
|
|
|
|
return load(c, modname, nil, env)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
-- place package and require function into env
|
|
|
|
env.package = {
|
2018-01-26 11:37:49 +00:00
|
|
|
path = env.LUA_PATH or _G.LUA_PATH or DEFAULT_PATH,
|
|
|
|
upath = env.LUA_UPATH or _G.LUA_UPATH or DEFAULT_UPATH,
|
2018-01-24 22:39:38 +00:00
|
|
|
config = '/\n:\n?\n!\n-',
|
2019-01-13 00:51:56 +00:00
|
|
|
preload = { },
|
2018-01-24 22:39:38 +00:00
|
|
|
loaded = {
|
2018-12-23 22:32:06 +00:00
|
|
|
coroutine = coroutine,
|
|
|
|
io = io,
|
2018-01-24 22:39:38 +00:00
|
|
|
math = math,
|
2018-12-23 22:32:06 +00:00
|
|
|
os = os,
|
2018-01-24 22:39:38 +00:00
|
|
|
string = string,
|
|
|
|
table = table,
|
|
|
|
},
|
|
|
|
loaders = {
|
2019-01-27 03:58:02 +00:00
|
|
|
preloadSearcher,
|
|
|
|
loadedSearcher,
|
2018-01-24 22:39:38 +00:00
|
|
|
pathSearcher,
|
|
|
|
pastebinSearcher,
|
|
|
|
gitSearcher,
|
|
|
|
urlSearcher,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function env.require(modname)
|
|
|
|
for _,searcher in ipairs(env.package.loaders) do
|
|
|
|
local fn, msg = searcher(modname)
|
|
|
|
if fn then
|
|
|
|
local module, msg2 = fn(modname, env)
|
|
|
|
if not module then
|
|
|
|
error(msg2 or (modname .. ' module returned nil'), 2)
|
|
|
|
end
|
|
|
|
env.package.loaded[modname] = module
|
|
|
|
return module
|
|
|
|
end
|
|
|
|
if msg then
|
|
|
|
error(msg, 2)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
error('Unable to find module ' .. modname)
|
|
|
|
end
|
|
|
|
|
|
|
|
return env.require -- backwards compatible
|
2016-12-11 19:24:52 +00:00
|
|
|
end
|