Class TTokenizer
Unit
PasDoc_Tokenizer
Declaration
type TTokenizer = class(TObject)
Description
Converts an input TStream to a sequence of TToken objects.
Hierarchy
Overview
Fields
Methods
Properties
Description
Fields
data:image/s3,"s3://crabby-images/95594/955945d6570d692a3494909db26e9959ff724113" alt="Protected Protected" |
FVerbosity: Cardinal; |
|
data:image/s3,"s3://crabby-images/95594/955945d6570d692a3494909db26e9959ff724113" alt="Protected Protected" |
BufferedChar: Char; |
if IsCharBuffered is true, this field contains the buffered character
|
data:image/s3,"s3://crabby-images/95594/955945d6570d692a3494909db26e9959ff724113" alt="Protected Protected" |
EOS: Boolean; |
true if end of stream Stream has been reached, false otherwise
|
data:image/s3,"s3://crabby-images/95594/955945d6570d692a3494909db26e9959ff724113" alt="Protected Protected" |
IsCharBuffered: Boolean; |
if this is true, BufferedChar contains a buffered character; the next call to GetChar or PeekChar will return this character, not the next in the associated stream Stream
|
data:image/s3,"s3://crabby-images/95594/955945d6570d692a3494909db26e9959ff724113" alt="Protected Protected" |
Row: Integer; |
current row in stream Stream; useful when giving error messages
|
data:image/s3,"s3://crabby-images/95594/955945d6570d692a3494909db26e9959ff724113" alt="Protected Protected" |
Stream: TStream; |
the input stream this tokenizer is working on
|
data:image/s3,"s3://crabby-images/95594/955945d6570d692a3494909db26e9959ff724113" alt="Protected Protected" |
FStreamName: string; |
|
data:image/s3,"s3://crabby-images/95594/955945d6570d692a3494909db26e9959ff724113" alt="Protected Protected" |
FStreamPath: string; |
|
Methods
data:image/s3,"s3://crabby-images/95594/955945d6570d692a3494909db26e9959ff724113" alt="Protected Protected" |
procedure DoError(const AMessage: string; const AArguments: array of const); |
|
data:image/s3,"s3://crabby-images/95594/955945d6570d692a3494909db26e9959ff724113" alt="Protected Protected" |
procedure DoMessage(const AVerbosity: Cardinal; const MessageType: TPasDocMessageType; const AMessage: string; const AArguments: array of const); |
|
data:image/s3,"s3://crabby-images/95594/955945d6570d692a3494909db26e9959ff724113" alt="Protected Protected" |
procedure CheckForDirective(const t: TToken); |
|
data:image/s3,"s3://crabby-images/95594/955945d6570d692a3494909db26e9959ff724113" alt="Protected Protected" |
procedure ConsumeChar; |
|
data:image/s3,"s3://crabby-images/95594/955945d6570d692a3494909db26e9959ff724113" alt="Protected Protected" |
function CreateSymbolToken(const st: TSymbolType; const s: string): TToken; overload; |
|
data:image/s3,"s3://crabby-images/95594/955945d6570d692a3494909db26e9959ff724113" alt="Protected Protected" |
function CreateSymbolToken(const st: TSymbolType): TToken; overload; |
Uses default symbol representation, from SymbolNames[st]
|
data:image/s3,"s3://crabby-images/95594/955945d6570d692a3494909db26e9959ff724113" alt="Protected Protected" |
function GetChar(out c: AnsiChar): Integer; |
Returns 1 on success or 0 on failure
|
data:image/s3,"s3://crabby-images/95594/955945d6570d692a3494909db26e9959ff724113" alt="Protected Protected" |
function PeekChar(out c: Char): Boolean; |
|
data:image/s3,"s3://crabby-images/95594/955945d6570d692a3494909db26e9959ff724113" alt="Protected Protected" |
function ReadCommentType1: TToken; |
|
data:image/s3,"s3://crabby-images/95594/955945d6570d692a3494909db26e9959ff724113" alt="Protected Protected" |
function ReadCommentType2: TToken; |
|
data:image/s3,"s3://crabby-images/95594/955945d6570d692a3494909db26e9959ff724113" alt="Protected Protected" |
function ReadCommentType3: TToken; |
|
data:image/s3,"s3://crabby-images/95594/955945d6570d692a3494909db26e9959ff724113" alt="Protected Protected" |
function ReadAttAssemblerRegister: TToken; |
|
data:image/s3,"s3://crabby-images/95594/955945d6570d692a3494909db26e9959ff724113" alt="Protected Protected" |
function ReadLiteralString(var t: TToken): Boolean; |
|
data:image/s3,"s3://crabby-images/c3b87/c3b87b7ecf46c003681199bd4f77e9c2100bc23c" alt="Public Public" |
constructor Create( const AStream: TStream; const OnMessageEvent: TPasDocMessageEvent; const VerbosityLevel: Cardinal; const AStreamName, AStreamPath: string); |
Creates a TTokenizer and associates it with given input TStream. Note that AStream will be freed when this object will be freed.
|
data:image/s3,"s3://crabby-images/c3b87/c3b87b7ecf46c003681199bd4f77e9c2100bc23c" alt="Public Public" |
destructor Destroy; override; |
Releases all dynamically allocated memory.
|
data:image/s3,"s3://crabby-images/c3b87/c3b87b7ecf46c003681199bd4f77e9c2100bc23c" alt="Public Public" |
function HasData: Boolean; |
|
data:image/s3,"s3://crabby-images/c3b87/c3b87b7ecf46c003681199bd4f77e9c2100bc23c" alt="Public Public" |
function GetStreamInfo: string; |
|
data:image/s3,"s3://crabby-images/c3b87/c3b87b7ecf46c003681199bd4f77e9c2100bc23c" alt="Public Public" |
function GetToken(const NilOnEnd: Boolean = false): TToken; |
|
data:image/s3,"s3://crabby-images/c3b87/c3b87b7ecf46c003681199bd4f77e9c2100bc23c" alt="Public Public" |
procedure UnGetToken(var T: TToken); |
Makes the token T next to be returned by GetToken. Also sets T to Nil , to prevent you from freeing it accidentally.
You cannot have more than one "unget" token. If you only call UnGetToken after some GetToken, you are safe.
|
data:image/s3,"s3://crabby-images/c3b87/c3b87b7ecf46c003681199bd4f77e9c2100bc23c" alt="Public Public" |
function SkipUntilCompilerDirective: TToken; |
Skip all chars until it encounters some compiler directive, like $ELSE or $ENDIF. Returns either Nil or a token with MyType = TOK_DIRECTIVE.
|
Properties
data:image/s3,"s3://crabby-images/c3b87/c3b87b7ecf46c003681199bd4f77e9c2100bc23c" alt="Public Public" |
property StreamPath: string read FStreamPath; |
This is the path where the underlying file of this stream is located.
It may be an absolute path or a relative path. Relative paths are always resolved vs pasdoc current directory. This way user can give relative paths in command-line when writing Pascal source filenames to parse.
In particular, this may be '' to indicate current dir.
It's always specified like it was processed by IncludeTrailingPathDelimiter, so it has trailing PathDelim included (unless it was '', in which case it remains empty).
|
Generated by PasDoc 0.16.0.