| 1 |
#ifndef INC_CharBuffer_hpp__ |
| 2 |
#define INC_CharBuffer_hpp__ |
| 3 |
|
| 4 |
/* ANTLR Translator Generator |
| 5 |
* Project led by Terence Parr at http://www.jGuru.com |
| 6 |
* Software rights: http://www.antlr.org/license.html |
| 7 |
* |
| 8 |
* $Id: CharBuffer.hpp,v 1.1 2005-12-02 15:38:02 tim Exp $ |
| 9 |
*/ |
| 10 |
|
| 11 |
#include <istream> |
| 12 |
|
| 13 |
#include <antlr/config.hpp> |
| 14 |
#include <antlr/InputBuffer.hpp> |
| 15 |
|
| 16 |
#ifdef ANTLR_CXX_SUPPORTS_NAMESPACE |
| 17 |
namespace antlr { |
| 18 |
#endif |
| 19 |
|
| 20 |
/**A Stream of characters fed to the lexer from a InputStream that can |
| 21 |
* be rewound via mark()/rewind() methods. |
| 22 |
* <p> |
| 23 |
* A dynamic array is used to buffer up all the input characters. Normally, |
| 24 |
* "k" characters are stored in the buffer. More characters may be stored |
| 25 |
* during guess mode (testing syntactic predicate), or when LT(i>k) is |
| 26 |
* referenced. |
| 27 |
* Consumption of characters is deferred. In other words, reading the next |
| 28 |
* character is not done by consume(), but deferred until needed by LA or LT. |
| 29 |
* <p> |
| 30 |
* |
| 31 |
* @see antlr.CharQueue |
| 32 |
*/ |
| 33 |
|
| 34 |
class ANTLR_API CharBuffer : public InputBuffer { |
| 35 |
public: |
| 36 |
/// Create a character buffer |
| 37 |
CharBuffer( ANTLR_USE_NAMESPACE(std)istream& input ); |
| 38 |
/// Get the next character from the stream |
| 39 |
int getChar(); |
| 40 |
|
| 41 |
protected: |
| 42 |
// character source |
| 43 |
ANTLR_USE_NAMESPACE(std)istream& input; |
| 44 |
|
| 45 |
private: |
| 46 |
// NOTE: Unimplemented |
| 47 |
CharBuffer(const CharBuffer& other); |
| 48 |
CharBuffer& operator=(const CharBuffer& other); |
| 49 |
}; |
| 50 |
|
| 51 |
#ifdef ANTLR_CXX_SUPPORTS_NAMESPACE |
| 52 |
} |
| 53 |
#endif |
| 54 |
|
| 55 |
#endif //INC_CharBuffer_hpp__ |