blob: 75e40f84cfbe314e0a16d61e035bbd9fd188e287 [file] [log] [blame]
/*=========================================================================
* Copyright (c) 2002-2014 Pivotal Software, Inc. All Rights Reserved.
* This product is protected by U.S. and international copyright
* and intellectual property laws. Pivotal products are covered by
* more patents listed at http://www.pivotal.io/patents.
*=========================================================================
*/
#pragma once
#include "../gf_defs.hpp"
#include <vcclr.h>
#include <cppcache/CacheableKey.hpp>
#include "../LogM.hpp"
#include "../DataOutputM.hpp"
#include "../IGFSerializable.hpp"
using namespace System;
//namespace GemStone
//{
// namespace GemFire
// {
// namespace Cache
// {
// interface class IGFSerializable;
// }
// }
//}
namespace gemfire
{
/// <summary>
/// Wraps the managed <see cref="GemStone.GemFire.Cache.IGFSerializable" />
/// object and implements the native <c>gemfire::CacheableKey</c> interface.
/// </summary>
class ManagedCacheableKeyBytes
: public CacheableKey
{
private:
GemStone::GemFire::Cache::IGFSerializable^ getManagedObject() const;
/// <summary>
/// Using gcroot to hold the managed delegate pointer (since it cannot be stored directly).
/// Note: not using auto_gcroot since it will result in 'Dispose' of the IGFSerializable
/// to be called which is not what is desired when this object is destroyed. Normally this
/// managed object may be created by the user and will be handled automatically by the GC.
/// </summary>
// gcroot<GemStone::GemFire::Cache::IGFSerializable^> m_managedptr;
int m_domainId;
UInt32 m_classId;
uint8_t * m_bytes;
uint32_t m_size;
uint32_t m_hashCode;
// Disable the copy and assignment constructors
ManagedCacheableKeyBytes( const ManagedCacheableKeyBytes& );
ManagedCacheableKeyBytes& operator = ( const ManagedCacheableKeyBytes& );
public:
inline ManagedCacheableKeyBytes(){}
/// <summary>
/// Constructor to initialize with the provided managed object.
/// </summary>
/// <param name="managedptr">
/// The managed object.
/// </param>
inline ManagedCacheableKeyBytes(
GemStone::GemFire::Cache::IGFSerializable^ managedptr, bool storeBytes )
: m_domainId(System::Threading::Thread::GetDomainID()),
m_classId(managedptr->ClassId),
m_bytes(NULL),
m_size(0),
m_hashCode(0)
{
if(managedptr != nullptr)
{
if(storeBytes)//if value is form app
{
gemfire::DataOutput dataOut;
GemStone::GemFire::Cache::DataOutput mg_output( &dataOut, true);
managedptr->ToData( %mg_output );
//move cursor
//dataOut.advanceCursor(mg_output.BufferLength);
mg_output.WriteBytesToUMDataOutput();
m_bytes = dataOut.getBufferCopy();
m_size = dataOut.getBufferLength();
m_hashCode = managedptr->GetHashCode();
GemStone::GemFire::Cache::Log::Fine("ManagedCacheableKeyBytes::Constructor objectSize = " + m_size + " m_hashCode = " + m_hashCode);
}
}
}
/// <summary>
/// serialize this object
/// </summary>
virtual void toData( DataOutput& output ) const;
/// <summary>
/// deserialize this object, typical implementation should return
/// the 'this' pointer.
/// </summary>
virtual Serializable* fromData( DataInput& input );
/// <summary>
/// return the size of this object in bytes
/// </summary>
virtual uint32_t objectSize() const;
/// <summary>
/// return the classId of the instance being serialized.
/// This is used by deserialization to determine what instance
/// type to create and deserialize into.
/// </summary>
virtual int32_t classId( ) const;
/// <summary>
/// return the typeId of the instance being serialized.
/// This is used by deserialization to determine what instance
/// type to create and deserialize into.
/// </summary>
virtual int8_t typeId( ) const;
/// <summary>
/// return the Data Serialization Fixed ID type.
/// This is used to determine what instance type to create
/// and deserialize into.
///
/// Note that this should not be overridden by custom implementations
/// and is reserved only for builtin types.
/// </summary>
virtual int8_t DSFID() const;
/// <summary>
/// Display this object as 'string', which depends on the implementation in
/// the managed class
/// </summary>
virtual CacheableStringPtr toString( ) const;
/// <summary>
/// return true if this key matches other CacheableKey
/// </summary>
virtual bool operator == ( const CacheableKey& other ) const;
/// <summary>
/// return true if this key matches other ManagedCacheableKeyBytes
/// </summary>
virtual bool operator == ( const ManagedCacheableKeyBytes& other ) const;
/// <summary>
/// return the hashcode for this key.
/// </summary>
virtual uint32_t hashcode( ) const;
/// <summary>
/// Copy the string form of a key into a char* buffer for logging purposes.
/// implementations should only generate a string as long as maxLength chars,
/// and return the number of chars written. buffer is expected to be large
/// enough to hold at least maxLength chars.
/// The default implementation renders the classname and instance address.
/// </summary>
virtual size_t logString( char* buffer, size_t maxLength ) const;
/// <summary>
/// Returns the wrapped managed object reference.
/// </summary>
inline GemStone::GemFire::Cache::IGFSerializable^ ptr( ) const
{
return getManagedObject();
}
inline ~ManagedCacheableKeyBytes()
{
GemStone::GemFire::Cache::Log::Fine("ManagedCacheableKeyBytes::Destructor current AppDomain ID: " + System::Threading::Thread::GetDomainID() + " for object: " + System::Convert::ToString((int)this) + " with its AppDomain ID: " + m_domainId);
GF_SAFE_DELETE(m_bytes);
}
};
}