--[[ This file is part of Cratera Compiler Copyright (C) 2019 Soni L. This program is free software: you can redistribute it and/or modify it under the terms of the GNU Affero General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more details. You should have received a copy of the GNU Affero General Public License along with this program. If not, see . --]] -- this isn't supposed to be installed or anything it's just a basic CLI to -- print a lua or cratera file as a token stream. local parser = require "cratera.parser" -- CLI argument rules local defs = parser.selfify({}) defs['-'] = function(state, token) if state.filename then error("Must specify only one filename") end state.filename = true state.file = io.stdin return "self" end defs[parser.FALLBACK] = function(state, token) if state.filename then error("Must specify only one filename") end state.filename = token state.file, state.err = io.open(state.filename, "r") return "self" end defs[parser.EOZ] = function(state, token) if not state.file then error((state.filename and (state.err or "") or "No file specified") ) end return {} end defs[-1] = function(state, token, rule) if token ~= parser.EOZ and token:sub(1,1) == "-" and not rule then error("Unknown option: " .. token) end end defs['-l'] = function(state, token, rule) state.print_lineno = true return "self" end defs['--'] = parser.selfify({[parser.FALLBACK] = defs[parser.FALLBACK], [parser.EOZ] = defs[parser.EOZ]}) local state = parser.parse(defs, arg) local luatokens = require "cratera.luatokens" local file = state.file local tokens = luatokens.defs local print_lineno = state.print_lineno --local state, err, etoken, estate = parser.parse(tokens, function() return file:read(8192) end) local f, s, i = parser.stream(tokens, function() return file:read(8192) end) local lastline local lasttoken = 0 for pos, state, transemsg, etoken, estate in f, s, i do if not state then print("Parse error") break end if (state.line or 1) ~= lastline then lastline = state.line or 1 print("line", lastline) end for i,v in ipairs(state) do lasttoken = lasttoken + 1 v = luatokens.reverse_keywords[v] or luatokens.reverse_tokens[v] or v print(lasttoken, v) -- TODO formatting state[i] = nil end if not transemsg then break end end