blob: d3aa3b1c24089ae138d21d666327314df7347d40 [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 "CacheableHashMapMN.hpp"
using namespace System;
using namespace System::Collections::Generic;
namespace GemStone
{
namespace GemFire
{
namespace Cache { namespace Generic
{
/// <summary>
/// A mutable <c>ICacheableKey</c> to <c>IGFSerializable</c> hash map
/// that can serve as a distributable object for caching. This class
/// extends .NET generic <c>Dictionary</c> class. This class is meant
/// as a means to interoperate with java server side
/// <c>IdentityHashMap</c> class objects but is intentionally not
/// intended to provide <c>java.util.IdentityHashMap</c> semantics.
/// </summary>
ref class CacheableIdentityHashMap
: public CacheableHashMap
{
public:
/// <summary>
/// Allocates a new empty instance.
/// </summary>
inline CacheableIdentityHashMap()
: CacheableHashMap()
{ }
/// <summary>
/// Allocates a new instance copying from the given dictionary.
/// </summary>
/// <param name="dictionary">
/// The dictionary whose elements are copied to this HashMap.
/// </param>
inline CacheableIdentityHashMap(Object^ dictionary)
: CacheableHashMap(dictionary)
{ }
/// <summary>
/// Allocates a new empty instance with given initial size.
/// </summary>
/// <param name="capacity">
/// The initial capacity of the HashMap.
/// </param>
inline CacheableIdentityHashMap(int32_t capacity)
: CacheableHashMap(capacity)
{ }
/// <summary>
/// Static function to create a new empty instance.
/// </summary>
inline static CacheableIdentityHashMap^ Create()
{
return gcnew CacheableIdentityHashMap();
}
/// <summary>
/// Static function to create a new instance copying from the
/// given dictionary.
/// </summary>
inline static CacheableIdentityHashMap^ Create(
Object^ dictionary)
{
return gcnew CacheableIdentityHashMap(dictionary);
}
/// <summary>
/// Static function to create a new instance with given initial size.
/// </summary>
inline static CacheableIdentityHashMap^ Create(int32_t capacity)
{
return gcnew CacheableIdentityHashMap(capacity);
}
// Region: IGFSerializable Members
/// <summary>
/// Returns the classId of the instance being serialized.
/// This is used by deserialization to determine what instance
/// type to create and deserialize into.
/// </summary>
/// <returns>the classId</returns>
virtual property uint32_t ClassId
{
virtual uint32_t get() override
{
return GemFireClassIds::CacheableIdentityHashMap;
}
}
// End Region: IGFSerializable Members
/// <summary>
/// Factory function to register this class.
/// </summary>
static IGFSerializable^ CreateDeserializable()
{
return gcnew CacheableIdentityHashMap();
}
};
}
}
}
} //namespace