data-aux.lua / last modification: 2020-01-30 14:16
if not modules then modules = { } end modules ['data-aux'] = {
    version   = 1.001,
    comment   = "companion to luat-lib.mkiv",
    author    = "Hans Hagen, PRAGMA-ADE, Hasselt NL",
    copyright = "PRAGMA ADE / ConTeXt Development Team",
    license   = "see context related readme files"
}

local find = string.find
local type, next = type, next
local addsuffix, removesuffix = file.addsuffix, file.removesuffix
local loaddata, savedata = io.loaddata, io.savedata

local trace_locating = false  trackers.register("resolvers.locating", function(v) trace_locating = v end)

local resolvers = resolvers
local cleanpath = resolvers.cleanpath
local findfiles = resolvers.findfiles

local report_scripts = logs.reporter("resolvers","scripts")

function resolvers.updatescript(oldname,newname) -- oldname -> own.name, not per se a suffix
 -- local scriptpath = "scripts/context/lua"
    local scriptpath = "context/lua"
    local oldscript  = cleanpath(oldname)
    local newname    = addsuffix(newname,"lua")
    local newscripts = findfiles(newname) or { }
    if trace_locating then
        report_scripts("to be replaced old script %a", oldscript)
    end
    if #newscripts == 0 then
        if trace_locating then
            report_scripts("unable to locate new script")
        end
    else
        for i=1,#newscripts do
            local newscript = cleanpath(newscripts[i])
            if trace_locating then
                report_scripts("checking new script %a", newscript)
            end
            if oldscript == newscript then
                if trace_locating then
                    report_scripts("old and new script are the same")
                end
            elseif not find(newscript,scriptpath,1,true) then
                if trace_locating then
                    report_scripts("new script should come from %a",scriptpath)
                end
            elseif not (find(oldscript,removesuffix(newname).."$") or find(oldscript,newname.."$")) then
                if trace_locating then
                    report_scripts("invalid new script name")
                end
            else
                local newdata = loaddata(newscript)
                if newdata then
                    if trace_locating then
                        report_scripts("old script content replaced by new content: %s",oldscript)
                    end
                    savedata(oldscript,newdata)
                    break
                elseif trace_locating then
                    report_scripts("unable to load new script")
                end
            end
        end
    end
end