forked from izaya/OC-PsychOS2
added the preproc library, meaning PsychOS is nominally self-hosting
This commit is contained in:
parent
7dda36fd1d
commit
29cdcb1809
3
build.lua
Normal file
3
build.lua
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
local preproc = require "preproc"
|
||||||
|
--local tA = {...}
|
||||||
|
preproc(...)
|
2
build.sh
2
build.sh
@ -2,7 +2,7 @@
|
|||||||
LUA=${LUA:-lua}
|
LUA=${LUA:-lua}
|
||||||
rm -r target/*
|
rm -r target/*
|
||||||
mkdir -p target/doc &>/dev/null
|
mkdir -p target/doc &>/dev/null
|
||||||
$LUA luapreproc.lua module/init.lua target/init.lua
|
$LUA build.lua module/init.lua target/init.lua
|
||||||
echo _OSVERSION=\"PsychOS 2.0a2-$(git rev-parse --short HEAD)\" > target/version.lua
|
echo _OSVERSION=\"PsychOS 2.0a2-$(git rev-parse --short HEAD)\" > target/version.lua
|
||||||
cat target/version.lua target/init.lua > target/tinit.lua
|
cat target/version.lua target/init.lua > target/tinit.lua
|
||||||
mv target/tinit.lua target/init.lua
|
mv target/tinit.lua target/init.lua
|
||||||
|
69
lib/preproc.lua
Normal file
69
lib/preproc.lua
Normal file
@ -0,0 +1,69 @@
|
|||||||
|
local preproc = {}
|
||||||
|
preproc.directives = {}
|
||||||
|
|
||||||
|
function preproc.parsewords(line) -- string -- table -- Returns a table of words from the string *line*, parsing quotes and escapes.
|
||||||
|
local rt = {""}
|
||||||
|
local escaped, quoted = false, false
|
||||||
|
for c in line:gmatch(".") do
|
||||||
|
if escaped then
|
||||||
|
rt[#rt] = rt[#rt]..c
|
||||||
|
elseif c == '"' or c == "'" then
|
||||||
|
quoted = not quoted
|
||||||
|
elseif c == "\\" then
|
||||||
|
escaped = true
|
||||||
|
elseif c:match("%s") and not quoted and rt[#rt]:len() > 0 then
|
||||||
|
rt[#rt+1] = ""
|
||||||
|
else
|
||||||
|
rt[#rt] = rt[#rt]..c
|
||||||
|
end
|
||||||
|
end
|
||||||
|
return rt
|
||||||
|
end
|
||||||
|
|
||||||
|
function preproc.line(line) -- string -- -- Returns either a function - which can be called to get lines until it returns nil - or a string from processing *line* using preprocessor directives.
|
||||||
|
if line:match("^%-%-#") then
|
||||||
|
local directive, args = line:match("^%-%-#(%S+)%s(.+)")
|
||||||
|
print(directive,args)
|
||||||
|
local args = preproc.parsewords(args)
|
||||||
|
if preproc.directives[directive] then
|
||||||
|
return preproc.directives[directive](table.unpack(args))
|
||||||
|
else
|
||||||
|
error("unknown preprocessor directive: "..directive)
|
||||||
|
end
|
||||||
|
else
|
||||||
|
return line
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
function preproc.preproc(...) -- string -- string -- Returns the output from preprocessing the files listed in *...*.
|
||||||
|
local tA = {...}
|
||||||
|
local output = ""
|
||||||
|
for _,fname in ipairs(tA) do
|
||||||
|
local f,e = io.open(fname)
|
||||||
|
if not f then error("unable to open file "..fname..": "..e) end
|
||||||
|
for line in f:lines() do
|
||||||
|
local r = preproc.line(line)
|
||||||
|
if type(r) == "function" then
|
||||||
|
while true do
|
||||||
|
local rs = r()
|
||||||
|
if not rs then break end
|
||||||
|
output = output .. rs .. "\n"
|
||||||
|
end
|
||||||
|
else
|
||||||
|
output = output .. r .. "\n"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
return output
|
||||||
|
end
|
||||||
|
|
||||||
|
preproc.directives.include = preproc.preproc
|
||||||
|
|
||||||
|
return setmetatable(preproc,{__call=function(_,...)
|
||||||
|
local tA = {...}
|
||||||
|
local out = table.remove(tA,#tA)
|
||||||
|
local f,e = io.open(out,"wb")
|
||||||
|
if not f then error("unable to open file "..out..": "..e) end
|
||||||
|
f:write(preproc.preproc(table.unpack(tA)))
|
||||||
|
f:close()
|
||||||
|
end})
|
1
preproc.lua
Symbolic link
1
preproc.lua
Symbolic link
@ -0,0 +1 @@
|
|||||||
|
lib/preproc.lua
|
Loading…
Reference in New Issue
Block a user