You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@geode.apache.org by jb...@apache.org on 2017/08/11 23:53:05 UTC
[49/52] [partial] geode-native git commit: GEODE-3165: Reogranized
sources relative to the root for better CMake IDE integration.
http://git-wip-us.apache.org/repos/asf/geode-native/blob/6cbd424f/clicache/integration-test/BuiltinCacheableWrappersN.cs
----------------------------------------------------------------------
diff --git a/clicache/integration-test/BuiltinCacheableWrappersN.cs b/clicache/integration-test/BuiltinCacheableWrappersN.cs
new file mode 100644
index 0000000..444fe71
--- /dev/null
+++ b/clicache/integration-test/BuiltinCacheableWrappersN.cs
@@ -0,0 +1,2782 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements. See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You under the Apache License, Version 2.0
+ * (the "License"); you may not use this file except in compliance with
+ * the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+using System;
+using System.Collections.Generic;
+
+namespace Apache.Geode.Client.UnitTests
+{
+ using NUnit.Framework;
+ using Apache.Geode.DUnitFramework;
+ using Apache.Geode.Client;
+
+ #region Helper class
+
+ public class CacheableHelper
+ {
+ #region Constants and statics
+
+ private static uint[] CRC32Table = {
+ 0x00000000, 0x77073096, 0xee0e612c, 0x990951ba, 0x076dc419, 0x706af48f,
+ 0xe963a535, 0x9e6495a3, 0x0edb8832, 0x79dcb8a4, 0xe0d5e91e, 0x97d2d988,
+ 0x09b64c2b, 0x7eb17cbd, 0xe7b82d07, 0x90bf1d91, 0x1db71064, 0x6ab020f2,
+ 0xf3b97148, 0x84be41de, 0x1adad47d, 0x6ddde4eb, 0xf4d4b551, 0x83d385c7,
+ 0x136c9856, 0x646ba8c0, 0xfd62f97a, 0x8a65c9ec, 0x14015c4f, 0x63066cd9,
+ 0xfa0f3d63, 0x8d080df5, 0x3b6e20c8, 0x4c69105e, 0xd56041e4, 0xa2677172,
+ 0x3c03e4d1, 0x4b04d447, 0xd20d85fd, 0xa50ab56b, 0x35b5a8fa, 0x42b2986c,
+ 0xdbbbc9d6, 0xacbcf940, 0x32d86ce3, 0x45df5c75, 0xdcd60dcf, 0xabd13d59,
+ 0x26d930ac, 0x51de003a, 0xc8d75180, 0xbfd06116, 0x21b4f4b5, 0x56b3c423,
+ 0xcfba9599, 0xb8bda50f, 0x2802b89e, 0x5f058808, 0xc60cd9b2, 0xb10be924,
+ 0x2f6f7c87, 0x58684c11, 0xc1611dab, 0xb6662d3d, 0x76dc4190, 0x01db7106,
+ 0x98d220bc, 0xefd5102a, 0x71b18589, 0x06b6b51f, 0x9fbfe4a5, 0xe8b8d433,
+ 0x7807c9a2, 0x0f00f934, 0x9609a88e, 0xe10e9818, 0x7f6a0dbb, 0x086d3d2d,
+ 0x91646c97, 0xe6635c01, 0x6b6b51f4, 0x1c6c6162, 0x856530d8, 0xf262004e,
+ 0x6c0695ed, 0x1b01a57b, 0x8208f4c1, 0xf50fc457, 0x65b0d9c6, 0x12b7e950,
+ 0x8bbeb8ea, 0xfcb9887c, 0x62dd1ddf, 0x15da2d49, 0x8cd37cf3, 0xfbd44c65,
+ 0x4db26158, 0x3ab551ce, 0xa3bc0074, 0xd4bb30e2, 0x4adfa541, 0x3dd895d7,
+ 0xa4d1c46d, 0xd3d6f4fb, 0x4369e96a, 0x346ed9fc, 0xad678846, 0xda60b8d0,
+ 0x44042d73, 0x33031de5, 0xaa0a4c5f, 0xdd0d7cc9, 0x5005713c, 0x270241aa,
+ 0xbe0b1010, 0xc90c2086, 0x5768b525, 0x206f85b3, 0xb966d409, 0xce61e49f,
+ 0x5edef90e, 0x29d9c998, 0xb0d09822, 0xc7d7a8b4, 0x59b33d17, 0x2eb40d81,
+ 0xb7bd5c3b, 0xc0ba6cad, 0xedb88320, 0x9abfb3b6, 0x03b6e20c, 0x74b1d29a,
+ 0xead54739, 0x9dd277af, 0x04db2615, 0x73dc1683, 0xe3630b12, 0x94643b84,
+ 0x0d6d6a3e, 0x7a6a5aa8, 0xe40ecf0b, 0x9309ff9d, 0x0a00ae27, 0x7d079eb1,
+ 0xf00f9344, 0x8708a3d2, 0x1e01f268, 0x6906c2fe, 0xf762575d, 0x806567cb,
+ 0x196c3671, 0x6e6b06e7, 0xfed41b76, 0x89d32be0, 0x10da7a5a, 0x67dd4acc,
+ 0xf9b9df6f, 0x8ebeeff9, 0x17b7be43, 0x60b08ed5, 0xd6d6a3e8, 0xa1d1937e,
+ 0x38d8c2c4, 0x4fdff252, 0xd1bb67f1, 0xa6bc5767, 0x3fb506dd, 0x48b2364b,
+ 0xd80d2bda, 0xaf0a1b4c, 0x36034af6, 0x41047a60, 0xdf60efc3, 0xa867df55,
+ 0x316e8eef, 0x4669be79, 0xcb61b38c, 0xbc66831a, 0x256fd2a0, 0x5268e236,
+ 0xcc0c7795, 0xbb0b4703, 0x220216b9, 0x5505262f, 0xc5ba3bbe, 0xb2bd0b28,
+ 0x2bb45a92, 0x5cb36a04, 0xc2d7ffa7, 0xb5d0cf31, 0x2cd99e8b, 0x5bdeae1d,
+ 0x9b64c2b0, 0xec63f226, 0x756aa39c, 0x026d930a, 0x9c0906a9, 0xeb0e363f,
+ 0x72076785, 0x05005713, 0x95bf4a82, 0xe2b87a14, 0x7bb12bae, 0x0cb61b38,
+ 0x92d28e9b, 0xe5d5be0d, 0x7cdcefb7, 0x0bdbdf21, 0x86d3d2d4, 0xf1d4e242,
+ 0x68ddb3f8, 0x1fda836e, 0x81be16cd, 0xf6b9265b, 0x6fb077e1, 0x18b74777,
+ 0x88085ae6, 0xff0f6a70, 0x66063bca, 0x11010b5c, 0x8f659eff, 0xf862ae69,
+ 0x616bffd3, 0x166ccf45, 0xa00ae278, 0xd70dd2ee, 0x4e048354, 0x3903b3c2,
+ 0xa7672661, 0xd06016f7, 0x4969474d, 0x3e6e77db, 0xaed16a4a, 0xd9d65adc,
+ 0x40df0b66, 0x37d83bf0, 0xa9bcae53, 0xdebb9ec5, 0x47b2cf7f, 0x30b5ffe9,
+ 0xbdbdf21c, 0xcabac28a, 0x53b39330, 0x24b4a3a6, 0xbad03605, 0xcdd70693,
+ 0x54de5729, 0x23d967bf, 0xb3667a2e, 0xc4614ab8, 0x5d681b02, 0x2a6f2b94,
+ 0xb40bbe37, 0xc30c8ea1, 0x5a05df1b, 0x2d02ef8d
+ };
+
+ #endregion
+
+ /// <summary>
+ /// Generate a random <c>CData</c> structure.
+ /// </summary>
+ public static CData RandCData()
+ {
+ long rnd = (long)Util.Rand(int.MaxValue);
+ rnd = (rnd << 32) + (long)Util.Rand(int.MaxValue);
+ return new CData(Util.Rand(int.MaxValue), rnd);
+ }
+
+ public static PdxCData RandPdxCData()
+ {
+ long rnd = (long)Util.Rand(int.MaxValue);
+ rnd = (rnd << 32) + (long)Util.Rand(int.MaxValue);
+ return new PdxCData(Util.Rand(int.MaxValue), rnd);
+ }
+
+ public static uint CRC32(byte[] buffer)
+ {
+ if (buffer == null || buffer.Length == 0)
+ {
+ return 0;
+ }
+
+ uint crc32 = 0xffffffff;
+
+ for (int i = 0; i < buffer.Length; i++)
+ {
+ crc32 = ((crc32 >> 8) & 0x00ffffff) ^
+ CRC32Table[(crc32 ^ buffer[i]) & 0xff];
+ }
+ return ~crc32;
+ }
+
+ public static bool IsContainerTypeId(uint typeId)
+ {
+ return (typeId == GeodeClassIds.CacheableObjectArray) ||
+ (typeId == GeodeClassIds.CacheableVector) ||
+ (typeId == GeodeClassIds.CacheableArrayList) ||
+ (typeId == GeodeClassIds.CacheableStack) ||
+ (typeId == GeodeClassIds.CacheableHashMap) ||
+ (typeId == GeodeClassIds.CacheableIdentityHashMap) ||
+ (typeId == GeodeClassIds.CacheableHashTable) ||
+ (typeId == GeodeClassIds.CacheableLinkedHashSet) ||
+ (typeId == GeodeClassIds.CacheableHashSet);
+ }
+
+ public static bool IsUnhandledType(uint typeId)
+ {
+ // TODO: [sumedh] skipping CacheableFileName for now since it will
+ // not work on Windows without significant workarounds; also see
+ // the corresponding comment in C++ testThinClientCacheables.
+ // Also skipping C# specific classes.
+ return (typeId == GeodeClassIds.CacheableFileName) ||
+ (typeId == GeodeClassIds.CacheableManagedObject) ||
+ (typeId == GeodeClassIds.CacheableManagedObjectXml);
+ }
+ public static long ConstantDateTime = 0;
+ public static void RegisterBuiltins(long dateTime)
+ {
+ ConstantDateTime = dateTime;
+ CacheableWrapperFactory.ClearStaticVaraiables();
+ #region Cacheable keys
+
+ CacheableWrapperFactory.RegisterKeyType(GeodeClassIds.CacheableBoolean,
+ typeof(CacheableBooleanWrapper), CacheableBooleanWrapper.Create, typeof(bool));
+ CacheableWrapperFactory.RegisterKeyType(GeodeClassIds.CacheableByte,
+ typeof(CacheableByteWrapper), CacheableByteWrapper.Create, typeof(sbyte));
+ CacheableWrapperFactory.RegisterKeyType(GeodeClassIds.CacheableCharacter,
+ typeof(CacheableCharacterWrapper), CacheableCharacterWrapper.Create, typeof(Char));
+ CacheableWrapperFactory.RegisterKeyType(GeodeClassIds.CacheableDate,
+ typeof(CacheableDateWrapper), CacheableDateWrapper.Create, typeof(DateTime));
+ CacheableWrapperFactory.RegisterKeyType(GeodeClassIds.CacheableDouble,
+ typeof(CacheableDoubleWrapper), CacheableDoubleWrapper.Create, typeof(Double));
+ CacheableWrapperFactory.RegisterKeyType(GeodeClassIds.CacheableFileName,
+ typeof(CacheableFileNameWrapper), CacheableFileNameWrapper.Create, typeof(CacheableFileName));
+ CacheableWrapperFactory.RegisterKeyType(GeodeClassIds.CacheableFloat,
+ typeof(CacheableFloatWrapper), CacheableFloatWrapper.Create, typeof(float));
+ CacheableWrapperFactory.RegisterKeyType(GeodeClassIds.CacheableInt16,
+ typeof(CacheableInt16Wrapper), CacheableInt16Wrapper.Create, typeof(Int16));
+ CacheableWrapperFactory.RegisterKeyType(GeodeClassIds.CacheableInt32,
+ typeof(CacheableInt32Wrapper), CacheableInt32Wrapper.Create, typeof(Int32));
+ CacheableWrapperFactory.RegisterKeyType(GeodeClassIds.CacheableInt64,
+ typeof(CacheableInt64Wrapper), CacheableInt64Wrapper.Create, typeof(Int64));
+ CacheableWrapperFactory.RegisterKeyType(GeodeClassIds.CacheableASCIIString,
+ typeof(CacheableStringWrapper), CacheableStringWrapper.Create, typeof(string));
+ CacheableWrapperFactory.RegisterKeyType(GeodeClassIds.CacheableString,
+ typeof(CacheableUnicodeStringWrapper), CacheableUnicodeStringWrapper.Create);
+ CacheableWrapperFactory.RegisterKeyType(GeodeClassIds.CacheableASCIIStringHuge,
+ typeof(CacheableHugeStringWrapper), CacheableHugeStringWrapper.Create);
+ CacheableWrapperFactory.RegisterKeyType(GeodeClassIds.CacheableStringHuge,
+ typeof(CacheableHugeUnicodeStringWrapper), CacheableHugeUnicodeStringWrapper.Create);
+ CacheableWrapperFactory.RegisterKeyType(10001,
+ typeof(PdxCDataWrapper), PdxCDataWrapper.Create, typeof(PdxCData));
+
+ //need to register pdx type
+ Serializable.RegisterPdxType(PdxCData.CreateDeserializable);
+
+ #endregion
+
+ #region Other cacheables
+
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableBytes,
+ typeof(CacheableBytesWrapper), CacheableBytesWrapper.Create, typeof(byte[]));
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableDoubleArray,
+ typeof(CacheableDoubleArrayWrapper), CacheableDoubleArrayWrapper.Create, typeof(Double[]));
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableFloatArray,
+ typeof(CacheableFloatArrayWrapper), CacheableFloatArrayWrapper.Create, typeof(float[]));
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableHashMap,
+ typeof(CacheableHashMapWrapper), CacheableHashMapWrapper.Create, typeof(Dictionary<object, object>));
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableHashTable,
+ typeof(CacheableHashTableWrapper), CacheableHashTableWrapper.Create, typeof(System.Collections.Hashtable));
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableIdentityHashMap,
+ typeof(CacheableIdentityHashMapWrapper), CacheableIdentityHashMapWrapper.Create, typeof(Dictionary<object, object>));
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableHashSet,
+ typeof(CacheableHashSetWrapper), CacheableHashSetWrapper.Create, typeof(CacheableHashSet));
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableLinkedHashSet,
+ typeof(CacheableLinkedHashSetWrapper), CacheableLinkedHashSetWrapper.Create, typeof(CacheableLinkedHashSet));
+
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableInt16Array,
+ typeof(CacheableInt16ArrayWrapper), CacheableInt16ArrayWrapper.Create, typeof(Int16[]));
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableInt32Array,
+ typeof(CacheableInt32ArrayWrapper), CacheableInt32ArrayWrapper.Create, typeof(Int32[]));
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableInt64Array,
+ typeof(CacheableInt64ArrayWrapper), CacheableInt64ArrayWrapper.Create, typeof(Int64[]));
+ {//old one
+ //CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableNullString,
+ // typeof(CacheableNullStringWrapper), CacheableNullStringWrapper.Create);
+ //CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableASCIIString,
+ // typeof(CacheableEmptyStringWrapper), CacheableEmptyStringWrapper.Create);
+ //CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableString,
+ // typeof(CacheableEmptyUnicodeStringWrapper), CacheableEmptyUnicodeStringWrapper.Create);
+ }
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableStringArray,
+ typeof(CacheableStringArrayWrapper), CacheableStringArrayWrapper.Create, typeof(string[]));
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableUndefined,
+ typeof(CacheableUndefinedWrapper), CacheableUndefinedWrapper.Create, typeof(CacheableUndefined));
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableVector,
+ typeof(CacheableVectorWrapper), CacheableVectorWrapper.Create, typeof(System.Collections.ArrayList));
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableObjectArray,
+ typeof(CacheableObjectArrayWrapper), CacheableObjectArrayWrapper.Create, typeof(CacheableObjectArray));
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableArrayList,
+ typeof(CacheableArrayListWrapper), CacheableArrayListWrapper.Create, typeof(List<object>));
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableStack,
+ typeof(CacheableStackWrapper), CacheableStackWrapper.Create, typeof(Stack<object>));
+
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableManagedObject,
+ typeof(CacheableObjectWrapper), CacheableObjectWrapper.Create, typeof(CacheableObject));
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableManagedObjectXml,
+ typeof(CacheableObjectXmlWrapper), CacheableObjectXmlWrapper.Create, typeof(CacheableObjectXml));
+
+
+
+ #endregion
+ }
+
+ public static void RegisterBuiltinsJavaHashCode(long dateTime)
+ {
+ ConstantDateTime = dateTime;
+ CacheableWrapperFactory.ClearStaticVaraiables();
+ #region Cacheable keys
+
+ CacheableWrapperFactory.RegisterKeyType(GeodeClassIds.CacheableBoolean,
+ typeof(CacheableBooleanWrapper), CacheableBooleanWrapper.Create, typeof(bool));
+ CacheableWrapperFactory.RegisterKeyType(GeodeClassIds.CacheableByte,
+ typeof(CacheableByteWrapper), CacheableByteWrapper.Create, typeof(sbyte));
+ CacheableWrapperFactory.RegisterKeyType(GeodeClassIds.CacheableCharacter,
+ typeof(CacheableCharacterWrapper), CacheableCharacterWrapper.Create, typeof(Char));
+ CacheableWrapperFactory.RegisterKeyType(GeodeClassIds.CacheableDate,
+ typeof(CacheableDateWrapper), CacheableDateWrapper.Create, typeof(DateTime));
+ CacheableWrapperFactory.RegisterKeyType(GeodeClassIds.CacheableDouble,
+ typeof(CacheableDoubleWrapper), CacheableDoubleWrapper.Create, typeof(Double));
+ CacheableWrapperFactory.RegisterKeyType(GeodeClassIds.CacheableFileName,
+ typeof(CacheableFileNameWrapper), CacheableFileNameWrapper.Create, typeof(CacheableFileName));
+ CacheableWrapperFactory.RegisterKeyType(GeodeClassIds.CacheableFloat,
+ typeof(CacheableFloatWrapper), CacheableFloatWrapper.Create, typeof(float));
+ CacheableWrapperFactory.RegisterKeyType(GeodeClassIds.CacheableInt16,
+ typeof(CacheableInt16Wrapper), CacheableInt16Wrapper.Create, typeof(Int16));
+ CacheableWrapperFactory.RegisterKeyType(GeodeClassIds.CacheableInt32,
+ typeof(CacheableInt32Wrapper), CacheableInt32Wrapper.Create, typeof(Int32));
+ CacheableWrapperFactory.RegisterKeyType(GeodeClassIds.CacheableInt64,
+ typeof(CacheableInt64Wrapper), CacheableInt64Wrapper.Create, typeof(Int64));
+ CacheableWrapperFactory.RegisterKeyType(GeodeClassIds.CacheableASCIIString,
+ typeof(CacheableStringWrapper), CacheableStringWrapper.Create, typeof(string));
+ CacheableWrapperFactory.RegisterKeyType(GeodeClassIds.CacheableString,
+ typeof(CacheableUnicodeStringWrapper), CacheableUnicodeStringWrapper.Create);
+ CacheableWrapperFactory.RegisterKeyType(GeodeClassIds.CacheableASCIIStringHuge,
+ typeof(CacheableHugeStringWrapper), CacheableHugeStringWrapper.Create);
+ CacheableWrapperFactory.RegisterKeyType(GeodeClassIds.CacheableStringHuge,
+ typeof(CacheableHugeUnicodeStringWrapper), CacheableHugeUnicodeStringWrapper.Create);
+
+ //need to register pdx type
+ Serializable.RegisterPdxType(PdxCData.CreateDeserializable);
+
+ #endregion
+
+ #region Other cacheables
+
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableBytes,
+ typeof(CacheableBytesWrapper), CacheableBytesWrapper.Create, typeof(byte[]));
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableDoubleArray,
+ typeof(CacheableDoubleArrayWrapper), CacheableDoubleArrayWrapper.Create, typeof(Double[]));
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableFloatArray,
+ typeof(CacheableFloatArrayWrapper), CacheableFloatArrayWrapper.Create, typeof(float[]));
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableHashMap,
+ typeof(CacheableHashMapWrapper), CacheableHashMapWrapper.Create, typeof(Dictionary<object, object>));
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableHashTable,
+ typeof(CacheableHashTableWrapper), CacheableHashTableWrapper.Create, typeof(System.Collections.Hashtable));
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableIdentityHashMap,
+ typeof(CacheableIdentityHashMapWrapper), CacheableIdentityHashMapWrapper.Create, typeof(Dictionary<object, object>));
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableHashSet,
+ typeof(CacheableHashSetWrapper), CacheableHashSetWrapper.Create, typeof(CacheableHashSet));
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableLinkedHashSet,
+ typeof(CacheableLinkedHashSetWrapper), CacheableLinkedHashSetWrapper.Create, typeof(CacheableLinkedHashSet));
+
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableInt16Array,
+ typeof(CacheableInt16ArrayWrapper), CacheableInt16ArrayWrapper.Create, typeof(Int16[]));
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableInt32Array,
+ typeof(CacheableInt32ArrayWrapper), CacheableInt32ArrayWrapper.Create, typeof(Int32[]));
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableInt64Array,
+ typeof(CacheableInt64ArrayWrapper), CacheableInt64ArrayWrapper.Create, typeof(Int64[]));
+ {//old one
+ //CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableNullString,
+ // typeof(CacheableNullStringWrapper), CacheableNullStringWrapper.Create);
+ //CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableASCIIString,
+ // typeof(CacheableEmptyStringWrapper), CacheableEmptyStringWrapper.Create);
+ //CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableString,
+ // typeof(CacheableEmptyUnicodeStringWrapper), CacheableEmptyUnicodeStringWrapper.Create);
+ }
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableStringArray,
+ typeof(CacheableStringArrayWrapper), CacheableStringArrayWrapper.Create, typeof(string[]));
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableUndefined,
+ typeof(CacheableUndefinedWrapper), CacheableUndefinedWrapper.Create, typeof(CacheableUndefined));
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableVector,
+ typeof(CacheableVectorWrapper), CacheableVectorWrapper.Create, typeof(System.Collections.ArrayList));
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableObjectArray,
+ typeof(CacheableObjectArrayWrapper), CacheableObjectArrayWrapper.Create, typeof(CacheableObjectArray));
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableArrayList,
+ typeof(CacheableArrayListWrapper), CacheableArrayListWrapper.Create, typeof(List<object>));
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableStack,
+ typeof(CacheableStackWrapper), CacheableStackWrapper.Create, typeof(Stack<object>));
+
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableManagedObject,
+ typeof(CacheableObjectWrapper), CacheableObjectWrapper.Create, typeof(CacheableObject));
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableManagedObjectXml,
+ typeof(CacheableObjectXmlWrapper), CacheableObjectXmlWrapper.Create, typeof(CacheableObjectXml));
+
+
+
+ #endregion
+ }
+
+ public static void RegisterBuiltinsAD(long dateTime)
+ {
+ ConstantDateTime = dateTime;
+ CacheableWrapperFactory.ClearStaticVaraiables();
+ #region Cacheable keys
+
+ CacheableWrapperFactory.RegisterKeyType(GeodeClassIds.CacheableBoolean,
+ typeof(CacheableBooleanWrapper), CacheableBooleanWrapper.Create, typeof(bool));
+ CacheableWrapperFactory.RegisterKeyType(GeodeClassIds.CacheableByte,
+ typeof(CacheableByteWrapper), CacheableByteWrapper.Create, typeof(sbyte));
+ CacheableWrapperFactory.RegisterKeyType(GeodeClassIds.CacheableCharacter,
+ typeof(CacheableCharacterWrapper), CacheableCharacterWrapper.Create, typeof(Char));
+ CacheableWrapperFactory.RegisterKeyType(GeodeClassIds.CacheableDate,
+ typeof(CacheableDateWrapper), CacheableDateWrapper.Create, typeof(DateTime));
+ CacheableWrapperFactory.RegisterKeyType(GeodeClassIds.CacheableDouble,
+ typeof(CacheableDoubleWrapper), CacheableDoubleWrapper.Create, typeof(Double));
+ CacheableWrapperFactory.RegisterKeyType(GeodeClassIds.CacheableFileName,
+ typeof(CacheableFileNameWrapper), CacheableFileNameWrapper.Create, typeof(CacheableFileName));
+ CacheableWrapperFactory.RegisterKeyType(GeodeClassIds.CacheableFloat,
+ typeof(CacheableFloatWrapper), CacheableFloatWrapper.Create, typeof(float));
+ CacheableWrapperFactory.RegisterKeyType(GeodeClassIds.CacheableInt16,
+ typeof(CacheableInt16Wrapper), CacheableInt16Wrapper.Create, typeof(Int16));
+ CacheableWrapperFactory.RegisterKeyType(GeodeClassIds.CacheableInt32,
+ typeof(CacheableInt32Wrapper), CacheableInt32Wrapper.Create, typeof(Int32));
+ CacheableWrapperFactory.RegisterKeyType(GeodeClassIds.CacheableInt64,
+ typeof(CacheableInt64Wrapper), CacheableInt64Wrapper.Create, typeof(Int64));
+ CacheableWrapperFactory.RegisterKeyType(GeodeClassIds.CacheableASCIIString,
+ typeof(CacheableStringWrapper), CacheableStringWrapper.Create, typeof(string));
+ CacheableWrapperFactory.RegisterKeyType(GeodeClassIds.CacheableString,
+ typeof(CacheableUnicodeStringWrapper), CacheableUnicodeStringWrapper.Create);
+ {
+ //CacheableWrapperFactory.RegisterKeyType(GeodeClassIds.CacheableASCIIStringHuge,
+ // typeof(CacheableHugeStringWrapper), CacheableHugeStringWrapper.Create);
+ //CacheableWrapperFactory.RegisterKeyType(GeodeClassIds.CacheableStringHuge,
+ // typeof(CacheableHugeUnicodeStringWrapper), CacheableHugeUnicodeStringWrapper.Create);
+ }
+ CacheableWrapperFactory.RegisterKeyType(10001,
+ typeof(PdxCDataWrapper), PdxCDataWrapper.Create, typeof(PdxCData));
+
+ //need to register pdx type
+ Serializable.RegisterPdxType(PdxCData.CreateDeserializable);
+
+
+ #endregion
+
+ #region Other cacheables
+
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableBytes,
+ typeof(CacheableBytesWrapper), CacheableBytesWrapper.Create, typeof(byte[]));
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableDoubleArray,
+ typeof(CacheableDoubleArrayWrapper), CacheableDoubleArrayWrapper.Create, typeof(Double[]));
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableFloatArray,
+ typeof(CacheableFloatArrayWrapper), CacheableFloatArrayWrapper.Create, typeof(float[]));
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableHashMap,
+ typeof(CacheableHashMapWrapper), CacheableHashMapWrapper.Create, typeof(Dictionary<object, object>));
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableHashTable,
+ typeof(CacheableHashTableWrapper), CacheableHashTableWrapper.Create, typeof(System.Collections.Hashtable));
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableIdentityHashMap,
+ typeof(CacheableIdentityHashMapWrapper), CacheableIdentityHashMapWrapper.Create, typeof(Dictionary<object, object>));
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableHashSet,
+ typeof(CacheableHashSetWrapper), CacheableHashSetWrapper.Create, typeof(CacheableHashSet));
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableLinkedHashSet,
+ typeof(CacheableLinkedHashSetWrapper), CacheableLinkedHashSetWrapper.Create, typeof(CacheableLinkedHashSet));
+
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableInt16Array,
+ typeof(CacheableInt16ArrayWrapper), CacheableInt16ArrayWrapper.Create, typeof(Int16[]));
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableInt32Array,
+ typeof(CacheableInt32ArrayWrapper), CacheableInt32ArrayWrapper.Create, typeof(Int32[]));
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableInt64Array,
+ typeof(CacheableInt64ArrayWrapper), CacheableInt64ArrayWrapper.Create, typeof(Int64[]));
+ {//old one
+ //CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableNullString,
+ // typeof(CacheableNullStringWrapper), CacheableNullStringWrapper.Create);
+ //CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableASCIIString,
+ // typeof(CacheableEmptyStringWrapper), CacheableEmptyStringWrapper.Create);
+ //CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableString,
+ // typeof(CacheableEmptyUnicodeStringWrapper), CacheableEmptyUnicodeStringWrapper.Create);
+ }
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableStringArray,
+ typeof(CacheableStringArrayWrapper), CacheableStringArrayWrapper.Create, typeof(string[]));
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableUndefined,
+ typeof(CacheableUndefinedWrapper), CacheableUndefinedWrapper.Create, typeof(CacheableUndefined));
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableVector,
+ typeof(CacheableVectorWrapper), CacheableVectorWrapper.Create, typeof(System.Collections.ArrayList));
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableObjectArray,
+ typeof(CacheableObjectArrayWrapper), CacheableObjectArrayWrapper.Create, typeof(CacheableObjectArray));
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableArrayList,
+ typeof(CacheableArrayListWrapper), CacheableArrayListWrapper.Create, typeof(List<object>));
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableStack,
+ typeof(CacheableStackWrapper), CacheableStackWrapper.Create, typeof(Stack<object>));
+
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableManagedObject,
+ typeof(CacheableObjectWrapper), CacheableObjectWrapper.Create, typeof(CacheableObject));
+ CacheableWrapperFactory.RegisterType(GeodeClassIds.CacheableManagedObjectXml,
+ typeof(CacheableObjectXmlWrapper), CacheableObjectXmlWrapper.Create, typeof(CacheableObjectXml));
+
+
+ #endregion
+ }
+ }
+
+ #endregion
+
+ #region Builtin cacheable keys
+
+ public class CacheableBooleanWrapper : CacheableKeyWrapper
+ {
+ #region Static factory creation function
+
+ public static CacheableKeyWrapper Create()
+ {
+ return new CacheableBooleanWrapper();
+ }
+
+ #endregion
+
+ #region CacheableKeyWrapper Members
+
+ public override int MaxKeys
+ {
+ get
+ {
+ return 2;
+ }
+ }
+
+ public override void InitKey(int keyIndex, int maxSize)
+ {
+ bool value = (keyIndex % 2 == 1 ? true : false);
+ m_cacheableObject = value;
+ }
+
+ public override void InitRandomValue(int maxSize)
+ {
+ bool value = (Util.Rand(byte.MaxValue) % 2 == 1 ? true : false);
+ m_cacheableObject = value;
+ }
+
+ public override uint GetChecksum(object cacheableObject)
+ {
+ //Util.Log("cacheableObject Type = {0}", cacheableObject.GetType());
+ bool value = (bool)cacheableObject;
+ Assert.IsNotNull(value, "GetChecksum: Null object.");
+ return (uint)(value ? 1 : 0);
+ }
+
+ public override int GetHashCodeN(object cacheableObject)
+ {
+ bool val = (bool)cacheableObject;
+ if (val) return 1231;
+ else return 1237;
+ }
+
+ #endregion
+ }
+
+ public class CacheableByteWrapper : CacheableKeyWrapper
+ {
+ #region Static factory creation function
+
+ public static CacheableKeyWrapper Create()
+ {
+ return new CacheableByteWrapper();
+ }
+
+ #endregion
+
+ #region CacheableKeyWrapper Members
+
+ public override int MaxKeys
+ {
+ get
+ {
+ return byte.MaxValue;
+ }
+ }
+
+ public override void InitKey(int keyIndex, int maxSize)
+ {
+ sbyte value = (sbyte)keyIndex;
+ m_cacheableObject = value;
+ }
+
+ public override void InitRandomValue(int maxSize)
+ {
+ sbyte value = (sbyte)Util.Rand(byte.MaxValue);
+ m_cacheableObject = value;
+ }
+
+ public override uint GetChecksum(object cacheableObject)
+ {
+ sbyte value = (sbyte)cacheableObject;
+ Assert.IsNotNull(value, "GetChecksum: Null object.");
+ byte[] buffer = new byte[1];
+ buffer[0] = (byte)value;
+ return CacheableHelper.CRC32(buffer);
+ }
+
+ public override int GetHashCodeN(object cacheableObject)
+ {
+ sbyte val = (sbyte)cacheableObject;
+ return val;
+ }
+
+ #endregion
+ }
+
+ public class CacheableCharacterWrapper : CacheableKeyWrapper
+ {
+ #region Static factory creation function
+
+ public static CacheableKeyWrapper Create()
+ {
+ return new CacheableCharacterWrapper();
+ }
+
+ #endregion
+
+ #region CacheableKeyWrapper Members
+
+ public override int MaxKeys
+ {
+ get
+ {
+ return char.MaxValue;
+ }
+ }
+
+ public override void InitKey(int keyIndex, int maxSize)
+ {
+ char value = (char)keyIndex;
+ m_cacheableObject = value;
+ }
+
+ public override void InitRandomValue(int maxSize)
+ {
+ char value = (char)Util.Rand(char.MaxValue);
+ m_cacheableObject = value;
+ }
+
+ public override uint GetChecksum(object cacheableObject)
+ {
+ char obj = (char)cacheableObject;
+ Assert.IsNotNull(obj, "GetChecksum: Null object.");
+ char value = obj;
+ int numBytes = sizeof(char);
+ byte[] buffer = new byte[numBytes];
+ for (int i = 0; i < numBytes; i++)
+ {
+ buffer[i] = (byte)(value & 0xff);
+ value = (char)(value >> 8);
+ }
+ return CacheableHelper.CRC32(buffer);
+ }
+
+ public override int GetHashCodeN(object cacheableObject)
+ {
+ char val = (char)cacheableObject;
+ return val.GetHashCode();
+ }
+ #endregion
+ }
+
+ public class CacheableDateWrapper : CacheableKeyWrapper
+ {
+ #region Static factory creation function
+
+ public static CacheableKeyWrapper Create()
+ {
+ return new CacheableDateWrapper();
+ }
+
+ #endregion
+
+ #region CacheableKeyWrapper Members
+
+ public override int MaxKeys
+ {
+ get
+ {
+ return int.MaxValue;
+ }
+ }
+
+ public override void InitKey(int keyIndex, int maxSize)
+ {
+ //m_cacheableObject = DateTime.Today.AddMinutes(keyIndex % 0xFFFF);
+ DateTime dt = new DateTime(CacheableHelper.ConstantDateTime + keyIndex * TimeSpan.TicksPerMinute);
+ m_cacheableObject = dt;
+ Util.Log(" datevalue initkey " + dt.ToString());
+ }
+
+ private DateTime createRoundOffDTVal(DateTime dt)
+ {
+ long ticksToAdd = dt.Ticks % TimeSpan.TicksPerMillisecond;
+ ticksToAdd = (ticksToAdd >= (TimeSpan.TicksPerMillisecond / 2) ?
+ (TimeSpan.TicksPerMillisecond - ticksToAdd) : -ticksToAdd);
+ dt = dt.AddTicks(ticksToAdd);
+ return dt;
+ }
+
+ public override void InitRandomValue(int maxSize)
+ {
+ int rnd = Util.Rand(int.MaxValue);
+ //DateTime value = DateTime.Now.AddMilliseconds(rnd % 2 == 0 ? rnd : -rnd);
+ DateTime value = new DateTime(CacheableHelper.ConstantDateTime);
+ m_cacheableObject = value;
+ Util.Log(" datevalue InitRandomValue " + value.ToString());
+ }
+
+ public override uint GetChecksum(object cacheableObject)
+ {
+ //CacheableDate obj = cacheableObject as CacheableDate;
+ DateTime obj = (DateTime)cacheableObject;
+ Util.Log(" datevalue getchecksum " + obj.ToString());
+ Assert.IsNotNull(obj, "GetChecksum: Null object.");
+
+ obj = createRoundOffDTVal(obj);
+ long value = obj.Ticks;
+ int numBytes = sizeof(long);
+ byte[] buffer = new byte[numBytes];
+ for (int i = 0; i < numBytes; i++)
+ {
+ buffer[i] = (byte)(value & 0xff);
+ value = value >> 8;
+ }
+ uint cks = CacheableHelper.CRC32(buffer);
+ Util.Log(" datevalue getchecksum " + cks);
+ return cks;
+ }
+
+ #endregion
+ }
+
+ public class CacheableDoubleWrapper : CacheableKeyWrapper
+ {
+ #region Private constants
+
+ private const double MaxError = 1E-20;
+
+ #endregion
+
+ #region Static factory creation function
+
+ public static CacheableKeyWrapper Create()
+ {
+ return new CacheableDoubleWrapper();
+ }
+
+ #endregion
+
+ #region CacheableKeyWrapper Members
+
+ public override int MaxKeys
+ {
+ get
+ {
+ return int.MaxValue;
+ }
+ }
+
+ public override void InitKey(int keyIndex, int maxSize)
+ {
+ double value = (double)keyIndex;
+ m_cacheableObject = value;
+ }
+
+ public override void InitRandomValue(int maxSize)
+ {
+ double value = Util.Rand() * double.MaxValue;
+ m_cacheableObject = value;
+ }
+
+ public override uint GetChecksum(object cacheableObject)
+ {
+ double value = (double)cacheableObject;
+ Assert.IsNotNull(value, "GetChecksum: Null object.");
+ return CacheableHelper.CRC32(BitConverter.GetBytes(value));
+ }
+
+ public override int GetHashCodeN(object cacheableObject)
+ {
+ double val = (double)cacheableObject;
+ return val.GetHashCode();
+ }
+ #endregion
+ }
+
+ public class CacheableFileNameWrapper : CacheableKeyWrapper
+ {
+ #region Static factory creation function
+
+ public static CacheableKeyWrapper Create()
+ {
+ return new CacheableFileNameWrapper();
+ }
+
+ #endregion
+
+ #region CacheableKeyWrapper Members
+
+ public override int MaxKeys
+ {
+ get
+ {
+ return int.MaxValue;
+ }
+ }
+
+ public override void InitKey(int keyIndex, int maxSize)
+ {
+ Assert.Greater(maxSize, 0, "Size of key should be greater than zero.");
+ if (maxSize < 11)
+ {
+ maxSize = 11;
+ }
+ string value = "C:\\" + new string('\x0905', maxSize - 13) +
+ keyIndex.ToString("D10");
+ m_cacheableObject = CacheableFileName.Create(value);
+ }
+
+ public override void InitRandomValue(int maxSize)
+ {
+ Assert.Greater(maxSize, 0, "Size of value should be greater than zero.");
+ byte[] buffer = Util.RandBytes(maxSize / 2);
+ char[] value = new char[maxSize / 2];
+ for (int i = 0; i < maxSize / 2; i++)
+ {
+ value[i] = (char)((int)buffer[i] + 0x0901);
+ }
+ m_cacheableObject = CacheableFileName.Create(value);
+ }
+
+ public override uint GetChecksum(object cacheableObject)
+ {
+ CacheableFileName obj = cacheableObject as CacheableFileName;
+ Assert.IsNotNull(obj, "GetChecksum: Null object.");
+
+ string value = obj.Value;
+ byte[] buffer = new byte[value.Length * 2];
+ for (int i = 0; i < value.Length; i++)
+ {
+ char c = value[i];
+ buffer[i * 2] = (byte)(c & 0xff);
+ buffer[i * 2 + 1] = (byte)((c >> 8) & 0xff);
+ }
+ return CacheableHelper.CRC32(buffer);
+ }
+
+ #endregion
+ }
+
+ public class CacheableFloatWrapper : CacheableKeyWrapper
+ {
+ #region Private constants
+
+ private const float MaxError = 1E-10F;
+
+ #endregion
+
+ #region Static factory creation function
+
+ public static CacheableKeyWrapper Create()
+ {
+ return new CacheableFloatWrapper();
+ }
+
+ #endregion
+
+ #region CacheableKeyWrapper Members
+
+ public override int MaxKeys
+ {
+ get
+ {
+ return int.MaxValue;
+ }
+ }
+
+ public override void InitKey(int keyIndex, int maxSize)
+ {
+ float value = (float)keyIndex;
+ m_cacheableObject = value;
+ }
+
+ public override void InitRandomValue(int maxSize)
+ {
+ float value = (float)Util.Rand() * float.MaxValue;
+ m_cacheableObject = value;
+ }
+
+ public override uint GetChecksum(object cacheableObject)
+ {
+ float value = (float)cacheableObject;
+ Assert.IsNotNull(value, "GetChecksum: Null object.");
+ return CacheableHelper.CRC32(BitConverter.GetBytes(value));
+ }
+
+ public override int GetHashCodeN(object cacheableObject)
+ {
+ float val = (float)cacheableObject;
+ return val.GetHashCode();
+ }
+ #endregion
+ }
+
+ public class CacheableInt16Wrapper : CacheableKeyWrapper
+ {
+ #region Static factory creation function
+
+ public static CacheableKeyWrapper Create()
+ {
+ return new CacheableInt16Wrapper();
+ }
+
+ #endregion
+
+ #region CacheableKeyWrapper Members
+
+ public override int MaxKeys
+ {
+ get
+ {
+ return short.MaxValue;
+ }
+ }
+
+ public override void InitKey(int keyIndex, int maxSize)
+ {
+ short value = (short)keyIndex;
+ m_cacheableObject = value;
+ }
+
+ public override void InitRandomValue(int maxSize)
+ {
+ short value = (short)Util.Rand(short.MaxValue);
+ m_cacheableObject = value;
+ }
+
+ public override uint GetChecksum(object cacheableObject)
+ {
+ Int16 obj = (Int16)cacheableObject;
+ Assert.IsNotNull(obj, "GetChecksum: Null object.");
+ short value = obj;
+ int numBytes = sizeof(short);
+ byte[] buffer = new byte[numBytes];
+ for (int i = 0; i < numBytes; i++)
+ {
+ buffer[i] = (byte)(value & 0xff);
+ value = (short)(value >> 8);
+ }
+ return CacheableHelper.CRC32(buffer);
+ }
+
+ public override int GetHashCodeN(object cacheableObject)
+ {
+ Int16 val = (Int16)cacheableObject;
+ return val;
+ }
+ #endregion
+ }
+
+ public class CacheableInt32Wrapper : CacheableKeyWrapper
+ {
+ #region Static factory creation function
+
+ public static CacheableKeyWrapper Create()
+ {
+ return new CacheableInt32Wrapper();
+ }
+
+ #endregion
+
+ #region CacheableKeyWrapper Members
+
+ public override int MaxKeys
+ {
+ get
+ {
+ return int.MaxValue;
+ }
+ }
+
+ public override void InitKey(int keyIndex, int maxSize)
+ {
+ int value = keyIndex;
+ m_cacheableObject = value;
+ }
+
+ public override void InitRandomValue(int maxSize)
+ {
+ int value = Util.Rand(int.MaxValue);
+ m_cacheableObject = value;
+ }
+
+ public override uint GetChecksum(object cacheableObject)
+ {
+ Int32 obj = (Int32)cacheableObject;
+ Assert.IsNotNull(obj, "GetChecksum: Null object.");
+
+ int value = obj;
+ int numBytes = sizeof(int);
+ byte[] buffer = new byte[numBytes];
+ for (int i = 0; i < numBytes; i++)
+ {
+ buffer[i] = (byte)(value & 0xff);
+ value = value >> 8;
+ }
+ return CacheableHelper.CRC32(buffer);
+ }
+
+ public override int GetHashCodeN(object cacheableObject)
+ {
+ Int32 val = (Int32)cacheableObject;
+ return val;
+ }
+ #endregion
+ }
+
+ public class CacheableInt64Wrapper : CacheableKeyWrapper
+ {
+ #region Static factory creation function
+
+ public static CacheableKeyWrapper Create()
+ {
+ return new CacheableInt64Wrapper();
+ }
+
+ #endregion
+
+ #region CacheableKeyWrapper Members
+
+ public override int MaxKeys
+ {
+ get
+ {
+ return int.MaxValue;
+ }
+ }
+
+ public override void InitKey(int keyIndex, int maxSize)
+ {
+ long value = (long)keyIndex;
+ m_cacheableObject = value;
+ }
+
+ public override void InitRandomValue(int maxSize)
+ {
+ long value = Util.Rand(int.MaxValue);
+ value = (value << 32) + Util.Rand(int.MaxValue);
+ m_cacheableObject = value;
+ }
+
+ public override uint GetChecksum(object cacheableObject)
+ {
+ Int64 obj = (Int64)cacheableObject;
+ Assert.IsNotNull(obj, "GetChecksum: Null object.");
+ long value = obj;
+ int numBytes = sizeof(long);
+ byte[] buffer = new byte[numBytes];
+ for (int i = 0; i < numBytes; i++)
+ {
+ buffer[i] = (byte)(value & 0xff);
+ value = value >> 8;
+ }
+ return CacheableHelper.CRC32(buffer);
+ }
+
+ public override int GetHashCodeN(object cacheableObject)
+ {
+ Int64 val = (Int64)cacheableObject;
+ return val.GetHashCode();
+ }
+ #endregion
+ }
+
+ public class CacheableStringWrapper : CacheableKeyWrapper
+ {
+ #region Static factory creation function
+
+ public static CacheableKeyWrapper Create()
+ {
+ return new CacheableStringWrapper();
+ }
+
+ #endregion
+
+ #region CacheableKeyWrapper Members
+
+ public override int MaxKeys
+ {
+ get
+ {
+ return int.MaxValue;
+ }
+ }
+
+ public override void InitKey(int keyIndex, int maxSize)
+ {
+ Assert.Greater(maxSize, 0, "Size of key should be greater than zero.");
+ if (maxSize < 11)
+ {
+ maxSize = 11;
+ }
+ if (keyIndex == 0)
+ {
+ m_cacheableObject = string.Empty;
+ }
+ else
+ {
+ string value = new string('A', maxSize - 10) + keyIndex.ToString("D10");
+ m_cacheableObject = value;
+ }
+ }
+
+ public override void InitRandomValue(int maxSize)
+ {
+ Assert.Greater(maxSize, 0, "Size of value should be greater than zero.");
+ maxSize = (maxSize / 2) > 1 ? (maxSize / 2) : 2;
+ Util.Log(" in cacheable string wrapper maxsize = " + maxSize);
+ if (maxSize == 2)
+ {
+ m_cacheableObject = string.Empty;
+ }
+ else
+ {
+ byte[] buffer = Util.RandBytes(maxSize);
+ string value = BitConverter.ToString(buffer).Replace("-", string.Empty);
+ Util.Log("cacheable string wrapper " + value);
+ m_cacheableObject = value;
+ }
+ }
+
+ public override uint GetChecksum(object cacheableObject)
+ {
+ string obj = (string)cacheableObject;
+ Assert.IsNotNull(obj, "GetChecksum: Null object.");
+
+ string value = obj;
+ if (value != null)
+ {
+ byte[] buffer = new byte[value.Length];
+ for (int i = 0; i < value.Length; i++)
+ {
+ buffer[i] = (byte)value[i];
+ }
+ return CacheableHelper.CRC32(buffer);
+ }
+ return 0;
+ }
+
+ public override int GetHashCodeN(object cacheableObject)
+ {
+ string val = (string)cacheableObject;
+ return val.GetHashCode();
+ }
+ #endregion
+ }
+
+ public class CacheableUnicodeStringWrapper : CacheableKeyWrapper
+ {
+ #region Static factory creation function
+
+ public static CacheableKeyWrapper Create()
+ {
+ return new CacheableUnicodeStringWrapper();
+ }
+
+ #endregion
+
+ #region CacheableKeyWrapper Members
+
+ public override int MaxKeys
+ {
+ get
+ {
+ return int.MaxValue;
+ }
+ }
+
+ public override void InitKey(int keyIndex, int maxSize)
+ {
+ Assert.Greater(maxSize, 0, "Size of key should be greater than zero.");
+ if (maxSize < 11)
+ {
+ maxSize = 11;
+ }
+ if (keyIndex == 0)
+ {
+ m_cacheableObject = string.Empty;
+ }
+ else
+ {
+ string value = new string('\x0905', maxSize - 10) + keyIndex.ToString("D10");
+ m_cacheableObject = value;
+ }
+ }
+
+ public override void InitRandomValue(int maxSize)
+ {
+ Assert.Greater(maxSize, 0, "Size of value should be greater than zero.");
+ if (maxSize == 2)
+ {
+ m_cacheableObject = string.Empty;
+ }
+ else
+ {
+ byte[] buffer = Util.RandBytes(maxSize / 2);
+ char[] value = new char[maxSize / 2];
+ for (int i = 0; i < maxSize / 2; i++)
+ {
+ value[i] = (char)((int)buffer[i] + 0x0901);
+ }
+ m_cacheableObject = new string(value);
+ }
+ }
+
+ public override uint GetChecksum(object cacheableObject)
+ {
+ string obj = (string)cacheableObject;
+ Assert.IsNotNull(obj, "GetChecksum: Null object.");
+
+ string value = obj;
+ byte[] buffer = new byte[value.Length * 2];
+ for (int i = 0; i < value.Length; i++)
+ {
+ char c = value[i];
+ buffer[i * 2] = (byte)(c & 0xff);
+ buffer[i * 2 + 1] = (byte)((c >> 8) & 0xff);
+ }
+ return CacheableHelper.CRC32(buffer);
+ }
+
+ public override int GetHashCodeN(object cacheableObject)
+ {
+ string val = (string)cacheableObject;
+ return val.GetHashCode();
+ }
+ #endregion
+ }
+
+ public class CacheableHugeStringWrapper : CacheableKeyWrapper
+ {
+ #region Static factory creation function
+
+ public static CacheableKeyWrapper Create()
+ {
+ return new CacheableHugeStringWrapper();
+ }
+
+ #endregion
+
+ #region CacheableKeyWrapper Members
+
+ public override int MaxKeys
+ {
+ get
+ {
+ return int.MaxValue;
+ }
+ }
+
+ public override void InitKey(int keyIndex, int maxSize)
+ {
+ Assert.Greater(maxSize, 0, "Size of key should be greater than zero.");
+ if (maxSize < 0xFFFF)
+ {
+ maxSize += 0xFFFF + 1;
+ }
+ if (keyIndex == 0)
+ {
+ m_cacheableObject = string.Empty;
+ }
+ else
+ {
+ string value = new string('A', maxSize - 10) + keyIndex.ToString("D10");
+ m_cacheableObject = value;
+ }
+ }
+
+ public override void InitRandomValue(int maxSize)
+ {
+ if (maxSize < 0xFFFF)
+ {
+ maxSize += 0xFFFF + 1;
+ }
+ Assert.Greater(maxSize, 0, "Size of value should be greater than zero.");
+ if (maxSize < 0xFFFF + 10)
+ {
+ m_cacheableObject = string.Empty;
+ }
+ else
+ {
+ byte[] buffer = Util.RandBytes(maxSize);
+ string value = BitConverter.ToString(buffer).Replace("-", string.Empty);
+ m_cacheableObject = value;
+ }
+ }
+
+ public override uint GetChecksum(object cacheableObject)
+ {
+ string obj = (string)cacheableObject;
+ Assert.IsNotNull(obj, "GetChecksum: Null object.");
+
+ string value = obj;
+ byte[] buffer = new byte[value.Length];
+ for (int i = 0; i < value.Length; i++)
+ {
+ buffer[i] = (byte)value[i];
+ }
+ return CacheableHelper.CRC32(buffer);
+ }
+
+ public override int GetHashCodeN(object cacheableObject)
+ {
+ string val = (string)cacheableObject;
+ return val.GetHashCode();
+ }
+ #endregion
+ }
+
+ public class CacheableHugeUnicodeStringWrapper : CacheableKeyWrapper
+ {
+ #region Static factory creation function
+
+ public static CacheableKeyWrapper Create()
+ {
+ return new CacheableHugeUnicodeStringWrapper();
+ }
+
+ #endregion
+
+ #region CacheableKeyWrapper Members
+
+ public override int MaxKeys
+ {
+ get
+ {
+ return int.MaxValue;
+ }
+ }
+
+ public override void InitKey(int keyIndex, int maxSize)
+ {
+ Assert.Greater(maxSize, 0, "Size of key should be greater than zero.");
+ if (maxSize < 0xFFFF)
+ {
+ maxSize += 0xFFFF + 1;
+ }
+ if (keyIndex == 0)
+ {
+ m_cacheableObject = string.Empty;
+ }
+ else
+ {
+ string value = new string('\x0905', maxSize - 10) + keyIndex.ToString("D10");
+ m_cacheableObject = value;
+ }
+ }
+
+ public override void InitRandomValue(int maxSize)
+ {
+ if (maxSize < 0xFFFF)
+ {
+ maxSize += 0xFFFF + 1;
+ }
+ Assert.Greater(maxSize, 0, "Size of value should be greater than zero.");
+ if (maxSize < 0xFFFF + 10)
+ {
+ m_cacheableObject = string.Empty;
+ }
+ else
+ {
+ byte[] buffer = Util.RandBytes(maxSize);
+ char[] value = new char[maxSize];
+ for (int i = 0; i < maxSize; i++)
+ {
+ value[i] = (char)((int)buffer[i] + 0x0901);
+ }
+ m_cacheableObject = new string(value);
+ }
+ }
+
+ public override uint GetChecksum(object cacheableObject)
+ {
+ string obj = (string)cacheableObject;
+ Assert.IsNotNull(obj, "GetChecksum: Null object.");
+
+ string value = obj;
+ byte[] buffer = new byte[value.Length * 2];
+ for (int i = 0; i < value.Length; i++)
+ {
+ char c = value[i];
+ buffer[i * 2] = (byte)(c & 0xff);
+ buffer[i * 2 + 1] = (byte)((c >> 8) & 0xff);
+ }
+ return CacheableHelper.CRC32(buffer);
+ }
+
+ public override int GetHashCodeN(object cacheableObject)
+ {
+ string val = (string)cacheableObject;
+ return val.GetHashCode();
+ }
+ #endregion
+ }
+
+ #endregion
+
+ #region Builtin cacheables that are not keys
+
+ public class CacheableBytesWrapper : CacheableWrapper
+ {
+ #region Static factory creation function
+
+ public static CacheableWrapper Create()
+ {
+ return new CacheableBytesWrapper();
+ }
+
+ #endregion
+
+ #region CacheableWrapper Members
+
+ public override void InitRandomValue(int maxSize)
+ {
+ byte[] value = Util.RandBytes(maxSize);
+ m_cacheableObject = value;
+ }
+
+ public override uint GetChecksum(object cacheableObject)
+ {
+ byte[] value = (byte[])cacheableObject;
+ Assert.IsNotNull(value, "GetChecksum: Null object.");
+
+ return CacheableHelper.CRC32(value);
+ }
+ public override int GetHashCodeN(object cacheableObject)
+ {
+ byte[] val = (byte[])cacheableObject;
+ return val.GetHashCode();
+ }
+
+ #endregion
+ }
+
+ public class CacheableDoubleArrayWrapper : CacheableWrapper
+ {
+ #region Static factory creation function
+
+ public static CacheableWrapper Create()
+ {
+ return new CacheableDoubleArrayWrapper();
+ }
+
+ #endregion
+
+ #region CacheableWrapper Members
+
+ public override void InitRandomValue(int maxSize)
+ {
+ int arraySize = maxSize / sizeof(double);
+ arraySize = arraySize > 1 ? arraySize : 2;
+ double[] value = new double[arraySize];
+ for (int arrayIndex = 0; arrayIndex < arraySize; arrayIndex++)
+ {
+ value[arrayIndex] = Util.Rand() * double.MaxValue;
+ }
+ m_cacheableObject = value;
+ }
+
+ public override uint GetChecksum(object cacheableObject)
+ {
+ Double[] obj = cacheableObject as Double[];
+ Assert.IsNotNull(obj, "GetChecksum: Null object.");
+
+ double[] value = obj;
+ System.IO.MemoryStream ms = new System.IO.MemoryStream();
+ foreach (double v in value)
+ {
+ byte[] buffer = BitConverter.GetBytes(v);
+ ms.Write(buffer, 0, buffer.Length);
+ }
+ return CacheableHelper.CRC32(ms.ToArray());
+ }
+
+ public override int GetHashCodeN(object cacheableObject)
+ {
+ double[] val = (double[])cacheableObject;
+ return val.GetHashCode();
+ }
+ #endregion
+ }
+
+ public class CacheableFloatArrayWrapper : CacheableWrapper
+ {
+ #region Static factory creation function
+
+ public static CacheableWrapper Create()
+ {
+ return new CacheableFloatArrayWrapper();
+ }
+
+ #endregion
+
+ #region CacheableWrapper Members
+
+ public override void InitRandomValue(int maxSize)
+ {
+ int arraySize = maxSize / sizeof(float);
+ arraySize = arraySize > 1 ? arraySize : 2;
+ float[] value = new float[arraySize];
+ for (int arrayIndex = 0; arrayIndex < arraySize; arrayIndex++)
+ {
+ value[arrayIndex] = (float)Util.Rand() * float.MaxValue;
+ }
+ m_cacheableObject = value;
+ }
+
+ public override uint GetChecksum(object cacheableObject)
+ {
+ float[] obj = cacheableObject as float[];
+ Assert.IsNotNull(obj, "GetChecksum: Null object.");
+
+ float[] value = obj;
+ System.IO.MemoryStream ms = new System.IO.MemoryStream();
+ foreach (float v in value)
+ {
+ byte[] buffer = BitConverter.GetBytes(v);
+ ms.Write(buffer, 0, buffer.Length);
+ }
+ return CacheableHelper.CRC32(ms.ToArray());
+ }
+
+ public override int GetHashCodeN(object cacheableObject)
+ {
+ float[] val = (float[])cacheableObject;
+ return val.GetHashCode();
+ }
+ #endregion
+ }
+
+ public class CacheableHashMapWrapper : CacheableWrapper
+ {
+ #region Static factory creation function
+
+ public static CacheableWrapper Create()
+ {
+ return new CacheableHashMapWrapper();
+ }
+
+ #endregion
+
+ #region CacheableWrapper Members
+
+ public override void InitRandomValue(int maxSize)
+ {
+ //CacheableHashMap map = new CacheableHashMap();
+ Dictionary<object, object> map = new Dictionary<object, object>();
+ ICollection<UInt32> keyTypeIds =
+ CacheableWrapperFactory.GetRegisteredKeyTypeIds();
+ ICollection<UInt32> valueTypeIds =
+ CacheableWrapperFactory.GetRegisteredValueTypeIds();
+ int keySize = 16;
+ maxSize = maxSize / (keyTypeIds.Count * valueTypeIds.Count) + 1;
+ CacheableKeyWrapper keyWrapper;
+ CacheableWrapper valueWrapper;
+ foreach (UInt32 keyTypeId in keyTypeIds)
+ {
+ int index = 0;
+ foreach (UInt32 valueTypeId in valueTypeIds)
+ {
+ if ((valueTypeId == GeodeClassIds.CacheableASCIIStringHuge ||
+ valueTypeId == GeodeClassIds.CacheableStringHuge)
+ && !(keyTypeId == GeodeClassIds.CacheableBoolean))
+ {
+ continue;
+ }
+ if ((keyTypeId == GeodeClassIds.CacheableASCIIStringHuge ||
+ keyTypeId == GeodeClassIds.CacheableStringHuge)
+ && !(valueTypeId == GeodeClassIds.CacheableBoolean))
+ {
+ continue;
+ }
+ // null object does not work on server side during deserialization
+ if (valueTypeId == GeodeClassIds.CacheableNullString)
+ {
+ continue;
+ }
+
+ keyWrapper = CacheableWrapperFactory.CreateKeyInstance(keyTypeId);
+ Assert.IsNotNull(keyWrapper, "CacheableHashMapWrapper.InitRandomValue:" +
+ " Could not create an instance of typeId [{0}].", keyTypeId);
+ if (keyWrapper.MaxKeys <= index)
+ {
+ break;
+ }
+ keyWrapper.InitKey((int)(keyTypeId << 8) + index, keySize);
+ if (!CacheableHelper.IsContainerTypeId(valueTypeId) &&
+ !CacheableHelper.IsUnhandledType(valueTypeId))
+ {
+ valueWrapper = CacheableWrapperFactory.CreateInstance(valueTypeId);
+ Assert.IsNotNull(valueWrapper, "CacheableHashMapWrapper.InitRandomValue:" +
+ " Could not create an instance of typeId [{0}].", valueTypeId);
+ valueWrapper.InitRandomValue(maxSize);
+ Util.Log(" updating map " + keyWrapper.CacheableKey + " : " + valueWrapper.Cacheable);
+ map.Add(keyWrapper.CacheableKey, valueWrapper.Cacheable);
+ }
+ index++;
+ }
+ }
+ m_cacheableObject = map;
+ }
+
+ public override uint GetChecksum(object cacheableObject)
+ {
+ //CacheableHashMap value = cacheableObject as CacheableHashMap;
+ Dictionary<object, object> value = cacheableObject as Dictionary<object, object>;
+ Assert.IsNotNull(value, "GetChecksum: Null object.");
+
+ uint ckSum = 0;
+ CacheableKeyWrapper keyWrapper;
+ CacheableWrapper valueWrapper;
+ foreach (KeyValuePair<object, object> pair in value)
+ {
+ Util.Log(" pair " + pair.Key.GetType() + " : " + pair.Value.GetType());
+ keyWrapper = CacheableWrapperFactory.CreateKeyInstance((pair.Key));
+ Assert.IsNotNull(keyWrapper, "CacheableHashMap.GetChecksum:" +
+ " Could not create an instance of typeId [{0}].",
+ keyWrapper.TypeId);
+ valueWrapper = CacheableWrapperFactory.CreateInstance(
+ pair.Value);
+ Assert.IsNotNull(valueWrapper, "CacheableHashMap.GetChecksum:" +
+ " Could not create an instance of typeId [{0}].",
+ valueWrapper.TypeId);
+
+ ckSum ^= (keyWrapper.GetChecksum(pair.Key) ^
+ valueWrapper.GetChecksum(pair.Value));
+ }
+ return ckSum;
+ }
+
+ #endregion
+ }
+
+ public class CacheableHashTableWrapper : CacheableWrapper
+ {
+ #region Static factory creation function
+
+ public static CacheableWrapper Create()
+ {
+ return new CacheableHashTableWrapper();
+ }
+
+ #endregion
+
+ #region CacheableWrapper Members
+
+ public override void InitRandomValue(int maxSize)
+ {
+ //CacheableHashTable table = new CacheableHashTable();
+ System.Collections.Hashtable table = new System.Collections.Hashtable();
+ ICollection<UInt32> keyTypeIds =
+ CacheableWrapperFactory.GetRegisteredKeyTypeIds();
+ ICollection<UInt32> valueTypeIds =
+ CacheableWrapperFactory.GetRegisteredValueTypeIds();
+ int keySize = 16;
+ maxSize = maxSize / (keyTypeIds.Count * valueTypeIds.Count) + 1;
+ CacheableKeyWrapper keyWrapper;
+ CacheableWrapper valueWrapper;
+ foreach (UInt32 keyTypeId in keyTypeIds)
+ {
+ int index = 0;
+ foreach (UInt32 valueTypeId in valueTypeIds)
+ {
+ if ((valueTypeId == GeodeClassIds.CacheableASCIIStringHuge ||
+ valueTypeId == GeodeClassIds.CacheableStringHuge)
+ && !(keyTypeId == GeodeClassIds.CacheableBoolean))
+ {
+ continue;
+ }
+ if ((keyTypeId == GeodeClassIds.CacheableASCIIStringHuge ||
+ keyTypeId == GeodeClassIds.CacheableStringHuge)
+ && !(valueTypeId == GeodeClassIds.CacheableBoolean))
+ {
+ continue;
+ }
+ if (valueTypeId == GeodeClassIds.CacheableNullString)
+ {
+ continue;
+ }
+
+ keyWrapper = CacheableWrapperFactory.CreateKeyInstance(keyTypeId);
+ Assert.IsNotNull(keyWrapper, "CacheableHashTableWrapper.InitRandomValue:" +
+ " Could not create an instance of typeId [{0}].", keyTypeId);
+ if (keyWrapper.MaxKeys <= index)
+ {
+ break;
+ }
+ keyWrapper.InitKey((int)(keyTypeId << 8) + index, keySize);
+
+ if (!CacheableHelper.IsContainerTypeId(valueTypeId) &&
+ !CacheableHelper.IsUnhandledType(valueTypeId))
+ {
+ valueWrapper = CacheableWrapperFactory.CreateInstance(valueTypeId);
+ Assert.IsNotNull(valueWrapper, "CacheableHashTableWrapper.InitRandomValue:" +
+ " Could not create an instance of typeId [{0}].", valueTypeId);
+ valueWrapper.InitRandomValue(maxSize);
+ if (valueWrapper.Cacheable == null)
+ {
+ Util.Log(" adding null value " + valueWrapper.GetType() + " : " + valueTypeId);
+ }
+ else
+ Util.Log(" adding value " + valueWrapper.GetType() + " : " + valueTypeId);
+ table.Add(keyWrapper.CacheableKey, valueWrapper.Cacheable);
+ }
+ index++;
+ }
+ }
+ m_cacheableObject = table;
+ }
+
+ public override uint GetChecksum(object cacheableObject)
+ {
+ //Dictionary<object, object> value = new Dictionary<object, object>();
+ System.Collections.Hashtable value = cacheableObject as System.Collections.Hashtable;
+ Assert.IsNotNull(value, "GetChecksum: Null object.");
+
+ uint ckSum = 0;
+ CacheableKeyWrapper keyWrapper;
+ CacheableWrapper valueWrapper;
+ foreach (System.Collections.DictionaryEntry pair in value)
+ {
+ keyWrapper = CacheableWrapperFactory.CreateKeyInstance(
+ pair.Key);
+ Assert.IsNotNull(keyWrapper, "CacheableHashTable.GetChecksum:" +
+ " Could not create an instance of typeId [{0}].",
+ keyWrapper.TypeId);
+ valueWrapper = CacheableWrapperFactory.CreateInstance(
+ pair.Value);
+ Assert.IsNotNull(valueWrapper, "CacheableHashTable.GetChecksum:" +
+ " Could not create an instance of typeId [{0}].",
+ valueWrapper.TypeId);
+
+ ckSum ^= (keyWrapper.GetChecksum(pair.Key) ^
+ valueWrapper.GetChecksum(pair.Value));
+ }
+ return ckSum;
+ }
+
+ #endregion
+ }
+
+ public class CacheableIdentityHashMapWrapper : CacheableWrapper
+ {
+ #region Static factory creation function
+
+ public static CacheableWrapper Create()
+ {
+ return new CacheableIdentityHashMapWrapper();
+ }
+
+ #endregion
+
+ #region CacheableWrapper Members
+
+ public override void InitRandomValue(int maxSize)
+ {
+ //CacheableIdentityHashMap map = new CacheableIdentityHashMap();
+ Dictionary<object, object> map = new Dictionary<object, object>();
+ ICollection<UInt32> keyTypeIds =
+ CacheableWrapperFactory.GetRegisteredKeyTypeIds();
+ ICollection<UInt32> valueTypeIds =
+ CacheableWrapperFactory.GetRegisteredValueTypeIds();
+ int keySize = 16;
+ maxSize = maxSize / (keyTypeIds.Count * valueTypeIds.Count) + 1;
+ CacheableKeyWrapper keyWrapper;
+ CacheableWrapper valueWrapper;
+ foreach (UInt32 keyTypeId in keyTypeIds)
+ {
+ int index = 0;
+ foreach (UInt32 valueTypeId in valueTypeIds)
+ {
+ if ((valueTypeId == GeodeClassIds.CacheableASCIIStringHuge ||
+ valueTypeId == GeodeClassIds.CacheableStringHuge)
+ && !(keyTypeId == GeodeClassIds.CacheableBoolean))
+ {
+ continue;
+ }
+ if ((keyTypeId == GeodeClassIds.CacheableASCIIStringHuge ||
+ keyTypeId == GeodeClassIds.CacheableStringHuge)
+ && !(valueTypeId == GeodeClassIds.CacheableBoolean))
+ {
+ continue;
+ }
+ // null object does not work on server side during deserialization
+ if (valueTypeId == GeodeClassIds.CacheableNullString)
+ {
+ continue;
+ }
+
+ keyWrapper = CacheableWrapperFactory.CreateKeyInstance(keyTypeId);
+ Assert.IsNotNull(keyWrapper, "CacheableIdentityHashMapWrapper.InitRandomValue:" +
+ " Could not create an instance of typeId [{0}].", keyTypeId);
+ if (keyWrapper.MaxKeys <= index)
+ {
+ break;
+ }
+ keyWrapper.InitKey((int)(keyTypeId << 8) + index, keySize);
+
+ if (!CacheableHelper.IsContainerTypeId(valueTypeId) &&
+ !CacheableHelper.IsUnhandledType(valueTypeId))
+ {
+ valueWrapper = CacheableWrapperFactory.CreateInstance(valueTypeId);
+ Assert.IsNotNull(valueWrapper, "CacheableIdentityHashMapWrapper.InitRandomValue:" +
+ " Could not create an instance of typeId [{0}].", valueTypeId);
+ valueWrapper.InitRandomValue(maxSize);
+ map.Add(keyWrapper.CacheableKey, valueWrapper.Cacheable);
+ }
+ index++;
+ }
+ }
+ m_cacheableObject = map;
+ }
+
+ public override uint GetChecksum(object cacheableObject)
+ {
+
+ //CacheableHashMap value = cacheableObject as CacheableHashMap;
+ Dictionary<object, object> value = new Dictionary<object, object>();
+ Assert.IsNotNull(value, "GetChecksum: Null object.");
+
+ uint ckSum = 0;
+ CacheableKeyWrapper keyWrapper;
+ CacheableWrapper valueWrapper;
+ foreach (KeyValuePair<object, object> pair in value)
+ {
+ keyWrapper = CacheableWrapperFactory.CreateKeyInstance(
+ pair.Key);
+ Assert.IsNotNull(keyWrapper, "CacheableIdentityHashMap.GetChecksum:" +
+ " Could not create an instance of typeId [{0}].",
+ keyWrapper.TypeId);
+ valueWrapper = CacheableWrapperFactory.CreateInstance(
+ pair.Value);
+ Assert.IsNotNull(valueWrapper, "CacheableIdentityHashMap.GetChecksum:" +
+ " Could not create an instance of typeId [{0}].",
+ valueWrapper.TypeId);
+
+ ckSum ^= (keyWrapper.GetChecksum(pair.Key) ^
+ valueWrapper.GetChecksum(pair.Value));
+ }
+ return ckSum;
+ }
+
+ #endregion
+ }
+
+ public class CacheableHashSetWrapper : CacheableWrapper
+ {
+ #region Static factory creation function
+
+ public static CacheableWrapper Create()
+ {
+ return new CacheableHashSetWrapper();
+ }
+
+ #endregion
+
+ #region CacheableWrapper Members
+
+ public override void InitRandomValue(int maxSize)
+ {
+ CacheableHashSet set = new CacheableHashSet();
+ //List<object> set = new List<object>();
+
+ //Dictionary set = new Dictionary();
+ ICollection<UInt32> keyTypeIds =
+ CacheableWrapperFactory.GetRegisteredKeyTypeIds();
+ maxSize = maxSize / keyTypeIds.Count + 1;
+ CacheableKeyWrapper wrapper;
+ int keyIndex = 0;
+ foreach (UInt32 typeId in keyTypeIds)
+ {
+ if (!CacheableHelper.IsContainerTypeId(typeId) &&
+ !CacheableHelper.IsUnhandledType(typeId))
+ {
+ wrapper = CacheableWrapperFactory.CreateKeyInstance(typeId);
+ Assert.IsNotNull(wrapper, "CacheableHashSetWrapper.InitRandomValue:" +
+ " Could not create an instance of typeId [{0}].", typeId);
+ wrapper.InitKey(keyIndex++, maxSize);
+
+
+ set.Add(wrapper.CacheableKey);
+ }
+ }
+ m_cacheableObject = set;
+ }
+
+ public override uint GetChecksum(object cacheableObject)
+ {
+ CacheableHashSet value = cacheableObject as CacheableHashSet;
+ //List<object> value = cacheableObject as List<object>;
+ Assert.IsNotNull(value, "GetChecksum: Null object.");
+
+ uint ckSum = 0;
+ CacheableKeyWrapper wrapper;
+ foreach (object key in value)
+ {
+ wrapper = CacheableWrapperFactory.CreateKeyInstance(key);
+ Assert.IsNotNull(wrapper, "CacheableHashSet.GetChecksum:" +
+ " Could not create an instance of typeId [{0}].", wrapper.TypeId);
+ ckSum ^= wrapper.GetChecksum(key);
+ }
+ return ckSum;
+ }
+
+ public override int GetHashCodeN(object cacheableObject)
+ {
+ CacheableHashSet value = cacheableObject as CacheableHashSet;
+
+ return value.GetHashCode();
+ }
+ #endregion
+ }
+
+ public class CacheableLinkedHashSetWrapper : CacheableWrapper
+ {
+ #region Static factory creation function
+
+ public static CacheableWrapper Create()
+ {
+ return new CacheableLinkedHashSetWrapper();
+ }
+
+ #endregion
+
+ #region CacheableWrapper Members
+
+ public override void InitRandomValue(int maxSize)
+ {
+ CacheableLinkedHashSet set = new CacheableLinkedHashSet();
+ //Dictionary<object, object> set = new Dictionary<object, object>();
+ //List<object> set = new List<object>();
+ ICollection<UInt32> keyTypeIds =
+ CacheableWrapperFactory.GetRegisteredKeyTypeIds();
+ maxSize = maxSize / keyTypeIds.Count + 1;
+ CacheableKeyWrapper wrapper;
+ int keyIndex = 0;
+ foreach (UInt32 typeId in keyTypeIds)
+ {
+ if (!CacheableHelper.IsContainerTypeId(typeId) &&
+ !CacheableHelper.IsUnhandledType(typeId))
+ {
+ wrapper = CacheableWrapperFactory.CreateKeyInstance(typeId);
+ Assert.IsNotNull(wrapper, "CacheableLinkedHashSetWrapper.InitRandomValue:" +
+ " Could not create an instance of typeId [{0}].", typeId);
+ wrapper.InitKey(keyIndex++, maxSize);
+ set.Add(wrapper.CacheableKey);
+ }
+ }
+ m_cacheableObject = set;
+ }
+
+ public override uint GetChecksum(object cacheableObject)
+ {
+ //List<object> value = new List<object>();
+ CacheableLinkedHashSet value = cacheableObject as CacheableLinkedHashSet;
+ Assert.IsNotNull(value, "GetChecksum: Null object.");
+
+ uint ckSum = 0;
+ CacheableKeyWrapper wrapper;
+ foreach (object key in value)
+ {
+ wrapper = CacheableWrapperFactory.CreateKeyInstance(key);
+ Assert.IsNotNull(wrapper, "CacheableLinkedHashSet.GetChecksum:" +
+ " Could not create an instance of typeId [{0}].", wrapper.TypeId);
+ ckSum ^= wrapper.GetChecksum(key);
+ }
+ return ckSum;
+ }
+
+ #endregion
+ }
+
+ public class CacheableInt16ArrayWrapper : CacheableWrapper
+ {
+ #region Static factory creation function
+
+ public static CacheableWrapper Create()
+ {
+ return new CacheableInt16ArrayWrapper();
+ }
+
+ #endregion
+
+ #region CacheableWrapper Members
+
+ public override void InitRandomValue(int maxSize)
+ {
+ int arraySize = maxSize / sizeof(short);
+ arraySize = arraySize > 1 ? arraySize : 2;
+ short[] value = new short[arraySize];
+ for (int arrayIndex = 0; arrayIndex < arraySize; arrayIndex++)
+ {
+ value[arrayIndex] = (short)Util.Rand(short.MaxValue);
+ }
+ m_cacheableObject = value;
+ }
+
+ public override uint GetChecksum(object cacheableObject)
+ {
+ Int16[] obj = cacheableObject as Int16[];
+ Assert.IsNotNull(obj, "GetChecksum: Null object.");
+
+ short[] value = obj;
+ System.IO.MemoryStream ms = new System.IO.MemoryStream();
+ foreach (short v in value)
+ {
+ short conv = v;
+ int numBytes = sizeof(short);
+ for (int i = 0; i < numBytes; i++)
+ {
+ ms.WriteByte((byte)(conv & 0xff));
+ conv = (short)(conv >> 8);
+ }
+ }
+ return CacheableHelper.CRC32(ms.ToArray());
+ }
+
+ #endregion
+ }
+
+ public class CacheableInt32ArrayWrapper : CacheableWrapper
+ {
+ #region Static factory creation function
+
+ public static CacheableWrapper Create()
+ {
+ return new CacheableInt32ArrayWrapper();
+ }
+
+ #endregion
+
+ #region CacheableWrapper Members
+
+ public override void InitRandomValue(int maxSize)
+ {
+ int arraySize = maxSize / sizeof(int);
+ arraySize = arraySize > 1 ? arraySize : 2;
+ int[] value = new int[arraySize];
+ for (int arrayIndex = 0; arrayIndex < arraySize; arrayIndex++)
+ {
+ value[arrayIndex] = Util.Rand(int.MaxValue);
+ }
+ m_cacheableObject = value;
+ }
+
+ public override uint GetChecksum(object cacheableObject)
+ {
+ Int32[] obj = cacheableObject as Int32[];
+ Assert.IsNotNull(obj, "GetChecksum: Null object.");
+
+ int[] value = obj;
+ System.IO.MemoryStream ms = new System.IO.MemoryStream();
+ foreach (int v in value)
+ {
+ int conv = v;
+ int numBytes = sizeof(int);
+ for (int i = 0; i < numBytes; i++)
+ {
+ ms.WriteByte((byte)(conv & 0xff));
+ conv = conv >> 8;
+ }
+ }
+ return CacheableHelper.CRC32(ms.ToArray());
+ }
+
+ #endregion
+ }
+
+ public class CacheableInt64ArrayWrapper : CacheableWrapper
+ {
+ #region Static factory creation function
+
+ public static CacheableWrapper Create()
+ {
+ return new CacheableInt64ArrayWrapper();
+ }
+
+ #endregion
+
+ #region CacheableWrapper Members
+
+ public override void InitRandomValue(int maxSize)
+ {
+ int arraySize = maxSize / sizeof(long);
+ arraySize = arraySize > 1 ? arraySize : 2;
+ long[] value = new long[arraySize];
+ long rnd;
+ for (int arrayIndex = 0; arrayIndex < arraySize; arrayIndex++)
+ {
+ rnd = (long)Util.Rand(int.MaxValue);
+ rnd = (rnd << 32) + (long)Util.Rand(int.MaxValue);
+ value[arrayIndex] = rnd;
+ }
+ m_cacheableObject = value;
+ }
+
+ public override uint GetChecksum(object cacheableObject)
+ {
+ Int64[] obj = cacheableObject as Int64[];
+ Assert.IsNotNull(obj, "GetChecksum: Null object.");
+
+ long[] value = obj;
+ System.IO.MemoryStream ms = new System.IO.MemoryStream();
+ foreach (long v in value)
+ {
+ long conv = v;
+ int numBytes = sizeof(long);
+ for (int i = 0; i < numBytes; i++)
+ {
+ ms.WriteByte((byte)(conv & 0xff));
+ conv = conv >> 8;
+ }
+ }
+ return CacheableHelper.CRC32(ms.ToArray());
+ }
+
+ #endregion
+ }
+
+ public class CacheableNullStringWrapper : CacheableWrapper
+ {
+ #region Static factory creation function
+
+ public static CacheableWrapper Create()
+ {
+ return new CacheableNullStringWrapper();
+ }
+
+ #endregion
+
+ #region CacheableWrapper Members
+
+ public override void InitRandomValue(int maxSize)
+ {
+ //m_cacheableObject = CacheableString.Create((string)null);
+ m_cacheableObject = null;
+ }
+
+ public override uint GetChecksum(object cacheableObject)
+ {
+ //CacheableString value = cacheableObject as CacheableString;
+ Assert.IsNull(cacheableObject, "GetChecksum: expected null object.");
+ return (uint)0;
+ }
+
+ #endregion
+ }
+
+ public class CacheableEmptyStringWrapper : CacheableWrapper
+ {
+ #region Static factory creation function
+
+ public static CacheableWrapper Create()
+ {
+ return new CacheableEmptyStringWrapper();
+ }
+
+ #endregion
+
+ #region CacheableWrapper Members
+
+ public override void InitRandomValue(int maxSize)
+ {
+ //m_cacheableObject = CacheableString.Create(string.Empty);
+ m_cacheableObject = string.Empty;
+ }
+
+ public override uint GetChecksum(object cacheableObject)
+ {
+ string value = cacheableObject as string;
+ Assert.IsNotNull(value, "GetChecksum: expected non null object.");
+ Assert.IsTrue(value == string.Empty || value.Length == 0, "Expected IsNullOrEmpty " + value.Length);
+ return (uint)0;
+ }
+
+ #endregion
+ }
+
+ public class CacheableEmptyUnicodeStringWrapper : CacheableWrapper
+ {
+ // TODO : VJR : Is this a real UNICODE empty string?
+ // See bugs #324 and #356 to add this wrapper when tracking them.
+
+ #region Static factory creation function
+
+ public static CacheableWrapper Create()
+ {
+ return new CacheableEmptyUnicodeStringWrapper();
+ }
+
+ #endregion
+
+ #region CacheableWrapper Members
+
+ public override void InitRandomValue(int maxSize)
+ {
+ //m_cacheableObject = CacheableString.Create(string.Empty);
+ m_cacheableObject = string.Empty;
+ }
+
+ public override uint GetChecksum(object cacheableObject)
+ {
+ string value = cacheableObject as string;
+ Assert.IsNotNull(value, "GetChecksum: expected non null object.");
+ Assert.IsTrue(value == string.Empty || value.Length == 0, "Expected IsNullOrEmpty");
+ return (uint)0;
+ }
+
+ #endregion
+ }
+
+ public class CacheableStringArrayWrapper : CacheableWrapper
+ {
+ #region Static factory creation function
+
+ public static CacheableWrapper Create()
+ {
+ return new CacheableStringArrayWrapper();
+ }
+
+ #endregion
+
+ #region CacheableWrapper Members
+
+ public override void InitRandomValue(int maxSize)
+ {
+ int arraySize = 16;
+ maxSize = maxSize / arraySize;
+ if (maxSize < 2)
+ {
+ maxSize = 2;
+ }
+ String[] value = new String[arraySize];
+ for (int arrayIndex = 0; arrayIndex < arraySize; arrayIndex++)
+ {
+ if (arrayIndex % 2 == 0)
+ {
+ byte[] buffer = Util.RandBytes(maxSize / 2);
+ value[arrayIndex] = BitConverter.ToString(buffer).Replace("-", string.Empty);
+ }
+ else
+ {
+ byte[] buffer = Util.RandBytes(maxSize / 2);
+ char[] charArray = new char[maxSize / 2];
+ for (int i = 0; i < maxSize / 2; i++)
+ {
+ charArray[i] = (char)((int)buffer[i] + 0x0901);
+ }
+ value[arrayIndex] = new String(charArray);
+ }
+ }
+ //m_cacheableObject = CacheableStringArray.Create(value);
+ m_cacheableObject = value;
+ }
+
+ public override uint GetChecksum(object cacheableObject)
+ {
+ String[] value = cacheableObject as String[];
+ Assert.IsNotNull(value, "GetChecksum: Null object.");
+
+ System.IO.MemoryStream ms = new System.IO.MemoryStream();
+ foreach (String str in value)
+ {
+ foreach (char c in str)
+ {
+ ms.WriteByte((byte)(c & 0xff));
+ byte uByte = (byte)((c >> 8) & 0xff);
+ if (uByte != 0x00)
+ ms.WriteByte(uByte);
+ }
+ }
+ return CacheableHelper.CRC32(ms.ToArray());
+ }
+
+ #endregion
+ }
+
+ public class CacheableUndefinedWrapper : CacheableWrapper
+ {
+ #region Static factory creation function
+
+ public static CacheableWrapper Create()
+ {
+ return new CacheableUndefinedWrapper();
+ }
+
+ #endregion
+
+ #region CacheableWrapper Members
+
+ public override void InitRandomValue(int maxSize)
+ {
+ m_cacheableObject = new CacheableUndefined();
+ }
+
+ public override uint GetChecksum(object cacheableObject)
+ {
+ CacheableUndefined value = cacheableObject as CacheableUndefined;
+ // TODO: [sumedh] server sends back null; check this
+ //Assert.IsNotNull(value, "GetChecksum: Null object.");
+
+ return 0;
+ }
+
+ #endregion
+ }
+
+ public class CacheableVectorWrapper : CacheableWrapper
+ {
+ #region Static factory creation function
+
+ public static CacheableWrapper Create()
+ {
+ return new CacheableVectorWrapper();
+ }
+
+ #endregion
+
+ #region CacheableWrapper Members
+
+ public override void InitRandomValue(int maxSize)
+ {
+ //CacheableVector vec = new CacheableVector();
+ System.Collections.ArrayList vec = new System.Collections.ArrayList();
+
+ ICollection<UInt32> valueTypeIds =
+ CacheableWrapperFactory.GetRegisteredValueTypeIds();
+ maxSize = maxSize / valueTypeIds.Count + 1;
+ CacheableWrapper wrapper;
+ foreach (UInt32 typeId in valueTypeIds)
+ {
+ if (!CacheableHelper.IsContainerTypeId(typeId) &&
+ !CacheableHelper.IsUnhandledType(typeId))
+ {
+ wrapper = CacheableWrapperFactory.CreateInstance(typeId);
+ Assert.IsNotNull(wrapper, "CacheableVectorWrapper.InitRandomValue:" +
+ " Could not create an instance of typeId [{0}].", typeId);
+ wrapper.InitRandomValue(maxSize);
+ vec.Add(wrapper.Cacheable);
+ }
+ }
+ m_cacheableObject = vec;
+ }
+
+ public override uint GetChecksum(object cacheableObject)
+ {
+ System.Collections.ArrayList value = cacheableObject as System.Collections.ArrayList;
+ Assert.IsNotNull(value, "GetChecksum: Null object.");
+
+ uint ckSum = 0;
+ CacheableWrapper wrapper;
+ foreach (object obj in value)
+ {
+ if (obj == null)
+ {
+ continue;
+ }
+ wrapper = CacheableWrapperFactory.CreateInstance(obj);
+ Assert.IsNotNull(wrapper, "CacheableVectorWrapper.GetChecksum:" +
+ " Could not create an instance of typeId [{0}].", wrapper.TypeId);
+ ckSum ^= wrapper.GetChecksum(obj);
+ }
+ return ckSum;
+ }
+
+ #endregion
+ }
+
+ public class CacheableObjectArrayWrapper : CacheableWrapper
+ {
+ #region Static factory creation function
+
+ public static CacheableWrapper Create()
+ {
+ return new CacheableObjectArrayWrapper();
+ }
+
+ #endregion
+
+ #region CacheableWrapper Members
+
+ public override void InitRandomValue(int maxSize)
+ {
+ CacheableObjectArray arr = new CacheableObjectArray();
+ ICollection<UInt32> valueTypeIds =
+ CacheableWrapperFactory.GetRegisteredValueTypeIds();
+ maxSize = maxSize / valueTypeIds.Count + 1;
+ CacheableWrapper wrapper;
+ foreach (UInt32 typeId in valueTypeIds)
+ {
+ if (!CacheableHelper.IsContainerTypeId(typeId) &&
+ !CacheableHelper.IsUnhandledType(typeId))
+ {
+ wrapper = CacheableWrapperFactory.CreateInstance(typeId);
+ Assert.IsNotNull(wrapper, "CacheableObjectArrayWrapper.InitRandomValue:" +
+ " Could not create an instance of typeId [{0}].", typeId);
+ wrapper.InitRandomValue(maxSize);
+
+ arr.Add(wrapper.Cacheable);
+ }
+ }
+ m_cacheableObject = arr;
+ }
+
+ public override uint GetChecksum(object cacheableObject)
+ {
+ CacheableObjectArray value = cacheableObject as CacheableObjectArray;
+ Assert.IsNotNull(value, "GetChecksum: Null object.");
+
+ uint ckSum = 0;
+ CacheableWrapper wrapper;
+ foreach (object obj in value)
+ {
+ if (obj == null)
+ {
+ continue;
+ }
+ wrapper = CacheableWrapperFactory.CreateInstance(obj);
+ Assert.IsNotNull(wrapper, "CacheableObjectArrayWrapper.GetChecksum:" +
+ " Could not create an instance of typeId [{0}].", wrapper.TypeId);
+ ckSum ^= wrapper.GetChecksum(obj);
+ }
+ return ckSum;
+ }
+
+ #endregion
+ }
+
+ public class CacheableArrayListWrapper : CacheableWrapper
+ {
+ #region Static factory creation function
+
+ public static CacheableWrapper Create()
+ {
+ return new CacheableArrayListWrapper();
+ }
+
+ #endregion
+
+ #region CacheableWrapper Members
+
+ public override void InitRandomValue(int maxSize)
+ {
+ //CacheableArrayList arrayList = new CacheableArrayList();
+ List<object> arrayList = new List<object>();
+
+ ICollection<UInt32> valueTypeIds =
+ CacheableWrapperFactory.GetRegisteredValueTypeIds();
+ maxSize = maxSize / valueTypeIds.Count + 1;
+ CacheableWrapper wrapper;
+ Util.Log(" arrayList size InitRandomValue ");
+ foreach (UInt32 typeId in valueTypeIds)
+ {
+ if (!CacheableHelper.IsContainerTypeId(typeId) &&
+ !CacheableHelper.IsUnhandledType(typeId))
+ {
+ wrapper = CacheableWrapperFactory.CreateInstance(typeId);
+ Assert.IsNotNull(wrapper, "CacheableArrayListWrapper.InitRandomValue:" +
+ " Could not create an instance of typeId [{0}].", typeId);
+ wrapper.InitRandomValue(maxSize);
+ arrayList.Add(wrapper.Cacheable);
+ }
+ }
+ m_cacheableObject = arrayList;
+ Util.Log(" arrayList size InitRandomValue " + arrayList.Count);
+ }
+
+ public override uint GetChecksum(object cacheableObject)
+ {
+ List<object> value = cacheableObject as List<object>;
+ Assert.IsNotNull(value, "GetChecksum: Null object.");
+
+ uint ckSum = 0;
+ CacheableWrapper wrapper;
+ foreach (object obj in value)
+ {
+ if (obj == null)
+ {
+ continue;
+ }
+ wrapper = CacheableWrapperFactory.CreateInstance(obj);
+ Assert.IsNotNull(wrapper, "CacheableArrayListWrapper.GetChecksum:" +
+ " Could not create an instance of typeId [{0}].", wrapper.TypeId);
+ ckSum ^= wrapper.GetChecksum(obj);
+ }
+ return ckSum;
+ }
+
+ #endregion
+ }
+
+ public class CacheableStackWrapper : CacheableWrapper
+ {
+ #region Static factory creation function
+
+ public static CacheableWrapper Create()
+ {
+ return new CacheableStackWrapper();
+ }
+
+ #endregion
+
+ #region CacheableWrapper Members
+
+ public override void InitRandomValue(int maxSize)
+ {
+ //CacheableStack vec = new CacheableStack();
+ Stack<object> vec = new Stack<object>();
+
+ ICollection<UInt32> valueTypeIds =
+ CacheableWrapperFactory.GetRegisteredValueTypeIds();
+ maxSize = maxSize / valueTypeIds.Count + 1;
+ CacheableWrapper wrapper;
+ foreach (UInt32 typeId in valueTypeIds)
+ {
+ if (!CacheableHelper.IsContainerTypeId(typeId) &&
+ !CacheableHelper.IsUnhandledType(typeId))
+ {
+ wrapper = CacheableWrapperFactory.CreateInstance(typeId);
+ Assert.IsNotNull(wrapper, "CacheableStackWrapper.InitRandomValue:" +
+ " Could not create an instance of typeId [{0}].", typeId);
+ wrapper.InitRandomValue(maxSize);
+ vec.Push(wrapper.Cacheable);
+ }
+ }
+ m_cacheableObject = vec;
+ }
+
+ public override uint GetChecksum(object cacheableObject)
+ {
+ Stack<object> value = cacheableObject as Stack<object>;
+ Assert.IsNotNull(value, "GetChecksum: Null object.");
+
+ uint ckSum = 0;
+ CacheableWrapper wrapper;
+ foreach (Object obj in value)
+ {
+ if (obj == null)
+ {
+ continue;
+ }
+ wrapper = CacheableWrapperFactory.CreateInstance(obj);
+ Assert.IsNotNull(wrapper, "CacheableStackWrapper.GetChecksum:" +
+ " Could not create an instance of typeId [{0}].", wrapper.TypeId);
+ ckSum ^= wrapper.GetChecksum(obj);
+ }
+ return ckSum;
+ }
+
+ #endregion
+ }
+
+ public class CacheableObjectWrapper : CacheableWrapper
+ {
+ #region Static factory creation function
+
+ public static CacheableWrapper Create()
+ {
+ return new CacheableObjectWrapper();
+ }
+
+ #endregion
+
+ #region CacheableWrapper Members
+
+ public override void InitRandomValue(int maxSize)
+ {
+ CData value = CacheableHelper.RandCData();
+ m_cacheableObject = CacheableObject.Create(value);
+ }
+
+ public override uint GetChecksum(object cacheableObject)
+ {
+ CacheableObject obj = cacheableObject as CacheableObject;
+ Assert.IsNotNull(obj, "GetChecksum: Null object.");
+
+ CData value = (CData)obj.Value;
+ System.IO.MemoryStream ms = new System.IO.MemoryStream();
+ int first = value.First;
+ int numBytes = sizeof(int);
+ for (int i = 0; i < numBytes; i++)
+ {
+ ms.WriteByte((byte)(first & 0xff));
+ first = first >> 8;
+ }
+ long second = value.Second;
+ numBytes = sizeof(long);
+ for (int i = 0; i < numBytes; i++)
+ {
+ ms.WriteByte((byte)(second & 0xff));
+ second = second >> 8;
+ }
+ return CacheableHelper.CRC32(ms.ToArray());
+ }
+
+
+ #endregion
+ }
+
+ public class CacheableObjectXmlWrapper : CacheableWrapper
+ {
+ #region Static factory creation function
+
+ public static CacheableWrapper Create()
+ {
+ return new CacheableObjectXmlWrapper();
+ }
+
+ #endregion
+
+ #region CacheableWrapper Members
+
+ public override void InitRandomValue(int maxSize)
+ {
+ CData value = CacheableHelper.RandCData();
+ m_cacheableObject = CacheableObjectXml.Create(value);
+ }
+
+ public override uint GetChecksum(object cacheableObject)
+ {
+ CacheableObjectXml obj = cacheableObject as CacheableObjectXml;
+ Assert.IsNotNull(obj, "GetChecksum: Null object.");
+
+ CData value = (CData)obj.Value;
+ System.IO.MemoryStream ms = new System.IO.MemoryStream();
+ int first = value.First;
+ int numBytes = sizeof(int);
+ for (int i = 0; i < numBytes; i++)
+ {
+ ms.WriteByte((byte)(first & 0xff));
+ first = first >> 8;
+ }
+ long second = value.Second;
+ numBytes = sizeof(long);
+ for (int i = 0; i < numBytes; i++)
+ {
+ ms.WriteByte((byte)(second & 0xff));
+ second = second >> 8;
+ }
+ return CacheableHelper.CRC32(ms.ToArray());
+ }
+
+ #endregion
+ }
+
+ public class PdxCDataWrapper : CacheableKeyWrapper
+ {
+ #region Static factory creation function
+
+ public static CacheableKeyWrapper Create()
+ {
+ return new PdxCDataWrapper();
+ }
+
+ #endregion
+
+ #region CacheableWrapper Members
+
+ public override void InitRandomValue(int maxSize)
+ {
+ PdxCData value = CacheableHelper.RandPdxCData();
+ m_cacheableObject = value;
+ }
+
+ public override uint GetChecksum(object ca
<TRUNCATED>