123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115 |
- /* Copyright (c) 2012-2017 The ANTLR Project. All rights reserved.
- * Use of this file is governed by the BSD 3-clause license that
- * can be found in the LICENSE.txt file in the project root.
- */
- #pragma once
- #include "TokenStream.h"
- namespace antlr4 {
- class ANTLR4CPP_PUBLIC UnbufferedTokenStream : public TokenStream {
- public:
- UnbufferedTokenStream(TokenSource *tokenSource);
- UnbufferedTokenStream(TokenSource *tokenSource, int bufferSize);
- UnbufferedTokenStream(const UnbufferedTokenStream& other) = delete;
- virtual ~UnbufferedTokenStream();
- UnbufferedTokenStream& operator = (const UnbufferedTokenStream& other) = delete;
- virtual Token* get(size_t i) const override;
- virtual Token* LT(ssize_t i) override;
- virtual size_t LA(ssize_t i) override;
- virtual TokenSource* getTokenSource() const override;
- virtual std::string getText(const misc::Interval &interval) override;
- virtual std::string getText() override;
- virtual std::string getText(RuleContext *ctx) override;
- virtual std::string getText(Token *start, Token *stop) override;
- virtual void consume() override;
- /// <summary>
- /// Return a marker that we can release later.
- /// <p/>
- /// The specific marker value used for this class allows for some level of
- /// protection against misuse where {@code seek()} is called on a mark or
- /// {@code release()} is called in the wrong order.
- /// </summary>
- virtual ssize_t mark() override;
- virtual void release(ssize_t marker) override;
- virtual size_t index() override;
- virtual void seek(size_t index) override;
- virtual size_t size() override;
- virtual std::string getSourceName() const override;
- protected:
- /// Make sure we have 'need' elements from current position p. Last valid
- /// p index is tokens.length - 1. p + need - 1 is the tokens index 'need' elements
- /// ahead. If we need 1 element, (p+1-1)==p must be less than tokens.length.
- TokenSource *_tokenSource;
- /// <summary>
- /// A moving window buffer of the data being scanned. While there's a marker,
- /// we keep adding to buffer. Otherwise, <seealso cref="#consume consume()"/> resets so
- /// we start filling at index 0 again.
- /// </summary>
- std::vector<std::unique_ptr<Token>> _tokens;
- /// <summary>
- /// 0..n-1 index into <seealso cref="#tokens tokens"/> of next token.
- /// <p/>
- /// The {@code LT(1)} token is {@code tokens[p]}. If {@code p == n}, we are
- /// out of buffered tokens.
- /// </summary>
- size_t _p;
- /// <summary>
- /// Count up with <seealso cref="#mark mark()"/> and down with
- /// <seealso cref="#release release()"/>. When we {@code release()} the last mark,
- /// {@code numMarkers} reaches 0 and we reset the buffer. Copy
- /// {@code tokens[p]..tokens[n-1]} to {@code tokens[0]..tokens[(n-1)-p]}.
- /// </summary>
- int _numMarkers;
- /// <summary>
- /// This is the {@code LT(-1)} token for the current position.
- /// </summary>
- Token *_lastToken;
- /// <summary>
- /// When {@code numMarkers > 0}, this is the {@code LT(-1)} token for the
- /// first token in <seealso cref="#tokens"/>. Otherwise, this is {@code null}.
- /// </summary>
- Token *_lastTokenBufferStart;
- /// <summary>
- /// Absolute token index. It's the index of the token about to be read via
- /// {@code LT(1)}. Goes from 0 to the number of tokens in the entire stream,
- /// although the stream size is unknown before the end is reached.
- /// <p/>
- /// This value is used to set the token indexes if the stream provides tokens
- /// that implement <seealso cref="WritableToken"/>.
- /// </summary>
- size_t _currentTokenIndex;
- virtual void sync(ssize_t want);
- /// <summary>
- /// Add {@code n} elements to the buffer. Returns the number of tokens
- /// actually added to the buffer. If the return value is less than {@code n},
- /// then EOF was reached before {@code n} tokens could be added.
- /// </summary>
- virtual size_t fill(size_t n);
- virtual void add(std::unique_ptr<Token> t);
- size_t getBufferStartIndex() const;
- private:
- void InitializeInstanceFields();
- };
- } // namespace antlr4
|