if not modules then modules = { } end modules ['strc-lev'] = { version = 1.001, comment = "companion to strc-lev.mkiv", author = "Hans Hagen, PRAGMA-ADE, Hasselt NL", copyright = "PRAGMA ADE / ConTeXt Development Team", license = "see context related readme files" } local insert, remove = table.insert, table.remove local settings_to_array = utilities.parsers.settings_to_array local context = context local interfaces = interfaces local sections = structures.sections local implement = interfaces.implement local v_default = interfaces.variables.default sections.levels = sections.levels or { } local level = 0 local levels = sections.levels local categories = { } local f_two_colon = string.formatters["%s:%s"] storage.register("structures/sections/levels", levels, "structures.sections.levels") local function definesectionlevels(category,list) list = settings_to_array(list) for i=1,#list do list[i] = settings_to_array(list[i]) end levels[category] = list end local ctx_nostarthead = context.nostarthead local ctx_dostarthead = context.dostarthead local ctx_nostophead = context.nostophead local ctx_dostophead = context.dostophead local function startsectionlevel(n,category,current) category = category ~= "" and category or v_default local lc = levels[category] for i=1,#lc do local lcl = lc[i] if (lcl[n] or lcl[1]) == current then level = i break end end level = level + 1 if not lc or level > #lc then level = level - 1 local what = f_two_colon(category,level) ctx_nostarthead { what } insert(categories,{ category, n, level, what }) else local lcl = lc[level] if n > #lcl then n = #lcl end ctx_dostarthead { lcl[n] } insert(categories,{ category, n }) end end local function stopsectionlevel() local top = remove(categories) if top then local category = top[1] local n = top[2] local bad = top[3] local what = top[4] local lc = levels[category] if not lc or bad then ctx_nostophead { what } level = bad else local lcl = lc[level] if n > #lcl then n = #lcl end ctx_dostophead { lcl[n] } level = level - 1 end else ctx_nostophead { "?" } end end implement { name = "definesectionlevels", actions = definesectionlevels, arguments = "2 strings", } implement { name = "startsectionlevel", actions = startsectionlevel, arguments = { "integer", "string", "string" }, } implement { name = "stopsectionlevel", actions = stopsectionlevel, }