Added methods AddToMessage() and SetFromMessage() to add the value of the
variant as a field to a message, respectively initialize the variant from one. git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@33901 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
6309d64e37
commit
be350af3d9
@ -19,6 +19,9 @@ enum {
|
|||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
class BMessage;
|
||||||
|
|
||||||
|
|
||||||
class BVariant {
|
class BVariant {
|
||||||
public:
|
public:
|
||||||
inline BVariant();
|
inline BVariant();
|
||||||
@ -95,6 +98,11 @@ public:
|
|||||||
// has effect only on scalar types (pointer
|
// has effect only on scalar types (pointer
|
||||||
// counting as scalar, not string, though)
|
// counting as scalar, not string, though)
|
||||||
|
|
||||||
|
status_t AddToMessage(BMessage& message,
|
||||||
|
const char* fieldName) const;
|
||||||
|
status_t SetFromMessage(const BMessage& message,
|
||||||
|
const char* fieldName);
|
||||||
|
|
||||||
static size_t SizeOfType(type_code type);
|
static size_t SizeOfType(type_code type);
|
||||||
static bool TypeIsNumber(type_code type);
|
static bool TypeIsNumber(type_code type);
|
||||||
static bool TypeIsInteger(type_code type,
|
static bool TypeIsInteger(type_code type,
|
||||||
|
@ -10,6 +10,7 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
#include <ByteOrder.h>
|
#include <ByteOrder.h>
|
||||||
|
#include <Message.h>
|
||||||
|
|
||||||
|
|
||||||
template<typename NumberType>
|
template<typename NumberType>
|
||||||
@ -356,6 +357,65 @@ BVariant::SwapEndianess()
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
status_t
|
||||||
|
BVariant::AddToMessage(BMessage& message, const char* fieldName) const
|
||||||
|
{
|
||||||
|
switch (fType) {
|
||||||
|
case B_BOOL_TYPE:
|
||||||
|
return message.AddBool(fieldName, fBool);
|
||||||
|
case B_INT8_TYPE:
|
||||||
|
return fInt8 != 0;
|
||||||
|
return message.AddInt8(fieldName, fInt8);
|
||||||
|
case B_UINT8_TYPE:
|
||||||
|
return message.AddUInt8(fieldName, fUInt8);
|
||||||
|
case B_INT16_TYPE:
|
||||||
|
return message.AddInt16(fieldName, fInt16);
|
||||||
|
case B_UINT16_TYPE:
|
||||||
|
return message.AddUInt16(fieldName, fUInt16);
|
||||||
|
case B_INT32_TYPE:
|
||||||
|
return message.AddInt32(fieldName, fInt32);
|
||||||
|
case B_UINT32_TYPE:
|
||||||
|
return message.AddUInt32(fieldName, fUInt32);
|
||||||
|
case B_INT64_TYPE:
|
||||||
|
return message.AddInt64(fieldName, fInt64);
|
||||||
|
case B_UINT64_TYPE:
|
||||||
|
return message.AddUInt64(fieldName, fUInt64);
|
||||||
|
case B_FLOAT_TYPE:
|
||||||
|
return message.AddFloat(fieldName, fFloat);
|
||||||
|
case B_DOUBLE_TYPE:
|
||||||
|
return message.AddDouble(fieldName, fDouble);
|
||||||
|
case B_POINTER_TYPE:
|
||||||
|
return message.AddPointer(fieldName, fPointer);
|
||||||
|
case B_STRING_TYPE:
|
||||||
|
return message.AddString(fieldName, fString);
|
||||||
|
default:
|
||||||
|
return B_UNSUPPORTED;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
status_t
|
||||||
|
BVariant::SetFromMessage(const BMessage& message, const char* fieldName)
|
||||||
|
{
|
||||||
|
// get the message field info
|
||||||
|
type_code type;
|
||||||
|
int32 count;
|
||||||
|
status_t error = message.GetInfo(fieldName, &type, &count);
|
||||||
|
if (error != B_OK)
|
||||||
|
return error;
|
||||||
|
|
||||||
|
// get the data
|
||||||
|
const void* data;
|
||||||
|
ssize_t numBytes;
|
||||||
|
error = message.FindData(fieldName, type, &data, &numBytes);
|
||||||
|
if (error != B_OK)
|
||||||
|
return error;
|
||||||
|
|
||||||
|
// init the object
|
||||||
|
return SetToTypedData(data, type);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/*static*/ size_t
|
/*static*/ size_t
|
||||||
BVariant::SizeOfType(type_code type)
|
BVariant::SizeOfType(type_code type)
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user