| Zydis
    v3.2.0
    | 
Implements the ZydisFormatterToken type and provides functions to use it.  
More...
#include <ZydisExportConfig.h>#include <Zycore/String.h>#include <Zycore/Types.h>#include <Zydis/Status.h>

Go to the source code of this file.
| Data Structures | |
| struct | ZydisFormatterToken_ | 
| Defines the ZydisFormatterTokenstruct.  More... | |
| struct | ZydisFormatterBuffer_ | 
| Defines the ZydisFormatterBufferstruct.  More... | |
| Macros | |
| #define | ZYDIS_TOKEN_INVALID 0x00 | 
| #define | ZYDIS_TOKEN_WHITESPACE 0x01 | 
| A whitespace character.  More... | |
| #define | ZYDIS_TOKEN_DELIMITER 0x02 | 
| A delimiter character (like ‘’,' ,':','+','-','*'`).  More... | |
| #define | ZYDIS_TOKEN_PARENTHESIS_OPEN 0x03 | 
| An opening parenthesis character (like ‘’(' ,'[','{'`).  More... | |
| #define | ZYDIS_TOKEN_PARENTHESIS_CLOSE 0x04 | 
| A closing parenthesis character (like ‘’)' ,']','}'`).  More... | |
| #define | ZYDIS_TOKEN_PREFIX 0x05 | 
| A prefix literal (like "LOCK","REP").  More... | |
| #define | ZYDIS_TOKEN_MNEMONIC 0x06 | 
| A mnemonic literal (like "MOV","VCMPPSD","LCALL").  More... | |
| #define | ZYDIS_TOKEN_REGISTER 0x07 | 
| A register literal (like "RAX","DS","%ECX").  More... | |
| #define | ZYDIS_TOKEN_ADDRESS_ABS 0x08 | 
| An absolute address literal (like 0x00400000).  More... | |
| #define | ZYDIS_TOKEN_ADDRESS_REL 0x09 | 
| A relative address literal (like -0x100).  More... | |
| #define | ZYDIS_TOKEN_DISPLACEMENT 0x0A | 
| A displacement literal (like 0xFFFFFFFF,-0x100,+0x1234).  More... | |
| #define | ZYDIS_TOKEN_IMMEDIATE 0x0B | 
| An immediate literal (like 0xC0,-0x1234,$0x0000).  More... | |
| #define | ZYDIS_TOKEN_TYPECAST 0x0C | 
| A typecast literal (like DWORD PTR).  More... | |
| #define | ZYDIS_TOKEN_DECORATOR 0x0D | 
| A decorator literal (like "Z","1TO4").  More... | |
| #define | ZYDIS_TOKEN_SYMBOL 0x0E | 
| A symbol literal.  More... | |
| #define | ZYDIS_TOKEN_USER 0x80 | 
| The base for user-defined token types.  More... | |
| Typedefs | |
| typedef ZyanU8 | ZydisTokenType | 
| @biref Defines the ZydisTokenTypedata-type.  More... | |
| typedef struct ZydisFormatterToken_ | ZydisFormatterToken | 
| Defines the ZydisFormatterTokenstruct.  More... | |
| typedef const ZydisFormatterToken | ZydisFormatterTokenConst | 
| Defines the ZydisFormatterTokenConstdata-type.  More... | |
| typedef struct ZydisFormatterBuffer_ | ZydisFormatterBuffer | 
| Defines the ZydisFormatterBufferstruct.  More... | |
| Functions | |
| ZYDIS_EXPORT ZyanStatus | ZydisFormatterTokenGetValue (const ZydisFormatterToken *token, ZydisTokenType *type, ZyanConstCharPointer *value) | 
| Returns the typeand the stringvalueof the giventoken.  More... | |
| ZYDIS_EXPORT ZyanStatus | ZydisFormatterTokenNext (ZydisFormatterTokenConst **token) | 
| Obtains the next tokenlinked to the passed one.  More... | |
| ZYDIS_EXPORT ZyanStatus | ZydisFormatterBufferGetToken (const ZydisFormatterBuffer *buffer, ZydisFormatterTokenConst **token) | 
| Returns the current (most recently added) token.  More... | |
| ZYDIS_EXPORT ZyanStatus | ZydisFormatterBufferGetString (ZydisFormatterBuffer *buffer, ZyanString **string) | 
| Returns the ZyanStringinstance associated with the given buffer.  More... | |
| ZYDIS_EXPORT ZyanStatus | ZydisFormatterBufferAppend (ZydisFormatterBuffer *buffer, ZydisTokenType type) | 
| Appends a new token to the buffer.  More... | |
| ZYDIS_EXPORT ZyanStatus | ZydisFormatterBufferRemember (const ZydisFormatterBuffer *buffer, ZyanUPointer *state) | 
| Returns a snapshot of the buffer-state.  More... | |
| ZYDIS_EXPORT ZyanStatus | ZydisFormatterBufferRestore (ZydisFormatterBuffer *buffer, ZyanUPointer state) | 
| Restores a previously saved buffer-state.  More... | |
Implements the ZydisFormatterToken type and provides functions to use it. 
| #define ZYDIS_TOKEN_ADDRESS_ABS 0x08 | 
An absolute address literal (like 0x00400000). 
| #define ZYDIS_TOKEN_ADDRESS_REL 0x09 | 
A relative address literal (like -0x100). 
| #define ZYDIS_TOKEN_DECORATOR 0x0D | 
A decorator literal (like "Z", "1TO4"). 
| #define ZYDIS_TOKEN_DELIMITER 0x02 | 
A delimiter character (like ‘’,',':','+','-','*'`). 
| #define ZYDIS_TOKEN_DISPLACEMENT 0x0A | 
A displacement literal (like 0xFFFFFFFF, -0x100, +0x1234). 
| #define ZYDIS_TOKEN_IMMEDIATE 0x0B | 
An immediate literal (like 0xC0, -0x1234, $0x0000). 
| #define ZYDIS_TOKEN_INVALID 0x00 | 
| #define ZYDIS_TOKEN_MNEMONIC 0x06 | 
A mnemonic literal (like "MOV", "VCMPPSD", "LCALL"). 
| #define ZYDIS_TOKEN_PARENTHESIS_CLOSE 0x04 | 
A closing parenthesis character (like ‘’)',']','}'`). 
| #define ZYDIS_TOKEN_PARENTHESIS_OPEN 0x03 | 
An opening parenthesis character (like ‘’(','[','{'`). 
| #define ZYDIS_TOKEN_PREFIX 0x05 | 
A prefix literal (like "LOCK", "REP"). 
| #define ZYDIS_TOKEN_REGISTER 0x07 | 
A register literal (like "RAX", "DS", "%ECX"). 
| #define ZYDIS_TOKEN_SYMBOL 0x0E | 
A symbol literal.
| #define ZYDIS_TOKEN_TYPECAST 0x0C | 
A typecast literal (like DWORD PTR). 
| #define ZYDIS_TOKEN_USER 0x80 | 
The base for user-defined token types.
| #define ZYDIS_TOKEN_WHITESPACE 0x01 | 
A whitespace character.
| typedef struct ZydisFormatterBuffer_ ZydisFormatterBuffer | 
Defines the ZydisFormatterBuffer struct. 
All fields in this struct should be considered as "private". Any changes may lead to unexpected behavior.
| typedef struct ZydisFormatterToken_ ZydisFormatterToken | 
Defines the ZydisFormatterToken struct. 
All fields in this struct should be considered as "private". Any changes may lead to unexpected behavior.
| typedef const ZydisFormatterToken ZydisFormatterTokenConst | 
Defines the ZydisFormatterTokenConst data-type. 
| typedef ZyanU8 ZydisTokenType | 
@biref Defines the ZydisTokenType data-type. 
| ZYDIS_EXPORT ZyanStatus ZydisFormatterBufferAppend | ( | ZydisFormatterBuffer * | buffer, | 
| ZydisTokenType | type | ||
| ) | 
Appends a new token to the buffer. 
| buffer | A pointer to the ZydisFormatterBufferstruct. | 
| type | The type of the new token. | 
Note that the ZyanString instance returned by ZydisFormatterBufferGetString will automatically be updated by calling this function. 
| ZYDIS_EXPORT ZyanStatus ZydisFormatterBufferGetString | ( | ZydisFormatterBuffer * | buffer, | 
| ZyanString ** | string | ||
| ) | 
Returns the ZyanString instance associated with the given buffer. 
| buffer | A pointer to the ZydisFormatterBufferstruct. | 
| string | Receives a pointer to the ZyanStringinstance associated with the given buffer. | 
This function returns ZYAN_STATUS_INVALID_OPERATION, if the buffer does not contain at least one token.
The returned string always refers to the literal value of the current (most recently added) token and will remain valid until the buffer is destroyed.
| ZYDIS_EXPORT ZyanStatus ZydisFormatterBufferGetToken | ( | const ZydisFormatterBuffer * | buffer, | 
| ZydisFormatterTokenConst ** | token | ||
| ) | 
Returns the current (most recently added) token.
| buffer | A pointer to the ZydisFormatterBufferstruct. | 
| token | Receives a pointer to the current token. | 
This function returns ZYAN_STATUS_INVALID_OPERATION, if the buffer does not contain at least one token. 
| ZYDIS_EXPORT ZyanStatus ZydisFormatterBufferRemember | ( | const ZydisFormatterBuffer * | buffer, | 
| ZyanUPointer * | state | ||
| ) | 
Returns a snapshot of the buffer-state.
| buffer | A pointer to the ZydisFormatterBufferstruct. | 
| state | Receives a snapshot of the buffer-state. | 
Note that the buffer-state is saved inside the buffer itself and thus becomes invalid as soon as the buffer gets overwritten or destroyed.
| ZYDIS_EXPORT ZyanStatus ZydisFormatterBufferRestore | ( | ZydisFormatterBuffer * | buffer, | 
| ZyanUPointer | state | ||
| ) | 
Restores a previously saved buffer-state.
| buffer | A pointer to the ZydisFormatterBufferstruct. | 
| state | The buffer-state to restore. | 
All tokens added after obtaining the given state snapshot will be removed. This function does NOT restore any string content.
Note that the ZyanString instance returned by ZydisFormatterBufferGetString will automatically be updated by calling this function. 
| ZYDIS_EXPORT ZyanStatus ZydisFormatterTokenGetValue | ( | const ZydisFormatterToken * | token, | 
| ZydisTokenType * | type, | ||
| ZyanConstCharPointer * | value | ||
| ) | 
Returns the type and the string value of the given token. 
| token | A pointer to the ZydisFormatterTokenstruct. | 
| type | Receives the token type. | 
| value | Receives a pointer to the string value of the token. | 
| ZYDIS_EXPORT ZyanStatus ZydisFormatterTokenNext | ( | ZydisFormatterTokenConst ** | token | ) | 
Obtains the next token linked to the passed one. 
| token | Receives a pointer to the next ZydisFormatterTokenstruct linked to the passed one. |