// Copyright (C) 2017 xaizek <xaizek@posteo.net>
//
// This file is part of zograscope.
//
// zograscope is free software: you can redistribute it and/or modify
// it under the terms of version 3 of the GNU Affero General Public License as
// published by the Free Software Foundation.
//
// zograscope 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 zograscope. If not, see <http://www.gnu.org/licenses/>.
#ifndef ZOGRASCOPE_MAKE_MAKELEXERDATA_HPP_
#define ZOGRASCOPE_MAKE_MAKELEXERDATA_HPP_
#include <cstddef>
#include <cstring>
#include <string>
#include <vector>
#include "make/make-parser.gen.hpp"
#include "LexerData.hpp"
// Make-specific state of the lexer.
struct MakeLexerData : LexerData
{
// Type of nesting.
enum {
FunctionNesting, // Function nesting.
ArgumentNesting, // Function argument nesting.
EvalArgumentNesting, // `$$(...)` inside a call.
};
std::size_t offset = 0U; // Byte offset in the input.
std::size_t line = 1U; // Current line number.
std::size_t col = 1U; // Current column number.
// Start token for things like comments and literals.
MAKE_STYPE startTok = {};
// Start location for things like comments and literals.
MAKE_LTYPE startLoc = {};
// Offset of the last token that was returned by the lexer.
std::size_t lastReturnedOffset = static_cast<std::size_t>(-1);
// Id of the last token that was returned by the lexer
int lastToken = 0;
// Whether whitespace token might be needed before the next token.
bool fakeWSIsNeeded = false;
// Keeps track of function nesting (where keywords stop being keywords).
std::vector<unsigned char> nesting;
MakeParseData *pd; // Link to Make-specific state of the parser.
// Remembers arguments to use them in the lexer, all of them must be alive
// during lexing (including the string which isn't copied).
MakeLexerData(const std::string &str, int tabWidth, TreeBuilder &tb,
MakeParseData &pd)
: LexerData(str, tabWidth, tb), pd(&pd)
{ }
};
#endif // ZOGRASCOPE_MAKE_MAKELEXERDATA_HPP_
Before first commit, do not forget to setup your git environment:
git config --global user.name "your_name_here"
git config --global user.email "your@email_here"
Clone this repository using HTTP(S):
git clone https://code.reversed.top/user/xaizek/zograscope
Clone this repository using ssh (do not forget to upload a key first):
git clone ssh://rocketgit@code.reversed.top/user/xaizek/zograscope
You are allowed to anonymously push to this repository.
This means that your pushed commits will automatically be transformed into a
pull request:
... clone the repository ...
... make some changes and some commits ...
git push origin master