xaizek / zograscope (License: AGPLv3 only) (since 2018-12-07)
Mainly a syntax-aware diff that also provides a number of additional tools.
<root> / src / make / MakeLexerData.hpp (b80610a76141bfd1252be45a828a85a28a59a5af) (2,407B) (mode 100644) [raw]
// 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_
Hints

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