Represents a VarBind according to RFC 2741, section 5.4. More...
#include <varbind.hpp>
Public Types | |
| enum | type_t { Null = 5, noSuchObject = 128, noSuchInstance = 129, endOfMibView = 130 } |
| These values can be used to create a VarBind. More... | |
Public Member Functions | |
| varbind (const oid &, boost::shared_ptr< variable > v) | |
| Create a VarBind with an oid and a var. | |
| varbind (const oid &, type_t) | |
| Create VarBind without var, but with a type. | |
| varbind (binary::const_iterator &pos, const binary::const_iterator &end, bool big_endian=true) | |
| Construct the object from input stream. | |
| binary | serialize () const |
| Serialize the varbind. | |
Private Attributes | |
| oid | name |
| The name (OID) of the VarBind. | |
| boost::shared_ptr< variable > | var |
| The variable inside the varbind. | |
| uint16_t | type |
| The type of the varbind. | |
Represents a VarBind according to RFC 2741, section 5.4.
Definition at line 39 of file varbind.hpp.
These values can be used to create a VarBind.
Definition at line 86 of file varbind.hpp.
Create a VarBind with an oid and a var.
The variable must be one of the following types:
Definition at line 58 of file varbind.cpp.
Create VarBind without var, but with a type.
Only the constants defined by varbind::type_t are allowed. A wrong type will cause an inval_param exception.
Definition at line 81 of file varbind.cpp.
References endOfMibView, name, noSuchInstance, noSuchObject, Null, and type.
| varbind::varbind | ( | binary::const_iterator & | pos, |
| const binary::const_iterator & | end, | ||
| bool | big_endian = true |
||
| ) |
Construct the object from input stream.
This constructor parses the serialized form of the object. It takes an iterator, starts parsing at the position of the iterator and advances the iterator to the position right behind the object.
The constructor expects valid data from the stream; if parsing fails, parse_error is thrown. In this case, the iterator position is undefined.
| pos | Iterator pointing to the current stream position. The iterator is advanced while reading the header. |
| end | Iterator pointing one element past the end of the current stream. This is needed to mark the end of the buffer. |
| big_endian | Whether the input stream is in big endian format |
Definition at line 101 of file varbind.cpp.
References name, agentxcpp::read16(), type, and var.
| binary varbind::serialize | ( | ) | const |
Serialize the varbind.
This creates the binary representation of the varbind.
Definition at line 36 of file varbind.cpp.
References name, agentxcpp::oid::serialize(), type, and var.
|
private |
The name (OID) of the VarBind.
Definition at line 45 of file varbind.hpp.
Referenced by serialize(), and varbind().
|
private |
The type of the varbind.
This field represents the type as described in RFC 2741, section 5.4. The serialize() function will copy it directly into the varbind.
Definition at line 62 of file varbind.hpp.
Referenced by serialize(), and varbind().
|
private |
The variable inside the varbind.
This pointer may be 0 if the varbind has a type without a variable (e.g. "NoSuchObject").
Definition at line 53 of file varbind.hpp.
Referenced by serialize(), and varbind().