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

-- used in chem-ini.lua

local lpegmatch, patterns = lpeg.match, lpeg.patterns
local P, R, V, Cc, Cs = lpeg.P, lpeg.R, lpeg.V, lpeg.Cc, lpeg.Cs
local format = string.format

local cpatterns     = patterns.context or { }
patterns.context    = cpatterns

local utf8character = patterns.utf8character
local cardinal      = patterns.cardinal

local leftbrace     = P("{")
local rightbrace    = P("}")
local backslash     = P("\\")
local csname        = backslash * P(1) * (1-backslash-leftbrace)^0 * P(" ")^0
local sign          = P("+") / "\\textplus "
                    + P("-") / "\\textminus "
local nested        = P { leftbrace * (V(1) + (1-rightbrace))^0 * rightbrace }
local subscript     = P("_")
local superscript   = P("^")

-- local scripts    = P { "start",
--                        start     = V("csname") + V("lowfirst") + V("highfirst"),
--                        csname    = csname,
--                        content   = Cs(V("csname") + nested + sign^-1 * (cardinal + utf8character)),
--                        lowfirst  = subscript   * ( Cc("\\lohi{%s}{%s}") * V("content") * superscript + Cc("\\low{%s}" ) ) * V("content") / format,
--                        highfirst = superscript * ( Cc("\\hilo{%s}{%s}") * V("content") * subscript   + Cc("\\high{%s}") ) * V("content") / format,
--                    }

-- local scripts    = P { "start",
--                           start     = (V("csname") + V("lowfirst") + V("highfirst"))^1,
--                           csname    = csname,
--                           content   = Cs(V("csname") + nested + sign^-1 * (cardinal + utf8character)),
--                           lowfirst  = (subscript  /"") * ( Cc("\\lohi{") * V("content") * Cc("}{") * (superscript/"") + Cc("\\low{" ) ) * V("content") * Cc("}"),
--                           highfirst = (superscript/"") * ( Cc("\\hilo{") * V("content") * Cc("}{") * (subscript  /"") + Cc("\\high{") ) * V("content") * Cc("}"),
--                       }

local scripted      = Cs { "start",
                          start     = (V("csname") + V("nested") + V("lowfirst") + V("highfirst") + V("character"))^1,
                          rest      = V("csname") + V("nested") + V("lowfirst") + V("highfirst"),
                          csname    = csname,
                          character = utf8character,
                       -- nested    = leftbrace * (V("rest") + (V("character")-rightbrace))^0 * rightbrace,
                          nested    = leftbrace * (V("start") -rightbrace)^0 * rightbrace,
                       -- content   = Cs(V("nested") + sign^-1 * (cardinal + V("character"))),
                          content   = V("nested") + sign^-1 * (cardinal + V("character")) + sign,
                          lowfirst  = (subscript  /"") * ( Cc("\\lohi{") * V("content") * Cc("}{") * (superscript/"") + Cc("\\low{" ) ) * V("content") * Cc("}"),
                          highfirst = (superscript/"") * ( Cc("\\hilo{") * V("content") * Cc("}{") * (subscript  /"") + Cc("\\high{") ) * V("content") * Cc("}"),
                      }

cpatterns.csname    = csname
cpatterns.scripted  = scripted
cpatterns.nested    = nested

-- print(lpegmatch(scripted,"10^-3_x"))
-- print(lpegmatch(scripted,"\\L {C_5}"))
-- print(lpegmatch(scripted,"\\SL{}"))
-- print(lpegmatch(scripted,"\\SL{C_5}"))
-- print(lpegmatch(scripted,"\\SL{C_5}"))
-- print(lpegmatch(scripted,"{C_5}"))
-- print(lpegmatch(scripted,"{\\C_5}"))
-- print(lpegmatch(scripted,"10^-a"))