#include <DataConversion.h>
Inheritance diagram for DataConverter:

These objects are used by such things as SgAsmGenericFile::parse(), where an encoded file is read into a buffer from disk and then decoded in memory. This allows ROSE to operate on malicious software while hiding the software from the operating system while it sits on disk.
Public Member Functions | |
| virtual | ~DataConverter () |
| virtual std::string | name () const =0 |
| Name of the converter, mostly for debugging purposes. | |
| virtual uint8_t * | encode (uint8_t *buffer, size_t *nbytes)=0 |
| Encodes a buffer. | |
| virtual uint8_t * | decode (uint8_t *buffer, size_t *nbytes)=0 |
| Decodes a buffer. | |
| virtual DataConverter::~DataConverter | ( | ) | [inline, virtual] |
| virtual std::string DataConverter::name | ( | ) | const [pure virtual] |
| virtual uint8_t* DataConverter::encode | ( | uint8_t * | buffer, | |
| size_t * | nbytes | |||
| ) | [pure virtual] |
Encodes a buffer.
Encodes the supplied buffer either in place or into a newly allocated buffer. The return value is the location of the encoded data and the nbytes argument should be updated to reflect the size of the encoded data. The original buffer should not be deleted by this method.
Implemented in Rot13.
| virtual uint8_t* DataConverter::decode | ( | uint8_t * | buffer, | |
| size_t * | nbytes | |||
| ) | [pure virtual] |
Decodes a buffer.
Decodes the supplied buffer either in place or into a newly allocated buffer. The return value is the location of the decoded data and the nbytes argument should be updated to reflect the size of the decoded data. The original buffer should not be deleted by this method.
Implemented in Rot13.
1.4.7