https://github.com/shader-slang/slang
Tip revision: 48ae5496516878768d7de241b9b7fbba91fbaa74 authored by Tim Foley on 19 June 2019, 14:23:49 UTC
Start exposing a new COM-lite API (#987)
Start exposing a new COM-lite API (#987)
Tip revision: 48ae549
slang-lexer.h
#ifndef SLANG_LEXER_H
#define SLANG_LEXER_H
#include "../core/slang-basic.h"
#include "slang-diagnostics.h"
namespace Slang
{
struct NamePool;
//
struct TokenList
{
Token* begin() const;
Token* end() const;
List<Token> mTokens;
};
struct TokenSpan
{
TokenSpan();
TokenSpan(
TokenList const& tokenList)
: mBegin(tokenList.begin())
, mEnd (tokenList.end ())
{}
Token* begin() const { return mBegin; }
Token* end () const { return mEnd ; }
int GetCount() { return (int)(mEnd - mBegin); }
Token* mBegin;
Token* mEnd;
};
struct TokenReader
{
Token nextToken;
TokenReader();
explicit TokenReader(TokenSpan const& tokens)
: mCursor(tokens.begin())
, mEnd (tokens.end ())
, nextToken(tokens.begin() ? *tokens.begin() : GetEndOfFileToken())
{}
explicit TokenReader(TokenList const& tokens)
: mCursor(tokens.begin())
, mEnd (tokens.end ())
, nextToken(tokens.begin() ? *tokens.begin() : GetEndOfFileToken())
{}
struct ParsingCursor
{
Token nextToken;
Token* tokenReaderCursor = nullptr;
};
ParsingCursor getCursor()
{
ParsingCursor rs;
rs.nextToken = nextToken;
rs.tokenReaderCursor = mCursor;
return rs;
}
void setCursor(ParsingCursor cursor)
{
mCursor = cursor.tokenReaderCursor;
nextToken = cursor.nextToken;
}
bool IsAtEnd() const { return mCursor == mEnd; }
Token& PeekToken();
TokenType PeekTokenType() const;
SourceLoc PeekLoc() const;
Token AdvanceToken();
int GetCount() { return (int)(mEnd - mCursor); }
Token* mCursor;
Token* mEnd;
static Token GetEndOfFileToken();
};
typedef unsigned int LexerFlags;
enum
{
kLexerFlag_InDirective = 1 << 0, ///< Turn end-of-line and end-of-file into end-of-directive
kLexerFlag_ExpectFileName = 1 << 1, ///< Support `<>` style strings for file paths
kLexerFlag_IgnoreInvalid = 1 << 2, ///< Suppress errors about invalid/unsupported characters
kLexerFlag_ExpectDirectiveMessage = 1 << 3, ///< Don't lexer ordinary tokens, and instead consume rest of line as a string
};
struct Lexer
{
void initialize(
SourceView* sourceView,
DiagnosticSink* sink,
NamePool* namePool,
MemoryArena* memoryArena);
~Lexer();
Token lexToken(LexerFlags extraFlags = 0);
TokenList lexAllTokens();
SourceView* sourceView;
DiagnosticSink* sink;
NamePool* namePool;
char const* cursor;
char const* begin;
char const* end;
/// The starting sourceLoc (same as first location of SourceView)
SourceLoc startLoc;
TokenFlags tokenFlags;
LexerFlags lexerFlags;
MemoryArena* memoryArena;
};
// Helper routines for extracting values from tokens
String getStringLiteralTokenValue(Token const& token);
String getFileNameTokenValue(Token const& token);
typedef int64_t IntegerLiteralValue;
typedef double FloatingPointLiteralValue;
IntegerLiteralValue getIntegerLiteralValue(Token const& token, UnownedStringSlice* outSuffix = 0);
FloatingPointLiteralValue getFloatingPointLiteralValue(Token const& token, UnownedStringSlice* outSuffix = 0);
}
#endif