hippomocks: Import sources from upstream
authorPhilippe Coval <philippe.coval@osg.samsung.com>
Mon, 5 Sep 2016 12:58:29 +0000 (14:58 +0200)
committerPhilippe Coval <philippe.coval@osg.samsung.com>
Tue, 18 Apr 2017 11:08:50 +0000 (13:08 +0200)
From:
  https://github.com/dascandy/hippomocks/archive/8e210c5808d490b26fff69151c801fa28d291fcb.zip

It is strongly recommended to rely on scons instead,
 if not possible, this change workaround this.

For more details about building IoTivity please check:

https://wiki.iotivity.org/build

Bug: https://jira.iotivity.org/browse/IOT-820
Bug-Tizen: https://bugs.tizen.org/jira/browse/TINF-861
Change-Id: Ibfddc7be509ec992bfaa7a7bf6759a12b56a9f02
Origin: https://gerrit.iotivity.org/gerrit/#/c/11747/
Signed-off-by: Philippe Coval <philippe.coval@osg.samsung.com>
45 files changed:
extlibs/hippomocks-master/.gitignore [new file with mode: 0644]
extlibs/hippomocks-master/.travis.yml [new file with mode: 0644]
extlibs/hippomocks-master/CMakeLists.txt [new file with mode: 0644]
extlibs/hippomocks-master/HippoMocks/comsupport.h [new file with mode: 0644]
extlibs/hippomocks-master/HippoMocks/hippomocks.h [new file with mode: 0644]
extlibs/hippomocks-master/HippoMocksTest/CMakeLists.txt [new file with mode: 0644]
extlibs/hippomocks-master/HippoMocksTest/Framework.cpp [new file with mode: 0644]
extlibs/hippomocks-master/HippoMocksTest/Framework.h [new file with mode: 0644]
extlibs/hippomocks-master/HippoMocksTest/HippoMocks.dev [new file with mode: 0644]
extlibs/hippomocks-master/HippoMocksTest/HippoMocks.pro [new file with mode: 0644]
extlibs/hippomocks-master/HippoMocksTest/HippoMocksTest.sln [new file with mode: 0644]
extlibs/hippomocks-master/HippoMocksTest/HippoMocksTest.vcproj [new file with mode: 0644]
extlibs/hippomocks-master/HippoMocksTest/HippoMocksTest_2012.sln [new file with mode: 0644]
extlibs/hippomocks-master/HippoMocksTest/HippoMocksTest_2012.vcxproj [new file with mode: 0644]
extlibs/hippomocks-master/HippoMocksTest/is_virtual.cpp [new file with mode: 0644]
extlibs/hippomocks-master/HippoMocksTest/main.cpp [new file with mode: 0644]
extlibs/hippomocks-master/HippoMocksTest/makefile [new file with mode: 0644]
extlibs/hippomocks-master/HippoMocksTest/test.cpp [new file with mode: 0644]
extlibs/hippomocks-master/HippoMocksTest/test_args.cpp [new file with mode: 0644]
extlibs/hippomocks-master/HippoMocksTest/test_array.cpp [new file with mode: 0644]
extlibs/hippomocks-master/HippoMocksTest/test_autoptr.cpp [new file with mode: 0644]
extlibs/hippomocks-master/HippoMocksTest/test_cfuncs.cpp [new file with mode: 0644]
extlibs/hippomocks-master/HippoMocksTest/test_class_args.cpp [new file with mode: 0644]
extlibs/hippomocks-master/HippoMocksTest/test_com_support_stdcall.cpp [new file with mode: 0644]
extlibs/hippomocks-master/HippoMocksTest/test_constref_params.cpp [new file with mode: 0644]
extlibs/hippomocks-master/HippoMocksTest/test_cv_funcs.cpp [new file with mode: 0644]
extlibs/hippomocks-master/HippoMocksTest/test_do.cpp [new file with mode: 0644]
extlibs/hippomocks-master/HippoMocksTest/test_dontcare.cpp [new file with mode: 0644]
extlibs/hippomocks-master/HippoMocksTest/test_except.cpp [new file with mode: 0644]
extlibs/hippomocks-master/HippoMocksTest/test_exception_quality.cpp [new file with mode: 0644]
extlibs/hippomocks-master/HippoMocksTest/test_filter.cpp [new file with mode: 0644]
extlibs/hippomocks-master/HippoMocksTest/test_inparam.cpp [new file with mode: 0644]
extlibs/hippomocks-master/HippoMocksTest/test_membermock.cpp [new file with mode: 0644]
extlibs/hippomocks-master/HippoMocksTest/test_mi.cpp [new file with mode: 0644]
extlibs/hippomocks-master/HippoMocksTest/test_nevercall.cpp [new file with mode: 0644]
extlibs/hippomocks-master/HippoMocksTest/test_optional.cpp [new file with mode: 0644]
extlibs/hippomocks-master/HippoMocksTest/test_outparam.cpp [new file with mode: 0644]
extlibs/hippomocks-master/HippoMocksTest/test_overload.cpp [new file with mode: 0644]
extlibs/hippomocks-master/HippoMocksTest/test_ref_args.cpp [new file with mode: 0644]
extlibs/hippomocks-master/HippoMocksTest/test_regression_arg_count.cpp [new file with mode: 0644]
extlibs/hippomocks-master/HippoMocksTest/test_retval.cpp [new file with mode: 0644]
extlibs/hippomocks-master/HippoMocksTest/test_transaction.cpp [new file with mode: 0644]
extlibs/hippomocks-master/HippoMocksTest/test_zombie.cpp [new file with mode: 0644]
extlibs/hippomocks-master/README.md [new file with mode: 0644]
extlibs/hippomocks-master/makefile [new file with mode: 0644]

diff --git a/extlibs/hippomocks-master/.gitignore b/extlibs/hippomocks-master/.gitignore
new file mode 100644 (file)
index 0000000..5bbaab6
--- /dev/null
@@ -0,0 +1,6 @@
+*.d
+*.o
+*.exe
+
+*.user
+*.bak
diff --git a/extlibs/hippomocks-master/.travis.yml b/extlibs/hippomocks-master/.travis.yml
new file mode 100644 (file)
index 0000000..6084d99
--- /dev/null
@@ -0,0 +1,22 @@
+language: cpp
+compiler:
+- clang
+- gcc
+script:
+- make && make test
+
+env:
+  global:
+   # The next declaration is the encrypted COVERITY_SCAN_TOKEN, created
+   #   via the "travis encrypt" command using the project repo's public key
+   - secure: "Jt0baUgI9mwbUptf+4NpYJREp7s2YfDj+jH7e9ZTAdriuN6h8Qwtd+tHjIusAG5iO4wecHOh8kOxlDvqTAn6YiXnHELhJieNxFIFwUlyfwYpnNMF41JpO5nsvyffu/xSJHw1hUpJ5xJDOKOBAQ1UBR42gM56hJfyjRE8zoKxM0s="
+
+addons:
+  coverity_scan:
+    project:
+      name: "dascandy/hippomocks"
+      description: "HippoMocks, C++98 Mocking Framework"
+    notification_email: dascandy@gmail.com
+    build_command: make && make test
+    branch_pattern: master
+
diff --git a/extlibs/hippomocks-master/CMakeLists.txt b/extlibs/hippomocks-master/CMakeLists.txt
new file mode 100644 (file)
index 0000000..64f40c4
--- /dev/null
@@ -0,0 +1,11 @@
+cmake_minimum_required(VERSION 3.0)
+enable_testing()
+
+if (NOT MSVC)
+  set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wall -Wextra -pedantic -Wno-long-long -std=c++11")
+endif()
+
+add_subdirectory(HippoMocksTest)
+
+install(FILES ${PROJECT_SOURCE_DIR}/HippoMocks/hippomocks.h
+        DESTINATION include/)
diff --git a/extlibs/hippomocks-master/HippoMocks/comsupport.h b/extlibs/hippomocks-master/HippoMocks/comsupport.h
new file mode 100644 (file)
index 0000000..fe2f0f0
--- /dev/null
@@ -0,0 +1,42 @@
+#pragma once
+
+#ifdef _MSC_VER
+#include <hippomocks.h>
+#include <winerror.h>
+
+template <typename T>
+void AddComExpectations(HM_NS MockRepository& mocks, T* m)
+{
+       mocks.OnCall(m, T::AddRef)
+               .Return(1);
+       mocks.OnCall(m, T::Release)
+               .Return(1);
+       mocks.OnCall(m, T::QueryInterface)
+               .With(__uuidof(T), Out((void**)m))
+               .Return(S_OK);
+
+       mocks.OnCall(m, T::QueryInterface)
+               .With(__uuidof(IUnknown), Out((void**)m))
+               .Return(S_OK);
+
+}
+
+template <typename T1, typename T2>
+void ConnectComInterfaces(HM_NS MockRepository& mocks, T1* m1, T2* m2)
+{
+       //from T1 to T2
+       mocks.OnCall(m1, T1::QueryInterface)
+               .With(__uuidof(T2), Out((void**)m2))
+               .Return(S_OK);
+       //from T2 to T1
+       mocks.OnCall(m2, T2::QueryInterface)
+               .With(__uuidof(T1), Out((void**)m1))
+               .Return(S_OK);
+
+       AddComExpectations(mocks, m1);
+       AddComExpectations(mocks, m2);
+
+       //no support for interface hierarchies
+       //no Base IUnknown -> do it yourself if you really need that special case
+}
+#endif
\ No newline at end of file
diff --git a/extlibs/hippomocks-master/HippoMocks/hippomocks.h b/extlibs/hippomocks-master/HippoMocks/hippomocks.h
new file mode 100644 (file)
index 0000000..8b88af3
--- /dev/null
@@ -0,0 +1,6350 @@
+// HippoMocks, a library for using mocks in unit testing of C++ code.
+// Copyright (C) 2008, Bas van Tiel, Christian Rexwinkel, Mike Looijmans,
+// Peter Bindels
+//
+// This library is free software; you can redistribute it and/or
+// modify it under the terms of the GNU Lesser General Public
+// License as published by the Free Software Foundation; either
+// version 2.1 of the License, or (at your option) any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+// Lesser General Public License for more details.
+//
+// You should have received a copy of the GNU Lesser General Public
+// License along with this library; if not, write to the Free Software
+// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA
+//
+// You can also retrieve it from http://www.gnu.org/licenses/lgpl-2.1.html
+
+#ifndef HIPPOMOCKS_H
+#define HIPPOMOCKS_H
+
+// If you want to put all HippoMocks symbols into the global namespace, use the define below.
+//#define NO_HIPPOMOCKS_NAMESPACE
+
+// The DEFAULT_AUTOEXPECT is an option that determines whether tests are, by default, under- or
+// overspecified. Auto-expect, by function, adds an expectation to the current ExpectCall that
+// it will happen after the previous ExpectCall. For many people this is an intuitive and logical
+// thing when writing a C++ program. Usually, this makes your test workable but overspecified.
+// Overspecified means that your test will fail on working code that does things in a different
+// order. The alternative, underspecified, allows code to pass your test that does things in a
+// different order, where that different order should be considered wrong. Consider reading a
+// file, where it needs to be first opened, then read and then closed.
+//
+// The default is to make tests overspecified. At least it prevents faulty code from passing
+// unit tests. To locally disable (or enable) this behaviour, set the boolean autoExpect on your
+// MockRepository to false (or true). To globally override, redefine DEFAULT_AUTOEXPECT to false.
+#ifndef DEFAULT_AUTOEXPECT
+#define DEFAULT_AUTOEXPECT true
+#endif
+
+#ifdef NO_HIPPOMOCKS_NAMESPACE
+#define HM_NS
+#else
+#define HM_NS HippoMocks::
+#endif
+
+#ifdef _MSC_VER
+#ifdef _WIN64
+#define WINCALL
+#else
+#define WINCALL __stdcall
+#endif
+#endif
+#ifndef DEBUGBREAK
+#ifdef _MSC_VER
+extern "C" __declspec(dllimport) int WINCALL IsDebuggerPresent();
+extern "C" __declspec(dllimport) void WINCALL DebugBreak();
+#define DEBUGBREAK(e) if (IsDebuggerPresent()) DebugBreak(); else (void)0
+#else
+#define DEBUGBREAK(e)
+#endif
+#endif
+
+#ifndef DONTCARE_NAME
+#define DONTCARE_NAME _
+#endif
+
+#ifndef VIRT_FUNC_LIMIT
+#define VIRT_FUNC_LIMIT 1024
+#elif VIRT_FUNC_LIMIT > 1024
+#error Adjust the code to support more than 1024 virtual functions before setting the VIRT_FUNC_LIMIT above 1024
+#endif
+
+#ifdef __GNUC__
+#define EXTRA_DESTRUCTOR
+#endif
+
+#ifdef __EDG__
+#define FUNCTION_BASE 3
+#define FUNCTION_STRIDE 2
+#else
+#define FUNCTION_BASE 0
+#define FUNCTION_STRIDE 1
+#endif
+
+#if defined(_M_IX86) || defined(__i386__) || defined(i386) || defined(_X86_) || defined(__THW_INTEL) ||  defined(__x86_64__) || defined(_M_X64)
+#define SOME_X86
+#elif defined(arm) || defined(__arm__) || defined(ARM) || defined(_ARM_) || defined(__aarch64__)
+#define SOME_ARM
+#endif
+
+#if defined(__x86_64__) || defined(_M_X64)
+#define CMOCK_FUNC_PLATFORMIS64BIT
+#endif
+
+#ifdef SOME_X86
+#if defined(_MSC_VER) && (defined(_WIN32) || defined(_WIN64))
+#define _HIPPOMOCKS__ENABLE_CFUNC_MOCKING_SUPPORT
+#elif defined(__linux__) && defined(__GNUC__)
+#define _HIPPOMOCKS__ENABLE_CFUNC_MOCKING_SUPPORT
+#elif defined(__APPLE__)
+#define _HIPPOMOCKS__ENABLE_CFUNC_MOCKING_SUPPORT
+#endif
+#elif defined(SOME_ARM) && defined(__GNUC__)
+#define _HIPPOMOCKS__ENABLE_CFUNC_MOCKING_SUPPORT
+
+// This clear-cache is *required*. The tests will fail if you remove it.
+extern "C" void __clear_cache(char *beg, char *end);
+#endif
+
+#if defined(__GNUC__) && !defined(__EXCEPTIONS)
+#define HM_NO_EXCEPTIONS
+class X{};
+#define BASE_EXCEPTION X
+#else
+#ifndef BASE_EXCEPTION
+#define BASE_EXCEPTION std::exception
+#include <exception>
+#endif
+#endif
+
+#include <cstdio>
+#include <list>
+#include <map>
+#include <memory>
+#include <iostream>
+#include <sstream>
+#include <cstring>
+#include <algorithm>
+#include <limits>
+
+#ifdef _MSC_VER
+// these warnings are pointless and huge, and will confuse new users.
+#pragma warning(push)
+// If you can't generate an assignment operator the least you can do is shut up.
+#pragma warning(disable: 4512)
+// Alignment not right in a union?
+#pragma warning(disable: 4121)
+// No deprecated warnings on functions that really aren't deprecated at all.
+#pragma warning(disable: 4996)
+
+// Tell Microsoft to conform to C++ (as far as is possible...)
+#pragma pointers_to_members(full_generality, virtual_inheritance)
+#endif
+
+#ifndef NO_HIPPOMOCKS_NAMESPACE
+namespace HippoMocks
+{
+#endif
+
+//Type-safe exception wrapping
+class ExceptionHolder
+{
+public:
+       virtual ~ExceptionHolder() {}
+       virtual void rethrow() = 0;
+       template <typename T>
+       static ExceptionHolder *Create(T ex);
+};
+
+template <class T>
+class ExceptionWrapper : public ExceptionHolder {
+       T exception;
+public:
+       ExceptionWrapper(T ex) : exception(ex) {}
+       void rethrow() { throw exception; }
+};
+
+template <typename T>
+ExceptionHolder *ExceptionHolder::Create(T ex)
+{
+       return new ExceptionWrapper<T>(ex);
+}
+
+#ifdef HM_NO_EXCEPTIONS
+#define RAISEEXCEPTION(e)                      { std::string err = e.what(); DEBUGBREAK(e); printf("Mock error found - Fatal due to no exception support:\n"); \
+       printf("%s\n", err.c_str()); \
+       abort(); exit(-1); }
+#define RAISELATENTEXCEPTION(e)        { std::string err = e.what(); DEBUGBREAK(e); printf("Mock error found - Fatal due to no exception support:\n"); \
+       printf("%s\n", err.c_str()); \
+       abort(); exit(-1); }
+#else
+#define RAISEEXCEPTION(e)                      { DEBUGBREAK(e); throw e; }
+#define RAISELATENTEXCEPTION(e)                { DEBUGBREAK(e); if (std::uncaught_exception()) \
+       MockRepoInstanceHolder<0>::instance->SetLatentException(ExceptionHolder::Create(e)); \
+       else throw e; }
+#endif
+
+#ifdef _HIPPOMOCKS__ENABLE_CFUNC_MOCKING_SUPPORT
+#include <memory.h>
+
+#if defined(_WIN32)
+#ifndef NO_HIPPOMOCKS_NAMESPACE
+}
+#endif
+
+// De-windows.h-ified import to avoid including that file.
+#ifdef _WIN64
+extern "C" __declspec(dllimport) int WINCALL VirtualProtect(void *func, unsigned long long byteCount, unsigned long flags, unsigned long *oldFlags);
+#else
+extern "C" __declspec(dllimport) int WINCALL VirtualProtect(void *func, unsigned long byteCount, unsigned long flags, unsigned long *oldFlags);
+#endif
+
+#ifndef PAGE_EXECUTE_READWRITE
+#define PAGE_EXECUTE_READWRITE 0x40
+#endif
+
+#ifndef NO_HIPPOMOCKS_NAMESPACE
+namespace HippoMocks {
+#endif
+
+class Unprotect
+{
+public:
+  Unprotect(void *location, size_t byteCount)
+  : origFunc(location)
+  , byteCount(byteCount)
+  {
+       VirtualProtect(origFunc, byteCount, PAGE_EXECUTE_READWRITE, &oldprotect);
+  }
+  ~Unprotect()
+  {
+       unsigned long dontcare;
+       VirtualProtect(origFunc, byteCount, oldprotect, &dontcare);
+  }
+private:
+  void *origFunc;
+  size_t byteCount;
+  unsigned long oldprotect;
+};
+#else
+#include <sys/mman.h>
+#include <stdint.h>
+
+class Unprotect
+{
+public:
+  Unprotect(void *location, size_t count)
+  : origFunc((intptr_t)location & (~0xFFF))
+  , byteCount(count + ((intptr_t)location - origFunc))
+  {
+       mprotect((void *)origFunc, this->byteCount, PROT_READ|PROT_WRITE|PROT_EXEC);
+  };
+  ~Unprotect()
+  {
+       mprotect((void *)origFunc, byteCount, PROT_READ|PROT_EXEC);
+  }
+private:
+  intptr_t origFunc;
+  int byteCount;
+};
+#endif
+
+typedef unsigned int e9ptrsize_t;
+
+template <typename T, typename U>
+T horrible_cast(U u)
+{
+       union { T t; U u; } un;
+       un.u = u;
+       return un.t;
+}
+
+class Replace
+{
+private:
+  void *origFunc;
+  char backupData[16]; // typical use is 5 for 32-bit and 14 for 64-bit code.
+public:
+  template <typename T>
+  Replace(T funcptr, T replacement)
+         : origFunc(horrible_cast<void *>(funcptr))
+  {
+       Unprotect _allow_write(origFunc, sizeof(backupData));
+       memcpy(backupData, origFunc, sizeof(backupData));
+#ifdef SOME_X86
+#ifdef CMOCK_FUNC_PLATFORMIS64BIT
+       if (llabs((long long)origFunc - (long long)replacement) < 0x80000000LL) {
+#endif
+         *(unsigned char *)origFunc = 0xE9;
+         *(e9ptrsize_t*)(horrible_cast<intptr_t>(origFunc) + 1) = (e9ptrsize_t)(horrible_cast<intptr_t>(replacement) - horrible_cast<intptr_t>(origFunc) - sizeof(e9ptrsize_t) - 1);
+#ifdef CMOCK_FUNC_PLATFORMIS64BIT
+       } else {
+         unsigned char *func = (unsigned char *)origFunc;
+         func[0] = 0xFF; // jmp (rip + imm32)
+         func[1] = 0x25;
+         func[2] = 0x00; // imm32 of 0, so immediately after the instruction
+         func[3] = 0x00;
+         func[4] = 0x00;
+         func[5] = 0x00;
+         *(long long*)(horrible_cast<intptr_t>(origFunc) + 6) = (long long)(horrible_cast<intptr_t>(replacement));
+       }
+#endif
+#elif defined(SOME_ARM)
+       unsigned int *rawptr = (unsigned int *)((intptr_t)(origFunc) & (~3));
+       if ((intptr_t)origFunc & 1) {
+         rawptr[0] = 0x6800A001;
+         rawptr[1] = 0x46874687;
+         rawptr[2] = (intptr_t)replacement;
+       } else {
+         rawptr[0] = 0xE59FF000;
+         rawptr[1] = (intptr_t)replacement;
+         rawptr[2] = (intptr_t)replacement;
+       }
+       __clear_cache((char *)rawptr, (char *)rawptr+16);
+#endif
+  }
+  ~Replace()
+  {
+       Unprotect _allow_write(origFunc, sizeof(backupData));
+       memcpy(origFunc, backupData, sizeof(backupData));
+#ifdef SOME_ARM
+       unsigned int *rawptr = (unsigned int *)((intptr_t)(origFunc) & (~3));
+       __clear_cache((char *)rawptr, (char *)rawptr+16);
+#endif
+  }
+};
+#endif
+
+class MockRepository;
+
+struct
+RegistrationType
+{
+   RegistrationType( unsigned min, unsigned max ) : minimum( min ), maximum( max ) {}
+   unsigned minimum;
+   unsigned maximum;
+};
+
+inline
+bool operator==( RegistrationType const& rhs, RegistrationType const& lhs )
+{
+   return rhs.minimum == lhs.minimum && rhs.maximum == lhs.maximum;
+}
+
+
+const RegistrationType Any = RegistrationType((std::numeric_limits<unsigned>::min)(), (std::numeric_limits<unsigned>::max)());
+const RegistrationType Never = RegistrationType((std::numeric_limits<unsigned>::min)(), (std::numeric_limits<unsigned>::min)());
+const RegistrationType Once = RegistrationType( 1, 1 );
+
+
+
+
+// base type
+class base_mock {
+public:
+       void destroy() { unwriteVft(); delete this; }
+       virtual ~base_mock() {}
+       void *rewriteVft(void *newVf)
+       {
+               void *oldVf = *(void **)this;
+               *(void **)this = newVf;
+               return oldVf;
+       }
+       void reset()
+       {
+               unwriteVft();
+               mock_reset();
+       }
+       virtual void mock_reset() = 0;
+       void unwriteVft()
+       {
+               *(void **)this = (*(void ***)this)[VIRT_FUNC_LIMIT+1];
+       }
+};
+
+template <typename T>
+class ByRef
+{
+public:
+  explicit ByRef(T &argument) : arg(argument) {}
+  void operator()() { arg(); }
+  T &arg;
+};
+
+template <typename T>
+ByRef<T> byRef(T &arg) {
+  return ByRef<T>(arg);
+}
+
+class NullType
+{
+public:
+       bool operator==(const NullType &) const
+       {
+               return true;
+       }
+};
+
+class DontCare {
+private:
+  inline DontCare &Instance();
+};
+static DontCare DONTCARE_NAME;
+inline DontCare &DontCare::Instance()
+{
+  return DONTCARE_NAME;
+}
+
+template <typename T>
+struct OutParam: public DontCare
+{
+       explicit OutParam(T val): value(val) {}
+       T value;
+};
+
+template <typename T>
+OutParam<T> Out(T t) { return OutParam<T>(t); }
+
+template <typename T, bool isPointer>
+struct InParam;
+
+template <typename T>
+struct InParam<T, false>: public DontCare
+{
+       explicit InParam(T& val): value(val)
+       {
+       }
+       T& value;
+};
+
+template <typename T>
+struct InParam<T, true>: public DontCare
+{
+       explicit InParam(T*& val): value(val)
+       {
+       }
+       T*& value;
+};
+
+template <typename T>
+InParam<T, false> In(T& t) { return InParam<T, false>(t); }
+
+template <typename T>
+InParam<T, true> In(T*& t) { return InParam<T, true>(t); }
+
+struct NotPrintable { template <typename T> NotPrintable(T const&) {} };
+
+inline std::ostream &operator<<(std::ostream &os, NotPrintable const&)
+{
+       os << "???";
+       return os;
+}
+
+inline std::ostream &operator<<(std::ostream &os, DontCare const&)
+{
+       os << "_";
+       return os;
+}
+
+template <typename T>
+inline std::ostream &operator<<(std::ostream &os, ByRef<T> &ref) {
+  os << "byRef(" << (T)ref << ")";
+  return os;
+}
+
+template <typename T>
+struct printArg
+{
+       static inline void print(std::ostream &os, T arg, bool withComma)
+       {
+               if (withComma)
+                       os << ",";
+               os << arg;
+       }
+};
+
+template <>
+struct printArg<NullType>
+{
+       static void print(std::ostream &, NullType , bool)
+       {
+       }
+};
+
+class base_tuple
+{
+protected:
+       base_tuple()
+       {
+       }
+public:
+       virtual ~base_tuple()
+       {
+       }
+       virtual void printTo(std::ostream &os) const = 0;
+};
+
+template <typename X>
+struct no_cref { typedef X type; };
+
+template <typename X>
+struct no_cref<const X &> { typedef X type; };
+
+template <typename A> struct with_const { typedef const A type; };
+template <typename A> struct with_const<A &> { typedef const A &type; };
+template <typename A> struct with_const<const A> { typedef const A type; };
+template <typename A> struct with_const<const A &> { typedef const A &type; };
+
+template <typename T> struct base_type { typedef T type; };
+template <typename T> struct base_type<T&> { typedef T type; };
+template <typename T> struct base_type<const T> { typedef T type; };
+template <typename T> struct base_type<const T&> { typedef T type; };
+
+template <typename T>
+struct comparer
+{
+       static inline bool compare(typename with_const<T>::type a, typename with_const<T>::type b)
+       {
+               return a == b;
+       }
+       static inline bool compare(DontCare, typename with_const<T>::type)
+       {
+               return true;
+       }
+  template <typename U>
+  static inline bool compare(const ByRef<U> &a, typename with_const<T>::type b)
+  {
+       return &a.arg == &b;
+  }
+};
+
+template <typename T>
+struct IsOutParamType { enum { value = false }; };
+template <typename T>
+struct IsOutParamType<OutParam<T> > { enum { value = true }; };
+
+template <typename T>
+struct IsInParamType { enum { value = false }; };
+template <typename T>
+struct IsInParamType<InParam<T, true> > { enum { value = true }; };
+template <typename T>
+struct IsInParamType<InParam<T, false> > { enum { value = true }; };
+
+template <typename T1, typename T2, bool Assign>
+struct do_assign;
+
+template <typename T1, typename T2>
+struct do_assign<T1, T2*, true>
+{
+  static void assign_to(T1 outparam, T2 *refparam)
+  {
+       *refparam = outparam.value;
+  }
+  static void assign_from(T1 inparam, T2 *refparam)
+  {
+       inparam.value = refparam;
+  }
+};
+
+template <typename T1, typename T2>
+struct do_assign<T1, T2&, true>
+{
+  static void assign_to(T1 outparam, T2 &refparam)
+  {
+       refparam = outparam.value;
+  }
+  static void assign_from(T1 inparam, T2 &refparam)
+  {
+       inparam.value = refparam;
+  }
+};
+
+template <typename T1, typename T2>
+struct do_assign<T1, T2, false>
+{
+       static void assign_to(T1, T2) {}
+       static void assign_from(T1, T2) {}
+};
+
+template <typename T1, typename T2>
+void out_assign(T1 a, T2 b)
+{
+       do_assign<T1, T2, IsOutParamType<typename base_type<T1>::type>::value >::assign_to(a, b);
+}
+
+template <typename T1, typename T2>
+void in_assign(T1 a, T2 b)
+{
+       do_assign<T1, T2, IsInParamType<typename base_type<T1>::type>::value >::assign_from(a, b);
+}
+
+template <typename A = NullType, typename B = NullType, typename C = NullType, typename D = NullType,
+                 typename E = NullType, typename F = NullType, typename G = NullType, typename H = NullType,
+                 typename I = NullType, typename J = NullType, typename K = NullType, typename L = NullType,
+                 typename M = NullType, typename N = NullType, typename O = NullType, typename P = NullType>
+class ref_tuple : public base_tuple
+{
+public:
+       A a;
+       B b;
+       C c;
+       D d;
+       E e;
+       F f;
+       G g;
+       H h;
+       I i;
+       J j;
+       K k;
+       L l;
+       M m;
+       N n;
+       O o;
+       P p;
+       ref_tuple(A valueA = A(), B valueB = B(), C valueC = C(), D valueD = D(), E valueE = E(), F valueF = F(), G valueG = G(), H valueH = H(), I valueI = I(), J valueJ = J(), K valueK = K(), L valueL = L(), M valueM = M(), N valueN = N(), O valueO = O(), P valueP = P())
+                 : a(valueA), b(valueB), c(valueC), d(valueD), e(valueE), f(valueF), g(valueG), h(valueH), i(valueI), j(valueJ), k(valueK), l(valueL), m(valueM), n(valueN), o(valueO), p(valueP)
+       {}
+       virtual void printTo(std::ostream &os) const
+       {
+         os << "(";
+         printArg<A>::print(os, a, false);
+         printArg<B>::print(os, b, true);
+         printArg<C>::print(os, c, true);
+         printArg<D>::print(os, d, true);
+         printArg<E>::print(os, e, true);
+         printArg<F>::print(os, f, true);
+         printArg<G>::print(os, g, true);
+         printArg<H>::print(os, h, true);
+         printArg<I>::print(os, i, true);
+         printArg<J>::print(os, j, true);
+         printArg<K>::print(os, k, true);
+         printArg<L>::print(os, l, true);
+         printArg<M>::print(os, m, true);
+         printArg<N>::print(os, n, true);
+         printArg<O>::print(os, o, true);
+         printArg<P>::print(os, p, true);
+         os << ")";
+       }
+};
+
+template <typename A = NullType, typename B = NullType, typename C = NullType, typename D = NullType,
+                 typename E = NullType, typename F = NullType, typename G = NullType, typename H = NullType,
+                 typename I = NullType, typename J = NullType, typename K = NullType, typename L = NullType,
+                 typename M = NullType, typename N = NullType, typename O = NullType, typename P = NullType>
+class ref_comparable_assignable_tuple : public base_tuple
+{
+public:
+       virtual bool operator==(const ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P> &bo) = 0;
+       virtual void assign_from(ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P> &from) = 0;
+  virtual void assign_to(ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P> &to) = 0;
+};
+
+template <typename T> struct no_array { typedef T type; };
+template <typename T, int N> struct no_array<T[N]> { typedef T* type; };
+
+template <typename B>
+struct store_as
+{
+       typedef typename no_array<B>::type type;
+};
+
+template <typename B>
+struct store_as<B&>
+{
+  typedef typename no_array<B>::type type;
+};
+
+template <typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H,
+                 typename I, typename J, typename K, typename L, typename M, typename N, typename O, typename P,
+                 typename CA, typename CB, typename CC, typename CD, typename CE, typename CF, typename CG, typename CH,
+                 typename CI, typename CJ, typename CK, typename CL, typename CM, typename CN, typename CO, typename CP>
+class copy_tuple : public ref_comparable_assignable_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P>
+{
+public:
+       typename store_as<CA>::type a;
+       typename store_as<CB>::type b;
+       typename store_as<CC>::type c;
+       typename store_as<CD>::type d;
+       typename store_as<CE>::type e;
+       typename store_as<CF>::type f;
+       typename store_as<CG>::type g;
+       typename store_as<CH>::type h;
+       typename store_as<CI>::type i;
+       typename store_as<CJ>::type j;
+       typename store_as<CK>::type k;
+       typename store_as<CL>::type l;
+       typename store_as<CM>::type m;
+       typename store_as<CN>::type n;
+       typename store_as<CO>::type o;
+       typename store_as<CP>::type p;
+       copy_tuple(typename store_as<CA>::type valueA, typename store_as<CB>::type valueB,
+               typename store_as<CC>::type valueC, typename store_as<CD>::type valueD,
+               typename store_as<CE>::type valueE, typename store_as<CF>::type valueF,
+               typename store_as<CG>::type valueG, typename store_as<CH>::type valueH,
+               typename store_as<CI>::type valueI, typename store_as<CJ>::type valueJ,
+               typename store_as<CK>::type valueK, typename store_as<CL>::type valueL,
+               typename store_as<CM>::type valueM, typename store_as<CN>::type valueN,
+               typename store_as<CO>::type valueO, typename store_as<CP>::type valueP)
+                 : a(valueA), b(valueB), c(valueC), d(valueD), e(valueE), f(valueF), g(valueG), h(valueH), i(valueI), j(valueJ), k(valueK), l(valueL), m(valueM), n(valueN), o(valueO), p(valueP)
+       {}
+       bool operator==(const ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P> &to)
+       {
+               return (comparer<A>::compare(a, to.a) &&
+                               comparer<B>::compare(b, to.b) &&
+                               comparer<C>::compare(c, to.c) &&
+                               comparer<D>::compare(d, to.d) &&
+                               comparer<E>::compare(e, to.e) &&
+                               comparer<F>::compare(f, to.f) &&
+                               comparer<G>::compare(g, to.g) &&
+                               comparer<H>::compare(h, to.h) &&
+                               comparer<I>::compare(i, to.i) &&
+                               comparer<J>::compare(j, to.j) &&
+                               comparer<K>::compare(k, to.k) &&
+                               comparer<L>::compare(l, to.l) &&
+                               comparer<M>::compare(m, to.m) &&
+                               comparer<N>::compare(n, to.n) &&
+                               comparer<O>::compare(o, to.o) &&
+                               comparer<P>::compare(p, to.p));
+       }
+       void assign_from(ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P> &from)
+       {
+               in_assign< typename store_as<CA>::type, A>(a, from.a);
+               in_assign< typename store_as<CB>::type, B>(b, from.b);
+               in_assign< typename store_as<CC>::type, C>(c, from.c);
+               in_assign< typename store_as<CD>::type, D>(d, from.d);
+               in_assign< typename store_as<CE>::type, E>(e, from.e);
+               in_assign< typename store_as<CF>::type, F>(f, from.f);
+               in_assign< typename store_as<CG>::type, G>(g, from.g);
+               in_assign< typename store_as<CH>::type, H>(h, from.h);
+               in_assign< typename store_as<CI>::type, I>(i, from.i);
+               in_assign< typename store_as<CJ>::type, J>(j, from.j);
+               in_assign< typename store_as<CK>::type, K>(k, from.k);
+               in_assign< typename store_as<CL>::type, L>(l, from.l);
+               in_assign< typename store_as<CM>::type, M>(m, from.m);
+               in_assign< typename store_as<CN>::type, N>(n, from.n);
+               in_assign< typename store_as<CO>::type, O>(o, from.o);
+               in_assign< typename store_as<CP>::type, P>(p, from.p);
+       }
+       void assign_to(ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P> &to)
+       {
+               out_assign< typename store_as<CA>::type, A>(a, to.a);
+               out_assign< typename store_as<CB>::type, B>(b, to.b);
+               out_assign< typename store_as<CC>::type, C>(c, to.c);
+               out_assign< typename store_as<CD>::type, D>(d, to.d);
+               out_assign< typename store_as<CE>::type, E>(e, to.e);
+               out_assign< typename store_as<CF>::type, F>(f, to.f);
+               out_assign< typename store_as<CG>::type, G>(g, to.g);
+               out_assign< typename store_as<CH>::type, H>(h, to.h);
+               out_assign< typename store_as<CI>::type, I>(i, to.i);
+               out_assign< typename store_as<CJ>::type, J>(j, to.j);
+               out_assign< typename store_as<CK>::type, K>(k, to.k);
+               out_assign< typename store_as<CL>::type, L>(l, to.l);
+               out_assign< typename store_as<CM>::type, M>(m, to.m);
+               out_assign< typename store_as<CN>::type, N>(n, to.n);
+               out_assign< typename store_as<CO>::type, O>(o, to.o);
+               out_assign< typename store_as<CP>::type, P>(p, to.p);
+       }
+       virtual void printTo(std::ostream &os) const
+       {
+               os << "(";
+               printArg<typename store_as<CA>::type>::print(os, a, false);
+               printArg<typename store_as<CB>::type>::print(os, b, true);
+               printArg<typename store_as<CC>::type>::print(os, c, true);
+               printArg<typename store_as<CD>::type>::print(os, d, true);
+               printArg<typename store_as<CE>::type>::print(os, e, true);
+               printArg<typename store_as<CF>::type>::print(os, f, true);
+               printArg<typename store_as<CG>::type>::print(os, g, true);
+               printArg<typename store_as<CH>::type>::print(os, h, true);
+               printArg<typename store_as<CI>::type>::print(os, i, true);
+               printArg<typename store_as<CJ>::type>::print(os, j, true);
+               printArg<typename store_as<CK>::type>::print(os, k, true);
+               printArg<typename store_as<CL>::type>::print(os, l, true);
+               printArg<typename store_as<CM>::type>::print(os, m, true);
+               printArg<typename store_as<CN>::type>::print(os, n, true);
+               printArg<typename store_as<CO>::type>::print(os, o, true);
+               printArg<typename store_as<CP>::type>::print(os, p, true);
+               os << ")";
+       }
+};
+
+inline std::ostream &operator<<(std::ostream &os, const MockRepository &repo);
+
+class BaseException
+#ifndef HM_NO_EXCEPTIONS
+       : public BASE_EXCEPTION
+#endif
+{
+public:
+       ~BaseException() throw() {}
+       const char *what() const throw() { return txt.c_str(); }
+protected:
+       std::string txt;
+};
+
+// exception types
+class ExpectationException : public BaseException {
+public:
+       ExpectationException(MockRepository *repo, const base_tuple *tuple, const char *funcName)
+       {
+               std::stringstream text;
+               text << "Function ";
+               text << funcName;
+               if (tuple)
+                       tuple->printTo(text);
+               else
+                       text << "(...)";
+               text << " called with mismatching expectation!" << std::endl;
+               text << *repo;
+               txt = text.str();
+       }
+};
+
+#ifdef LINUX_TARGET
+#include <execinfo.h>
+#endif
+
+class NotImplementedException : public BaseException {
+public:
+       NotImplementedException(MockRepository *repo)
+       {
+               std::stringstream text;
+               text << "Function called without expectation!" << std::endl;
+               text << *repo;
+
+#ifdef LINUX_TARGET
+               void* stacktrace[256];
+               size_t size = backtrace( stacktrace, sizeof(stacktrace) );
+               if( size > 0 )
+               {
+                       text << "Stackdump:" << std::endl;
+                       char **symbols = backtrace_symbols( stacktrace, size );
+                       for( size_t i = 0; i < size; i = i + 1 )
+                       {
+                               text << symbols[i] << std::endl;
+                       }
+                       free( symbols );
+               }
+#endif
+
+               txt = text.str();
+       }
+};
+
+class CallMissingException : public BaseException {
+public:
+       CallMissingException(MockRepository *repo)
+       {
+               std::stringstream text;
+               text << "Function with expectation not called!" << std::endl;
+               text << *repo;
+               txt = text.str();
+       }
+};
+
+class ZombieMockException : public BaseException {
+public:
+       ZombieMockException(MockRepository *repo)
+       {
+               std::stringstream text;
+               text << "Function called on mock that has already been destroyed!" << std::endl;
+               text << *repo;
+
+#ifdef LINUX_TARGET
+       void* stacktrace[256];
+       size_t size = backtrace( stacktrace, sizeof(stacktrace) );
+       if( size > 0 )
+       {
+         text << "Stackdump:" << std::endl;
+         char **symbols = backtrace_symbols( stacktrace, size );
+         for( size_t i = 0; i < size; i = i + 1 )
+         {
+               text << symbols[i] << std::endl;
+         }
+         free( symbols );
+       }
+#endif
+
+               txt = text.str();
+       }
+};
+
+class NoResultSetUpException : public BaseException {
+public:
+       NoResultSetUpException(MockRepository *repo, const base_tuple *tuple, const char *funcName)
+       {
+               std::stringstream text;
+               text << "No result set up on call to ";
+               text << funcName;
+               if (tuple)
+                       tuple->printTo(text);
+               else
+                       text << "(...)";
+               text << std::endl;
+               text << *repo;
+
+#ifdef LINUX_TARGET
+       void* stacktrace[256];
+       size_t size = backtrace( stacktrace, sizeof(stacktrace) );
+       if( size > 0 )
+       {
+         text << "Stackdump:" << std::endl;
+         char **symbols = backtrace_symbols( stacktrace, size );
+         for( size_t i = 0; i < size; i = i + 1 )
+         {
+               text << symbols[i] << std::endl;
+         }
+         free( symbols );
+       }
+#endif
+
+               txt = text.str();
+       }
+};
+
+// function-index-of-type
+class func_index {
+public:
+       int lci;
+       virtual int f0(int) { return lci=0; }                   virtual int f1(int) { return lci=1; }                   virtual int f2(int) { return lci=2; }                   virtual int f3(int) { return lci=3; }
+       virtual int f4(int) { return lci=4; }                   virtual int f5(int) { return lci=5; }                   virtual int f6(int) { return lci=6; }                   virtual int f7(int) { return lci=7; }
+       virtual int f8(int) { return lci=8; }                   virtual int f9(int) { return lci=9; }                   virtual int f10(int) { return lci=10; }         virtual int f11(int) { return lci=11; }
+       virtual int f12(int) { return lci=12; }         virtual int f13(int) { return lci=13; }         virtual int f14(int) { return lci=14; }         virtual int f15(int) { return lci=15; }
+       virtual int f16(int) { return lci=16; }         virtual int f17(int) { return lci=17; }         virtual int f18(int) { return lci=18; }         virtual int f19(int) { return lci=19; }
+       virtual int f20(int) { return lci=20; }         virtual int f21(int) { return lci=21; }         virtual int f22(int) { return lci=22; }         virtual int f23(int) { return lci=23; }
+       virtual int f24(int) { return lci=24; }         virtual int f25(int) { return lci=25; }         virtual int f26(int) { return lci=26; }         virtual int f27(int) { return lci=27; }
+       virtual int f28(int) { return lci=28; }         virtual int f29(int) { return lci=29; }         virtual int f30(int) { return lci=30; }         virtual int f31(int) { return lci=31; }
+       virtual int f32(int) { return lci=32; }         virtual int f33(int) { return lci=33; }         virtual int f34(int) { return lci=34; }         virtual int f35(int) { return lci=35; }
+       virtual int f36(int) { return lci=36; }         virtual int f37(int) { return lci=37; }         virtual int f38(int) { return lci=38; }         virtual int f39(int) { return lci=39; }
+       virtual int f40(int) { return lci=40; }         virtual int f41(int) { return lci=41; }         virtual int f42(int) { return lci=42; }         virtual int f43(int) { return lci=43; }
+       virtual int f44(int) { return lci=44; }         virtual int f45(int) { return lci=45; }         virtual int f46(int) { return lci=46; }         virtual int f47(int) { return lci=47; }
+       virtual int f48(int) { return lci=48; }         virtual int f49(int) { return lci=49; }         virtual int f50(int) { return lci=50; }         virtual int f51(int) { return lci=51; }
+       virtual int f52(int) { return lci=52; }         virtual int f53(int) { return lci=53; }         virtual int f54(int) { return lci=54; }         virtual int f55(int) { return lci=55; }
+       virtual int f56(int) { return lci=56; }         virtual int f57(int) { return lci=57; }         virtual int f58(int) { return lci=58; }         virtual int f59(int) { return lci=59; }
+       virtual int f60(int) { return lci=60; }         virtual int f61(int) { return lci=61; }         virtual int f62(int) { return lci=62; }         virtual int f63(int) { return lci=63; }
+       virtual int f64(int) { return lci=64; }         virtual int f65(int) { return lci=65; }         virtual int f66(int) { return lci=66; }         virtual int f67(int) { return lci=67; }
+       virtual int f68(int) { return lci=68; }         virtual int f69(int) { return lci=69; }         virtual int f70(int) { return lci=70; }         virtual int f71(int) { return lci=71; }
+       virtual int f72(int) { return lci=72; }         virtual int f73(int) { return lci=73; }         virtual int f74(int) { return lci=74; }         virtual int f75(int) { return lci=75; }
+       virtual int f76(int) { return lci=76; }         virtual int f77(int) { return lci=77; }         virtual int f78(int) { return lci=78; }         virtual int f79(int) { return lci=79; }
+       virtual int f80(int) { return lci=80; }         virtual int f81(int) { return lci=81; }         virtual int f82(int) { return lci=82; }         virtual int f83(int) { return lci=83; }
+       virtual int f84(int) { return lci=84; }         virtual int f85(int) { return lci=85; }         virtual int f86(int) { return lci=86; }         virtual int f87(int) { return lci=87; }
+       virtual int f88(int) { return lci=88; }         virtual int f89(int) { return lci=89; }         virtual int f90(int) { return lci=90; }         virtual int f91(int) { return lci=91; }
+       virtual int f92(int) { return lci=92; }         virtual int f93(int) { return lci=93; }         virtual int f94(int) { return lci=94; }         virtual int f95(int) { return lci=95; }
+       virtual int f96(int) { return lci=96; }         virtual int f97(int) { return lci=97; }         virtual int f98(int) { return lci=98; }         virtual int f99(int) { return lci=99; }
+       virtual int f100(int) { return lci=100; }               virtual int f101(int) { return lci=101; }               virtual int f102(int) { return lci=102; }               virtual int f103(int) { return lci=103; }
+       virtual int f104(int) { return lci=104; }               virtual int f105(int) { return lci=105; }               virtual int f106(int) { return lci=106; }               virtual int f107(int) { return lci=107; }
+       virtual int f108(int) { return lci=108; }               virtual int f109(int) { return lci=109; }               virtual int f110(int) { return lci=110; }               virtual int f111(int) { return lci=111; }
+       virtual int f112(int) { return lci=112; }               virtual int f113(int) { return lci=113; }               virtual int f114(int) { return lci=114; }               virtual int f115(int) { return lci=115; }
+       virtual int f116(int) { return lci=116; }               virtual int f117(int) { return lci=117; }               virtual int f118(int) { return lci=118; }               virtual int f119(int) { return lci=119; }
+       virtual int f120(int) { return lci=120; }               virtual int f121(int) { return lci=121; }               virtual int f122(int) { return lci=122; }               virtual int f123(int) { return lci=123; }
+       virtual int f124(int) { return lci=124; }               virtual int f125(int) { return lci=125; }               virtual int f126(int) { return lci=126; }               virtual int f127(int) { return lci=127; }
+       virtual int f128(int) { return lci=128; }               virtual int f129(int) { return lci=129; }               virtual int f130(int) { return lci=130; }               virtual int f131(int) { return lci=131; }
+       virtual int f132(int) { return lci=132; }               virtual int f133(int) { return lci=133; }               virtual int f134(int) { return lci=134; }               virtual int f135(int) { return lci=135; }
+       virtual int f136(int) { return lci=136; }               virtual int f137(int) { return lci=137; }               virtual int f138(int) { return lci=138; }               virtual int f139(int) { return lci=139; }
+       virtual int f140(int) { return lci=140; }               virtual int f141(int) { return lci=141; }               virtual int f142(int) { return lci=142; }               virtual int f143(int) { return lci=143; }
+       virtual int f144(int) { return lci=144; }               virtual int f145(int) { return lci=145; }               virtual int f146(int) { return lci=146; }               virtual int f147(int) { return lci=147; }
+       virtual int f148(int) { return lci=148; }               virtual int f149(int) { return lci=149; }               virtual int f150(int) { return lci=150; }               virtual int f151(int) { return lci=151; }
+       virtual int f152(int) { return lci=152; }               virtual int f153(int) { return lci=153; }               virtual int f154(int) { return lci=154; }               virtual int f155(int) { return lci=155; }
+       virtual int f156(int) { return lci=156; }               virtual int f157(int) { return lci=157; }               virtual int f158(int) { return lci=158; }               virtual int f159(int) { return lci=159; }
+       virtual int f160(int) { return lci=160; }               virtual int f161(int) { return lci=161; }               virtual int f162(int) { return lci=162; }               virtual int f163(int) { return lci=163; }
+       virtual int f164(int) { return lci=164; }               virtual int f165(int) { return lci=165; }               virtual int f166(int) { return lci=166; }               virtual int f167(int) { return lci=167; }
+       virtual int f168(int) { return lci=168; }               virtual int f169(int) { return lci=169; }               virtual int f170(int) { return lci=170; }               virtual int f171(int) { return lci=171; }
+       virtual int f172(int) { return lci=172; }               virtual int f173(int) { return lci=173; }               virtual int f174(int) { return lci=174; }               virtual int f175(int) { return lci=175; }
+       virtual int f176(int) { return lci=176; }               virtual int f177(int) { return lci=177; }               virtual int f178(int) { return lci=178; }               virtual int f179(int) { return lci=179; }
+       virtual int f180(int) { return lci=180; }               virtual int f181(int) { return lci=181; }               virtual int f182(int) { return lci=182; }               virtual int f183(int) { return lci=183; }
+       virtual int f184(int) { return lci=184; }               virtual int f185(int) { return lci=185; }               virtual int f186(int) { return lci=186; }               virtual int f187(int) { return lci=187; }
+       virtual int f188(int) { return lci=188; }               virtual int f189(int) { return lci=189; }               virtual int f190(int) { return lci=190; }               virtual int f191(int) { return lci=191; }
+       virtual int f192(int) { return lci=192; }               virtual int f193(int) { return lci=193; }               virtual int f194(int) { return lci=194; }               virtual int f195(int) { return lci=195; }
+       virtual int f196(int) { return lci=196; }               virtual int f197(int) { return lci=197; }               virtual int f198(int) { return lci=198; }               virtual int f199(int) { return lci=199; }
+       virtual int f200(int) { return lci=200; }               virtual int f201(int) { return lci=201; }               virtual int f202(int) { return lci=202; }               virtual int f203(int) { return lci=203; }
+       virtual int f204(int) { return lci=204; }               virtual int f205(int) { return lci=205; }               virtual int f206(int) { return lci=206; }               virtual int f207(int) { return lci=207; }
+       virtual int f208(int) { return lci=208; }               virtual int f209(int) { return lci=209; }               virtual int f210(int) { return lci=210; }               virtual int f211(int) { return lci=211; }
+       virtual int f212(int) { return lci=212; }               virtual int f213(int) { return lci=213; }               virtual int f214(int) { return lci=214; }               virtual int f215(int) { return lci=215; }
+       virtual int f216(int) { return lci=216; }               virtual int f217(int) { return lci=217; }               virtual int f218(int) { return lci=218; }               virtual int f219(int) { return lci=219; }
+       virtual int f220(int) { return lci=220; }               virtual int f221(int) { return lci=221; }               virtual int f222(int) { return lci=222; }               virtual int f223(int) { return lci=223; }
+       virtual int f224(int) { return lci=224; }               virtual int f225(int) { return lci=225; }               virtual int f226(int) { return lci=226; }               virtual int f227(int) { return lci=227; }
+       virtual int f228(int) { return lci=228; }               virtual int f229(int) { return lci=229; }               virtual int f230(int) { return lci=230; }               virtual int f231(int) { return lci=231; }
+       virtual int f232(int) { return lci=232; }               virtual int f233(int) { return lci=233; }               virtual int f234(int) { return lci=234; }               virtual int f235(int) { return lci=235; }
+       virtual int f236(int) { return lci=236; }               virtual int f237(int) { return lci=237; }               virtual int f238(int) { return lci=238; }               virtual int f239(int) { return lci=239; }
+       virtual int f240(int) { return lci=240; }               virtual int f241(int) { return lci=241; }               virtual int f242(int) { return lci=242; }               virtual int f243(int) { return lci=243; }
+       virtual int f244(int) { return lci=244; }               virtual int f245(int) { return lci=245; }               virtual int f246(int) { return lci=246; }               virtual int f247(int) { return lci=247; }
+       virtual int f248(int) { return lci=248; }               virtual int f249(int) { return lci=249; }               virtual int f250(int) { return lci=250; }               virtual int f251(int) { return lci=251; }
+       virtual int f252(int) { return lci=252; }               virtual int f253(int) { return lci=253; }               virtual int f254(int) { return lci=254; }               virtual int f255(int) { return lci=255; }
+       virtual int f256(int) { return lci=256; }               virtual int f257(int) { return lci=257; }               virtual int f258(int) { return lci=258; }               virtual int f259(int) { return lci=259; }
+       virtual int f260(int) { return lci=260; }               virtual int f261(int) { return lci=261; }               virtual int f262(int) { return lci=262; }               virtual int f263(int) { return lci=263; }
+       virtual int f264(int) { return lci=264; }               virtual int f265(int) { return lci=265; }               virtual int f266(int) { return lci=266; }               virtual int f267(int) { return lci=267; }
+       virtual int f268(int) { return lci=268; }               virtual int f269(int) { return lci=269; }               virtual int f270(int) { return lci=270; }               virtual int f271(int) { return lci=271; }
+       virtual int f272(int) { return lci=272; }               virtual int f273(int) { return lci=273; }               virtual int f274(int) { return lci=274; }               virtual int f275(int) { return lci=275; }
+       virtual int f276(int) { return lci=276; }               virtual int f277(int) { return lci=277; }               virtual int f278(int) { return lci=278; }               virtual int f279(int) { return lci=279; }
+       virtual int f280(int) { return lci=280; }               virtual int f281(int) { return lci=281; }               virtual int f282(int) { return lci=282; }               virtual int f283(int) { return lci=283; }
+       virtual int f284(int) { return lci=284; }               virtual int f285(int) { return lci=285; }               virtual int f286(int) { return lci=286; }               virtual int f287(int) { return lci=287; }
+       virtual int f288(int) { return lci=288; }               virtual int f289(int) { return lci=289; }               virtual int f290(int) { return lci=290; }               virtual int f291(int) { return lci=291; }
+       virtual int f292(int) { return lci=292; }               virtual int f293(int) { return lci=293; }               virtual int f294(int) { return lci=294; }               virtual int f295(int) { return lci=295; }
+       virtual int f296(int) { return lci=296; }               virtual int f297(int) { return lci=297; }               virtual int f298(int) { return lci=298; }               virtual int f299(int) { return lci=299; }
+       virtual int f300(int) { return lci=300; }               virtual int f301(int) { return lci=301; }               virtual int f302(int) { return lci=302; }               virtual int f303(int) { return lci=303; }
+       virtual int f304(int) { return lci=304; }               virtual int f305(int) { return lci=305; }               virtual int f306(int) { return lci=306; }               virtual int f307(int) { return lci=307; }
+       virtual int f308(int) { return lci=308; }               virtual int f309(int) { return lci=309; }               virtual int f310(int) { return lci=310; }               virtual int f311(int) { return lci=311; }
+       virtual int f312(int) { return lci=312; }               virtual int f313(int) { return lci=313; }               virtual int f314(int) { return lci=314; }               virtual int f315(int) { return lci=315; }
+       virtual int f316(int) { return lci=316; }               virtual int f317(int) { return lci=317; }               virtual int f318(int) { return lci=318; }               virtual int f319(int) { return lci=319; }
+       virtual int f320(int) { return lci=320; }               virtual int f321(int) { return lci=321; }               virtual int f322(int) { return lci=322; }               virtual int f323(int) { return lci=323; }
+       virtual int f324(int) { return lci=324; }               virtual int f325(int) { return lci=325; }               virtual int f326(int) { return lci=326; }               virtual int f327(int) { return lci=327; }
+       virtual int f328(int) { return lci=328; }               virtual int f329(int) { return lci=329; }               virtual int f330(int) { return lci=330; }               virtual int f331(int) { return lci=331; }
+       virtual int f332(int) { return lci=332; }               virtual int f333(int) { return lci=333; }               virtual int f334(int) { return lci=334; }               virtual int f335(int) { return lci=335; }
+       virtual int f336(int) { return lci=336; }               virtual int f337(int) { return lci=337; }               virtual int f338(int) { return lci=338; }               virtual int f339(int) { return lci=339; }
+       virtual int f340(int) { return lci=340; }               virtual int f341(int) { return lci=341; }               virtual int f342(int) { return lci=342; }               virtual int f343(int) { return lci=343; }
+       virtual int f344(int) { return lci=344; }               virtual int f345(int) { return lci=345; }               virtual int f346(int) { return lci=346; }               virtual int f347(int) { return lci=347; }
+       virtual int f348(int) { return lci=348; }               virtual int f349(int) { return lci=349; }               virtual int f350(int) { return lci=350; }               virtual int f351(int) { return lci=351; }
+       virtual int f352(int) { return lci=352; }               virtual int f353(int) { return lci=353; }               virtual int f354(int) { return lci=354; }               virtual int f355(int) { return lci=355; }
+       virtual int f356(int) { return lci=356; }               virtual int f357(int) { return lci=357; }               virtual int f358(int) { return lci=358; }               virtual int f359(int) { return lci=359; }
+       virtual int f360(int) { return lci=360; }               virtual int f361(int) { return lci=361; }               virtual int f362(int) { return lci=362; }               virtual int f363(int) { return lci=363; }
+       virtual int f364(int) { return lci=364; }               virtual int f365(int) { return lci=365; }               virtual int f366(int) { return lci=366; }               virtual int f367(int) { return lci=367; }
+       virtual int f368(int) { return lci=368; }               virtual int f369(int) { return lci=369; }               virtual int f370(int) { return lci=370; }               virtual int f371(int) { return lci=371; }
+       virtual int f372(int) { return lci=372; }               virtual int f373(int) { return lci=373; }               virtual int f374(int) { return lci=374; }               virtual int f375(int) { return lci=375; }
+       virtual int f376(int) { return lci=376; }               virtual int f377(int) { return lci=377; }               virtual int f378(int) { return lci=378; }               virtual int f379(int) { return lci=379; }
+       virtual int f380(int) { return lci=380; }               virtual int f381(int) { return lci=381; }               virtual int f382(int) { return lci=382; }               virtual int f383(int) { return lci=383; }
+       virtual int f384(int) { return lci=384; }               virtual int f385(int) { return lci=385; }               virtual int f386(int) { return lci=386; }               virtual int f387(int) { return lci=387; }
+       virtual int f388(int) { return lci=388; }               virtual int f389(int) { return lci=389; }               virtual int f390(int) { return lci=390; }               virtual int f391(int) { return lci=391; }
+       virtual int f392(int) { return lci=392; }               virtual int f393(int) { return lci=393; }               virtual int f394(int) { return lci=394; }               virtual int f395(int) { return lci=395; }
+       virtual int f396(int) { return lci=396; }               virtual int f397(int) { return lci=397; }               virtual int f398(int) { return lci=398; }               virtual int f399(int) { return lci=399; }
+       virtual int f400(int) { return lci=400; }               virtual int f401(int) { return lci=401; }               virtual int f402(int) { return lci=402; }               virtual int f403(int) { return lci=403; }
+       virtual int f404(int) { return lci=404; }               virtual int f405(int) { return lci=405; }               virtual int f406(int) { return lci=406; }               virtual int f407(int) { return lci=407; }
+       virtual int f408(int) { return lci=408; }               virtual int f409(int) { return lci=409; }               virtual int f410(int) { return lci=410; }               virtual int f411(int) { return lci=411; }
+       virtual int f412(int) { return lci=412; }               virtual int f413(int) { return lci=413; }               virtual int f414(int) { return lci=414; }               virtual int f415(int) { return lci=415; }
+       virtual int f416(int) { return lci=416; }               virtual int f417(int) { return lci=417; }               virtual int f418(int) { return lci=418; }               virtual int f419(int) { return lci=419; }
+       virtual int f420(int) { return lci=420; }               virtual int f421(int) { return lci=421; }               virtual int f422(int) { return lci=422; }               virtual int f423(int) { return lci=423; }
+       virtual int f424(int) { return lci=424; }               virtual int f425(int) { return lci=425; }               virtual int f426(int) { return lci=426; }               virtual int f427(int) { return lci=427; }
+       virtual int f428(int) { return lci=428; }               virtual int f429(int) { return lci=429; }               virtual int f430(int) { return lci=430; }               virtual int f431(int) { return lci=431; }
+       virtual int f432(int) { return lci=432; }               virtual int f433(int) { return lci=433; }               virtual int f434(int) { return lci=434; }               virtual int f435(int) { return lci=435; }
+       virtual int f436(int) { return lci=436; }               virtual int f437(int) { return lci=437; }               virtual int f438(int) { return lci=438; }               virtual int f439(int) { return lci=439; }
+       virtual int f440(int) { return lci=440; }               virtual int f441(int) { return lci=441; }               virtual int f442(int) { return lci=442; }               virtual int f443(int) { return lci=443; }
+       virtual int f444(int) { return lci=444; }               virtual int f445(int) { return lci=445; }               virtual int f446(int) { return lci=446; }               virtual int f447(int) { return lci=447; }
+       virtual int f448(int) { return lci=448; }               virtual int f449(int) { return lci=449; }               virtual int f450(int) { return lci=450; }               virtual int f451(int) { return lci=451; }
+       virtual int f452(int) { return lci=452; }               virtual int f453(int) { return lci=453; }               virtual int f454(int) { return lci=454; }               virtual int f455(int) { return lci=455; }
+       virtual int f456(int) { return lci=456; }               virtual int f457(int) { return lci=457; }               virtual int f458(int) { return lci=458; }               virtual int f459(int) { return lci=459; }
+       virtual int f460(int) { return lci=460; }               virtual int f461(int) { return lci=461; }               virtual int f462(int) { return lci=462; }               virtual int f463(int) { return lci=463; }
+       virtual int f464(int) { return lci=464; }               virtual int f465(int) { return lci=465; }               virtual int f466(int) { return lci=466; }               virtual int f467(int) { return lci=467; }
+       virtual int f468(int) { return lci=468; }               virtual int f469(int) { return lci=469; }               virtual int f470(int) { return lci=470; }               virtual int f471(int) { return lci=471; }
+       virtual int f472(int) { return lci=472; }               virtual int f473(int) { return lci=473; }               virtual int f474(int) { return lci=474; }               virtual int f475(int) { return lci=475; }
+       virtual int f476(int) { return lci=476; }               virtual int f477(int) { return lci=477; }               virtual int f478(int) { return lci=478; }               virtual int f479(int) { return lci=479; }
+       virtual int f480(int) { return lci=480; }               virtual int f481(int) { return lci=481; }               virtual int f482(int) { return lci=482; }               virtual int f483(int) { return lci=483; }
+       virtual int f484(int) { return lci=484; }               virtual int f485(int) { return lci=485; }               virtual int f486(int) { return lci=486; }               virtual int f487(int) { return lci=487; }
+       virtual int f488(int) { return lci=488; }               virtual int f489(int) { return lci=489; }               virtual int f490(int) { return lci=490; }               virtual int f491(int) { return lci=491; }
+       virtual int f492(int) { return lci=492; }               virtual int f493(int) { return lci=493; }               virtual int f494(int) { return lci=494; }               virtual int f495(int) { return lci=495; }
+       virtual int f496(int) { return lci=496; }               virtual int f497(int) { return lci=497; }               virtual int f498(int) { return lci=498; }               virtual int f499(int) { return lci=499; }
+       virtual int f500(int) { return lci=500; }               virtual int f501(int) { return lci=501; }               virtual int f502(int) { return lci=502; }               virtual int f503(int) { return lci=503; }
+       virtual int f504(int) { return lci=504; }               virtual int f505(int) { return lci=505; }               virtual int f506(int) { return lci=506; }               virtual int f507(int) { return lci=507; }
+       virtual int f508(int) { return lci=508; }               virtual int f509(int) { return lci=509; }               virtual int f510(int) { return lci=510; }               virtual int f511(int) { return lci=511; }
+       virtual int f512(int) { return lci=512; }               virtual int f513(int) { return lci=513; }               virtual int f514(int) { return lci=514; }               virtual int f515(int) { return lci=515; }
+       virtual int f516(int) { return lci=516; }               virtual int f517(int) { return lci=517; }               virtual int f518(int) { return lci=518; }               virtual int f519(int) { return lci=519; }
+       virtual int f520(int) { return lci=520; }               virtual int f521(int) { return lci=521; }               virtual int f522(int) { return lci=522; }               virtual int f523(int) { return lci=523; }
+       virtual int f524(int) { return lci=524; }               virtual int f525(int) { return lci=525; }               virtual int f526(int) { return lci=526; }               virtual int f527(int) { return lci=527; }
+       virtual int f528(int) { return lci=528; }               virtual int f529(int) { return lci=529; }               virtual int f530(int) { return lci=530; }               virtual int f531(int) { return lci=531; }
+       virtual int f532(int) { return lci=532; }               virtual int f533(int) { return lci=533; }               virtual int f534(int) { return lci=534; }               virtual int f535(int) { return lci=535; }
+       virtual int f536(int) { return lci=536; }               virtual int f537(int) { return lci=537; }               virtual int f538(int) { return lci=538; }               virtual int f539(int) { return lci=539; }
+       virtual int f540(int) { return lci=540; }               virtual int f541(int) { return lci=541; }               virtual int f542(int) { return lci=542; }               virtual int f543(int) { return lci=543; }
+       virtual int f544(int) { return lci=544; }               virtual int f545(int) { return lci=545; }               virtual int f546(int) { return lci=546; }               virtual int f547(int) { return lci=547; }
+       virtual int f548(int) { return lci=548; }               virtual int f549(int) { return lci=549; }               virtual int f550(int) { return lci=550; }               virtual int f551(int) { return lci=551; }
+       virtual int f552(int) { return lci=552; }               virtual int f553(int) { return lci=553; }               virtual int f554(int) { return lci=554; }               virtual int f555(int) { return lci=555; }
+       virtual int f556(int) { return lci=556; }               virtual int f557(int) { return lci=557; }               virtual int f558(int) { return lci=558; }               virtual int f559(int) { return lci=559; }
+       virtual int f560(int) { return lci=560; }               virtual int f561(int) { return lci=561; }               virtual int f562(int) { return lci=562; }               virtual int f563(int) { return lci=563; }
+       virtual int f564(int) { return lci=564; }               virtual int f565(int) { return lci=565; }               virtual int f566(int) { return lci=566; }               virtual int f567(int) { return lci=567; }
+       virtual int f568(int) { return lci=568; }               virtual int f569(int) { return lci=569; }               virtual int f570(int) { return lci=570; }               virtual int f571(int) { return lci=571; }
+       virtual int f572(int) { return lci=572; }               virtual int f573(int) { return lci=573; }               virtual int f574(int) { return lci=574; }               virtual int f575(int) { return lci=575; }
+       virtual int f576(int) { return lci=576; }               virtual int f577(int) { return lci=577; }               virtual int f578(int) { return lci=578; }               virtual int f579(int) { return lci=579; }
+       virtual int f580(int) { return lci=580; }               virtual int f581(int) { return lci=581; }               virtual int f582(int) { return lci=582; }               virtual int f583(int) { return lci=583; }
+       virtual int f584(int) { return lci=584; }               virtual int f585(int) { return lci=585; }               virtual int f586(int) { return lci=586; }               virtual int f587(int) { return lci=587; }
+       virtual int f588(int) { return lci=588; }               virtual int f589(int) { return lci=589; }               virtual int f590(int) { return lci=590; }               virtual int f591(int) { return lci=591; }
+       virtual int f592(int) { return lci=592; }               virtual int f593(int) { return lci=593; }               virtual int f594(int) { return lci=594; }               virtual int f595(int) { return lci=595; }
+       virtual int f596(int) { return lci=596; }               virtual int f597(int) { return lci=597; }               virtual int f598(int) { return lci=598; }               virtual int f599(int) { return lci=599; }
+       virtual int f600(int) { return lci=600; }               virtual int f601(int) { return lci=601; }               virtual int f602(int) { return lci=602; }               virtual int f603(int) { return lci=603; }
+       virtual int f604(int) { return lci=604; }               virtual int f605(int) { return lci=605; }               virtual int f606(int) { return lci=606; }               virtual int f607(int) { return lci=607; }
+       virtual int f608(int) { return lci=608; }               virtual int f609(int) { return lci=609; }               virtual int f610(int) { return lci=610; }               virtual int f611(int) { return lci=611; }
+       virtual int f612(int) { return lci=612; }               virtual int f613(int) { return lci=613; }               virtual int f614(int) { return lci=614; }               virtual int f615(int) { return lci=615; }
+       virtual int f616(int) { return lci=616; }               virtual int f617(int) { return lci=617; }               virtual int f618(int) { return lci=618; }               virtual int f619(int) { return lci=619; }
+       virtual int f620(int) { return lci=620; }               virtual int f621(int) { return lci=621; }               virtual int f622(int) { return lci=622; }               virtual int f623(int) { return lci=623; }
+       virtual int f624(int) { return lci=624; }               virtual int f625(int) { return lci=625; }               virtual int f626(int) { return lci=626; }               virtual int f627(int) { return lci=627; }
+       virtual int f628(int) { return lci=628; }               virtual int f629(int) { return lci=629; }               virtual int f630(int) { return lci=630; }               virtual int f631(int) { return lci=631; }
+       virtual int f632(int) { return lci=632; }               virtual int f633(int) { return lci=633; }               virtual int f634(int) { return lci=634; }               virtual int f635(int) { return lci=635; }
+       virtual int f636(int) { return lci=636; }               virtual int f637(int) { return lci=637; }               virtual int f638(int) { return lci=638; }               virtual int f639(int) { return lci=639; }
+       virtual int f640(int) { return lci=640; }               virtual int f641(int) { return lci=641; }               virtual int f642(int) { return lci=642; }               virtual int f643(int) { return lci=643; }
+       virtual int f644(int) { return lci=644; }               virtual int f645(int) { return lci=645; }               virtual int f646(int) { return lci=646; }               virtual int f647(int) { return lci=647; }
+       virtual int f648(int) { return lci=648; }               virtual int f649(int) { return lci=649; }               virtual int f650(int) { return lci=650; }               virtual int f651(int) { return lci=651; }
+       virtual int f652(int) { return lci=652; }               virtual int f653(int) { return lci=653; }               virtual int f654(int) { return lci=654; }               virtual int f655(int) { return lci=655; }
+       virtual int f656(int) { return lci=656; }               virtual int f657(int) { return lci=657; }               virtual int f658(int) { return lci=658; }               virtual int f659(int) { return lci=659; }
+       virtual int f660(int) { return lci=660; }               virtual int f661(int) { return lci=661; }               virtual int f662(int) { return lci=662; }               virtual int f663(int) { return lci=663; }
+       virtual int f664(int) { return lci=664; }               virtual int f665(int) { return lci=665; }               virtual int f666(int) { return lci=666; }               virtual int f667(int) { return lci=667; }
+       virtual int f668(int) { return lci=668; }               virtual int f669(int) { return lci=669; }               virtual int f670(int) { return lci=670; }               virtual int f671(int) { return lci=671; }
+       virtual int f672(int) { return lci=672; }               virtual int f673(int) { return lci=673; }               virtual int f674(int) { return lci=674; }               virtual int f675(int) { return lci=675; }
+       virtual int f676(int) { return lci=676; }               virtual int f677(int) { return lci=677; }               virtual int f678(int) { return lci=678; }               virtual int f679(int) { return lci=679; }
+       virtual int f680(int) { return lci=680; }               virtual int f681(int) { return lci=681; }               virtual int f682(int) { return lci=682; }               virtual int f683(int) { return lci=683; }
+       virtual int f684(int) { return lci=684; }               virtual int f685(int) { return lci=685; }               virtual int f686(int) { return lci=686; }               virtual int f687(int) { return lci=687; }
+       virtual int f688(int) { return lci=688; }               virtual int f689(int) { return lci=689; }               virtual int f690(int) { return lci=690; }               virtual int f691(int) { return lci=691; }
+       virtual int f692(int) { return lci=692; }               virtual int f693(int) { return lci=693; }               virtual int f694(int) { return lci=694; }               virtual int f695(int) { return lci=695; }
+       virtual int f696(int) { return lci=696; }               virtual int f697(int) { return lci=697; }               virtual int f698(int) { return lci=698; }               virtual int f699(int) { return lci=699; }
+       virtual int f700(int) { return lci=700; }               virtual int f701(int) { return lci=701; }               virtual int f702(int) { return lci=702; }               virtual int f703(int) { return lci=703; }
+       virtual int f704(int) { return lci=704; }               virtual int f705(int) { return lci=705; }               virtual int f706(int) { return lci=706; }               virtual int f707(int) { return lci=707; }
+       virtual int f708(int) { return lci=708; }               virtual int f709(int) { return lci=709; }               virtual int f710(int) { return lci=710; }               virtual int f711(int) { return lci=711; }
+       virtual int f712(int) { return lci=712; }               virtual int f713(int) { return lci=713; }               virtual int f714(int) { return lci=714; }               virtual int f715(int) { return lci=715; }
+       virtual int f716(int) { return lci=716; }               virtual int f717(int) { return lci=717; }               virtual int f718(int) { return lci=718; }               virtual int f719(int) { return lci=719; }
+       virtual int f720(int) { return lci=720; }               virtual int f721(int) { return lci=721; }               virtual int f722(int) { return lci=722; }               virtual int f723(int) { return lci=723; }
+       virtual int f724(int) { return lci=724; }               virtual int f725(int) { return lci=725; }               virtual int f726(int) { return lci=726; }               virtual int f727(int) { return lci=727; }
+       virtual int f728(int) { return lci=728; }               virtual int f729(int) { return lci=729; }               virtual int f730(int) { return lci=730; }               virtual int f731(int) { return lci=731; }
+       virtual int f732(int) { return lci=732; }               virtual int f733(int) { return lci=733; }               virtual int f734(int) { return lci=734; }               virtual int f735(int) { return lci=735; }
+       virtual int f736(int) { return lci=736; }               virtual int f737(int) { return lci=737; }               virtual int f738(int) { return lci=738; }               virtual int f739(int) { return lci=739; }
+       virtual int f740(int) { return lci=740; }               virtual int f741(int) { return lci=741; }               virtual int f742(int) { return lci=742; }               virtual int f743(int) { return lci=743; }
+       virtual int f744(int) { return lci=744; }               virtual int f745(int) { return lci=745; }               virtual int f746(int) { return lci=746; }               virtual int f747(int) { return lci=747; }
+       virtual int f748(int) { return lci=748; }               virtual int f749(int) { return lci=749; }               virtual int f750(int) { return lci=750; }               virtual int f751(int) { return lci=751; }
+       virtual int f752(int) { return lci=752; }               virtual int f753(int) { return lci=753; }               virtual int f754(int) { return lci=754; }               virtual int f755(int) { return lci=755; }
+       virtual int f756(int) { return lci=756; }               virtual int f757(int) { return lci=757; }               virtual int f758(int) { return lci=758; }               virtual int f759(int) { return lci=759; }
+       virtual int f760(int) { return lci=760; }               virtual int f761(int) { return lci=761; }               virtual int f762(int) { return lci=762; }               virtual int f763(int) { return lci=763; }
+       virtual int f764(int) { return lci=764; }               virtual int f765(int) { return lci=765; }               virtual int f766(int) { return lci=766; }               virtual int f767(int) { return lci=767; }
+       virtual int f768(int) { return lci=768; }               virtual int f769(int) { return lci=769; }               virtual int f770(int) { return lci=770; }               virtual int f771(int) { return lci=771; }
+       virtual int f772(int) { return lci=772; }               virtual int f773(int) { return lci=773; }               virtual int f774(int) { return lci=774; }               virtual int f775(int) { return lci=775; }
+       virtual int f776(int) { return lci=776; }               virtual int f777(int) { return lci=777; }               virtual int f778(int) { return lci=778; }               virtual int f779(int) { return lci=779; }
+       virtual int f780(int) { return lci=780; }               virtual int f781(int) { return lci=781; }               virtual int f782(int) { return lci=782; }               virtual int f783(int) { return lci=783; }
+       virtual int f784(int) { return lci=784; }               virtual int f785(int) { return lci=785; }               virtual int f786(int) { return lci=786; }               virtual int f787(int) { return lci=787; }
+       virtual int f788(int) { return lci=788; }               virtual int f789(int) { return lci=789; }               virtual int f790(int) { return lci=790; }               virtual int f791(int) { return lci=791; }
+       virtual int f792(int) { return lci=792; }               virtual int f793(int) { return lci=793; }               virtual int f794(int) { return lci=794; }               virtual int f795(int) { return lci=795; }
+       virtual int f796(int) { return lci=796; }               virtual int f797(int) { return lci=797; }               virtual int f798(int) { return lci=798; }               virtual int f799(int) { return lci=799; }
+       virtual int f800(int) { return lci=800; }               virtual int f801(int) { return lci=801; }               virtual int f802(int) { return lci=802; }               virtual int f803(int) { return lci=803; }
+       virtual int f804(int) { return lci=804; }               virtual int f805(int) { return lci=805; }               virtual int f806(int) { return lci=806; }               virtual int f807(int) { return lci=807; }
+       virtual int f808(int) { return lci=808; }               virtual int f809(int) { return lci=809; }               virtual int f810(int) { return lci=810; }               virtual int f811(int) { return lci=811; }
+       virtual int f812(int) { return lci=812; }               virtual int f813(int) { return lci=813; }               virtual int f814(int) { return lci=814; }               virtual int f815(int) { return lci=815; }
+       virtual int f816(int) { return lci=816; }               virtual int f817(int) { return lci=817; }               virtual int f818(int) { return lci=818; }               virtual int f819(int) { return lci=819; }
+       virtual int f820(int) { return lci=820; }               virtual int f821(int) { return lci=821; }               virtual int f822(int) { return lci=822; }               virtual int f823(int) { return lci=823; }
+       virtual int f824(int) { return lci=824; }               virtual int f825(int) { return lci=825; }               virtual int f826(int) { return lci=826; }               virtual int f827(int) { return lci=827; }
+       virtual int f828(int) { return lci=828; }               virtual int f829(int) { return lci=829; }               virtual int f830(int) { return lci=830; }               virtual int f831(int) { return lci=831; }
+       virtual int f832(int) { return lci=832; }               virtual int f833(int) { return lci=833; }               virtual int f834(int) { return lci=834; }               virtual int f835(int) { return lci=835; }
+       virtual int f836(int) { return lci=836; }               virtual int f837(int) { return lci=837; }               virtual int f838(int) { return lci=838; }               virtual int f839(int) { return lci=839; }
+       virtual int f840(int) { return lci=840; }               virtual int f841(int) { return lci=841; }               virtual int f842(int) { return lci=842; }               virtual int f843(int) { return lci=843; }
+       virtual int f844(int) { return lci=844; }               virtual int f845(int) { return lci=845; }               virtual int f846(int) { return lci=846; }               virtual int f847(int) { return lci=847; }
+       virtual int f848(int) { return lci=848; }               virtual int f849(int) { return lci=849; }               virtual int f850(int) { return lci=850; }               virtual int f851(int) { return lci=851; }
+       virtual int f852(int) { return lci=852; }               virtual int f853(int) { return lci=853; }               virtual int f854(int) { return lci=854; }               virtual int f855(int) { return lci=855; }
+       virtual int f856(int) { return lci=856; }               virtual int f857(int) { return lci=857; }               virtual int f858(int) { return lci=858; }               virtual int f859(int) { return lci=859; }
+       virtual int f860(int) { return lci=860; }               virtual int f861(int) { return lci=861; }               virtual int f862(int) { return lci=862; }               virtual int f863(int) { return lci=863; }
+       virtual int f864(int) { return lci=864; }               virtual int f865(int) { return lci=865; }               virtual int f866(int) { return lci=866; }               virtual int f867(int) { return lci=867; }
+       virtual int f868(int) { return lci=868; }               virtual int f869(int) { return lci=869; }               virtual int f870(int) { return lci=870; }               virtual int f871(int) { return lci=871; }
+       virtual int f872(int) { return lci=872; }               virtual int f873(int) { return lci=873; }               virtual int f874(int) { return lci=874; }               virtual int f875(int) { return lci=875; }
+       virtual int f876(int) { return lci=876; }               virtual int f877(int) { return lci=877; }               virtual int f878(int) { return lci=878; }               virtual int f879(int) { return lci=879; }
+       virtual int f880(int) { return lci=880; }               virtual int f881(int) { return lci=881; }               virtual int f882(int) { return lci=882; }               virtual int f883(int) { return lci=883; }
+       virtual int f884(int) { return lci=884; }               virtual int f885(int) { return lci=885; }               virtual int f886(int) { return lci=886; }               virtual int f887(int) { return lci=887; }
+       virtual int f888(int) { return lci=888; }               virtual int f889(int) { return lci=889; }               virtual int f890(int) { return lci=890; }               virtual int f891(int) { return lci=891; }
+       virtual int f892(int) { return lci=892; }               virtual int f893(int) { return lci=893; }               virtual int f894(int) { return lci=894; }               virtual int f895(int) { return lci=895; }
+       virtual int f896(int) { return lci=896; }               virtual int f897(int) { return lci=897; }               virtual int f898(int) { return lci=898; }               virtual int f899(int) { return lci=899; }
+       virtual int f900(int) { return lci=900; }               virtual int f901(int) { return lci=901; }               virtual int f902(int) { return lci=902; }               virtual int f903(int) { return lci=903; }
+       virtual int f904(int) { return lci=904; }               virtual int f905(int) { return lci=905; }               virtual int f906(int) { return lci=906; }               virtual int f907(int) { return lci=907; }
+       virtual int f908(int) { return lci=908; }               virtual int f909(int) { return lci=909; }               virtual int f910(int) { return lci=910; }               virtual int f911(int) { return lci=911; }
+       virtual int f912(int) { return lci=912; }               virtual int f913(int) { return lci=913; }               virtual int f914(int) { return lci=914; }               virtual int f915(int) { return lci=915; }
+       virtual int f916(int) { return lci=916; }               virtual int f917(int) { return lci=917; }               virtual int f918(int) { return lci=918; }               virtual int f919(int) { return lci=919; }
+       virtual int f920(int) { return lci=920; }               virtual int f921(int) { return lci=921; }               virtual int f922(int) { return lci=922; }               virtual int f923(int) { return lci=923; }
+       virtual int f924(int) { return lci=924; }               virtual int f925(int) { return lci=925; }               virtual int f926(int) { return lci=926; }               virtual int f927(int) { return lci=927; }
+       virtual int f928(int) { return lci=928; }               virtual int f929(int) { return lci=929; }               virtual int f930(int) { return lci=930; }               virtual int f931(int) { return lci=931; }
+       virtual int f932(int) { return lci=932; }               virtual int f933(int) { return lci=933; }               virtual int f934(int) { return lci=934; }               virtual int f935(int) { return lci=935; }
+       virtual int f936(int) { return lci=936; }               virtual int f937(int) { return lci=937; }               virtual int f938(int) { return lci=938; }               virtual int f939(int) { return lci=939; }
+       virtual int f940(int) { return lci=940; }               virtual int f941(int) { return lci=941; }               virtual int f942(int) { return lci=942; }               virtual int f943(int) { return lci=943; }
+       virtual int f944(int) { return lci=944; }               virtual int f945(int) { return lci=945; }               virtual int f946(int) { return lci=946; }               virtual int f947(int) { return lci=947; }
+       virtual int f948(int) { return lci=948; }               virtual int f949(int) { return lci=949; }               virtual int f950(int) { return lci=950; }               virtual int f951(int) { return lci=951; }
+       virtual int f952(int) { return lci=952; }               virtual int f953(int) { return lci=953; }               virtual int f954(int) { return lci=954; }               virtual int f955(int) { return lci=955; }
+       virtual int f956(int) { return lci=956; }               virtual int f957(int) { return lci=957; }               virtual int f958(int) { return lci=958; }               virtual int f959(int) { return lci=959; }
+       virtual int f960(int) { return lci=960; }               virtual int f961(int) { return lci=961; }               virtual int f962(int) { return lci=962; }               virtual int f963(int) { return lci=963; }
+       virtual int f964(int) { return lci=964; }               virtual int f965(int) { return lci=965; }               virtual int f966(int) { return lci=966; }               virtual int f967(int) { return lci=967; }
+       virtual int f968(int) { return lci=968; }               virtual int f969(int) { return lci=969; }               virtual int f970(int) { return lci=970; }               virtual int f971(int) { return lci=971; }
+       virtual int f972(int) { return lci=972; }               virtual int f973(int) { return lci=973; }               virtual int f974(int) { return lci=974; }               virtual int f975(int) { return lci=975; }
+       virtual int f976(int) { return lci=976; }               virtual int f977(int) { return lci=977; }               virtual int f978(int) { return lci=978; }               virtual int f979(int) { return lci=979; }
+       virtual int f980(int) { return lci=980; }               virtual int f981(int) { return lci=981; }               virtual int f982(int) { return lci=982; }               virtual int f983(int) { return lci=983; }
+       virtual int f984(int) { return lci=984; }               virtual int f985(int) { return lci=985; }               virtual int f986(int) { return lci=986; }               virtual int f987(int) { return lci=987; }
+       virtual int f988(int) { return lci=988; }               virtual int f989(int) { return lci=989; }               virtual int f990(int) { return lci=990; }               virtual int f991(int) { return lci=991; }
+       virtual int f992(int) { return lci=992; }               virtual int f993(int) { return lci=993; }               virtual int f994(int) { return lci=994; }               virtual int f995(int) { return lci=995; }
+       virtual int f996(int) { return lci=996; }               virtual int f997(int) { return lci=997; }               virtual int f998(int) { return lci=998; }               virtual int f999(int) { return lci=999; }
+       virtual int f1000(int) { return lci=1000; }     virtual int f1001(int) { return lci=1001; }     virtual int f1002(int) { return lci=1002; }     virtual int f1003(int) { return lci=1003; }
+       virtual int f1004(int) { return lci=1004; }     virtual int f1005(int) { return lci=1005; }     virtual int f1006(int) { return lci=1006; }     virtual int f1007(int) { return lci=1007; }
+       virtual int f1008(int) { return lci=1008; }     virtual int f1009(int) { return lci=1009; }     virtual int f1010(int) { return lci=1010; }     virtual int f1011(int) { return lci=1011; }
+       virtual int f1012(int) { return lci=1012; }     virtual int f1013(int) { return lci=1013; }     virtual int f1014(int) { return lci=1014; }     virtual int f1015(int) { return lci=1015; }
+       virtual int f1016(int) { return lci=1016; }     virtual int f1017(int) { return lci=1017; }     virtual int f1018(int) { return lci=1018; }     virtual int f1019(int) { return lci=1019; }
+       virtual int f1020(int) { return lci=1020; }     virtual int f1021(int) { return lci=1021; }     virtual int f1022(int) { return lci=1022; }     virtual int f1023(int) { return lci=1023; }
+       virtual ~func_index() {}
+};
+
+#ifdef _MSC_VER
+template <int s>
+int virtual_function_index(unsigned char *func)
+{
+       if (*func == 0xE9)
+       {
+               return virtual_function_index<0>(func + 5 + *(unsigned int *)(func + 1));
+       }
+       else
+       {
+#ifdef _WIN64
+               func++; // Add one to the pointer to skip the REX prefix used to access 64-bit registers.
+#endif
+               switch (*(unsigned int *)func)
+               { // mov ecx, this; jump [eax + v/Ib/Iw]
+               case 0x20ff018b: return 0;
+#ifdef _WIN32
+               case 0x0424448b: 
+                       if (func[7] == 0x20)
+                               return 0;
+                       return *(unsigned char *)(func + 8) / sizeof(void*);
+#endif
+               case 0x60ff018b: return *(unsigned char *)(func + sizeof(int)) / sizeof(void*);
+               case 0xA0ff018b: return *(unsigned long *)(func + sizeof(int)) / sizeof(void*);
+               default: return -1;
+               }
+       }
+}
+
+#endif
+
+template <typename T>
+std::pair<int, int> virtual_index(T t)
+{
+#if defined(__GNUG__)
+       union {
+               T t;
+               struct
+               {
+                       unsigned long value;
+                       unsigned long baseoffs;
+               } u;
+       } conv;
+       conv.t = t;
+#if defined(SOME_ARM)
+       // ARM ABI says the bit is in bsaeoffs instead, and that the value is shiffted left 1.
+       // This because valid ARM pointers may have the LSB set, so the "is virtual" bit had to be moved.
+       if (conv.u.baseoffs & 1)
+               return std::pair<int, int>(conv.u.baseoffs / (sizeof(void*) * 2), conv.u.value / sizeof(void *));
+#else
+       // simple Itanium ABI implementation, used by everything but Microsoft and embedded EDG-based compilers
+       if (conv.u.value & 1)
+               return std::pair<int, int>(conv.u.baseoffs / sizeof(void*), conv.u.value / sizeof(void *));
+#endif
+
+#elif defined(_MSC_VER)
+       union {
+               T t;
+               struct
+               {
+                       unsigned char *value;
+                       unsigned long baseoffs;
+               } u;
+       } conv;
+       conv.t = t;
+
+       int value = virtual_function_index<0>((unsigned char *)conv.u.value);
+       if (value != -1)
+               return std::pair<int, int>((int)(conv.u.baseoffs/sizeof(void*)), value);
+#elif defined(__EDG__)
+       union {
+               T t;
+               struct {
+                       short delta;
+                       short vindex;
+                       long vtordisp;
+               } u;
+       } conv;
+       conv.t = t;
+
+       if (conv.u.vindex != 0)
+               return std::pair<int, int>((conv.u.delta + conv.u.vtordisp)/sizeof(void*), conv.u.vindex * 2 + 1);
+#else
+#error No virtual indexing found for this compiler! Please contact the maintainers of HippoMocks
+#endif
+
+       return std::pair<int, int>(-1, 0);
+}
+
+template <typename T, typename U>
+T getNonvirtualMemberFunctionAddress(U u)
+{
+#ifdef __EDG__
+       // Edison Design Group C++ frontend (Comeau, Portland Group, Greenhills, etc)
+       union {
+         struct {
+                       short delta;
+                       short vindex;
+                       T t;
+         } mfp_structure;
+         U u;
+       } conv;
+#else
+       // Visual Studio, GCC, others
+       union {
+         struct {
+                       T t;
+               } mfp_structure;
+               U u;
+       } conv;
+#endif
+       conv.u = u;
+       return conv.mfp_structure.t;
+}
+
+class TypeDestructable {
+public:
+       virtual ~TypeDestructable() {}
+};
+
+template <typename A>
+class MemberWrap : public TypeDestructable {
+private:
+       A *member;
+public:
+       MemberWrap(A *mem)
+               : member(mem)
+       {
+               new (member) A();
+       }
+       ~MemberWrap()
+       {
+               member->~A();
+       }
+};
+
+// mock types
+template <class T>
+class mock : public base_mock
+{
+       typedef void (*funcptr)();
+       friend class MockRepository;
+       unsigned char remaining[sizeof(T)];
+       void NotImplemented() {
+               mock<T> *realMock = getRealThis();
+               if (realMock->isZombie)
+                       RAISEEXCEPTION(ZombieMockException(realMock->repo));
+               MockRepository *repository = realMock->repo;
+               RAISEEXCEPTION(:: HM_NS NotImplementedException(repository));
+       }
+protected:
+       std::map<int, void (**)()> funcTables;
+       void (*notimplementedfuncs[VIRT_FUNC_LIMIT])();
+public:
+       bool isZombie;
+       std::list<TypeDestructable *> members;
+       MockRepository *repo;
+       std::map<std::pair<int, int>, int> funcMap;
+       mock(MockRepository *repository)
+               : isZombie(false)
+               , repo(repository)
+       {
+               for (int i = 0; i < VIRT_FUNC_LIMIT; i++)
+               {
+                       notimplementedfuncs[i] = getNonvirtualMemberFunctionAddress<void (*)()>(&mock<T>::NotImplemented);
+               }
+               funcptr *funcTable = new funcptr[VIRT_FUNC_LIMIT+2];
+               memcpy(funcTable, notimplementedfuncs, sizeof(funcptr) * VIRT_FUNC_LIMIT);
+               ((void **)funcTable)[VIRT_FUNC_LIMIT] = this;
+               ((void **)funcTable)[VIRT_FUNC_LIMIT+1] = *(void **)this;
+               funcTables[0] = funcTable;
+               *(void **)this = funcTable;
+               for (unsigned int i = 1; i < sizeof(remaining) / sizeof(funcptr); i++)
+               {
+                       ((void **)this)[i] = (void *)notimplementedfuncs;
+               }
+       }
+       ~mock()
+       {
+               for (std::list<TypeDestructable *>::iterator i = members.begin(); i != members.end(); ++i)
+               {
+                       delete *i;
+               }
+               for (std::map<int, void (**)()>::iterator i = funcTables.begin(); i != funcTables.end(); ++i)
+               {
+                       delete [] i->second;
+               }
+       }
+       void mock_reset()
+       {
+               MockRepository *repository = this->repo;
+               // ugly but simple
+               this->~mock<T>();
+               new (this) mock<T>(repository);
+       }
+       mock<T> *getRealThis()
+       {
+               void ***base = (void ***)this;
+               return (mock<T> *)((*base)[VIRT_FUNC_LIMIT]);
+       }
+       std::pair<int, int> translateX(int x)
+       {
+               for (std::map<std::pair<int, int>, int>::iterator i = funcMap.begin(); i != funcMap.end(); ++i)
+               {
+                       if (i->second == x+1) return i->first;
+               }
+               return std::pair<int, int>(-1, 0);
+       }
+       template <int X>
+       void mockedDestructor(int);
+};
+
+// Do() function wrapping
+class VirtualDestructable { public: virtual ~VirtualDestructable() {} };
+
+template <typename Y>
+class TupleInvocable : public VirtualDestructable
+{
+public:
+       virtual Y operator()(const base_tuple &tupl) = 0;
+};
+
+template <typename Y,
+                 typename A = NullType, typename B = NullType, typename C = NullType, typename D = NullType,
+                 typename E = NullType, typename F = NullType, typename G = NullType, typename H = NullType,
+                 typename I = NullType, typename J = NullType, typename K = NullType, typename L = NullType,
+                 typename M = NullType, typename N = NullType, typename O = NullType, typename P = NullType>
+class Invocable : public TupleInvocable<Y>
+{
+public:
+       virtual Y operator()(A a = A(), B b = B(), C c = C(), D d = D(), E e = E(), F f = F(), G g = G(), H h = H(), I i = I(), J j = J(), K k = K(), L l = L(), M m = M(), N n = N(), O o = O(), P p = P()) = 0;
+       virtual Y operator()(const base_tuple &tupl) {
+               const ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P> &rTupl = reinterpret_cast<const ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P> &>(tupl);
+               return (*this)(rTupl.a, rTupl.b, rTupl.c, rTupl.d, rTupl.e, rTupl.f, rTupl.g, rTupl.h,
+                       rTupl.i, rTupl.j, rTupl.k, rTupl.l, rTupl.m, rTupl.n, rTupl.o, rTupl.p);
+       }
+};
+template <typename T, typename Y,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H,
+                 typename I, typename J, typename K, typename L,
+                 typename M, typename N, typename O, typename P>
+class DoWrapper : public Invocable<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P> {
+       T t;
+public:
+       DoWrapper(T templ) : t(templ) {}
+       virtual Y operator()(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k, L l, M m, N n, O o, P p)
+       {
+               return t(a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p);
+       }
+       using Invocable<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P>::operator();
+};
+template <typename T, typename Y,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H,
+                 typename I, typename J, typename K, typename L,
+                 typename M, typename N, typename O>
+class DoWrapper<T,Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,NullType> : public Invocable<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O> {
+       T t;
+public:
+       DoWrapper(T templ) : t(templ) {}
+       virtual Y operator()(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k, L l, M m, N n, O o, NullType)
+       {
+               return t(a,b,c,d,e,f,g,h,i,j,k,l,m,n,o);
+       }
+       using Invocable<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O>::operator();
+};
+template <typename T, typename Y,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H,
+                 typename I, typename J, typename K, typename L,
+                 typename M, typename N>
+class DoWrapper<T,Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,NullType,NullType> : public Invocable<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N> {
+       T t;
+public:
+       DoWrapper(T templ) : t(templ) {}
+       virtual Y operator()(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k, L l, M m, N n, NullType, NullType)
+       {
+               return t(a,b,c,d,e,f,g,h,i,j,k,l,m,n);
+       }
+       using Invocable<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N>::operator();
+};
+template <typename T, typename Y,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H,
+                 typename I, typename J, typename K, typename L,
+                 typename M>
+class DoWrapper<T,Y,A,B,C,D,E,F,G,H,I,J,K,L,M,NullType,NullType,NullType> : public Invocable<Y,A,B,C,D,E,F,G,H,I,J,K,L,M> {
+       T t;
+public:
+       DoWrapper(T templ) : t(templ) {}
+       virtual Y operator()(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k, L l, M m, NullType, NullType, NullType)
+       {
+               return t(a,b,c,d,e,f,g,h,i,j,k,l,m);
+       }
+       using Invocable<Y,A,B,C,D,E,F,G,H,I,J,K,L,M>::operator();
+};
+template <typename T, typename Y,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H,
+                 typename I, typename J, typename K, typename L>
+class DoWrapper<T,Y,A,B,C,D,E,F,G,H,I,J,K,L,NullType,NullType,NullType,NullType> : public Invocable<Y,A,B,C,D,E,F,G,H,I,J,K,L> {
+       T t;
+public:
+       DoWrapper(T templ) : t(templ) {}
+       virtual Y operator()(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k, L l, NullType, NullType, NullType, NullType)
+       {
+               return t(a,b,c,d,e,f,g,h,i,j,k,l);
+       }
+       using Invocable<Y,A,B,C,D,E,F,G,H,I,J,K,L>::operator();
+};
+template <typename T, typename Y,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H,
+                 typename I, typename J, typename K>
+class DoWrapper<T,Y,A,B,C,D,E,F,G,H,I,J,K,NullType,NullType,NullType,NullType,NullType> : public Invocable<Y,A,B,C,D,E,F,G,H,I,J,K> {
+       T t;
+public:
+       DoWrapper(T templ) : t(templ) {}
+       virtual Y operator()(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k, NullType, NullType, NullType, NullType, NullType)
+       {
+               return t(a,b,c,d,e,f,g,h,i,j,k);
+       }
+       using Invocable<Y,A,B,C,D,E,F,G,H,I,J,K>::operator();
+};
+template <typename T, typename Y,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H,
+                 typename I, typename J>
+class DoWrapper<T,Y,A,B,C,D,E,F,G,H,I,J,NullType,NullType,NullType,NullType,NullType,NullType> : public Invocable<Y,A,B,C,D,E,F,G,H,I,J> {
+       T t;
+public:
+       DoWrapper(T templ) : t(templ) {}
+       virtual Y operator()(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, NullType, NullType, NullType, NullType, NullType, NullType)
+       {
+               return t(a,b,c,d,e,f,g,h,i,j);
+       }
+       using Invocable<Y,A,B,C,D,E,F,G,H,I,J>::operator();
+};
+template <typename T, typename Y,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H,
+                 typename I>
+class DoWrapper<T,Y,A,B,C,D,E,F,G,H,I,NullType,NullType,NullType,NullType,NullType,NullType,NullType>  : public Invocable<Y,A,B,C,D,E,F,G,H,I>{
+       T t;
+public:
+       DoWrapper(T templ) : t(templ) {}
+       virtual Y operator()(A a, B b, C c, D d, E e, F f, G g, H h, I i, NullType, NullType, NullType, NullType, NullType, NullType, NullType)
+       {
+               return t(a,b,c,d,e,f,g,h,i);
+       }
+       using Invocable<Y,A,B,C,D,E,F,G,H,I>::operator();
+};
+template <typename T, typename Y,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H>
+class DoWrapper<T,Y,A,B,C,D,E,F,G,H,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> : public Invocable<Y,A,B,C,D,E,F,G,H> {
+       T t;
+public:
+       DoWrapper(T templ) : t(templ) {}
+       virtual Y operator()(A a, B b, C c, D d, E e, F f, G g, H h, NullType, NullType, NullType, NullType, NullType, NullType, NullType, NullType)
+       {
+               return t(a,b,c,d,e,f,g,h);
+       }
+       using Invocable<Y,A,B,C,D,E,F,G,H>::operator();
+};
+template <typename T, typename Y,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G>
+class DoWrapper<T,Y,A,B,C,D,E,F,G,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> : public Invocable<Y,A,B,C,D,E,F,G> {
+       T t;
+public:
+       DoWrapper(T templ) : t(templ) {}
+       virtual Y operator()(A a, B b, C c, D d, E e, F f, G g, NullType, NullType, NullType, NullType, NullType, NullType, NullType, NullType, NullType)
+       {
+               return t(a,b,c,d,e,f,g);
+       }
+       using Invocable<Y,A,B,C,D,E,F,G>::operator();
+};
+template <typename T, typename Y,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F>
+class DoWrapper<T,Y,A,B,C,D,E,F,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> : public Invocable<Y,A,B,C,D,E,F> {
+       T t;
+public:
+       DoWrapper(T templ) : t(templ) {}
+       virtual Y operator()(A a, B b, C c, D d, E e, F f, NullType, NullType, NullType, NullType, NullType, NullType, NullType, NullType, NullType, NullType)
+       {
+               return t(a,b,c,d,e,f);
+       }
+       using Invocable<Y,A,B,C,D,E,F>::operator();
+};
+template <typename T, typename Y,
+                 typename A, typename B, typename C, typename D,
+                 typename E>
+class DoWrapper<T,Y,A,B,C,D,E,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> : public Invocable<Y,A,B,C,D,E> {
+       T t;
+public:
+       DoWrapper(T templ) : t(templ) {}
+       virtual Y operator()(A a, B b, C c, D d, E e, NullType, NullType, NullType, NullType, NullType, NullType, NullType, NullType, NullType, NullType, NullType)
+       {
+               return t(a,b,c,d,e);
+       }
+       using Invocable<Y,A,B,C,D,E>::operator();
+};
+template <typename T, typename Y,
+                 typename A, typename B, typename C, typename D>
+class DoWrapper<T,Y,A,B,C,D,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> : public Invocable<Y,A,B,C,D> {
+       T t;
+public:
+       DoWrapper(T templ) : t(templ) {}
+       virtual Y operator()(A a, B b, C c, D d, NullType, NullType, NullType, NullType, NullType, NullType, NullType, NullType, NullType, NullType, NullType, NullType)
+       {
+               return t(a,b,c,d);
+       }
+       using Invocable<Y,A,B,C,D>::operator();
+};
+template <typename T, typename Y,
+                 typename A, typename B, typename C>
+class DoWrapper<T,Y,A,B,C,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> : public Invocable<Y,A,B,C> {
+       T t;
+public:
+       DoWrapper(T templ) : t(templ) {}
+       virtual Y operator()(A a, B b, C c, NullType, NullType, NullType, NullType, NullType, NullType, NullType, NullType, NullType, NullType, NullType, NullType, NullType)
+       {
+               return t(a,b,c);
+       }
+       using Invocable<Y,A,B,C>::operator();
+};
+template <typename T, typename Y, typename A, typename B>
+class DoWrapper<T,Y,A,B,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> : public Invocable<Y,A,B> {
+       T t;
+public:
+       DoWrapper(T templ) : t(templ) {}
+       virtual Y operator()(A a, B b, NullType, NullType, NullType, NullType, NullType, NullType, NullType, NullType, NullType, NullType, NullType, NullType, NullType, NullType)
+       {
+               return t(a,b);
+       }
+       using Invocable<Y,A,B>::operator();
+};
+template <typename T, typename Y, typename A>
+class DoWrapper<T,Y,A,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> : public Invocable<Y,A> {
+       T t;
+public:
+       DoWrapper(T templ) : t(templ) {}
+       virtual Y operator()(A a, NullType, NullType, NullType, NullType, NullType, NullType, NullType, NullType, NullType, NullType, NullType, NullType, NullType, NullType, NullType)
+       {
+               return t(a);
+       }
+       using Invocable<Y,A>::operator();
+};
+template <typename T, typename Y>
+class DoWrapper<T,Y,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> : public Invocable<Y> {
+       T t;
+public:
+       DoWrapper(T templ) : t(templ) {}
+       virtual Y operator()(NullType, NullType, NullType, NullType, NullType, NullType, NullType, NullType, NullType, NullType, NullType, NullType, NullType, NullType, NullType, NullType)
+       {
+               return t();
+       }
+       using Invocable<Y>::operator();
+};
+
+class ReturnValueHolder {
+public:
+       virtual ~ReturnValueHolder() {}
+};
+
+template <class T>
+class ReturnValueWrapper : public ReturnValueHolder {
+public:
+   virtual T value() = 0;
+};
+
+template <class T>
+class ReturnValueWrapperCopy : public ReturnValueWrapper<T> {
+public:
+       typename no_cref<T>::type rv;
+       ReturnValueWrapperCopy(T retValue) : rv(retValue) {}
+   virtual T value() { return rv; };
+};
+
+template <class T>
+class ReturnValueWrapperRef : public ReturnValueWrapper<T> {
+public:
+       T rv;
+       ReturnValueWrapperRef(T retValue) : rv(retValue) {}
+   virtual T value() { return rv; };
+};
+
+//Call wrapping
+class Call {
+public:
+       virtual bool matchesArgs(const base_tuple &tuple) = 0;
+       virtual void assignArgs(base_tuple &tuple) = 0;
+       ReturnValueHolder *retVal;
+#ifndef HM_NO_EXCEPTIONS
+       ExceptionHolder *eHolder;
+#endif
+       base_mock *mock;
+       VirtualDestructable *functor;
+       VirtualDestructable *matchFunctor;
+       std::pair<int, int> funcIndex;
+       std::list<Call *> previousCalls;
+       unsigned called;
+       RegistrationType expectation;
+       bool satisfied;
+       int lineno;
+       const char *funcName;
+       const char *fileName;
+protected:
+       Call(RegistrationType expect, base_mock *baseMock, const std::pair<int, int> &index, int X, const char *func, const char *file)
+               : retVal(0),
+#ifndef HM_NO_EXCEPTIONS
+               eHolder(0),
+#endif
+               mock(baseMock),
+               functor(0),
+               matchFunctor(0),
+               funcIndex(index),
+               called( 0 ),
+               expectation(expect),
+               satisfied(false),
+               lineno(X),
+               funcName(func),
+               fileName(file)
+       {
+       }
+public:
+       virtual const base_tuple *getArgs() const = 0;
+       virtual ~Call()
+       {
+#ifndef HM_NO_EXCEPTIONS
+               delete eHolder;
+#endif
+               delete functor;
+               delete matchFunctor;
+               delete retVal;
+       }
+};
+
+std::ostream &operator<<(std::ostream &os, const Call &call);
+
+template <typename Y,
+                 typename A = NullType, typename B = NullType, typename C = NullType, typename D = NullType,
+                 typename E = NullType, typename F = NullType, typename G = NullType, typename H = NullType,
+                 typename I = NullType, typename J = NullType, typename K = NullType, typename L = NullType,
+                 typename M = NullType, typename N = NullType, typename O = NullType, typename P = NullType>
+class TCall : public Call {
+private:
+       ref_comparable_assignable_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P> *args;
+public:
+               const base_tuple *getArgs() const { return args; }
+       TCall(RegistrationType expect, base_mock *baseMock, std::pair<int, int> index, int X, const char *func, const char *file) : Call(expect, baseMock, index, X, func ,file), args(0) {}
+       ~TCall() { delete args; }
+       bool matchesArgs(const base_tuple &tupl) {
+               return (!args && !matchFunctor) ||
+                       (args && (*args == reinterpret_cast<const ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P> &>(tupl))) ||
+                       (matchFunctor && (*(TupleInvocable<bool> *)(matchFunctor))(tupl));
+       }
+       void assignArgs(base_tuple &tupl) {
+               if(args) {
+                       args->assign_to(static_cast<ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P> &>(tupl));
+                       args->assign_from(static_cast<ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P> &>(tupl));
+               }
+       }
+       template <typename CA, typename CB, typename CC, typename CD,
+                         typename CE, typename CF, typename CG, typename CH,
+                         typename CI, typename CJ, typename CK, typename CL,
+                         typename CM, typename CN, typename CO, typename CP>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P> &With(const CA & a, const CB & b, const CC & c, const CD & d, const CE & e, const CF & f, const CG & g, const CH & h, const CI & i, const CJ & j, const CK & k, const CL & l, const CM & m, const CN & n, const CO & o, const CP & p) {
+               args = new copy_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P,
+                                                               const CA &,const CB &,const CC &,const CD &,const CE &,const CF &,const CG &,const CH &,const CI &,const CJ &,const CK &,const CL &,const CM &,const CN &,const CO &,const CP &>(a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p);
+               return *this;
+       }
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P> &After(Call &call) {
+               previousCalls.push_back(&call);
+               return *this;
+       }
+       template <typename T>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P> &Do(T function) { functor = new DoWrapper<T,Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P>(function); return *this; }
+       template <typename T>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P> &Match(T function) { matchFunctor = new DoWrapper<T,bool,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P>(function); return *this; }
+       Call &Return(Y obj) { retVal = new ReturnValueWrapperCopy<Y>(obj); return *this; }
+       Call &ReturnByRef(Y obj) { retVal = new ReturnValueWrapperRef<Y>(obj); return *this; }
+#ifndef HM_NO_EXCEPTIONS
+       template <typename Ex>
+       Call &Throw(Ex exception) { eHolder = new ExceptionWrapper<Ex>(exception); return *this; }
+#endif
+};
+template <typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H,
+                 typename I, typename J, typename K, typename L,
+                 typename M, typename N, typename O, typename P>
+class TCall<void,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P> : public Call {
+private:
+       ref_comparable_assignable_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P> *args;
+public:
+               const base_tuple *getArgs() const { return args; }
+       TCall(RegistrationType expect, base_mock *baseMock, std::pair<int, int> index, int X, const char *func, const char *file) : Call(expect, baseMock, index, X, func ,file), args(0) {}
+       ~TCall() { delete args; }
+       bool matchesArgs(const base_tuple &tupl) {
+               return (!args && !matchFunctor) ||
+                       (args && (*args == reinterpret_cast<const ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P> &>(tupl))) ||
+                       (matchFunctor && (*(TupleInvocable<bool> *)(matchFunctor))(tupl));
+       }
+       void assignArgs(base_tuple &tupl) {
+               if(args) {
+                       args->assign_to(static_cast<ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P> &>(tupl));
+                       args->assign_from(static_cast<ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P> &>(tupl));
+               }
+       }
+       template <typename CA, typename CB, typename CC, typename CD,
+                         typename CE, typename CF, typename CG, typename CH,
+                         typename CI, typename CJ, typename CK, typename CL,
+                         typename CM, typename CN, typename CO, typename CP>
+       TCall<void,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P> &With(const CA & a, const CB & b, const CC & c, const CD & d, const CE & e, const CF & f, const CG & g, const CH & h, const CI & i, const CJ & j, const CK & k, const CL & l, const CM & m, const CN & n, const CO & o, const CP & p) {
+               args = new copy_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P,
+                                                               const CA &,const CB &,const CC &,const CD &,const CE &,const CF &,const CG &,const CH &,const CI &,const CJ &,const CK &,const CL &,const CM &,const CN &,const CO &,const CP &>(a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p);
+               return *this;
+       }
+       TCall<void,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P> &After(Call &call) {
+               previousCalls.push_back(&call);
+               return *this;
+       }
+       template <typename T>
+       TCall<void,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P> &Do(T function) { functor = new DoWrapper<T,void,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P>(function); return *this; }
+       template <typename T>
+       TCall<void,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P> &Match(T function) { matchFunctor = new DoWrapper<T,bool,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P>(function); return *this; }
+#ifndef HM_NO_EXCEPTIONS
+       template <typename Ex>
+       Call &Throw(Ex exception) { eHolder = new ExceptionWrapper<Ex>(exception); return *this; }
+#endif
+};
+
+template <typename Y,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H,
+                 typename I, typename J, typename K, typename L,
+                 typename M, typename N, typename O>
+class TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,NullType> : public Call {
+private:
+       ref_comparable_assignable_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,NullType> *args;
+public:
+               const base_tuple *getArgs() const { return args; }
+       TCall(RegistrationType expect, base_mock *baseMock, std::pair<int, int> index, int X, const char *func, const char *file) : Call(expect, baseMock, index, X, func ,file), args(0) {}
+       ~TCall() { delete args; }
+       bool matchesArgs(const base_tuple &tupl) {
+               return (!args && !matchFunctor) ||
+                       (args && (*args == reinterpret_cast<const ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,NullType> &>(tupl))) ||
+                       (matchFunctor && (*(TupleInvocable<bool> *)(matchFunctor))(tupl));
+       }
+       void assignArgs(base_tuple &tupl) {
+               if(args) {
+                       args->assign_to(static_cast<ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,NullType> &>(tupl));
+                       args->assign_from(static_cast<ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,NullType> &>(tupl));
+               }
+       }
+       template <typename CA, typename CB, typename CC, typename CD,
+                         typename CE, typename CF, typename CG, typename CH,
+                         typename CI, typename CJ, typename CK, typename CL,
+                         typename CM, typename CN, typename CO>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,NullType> &With(const CA & a, const CB & b, const CC & c, const CD & d, const CE & e, const CF & f, const CG & g, const CH & h, const CI & i, const CJ & j, const CK & k, const CL & l, const CM & m, const CN & n, const CO & o) {
+               args = new copy_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,NullType,
+                                                               const CA &,const CB &,const CC &,const CD &,const CE &,const CF &,const CG &,const CH &,const CI &,const CJ &,const CK &,const CL &,const CM &,const CN &,const CO &,NullType>(a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,NullType());
+               return *this;
+       }
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,NullType> &After(Call &call) {
+               previousCalls.push_back(&call);
+               return *this;
+       }
+       template <typename T>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,NullType> &Do(T function) { functor = new DoWrapper<T,Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,NullType>(function); return *this; }
+       template <typename T>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,NullType> &Match(T function) { matchFunctor = new DoWrapper<T,bool,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,NullType>(function); return *this; }
+       Call &Return(Y obj) { retVal = new ReturnValueWrapperCopy<Y>(obj); return *this; }
+       Call &ReturnByRef(Y obj) { retVal = new ReturnValueWrapperRef<Y>(obj); return *this; }
+#ifndef HM_NO_EXCEPTIONS
+       template <typename Ex>
+       Call &Throw(Ex exception) { eHolder = new ExceptionWrapper<Ex>(exception); return *this; }
+#endif
+};
+template <typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H,
+                 typename I, typename J, typename K, typename L,
+                 typename M, typename N, typename O>
+class TCall<void,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,NullType> : public Call {
+private:
+       ref_comparable_assignable_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,NullType> *args;
+public:
+               const base_tuple *getArgs() const { return args; }
+       TCall(RegistrationType expect, base_mock *baseMock, std::pair<int, int> index, int X, const char *func, const char *file) : Call(expect, baseMock, index, X, func ,file), args(0) {}
+       ~TCall() { delete args; }
+       bool matchesArgs(const base_tuple &tupl) {
+               return (!args && !matchFunctor) ||
+                       (args && (*args == reinterpret_cast<const ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,NullType> &>(tupl))) ||
+                       (matchFunctor && (*(TupleInvocable<bool> *)(matchFunctor))(tupl));
+       }
+       void assignArgs(base_tuple &tupl) {
+               if(args) {
+                       args->assign_to(static_cast<ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,NullType> &>(tupl));
+                       args->assign_from(static_cast<ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,NullType> &>(tupl));
+               }
+       }
+       template <typename CA, typename CB, typename CC, typename CD,
+                         typename CE, typename CF, typename CG, typename CH,
+                         typename CI, typename CJ, typename CK, typename CL,
+                         typename CM, typename CN, typename CO>
+       TCall<void,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,NullType> &With(const CA & a, const CB & b, const CC & c, const CD & d, const CE & e, const CF & f, const CG & g, const CH & h, const CI & i, const CJ & j, const CK & k, const CL & l, const CM & m, const CN & n, const CO & o) {
+               args = new copy_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,NullType,
+                                                               const CA &,const CB &,const CC &,const CD &,const CE &,const CF &,const CG &,const CH &,const CI &,const CJ &,const CK &,const CL &,const CM &,const CN &,const CO &,NullType>(a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,NullType());
+               return *this;
+       }
+       TCall<void,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,NullType> &After(Call &call) {
+               previousCalls.push_back(&call);
+               return *this;
+       }
+       template <typename T>
+       TCall<void,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,NullType> &Do(T function) { functor = new DoWrapper<T,void,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,NullType>(function); return *this; }
+       template <typename T>
+       TCall<void,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,NullType> &Match(T function) { matchFunctor = new DoWrapper<T,bool,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,NullType>(function); return *this; }
+#ifndef HM_NO_EXCEPTIONS
+       template <typename Ex>
+       Call &Throw(Ex exception) { eHolder = new ExceptionWrapper<Ex>(exception); return *this; }
+#endif
+};
+
+template <typename Y,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H,
+                 typename I, typename J, typename K, typename L,
+                 typename M, typename N>
+class TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,NullType,NullType> : public Call {
+private:
+       ref_comparable_assignable_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,NullType,NullType> *args;
+public:
+               const base_tuple *getArgs() const { return args; }
+       TCall(RegistrationType expect, base_mock *baseMock, std::pair<int, int> index, int X, const char *func, const char *file) : Call(expect, baseMock, index, X, func ,file), args(0) {}
+       ~TCall() { delete args; }
+       bool matchesArgs(const base_tuple &tupl) {
+               return (!args && !matchFunctor) ||
+                       (args && (*args == reinterpret_cast<const ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,NullType,NullType> &>(tupl))) ||
+                       (matchFunctor && (*(TupleInvocable<bool> *)(matchFunctor))(tupl));
+       }
+       void assignArgs(base_tuple &tupl) {
+               if(args) {
+                       args->assign_to(static_cast<ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,NullType,NullType> &>(tupl));
+                       args->assign_from(static_cast<ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,NullType,NullType> &>(tupl));
+               }
+       }
+       template <typename CA, typename CB, typename CC, typename CD,
+                         typename CE, typename CF, typename CG, typename CH,
+                         typename CI, typename CJ, typename CK, typename CL,
+                         typename CM, typename CN>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,NullType,NullType> &With(const CA & a, const CB & b, const CC & c, const CD & d, const CE & e, const CF & f, const CG & g, const CH & h, const CI & i, const CJ & j, const CK & k, const CL & l, const CM & m, const CN & n) {
+               args = new copy_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,NullType,NullType,
+                                                               const CA &,const CB &,const CC &,const CD &,const CE &,const CF &,const CG &,const CH &,const CI &,const CJ &,const CK &,const CL &,const CM &,const CN &,NullType,NullType>(a,b,c,d,e,f,g,h,i,j,k,l,m,n,NullType(),NullType());
+               return *this;
+       }
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,NullType,NullType> &After(Call &call) {
+               previousCalls.push_back(&call);
+               return *this;
+       }
+       template <typename T>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,NullType,NullType> &Do(T function) { functor = new DoWrapper<T,Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,NullType,NullType>(function); return *this; }
+       template <typename T>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,NullType,NullType> &Match(T function) { matchFunctor = new DoWrapper<T,bool,A,B,C,D,E,F,G,H,I,J,K,L,M,N,NullType,NullType>(function); return *this; }
+       Call &Return(Y obj) { retVal = new ReturnValueWrapperCopy<Y>(obj); return *this; }
+       Call &ReturnByRef(Y obj) { retVal = new ReturnValueWrapperRef<Y>(obj); return *this; }
+#ifndef HM_NO_EXCEPTIONS
+       template <typename Ex>
+       Call &Throw(Ex exception) { eHolder = new ExceptionWrapper<Ex>(exception); return *this; }
+#endif
+};
+template <typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H,
+                 typename I, typename J, typename K, typename L,
+                 typename M, typename N>
+class TCall<void,A,B,C,D,E,F,G,H,I,J,K,L,M,N,NullType,NullType> : public Call {
+private:
+       ref_comparable_assignable_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,NullType,NullType> *args;
+public:
+               const base_tuple *getArgs() const { return args; }
+       TCall(RegistrationType expect, base_mock *baseMock, std::pair<int, int> index, int X, const char *func, const char *file) : Call(expect, baseMock, index, X, func ,file), args(0) {}
+       ~TCall() { delete args; }
+       bool matchesArgs(const base_tuple &tupl) {
+               return (!args && !matchFunctor) ||
+                       (args && (*args == reinterpret_cast<const ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,NullType,NullType> &>(tupl))) ||
+                       (matchFunctor && (*(TupleInvocable<bool> *)(matchFunctor))(tupl));
+       }
+       void assignArgs(base_tuple &tupl) {
+               if(args) {
+                       args->assign_to(static_cast<ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,NullType,NullType> &>(tupl));
+                       args->assign_from(static_cast<ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,NullType,NullType> &>(tupl));
+               }
+       }
+       template <typename CA, typename CB, typename CC, typename CD,
+                         typename CE, typename CF, typename CG, typename CH,
+                         typename CI, typename CJ, typename CK, typename CL,
+                         typename CM, typename CN>
+       TCall<void,A,B,C,D,E,F,G,H,I,J,K,L,M,N,NullType,NullType> &With(const CA & a, const CB & b, const CC & c, const CD & d, const CE & e, const CF & f, const CG & g, const CH & h, const CI & i, const CJ & j, const CK & k, const CL & l, const CM & m, const CN & n) {
+               args = new copy_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,NullType,NullType,
+                                                               const CA &,const CB &,const CC &,const CD &,const CE &,const CF &,const CG &,const CH &,const CI &,const CJ &,const CK &,const CL &,const CM &,const CN &,NullType,NullType>(a,b,c,d,e,f,g,h,i,j,k,l,m,n,NullType(),NullType());
+               return *this;
+       }
+       TCall<void,A,B,C,D,E,F,G,H,I,J,K,L,M,N,NullType,NullType> &After(Call &call) {
+               previousCalls.push_back(&call);
+               return *this;
+       }
+       template <typename T>
+       TCall<void,A,B,C,D,E,F,G,H,I,J,K,L,M,N,NullType,NullType> &Do(T function) { functor = new DoWrapper<T,void,A,B,C,D,E,F,G,H,I,J,K,L,M,N,NullType,NullType>(function); return *this; }
+       template <typename T>
+       TCall<void,A,B,C,D,E,F,G,H,I,J,K,L,M,N,NullType,NullType> &Match(T function) { matchFunctor = new DoWrapper<T,bool,A,B,C,D,E,F,G,H,I,J,K,L,M,N,NullType,NullType>(function); return *this; }
+#ifndef HM_NO_EXCEPTIONS
+       template <typename Ex>
+       Call &Throw(Ex exception) { eHolder = new ExceptionWrapper<Ex>(exception); return *this; }
+#endif
+};
+
+template <typename Y,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H,
+                 typename I, typename J, typename K, typename L,
+                 typename M>
+class TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,NullType,NullType,NullType> : public Call {
+private:
+       ref_comparable_assignable_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,NullType,NullType,NullType> *args;
+public:
+               const base_tuple *getArgs() const { return args; }
+       TCall(RegistrationType expect, base_mock *baseMock, std::pair<int, int> index, int X, const char *func, const char *file) : Call(expect, baseMock, index, X, func ,file), args(0) {}
+       ~TCall() { delete args; }
+       bool matchesArgs(const base_tuple &tupl) {
+               return (!args && !matchFunctor) ||
+                       (args && (*args == reinterpret_cast<const ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,NullType,NullType,NullType> &>(tupl))) ||
+                       (matchFunctor && (*(TupleInvocable<bool> *)(matchFunctor))(tupl));
+       }
+       void assignArgs(base_tuple &tupl) {
+               if(args) {
+                       args->assign_to(static_cast<ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,NullType,NullType,NullType> &>(tupl));
+                       args->assign_from(static_cast<ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,NullType,NullType,NullType> &>(tupl));
+               }
+       }
+       template <typename CA, typename CB, typename CC, typename CD,
+                         typename CE, typename CF, typename CG, typename CH,
+                         typename CI, typename CJ, typename CK, typename CL,
+                         typename CM>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,NullType,NullType,NullType> &With(const CA & a, const CB & b, const CC & c, const CD & d, const CE & e, const CF & f, const CG & g, const CH & h, const CI & i, const CJ & j, const CK & k, const CL & l, const CM & m) {
+               args = new copy_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,NullType,NullType,NullType,
+                                                               const CA &,const CB &,const CC &,const CD &,const CE &,const CF &,const CG &,const CH &,const CI &,const CJ &,const CK &,const CL &,const CM &,NullType,NullType,NullType>(a,b,c,d,e,f,g,h,i,j,k,l,m,NullType(),NullType(),NullType());
+               return *this;
+       }
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,NullType,NullType,NullType> &After(Call &call) {
+               previousCalls.push_back(&call);
+               return *this;
+       }
+       template <typename T>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,NullType,NullType,NullType> &Do(T function) { functor = new DoWrapper<T,Y,A,B,C,D,E,F,G,H,I,J,K,L,M,NullType,NullType,NullType>(function); return *this; }
+       template <typename T>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,NullType,NullType,NullType> &Match(T function) { matchFunctor = new DoWrapper<T,bool,A,B,C,D,E,F,G,H,I,J,K,L,M,NullType,NullType,NullType>(function); return *this; }
+       Call &Return(Y obj) { retVal = new ReturnValueWrapperCopy<Y>(obj); return *this; }
+       Call &ReturnByRef(Y obj) { retVal = new ReturnValueWrapperRef<Y>(obj); return *this; }
+#ifndef HM_NO_EXCEPTIONS
+       template <typename Ex>
+       Call &Throw(Ex exception) { eHolder = new ExceptionWrapper<Ex>(exception); return *this; }
+#endif
+};
+template <typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H,
+                 typename I, typename J, typename K, typename L,
+                 typename M>
+class TCall<void,A,B,C,D,E,F,G,H,I,J,K,L,M,NullType,NullType,NullType> : public Call {
+private:
+       ref_comparable_assignable_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,NullType,NullType,NullType> *args;
+public:
+               const base_tuple *getArgs() const { return args; }
+       TCall(RegistrationType expect, base_mock *baseMock, std::pair<int, int> index, int X, const char *func, const char *file) : Call(expect, baseMock, index, X, func ,file), args(0) {}
+       ~TCall() { delete args; }
+       bool matchesArgs(const base_tuple &tupl) {
+               return (!args && !matchFunctor) ||
+                       (args && (*args == reinterpret_cast<const ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,NullType,NullType,NullType> &>(tupl))) ||
+                       (matchFunctor && (*(TupleInvocable<bool> *)(matchFunctor))(tupl));
+       }
+       void assignArgs(base_tuple &tupl) {
+               if(args) {
+                       args->assign_to(static_cast<ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,NullType,NullType,NullType> &>(tupl));
+                       args->assign_from(static_cast<ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,NullType,NullType,NullType> &>(tupl));
+               }
+       }
+       template <typename CA, typename CB, typename CC, typename CD,
+                         typename CE, typename CF, typename CG, typename CH,
+                         typename CI, typename CJ, typename CK, typename CL,
+                         typename CM>
+       TCall<void,A,B,C,D,E,F,G,H,I,J,K,L,M,NullType,NullType,NullType> &With(const CA & a, const CB & b, const CC & c, const CD & d, const CE & e, const CF & f, const CG & g, const CH & h, const CI & i, const CJ & j, const CK & k, const CL & l, const CM & m) {
+               args = new copy_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,NullType,NullType,NullType,
+                                                               const CA &,const CB &,const CC &,const CD &,const CE &,const CF &,const CG &,const CH &,const CI &,const CJ &,const CK &,const CL &,const CM &,NullType,NullType,NullType>(a,b,c,d,e,f,g,h,i,j,k,l,m,NullType(),NullType(),NullType());
+               return *this;
+       }
+       TCall<void,A,B,C,D,E,F,G,H,I,J,K,L,M,NullType,NullType,NullType> &After(Call &call) {
+               previousCalls.push_back(&call);
+               return *this;
+       }
+       template <typename T>
+       TCall<void,A,B,C,D,E,F,G,H,I,J,K,L,M,NullType,NullType,NullType> &Do(T function) { functor = new DoWrapper<T,void,A,B,C,D,E,F,G,H,I,J,K,L,M,NullType,NullType,NullType>(function); return *this; }
+       template <typename T>
+       TCall<void,A,B,C,D,E,F,G,H,I,J,K,L,M,NullType,NullType,NullType> &Match(T function) { matchFunctor = new DoWrapper<T,bool,A,B,C,D,E,F,G,H,I,J,K,L,M,NullType,NullType,NullType>(function); return *this; }
+#ifndef HM_NO_EXCEPTIONS
+       template <typename Ex>
+       Call &Throw(Ex exception) { eHolder = new ExceptionWrapper<Ex>(exception); return *this; }
+#endif
+};
+
+template <typename Y,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H,
+                 typename I, typename J, typename K, typename L>
+class TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,NullType,NullType,NullType,NullType> : public Call {
+private:
+       ref_comparable_assignable_tuple<A,B,C,D,E,F,G,H,I,J,K,L,NullType,NullType,NullType,NullType> *args;
+public:
+               const base_tuple *getArgs() const { return args; }
+       TCall(RegistrationType expect, base_mock *baseMock, std::pair<int, int> index, int X, const char *func, const char *file) : Call(expect, baseMock, index, X, func ,file), args(0) {}
+       ~TCall() { delete args; }
+       bool matchesArgs(const base_tuple &tupl) {
+               return (!args && !matchFunctor) ||
+                       (args && (*args == reinterpret_cast<const ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,NullType,NullType,NullType,NullType> &>(tupl))) ||
+                       (matchFunctor && (*(TupleInvocable<bool> *)(matchFunctor))(tupl));
+       }
+       void assignArgs(base_tuple &tupl) {
+               if(args) {
+                       args->assign_to(static_cast<ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,NullType,NullType,NullType,NullType> &>(tupl));
+                       args->assign_from(static_cast<ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,NullType,NullType,NullType,NullType> &>(tupl));
+               }
+       }
+       template <typename CA, typename CB, typename CC, typename CD,
+                         typename CE, typename CF, typename CG, typename CH,
+                         typename CI, typename CJ, typename CK, typename CL>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,NullType,NullType,NullType,NullType> &With(const CA & a, const CB & b, const CC & c, const CD & d, const CE & e, const CF & f, const CG & g, const CH & h, const CI & i, const CJ & j, const CK & k, const CL & l) {
+               args = new copy_tuple<A,B,C,D,E,F,G,H,I,J,K,L,NullType,NullType,NullType,NullType,
+                                                               const CA &,const CB &,const CC &,const CD &,const CE &,const CF &,const CG &,const CH &,const CI &,const CJ &,const CK &,const CL &,NullType,NullType,NullType,NullType>(a,b,c,d,e,f,g,h,i,j,k,l,NullType(),NullType(),NullType(),NullType());
+               return *this;
+       }
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,NullType,NullType,NullType,NullType> &After(Call &call) {
+               previousCalls.push_back(&call);
+               return *this;
+       }
+       template <typename T>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,NullType,NullType,NullType,NullType> &Do(T function) { functor = new DoWrapper<T,Y,A,B,C,D,E,F,G,H,I,J,K,L,NullType,NullType,NullType,NullType>(function); return *this; }
+       template <typename T>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,NullType,NullType,NullType,NullType> &Match(T function) { matchFunctor = new DoWrapper<T,bool,A,B,C,D,E,F,G,H,I,J,K,L,NullType,NullType,NullType,NullType>(function); return *this; }
+       Call &Return(Y obj) { retVal = new ReturnValueWrapperCopy<Y>(obj); return *this; }
+       Call &ReturnByRef(Y obj) { retVal = new ReturnValueWrapperRef<Y>(obj); return *this; }
+#ifndef HM_NO_EXCEPTIONS
+       template <typename Ex>
+       Call &Throw(Ex exception) { eHolder = new ExceptionWrapper<Ex>(exception); return *this; }
+#endif
+};
+template <typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H,
+                 typename I, typename J, typename K, typename L>
+class TCall<void,A,B,C,D,E,F,G,H,I,J,K,L,NullType,NullType,NullType,NullType> : public Call {
+private:
+       ref_comparable_assignable_tuple<A,B,C,D,E,F,G,H,I,J,K,L,NullType,NullType,NullType,NullType> *args;
+public:
+               const base_tuple *getArgs() const { return args; }
+       TCall(RegistrationType expect, base_mock *baseMock, std::pair<int, int> index, int X, const char *func, const char *file) : Call(expect, baseMock, index, X, func ,file), args(0) {}
+       ~TCall() { delete args; }
+       bool matchesArgs(const base_tuple &tupl) {
+               return (!args && !matchFunctor) ||
+                       (args && (*args == reinterpret_cast<const ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,NullType,NullType,NullType,NullType> &>(tupl))) ||
+                       (matchFunctor && (*(TupleInvocable<bool> *)(matchFunctor))(tupl));
+       }
+       void assignArgs(base_tuple &tupl) {
+               if(args) {
+                       args->assign_to(static_cast<ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,NullType,NullType,NullType,NullType> &>(tupl));
+                       args->assign_from(static_cast<ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,NullType,NullType,NullType,NullType> &>(tupl));
+               }
+       }
+       template <typename CA, typename CB, typename CC, typename CD,
+                         typename CE, typename CF, typename CG, typename CH,
+                         typename CI, typename CJ, typename CK, typename CL>
+       TCall<void,A,B,C,D,E,F,G,H,I,J,K,L,NullType,NullType,NullType,NullType> &With(const CA & a, const CB & b, const CC & c, const CD & d, const CE & e, const CF & f, const CG & g, const CH & h, const CI & i, const CJ & j, const CK & k, const CL & l) {
+               args = new copy_tuple<A,B,C,D,E,F,G,H,I,J,K,L,NullType,NullType,NullType,NullType,
+                                                               const CA &,const CB &,const CC &,const CD &,const CE &,const CF &,const CG &,const CH &,const CI &,const CJ &,const CK &,const CL &,NullType,NullType,NullType,NullType>(a,b,c,d,e,f,g,h,i,j,k,l,NullType(),NullType(),NullType(),NullType());
+               return *this;
+       }
+       TCall<void,A,B,C,D,E,F,G,H,I,J,K,L,NullType,NullType,NullType,NullType> &After(Call &call) {
+               previousCalls.push_back(&call);
+               return *this;
+       }
+       template <typename T>
+       TCall<void,A,B,C,D,E,F,G,H,I,J,K,L,NullType,NullType,NullType,NullType> &Do(T function) { functor = new DoWrapper<T,void,A,B,C,D,E,F,G,H,I,J,K,L,NullType,NullType,NullType,NullType>(function); return *this; }
+       template <typename T>
+       TCall<void,A,B,C,D,E,F,G,H,I,J,K,L,NullType,NullType,NullType,NullType> &Match(T function) { matchFunctor = new DoWrapper<T,bool,A,B,C,D,E,F,G,H,I,J,K,L,NullType,NullType,NullType,NullType>(function); return *this; }
+#ifndef HM_NO_EXCEPTIONS
+       template <typename Ex>
+       Call &Throw(Ex exception) { eHolder = new ExceptionWrapper<Ex>(exception); return *this; }
+#endif
+};
+
+template <typename Y,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H,
+                 typename I, typename J, typename K>
+class TCall<Y,A,B,C,D,E,F,G,H,I,J,K,NullType,NullType,NullType,NullType,NullType> : public Call {
+private:
+       ref_comparable_assignable_tuple<A,B,C,D,E,F,G,H,I,J,K,NullType,NullType,NullType,NullType,NullType> *args;
+public:
+               const base_tuple *getArgs() const { return args; }
+       TCall(RegistrationType expect, base_mock *baseMock, std::pair<int, int> index, int X, const char *func, const char *file) : Call(expect, baseMock, index, X, func ,file), args(0) {}
+       ~TCall() { delete args; }
+       bool matchesArgs(const base_tuple &tupl) {
+               return (!args && !matchFunctor) ||
+                       (args && (*args == reinterpret_cast<const ref_tuple<A,B,C,D,E,F,G,H,I,J,K,NullType,NullType,NullType,NullType,NullType> &>(tupl))) ||
+                       (matchFunctor && (*(TupleInvocable<bool> *)(matchFunctor))(tupl));
+       }
+       void assignArgs(base_tuple &tupl) {
+               if(args) {
+                       args->assign_to(static_cast<ref_tuple<A,B,C,D,E,F,G,H,I,J,K,NullType,NullType,NullType,NullType,NullType> &>(tupl));
+                       args->assign_from(static_cast<ref_tuple<A,B,C,D,E,F,G,H,I,J,K,NullType,NullType,NullType,NullType,NullType> &>(tupl));
+               }
+       }
+       template <typename CA, typename CB, typename CC, typename CD,
+                         typename CE, typename CF, typename CG, typename CH,
+                         typename CI, typename CJ, typename CK>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,NullType,NullType,NullType,NullType,NullType> &With(const CA & a, const CB & b, const CC & c, const CD & d, const CE & e, const CF & f, const CG & g, const CH & h, const CI & i, const CJ & j, const CK & k) {
+               args = new copy_tuple<A,B,C,D,E,F,G,H,I,J,K,NullType,NullType,NullType,NullType,NullType,
+                                                               const CA &,const CB &,const CC &,const CD &,const CE &,const CF &,const CG &,const CH &,const CI &,const CJ &,const CK &,NullType,NullType,NullType,NullType,NullType>(a,b,c,d,e,f,g,h,i,j,k,NullType(),NullType(),NullType(),NullType(),NullType());
+               return *this;
+       }
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,NullType,NullType,NullType,NullType,NullType> &After(Call &call) {
+               previousCalls.push_back(&call);
+               return *this;
+       }
+       template <typename T>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,NullType,NullType,NullType,NullType,NullType> &Do(T function) { functor = new DoWrapper<T,Y,A,B,C,D,E,F,G,H,I,J,K,NullType,NullType,NullType,NullType,NullType>(function); return *this; }
+       template <typename T>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,NullType,NullType,NullType,NullType,NullType> &Match(T function) { matchFunctor = new DoWrapper<T,bool,A,B,C,D,E,F,G,H,I,J,K,NullType,NullType,NullType,NullType,NullType>(function); return *this; }
+       Call &Return(Y obj) { retVal = new ReturnValueWrapperCopy<Y>(obj); return *this; }
+       Call &ReturnByRef(Y obj) { retVal = new ReturnValueWrapperRef<Y>(obj); return *this; }
+#ifndef HM_NO_EXCEPTIONS
+       template <typename Ex>
+       Call &Throw(Ex exception) { eHolder = new ExceptionWrapper<Ex>(exception); return *this; }
+#endif
+};
+template <typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H,
+                 typename I, typename J, typename K>
+class TCall<void,A,B,C,D,E,F,G,H,I,J,K,NullType,NullType,NullType,NullType,NullType> : public Call {
+private:
+       ref_comparable_assignable_tuple<A,B,C,D,E,F,G,H,I,J,K,NullType,NullType,NullType,NullType,NullType> *args;
+public:
+               const base_tuple *getArgs() const { return args; }
+       TCall(RegistrationType expect, base_mock *baseMock, std::pair<int, int> index, int X, const char *func, const char *file) : Call(expect, baseMock, index, X, func ,file), args(0) {}
+       ~TCall() { delete args; }
+       bool matchesArgs(const base_tuple &tupl) {
+               return (!args && !matchFunctor) ||
+                       (args && (*args == reinterpret_cast<const ref_tuple<A,B,C,D,E,F,G,H,I,J,K,NullType,NullType,NullType,NullType,NullType> &>(tupl))) ||
+                       (matchFunctor && (*(TupleInvocable<bool> *)(matchFunctor))(tupl));
+       }
+       void assignArgs(base_tuple &tupl) {
+               if(args) {
+                       args->assign_to(static_cast<ref_tuple<A,B,C,D,E,F,G,H,I,J,K,NullType,NullType,NullType,NullType,NullType> &>(tupl));
+                       args->assign_from(static_cast<ref_tuple<A,B,C,D,E,F,G,H,I,J,K,NullType,NullType,NullType,NullType,NullType> &>(tupl));
+               }
+       }
+       template <typename CA, typename CB, typename CC, typename CD,
+                         typename CE, typename CF, typename CG, typename CH,
+                         typename CI, typename CJ, typename CK>
+       TCall<void,A,B,C,D,E,F,G,H,I,J,K,NullType,NullType,NullType,NullType,NullType> &With(const CA & a, const CB & b, const CC & c, const CD & d, const CE & e, const CF & f, const CG & g, const CH & h, const CI & i, const CJ & j, const CK & k) {
+               args = new copy_tuple<A,B,C,D,E,F,G,H,I,J,K,NullType,NullType,NullType,NullType,NullType,
+                                                               const CA &,const CB &,const CC &,const CD &,const CE &,const CF &,const CG &,const CH &,const CI &,const CJ &,const CK &,NullType,NullType,NullType,NullType,NullType>(a,b,c,d,e,f,g,h,i,j,k,NullType(),NullType(),NullType(),NullType(),NullType());
+               return *this;
+       }
+       TCall<void,A,B,C,D,E,F,G,H,I,J,K,NullType,NullType,NullType,NullType,NullType> &After(Call &call) {
+               previousCalls.push_back(&call);
+               return *this;
+       }
+       template <typename T>
+       TCall<void,A,B,C,D,E,F,G,H,I,J,K,NullType,NullType,NullType,NullType,NullType> &Do(T function) { functor = new DoWrapper<T,void,A,B,C,D,E,F,G,H,I,J,K,NullType,NullType,NullType,NullType,NullType>(function); return *this; }
+       template <typename T>
+       TCall<void,A,B,C,D,E,F,G,H,I,J,K,NullType,NullType,NullType,NullType,NullType> &Match(T function) { matchFunctor = new DoWrapper<T,bool,A,B,C,D,E,F,G,H,I,J,K,NullType,NullType,NullType,NullType,NullType>(function); return *this; }
+#ifndef HM_NO_EXCEPTIONS
+       template <typename Ex>
+       Call &Throw(Ex exception) { eHolder = new ExceptionWrapper<Ex>(exception); return *this; }
+#endif
+};
+
+template <typename Y,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H,
+                 typename I, typename J>
+class TCall<Y,A,B,C,D,E,F,G,H,I,J,NullType,NullType,NullType,NullType,NullType,NullType> : public Call {
+private:
+       ref_comparable_assignable_tuple<A,B,C,D,E,F,G,H,I,J,NullType,NullType,NullType,NullType,NullType,NullType> *args;
+public:
+               const base_tuple *getArgs() const { return args; }
+       TCall(RegistrationType expect, base_mock *baseMock, std::pair<int, int> index, int X, const char *func, const char *file) : Call(expect, baseMock, index, X, func ,file), args(0) {}
+       ~TCall() { delete args; }
+       bool matchesArgs(const base_tuple &tupl) {
+               return (!args && !matchFunctor) ||
+                       (args && (*args == reinterpret_cast<const ref_tuple<A,B,C,D,E,F,G,H,I,J,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl))) ||
+                       (matchFunctor && (*(TupleInvocable<bool> *)(matchFunctor))(tupl));
+       }
+       void assignArgs(base_tuple &tupl) {
+               if(args) {
+                       args->assign_to(static_cast<ref_tuple<A,B,C,D,E,F,G,H,I,J,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl));
+                       args->assign_from(static_cast<ref_tuple<A,B,C,D,E,F,G,H,I,J,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl));
+               }
+       }
+       template <typename CA, typename CB, typename CC, typename CD,
+                         typename CE, typename CF, typename CG, typename CH,
+                         typename CI, typename CJ>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,NullType,NullType,NullType,NullType,NullType,NullType> &With(const CA & a, const CB & b, const CC & c, const CD & d, const CE & e, const CF & f, const CG & g, const CH & h, const CI & i, const CJ & j) {
+               args = new copy_tuple<A,B,C,D,E,F,G,H,I,J,NullType,NullType,NullType,NullType,NullType,NullType,
+                                                               const CA &,const CB &,const CC &,const CD &,const CE &,const CF &,const CG &,const CH &,const CI &,const CJ &,NullType,NullType,NullType,NullType,NullType,NullType>(a,b,c,d,e,f,g,h,i,j,NullType(),NullType(),NullType(),NullType(),NullType(),NullType());
+               return *this;
+       }
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,NullType,NullType,NullType,NullType,NullType,NullType> &After(Call &call) {
+               previousCalls.push_back(&call);
+               return *this;
+       }
+       template <typename T>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,NullType,NullType,NullType,NullType,NullType,NullType> &Do(T function) { functor = new DoWrapper<T,Y,A,B,C,D,E,F,G,H,I,J,NullType,NullType,NullType,NullType,NullType,NullType>(function); return *this; }
+       template <typename T>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,NullType,NullType,NullType,NullType,NullType,NullType> &Match(T function) { matchFunctor = new DoWrapper<T,bool,A,B,C,D,E,F,G,H,I,J,NullType,NullType,NullType,NullType,NullType,NullType>(function); return *this; }
+       Call &Return(Y obj) { retVal = new ReturnValueWrapperCopy<Y>(obj); return *this; }
+       Call &ReturnByRef(Y obj) { retVal = new ReturnValueWrapperRef<Y>(obj); return *this; }
+#ifndef HM_NO_EXCEPTIONS
+       template <typename Ex>
+       Call &Throw(Ex exception) { eHolder = new ExceptionWrapper<Ex>(exception); return *this; }
+#endif
+};
+template <typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H,
+                 typename I, typename J>
+class TCall<void,A,B,C,D,E,F,G,H,I,J,NullType,NullType,NullType,NullType,NullType,NullType> : public Call {
+private:
+       ref_comparable_assignable_tuple<A,B,C,D,E,F,G,H,I,J,NullType,NullType,NullType,NullType,NullType,NullType> *args;
+public:
+               const base_tuple *getArgs() const { return args; }
+       TCall(RegistrationType expect, base_mock *baseMock, std::pair<int, int> index, int X, const char *func, const char *file) : Call(expect, baseMock, index, X, func ,file), args(0) {}
+       ~TCall() { delete args; }
+       bool matchesArgs(const base_tuple &tupl) {
+               return (!args && !matchFunctor) ||
+                       (args && (*args == reinterpret_cast<const ref_tuple<A,B,C,D,E,F,G,H,I,J,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl))) ||
+                       (matchFunctor && (*(TupleInvocable<bool> *)(matchFunctor))(tupl));
+       }
+       void assignArgs(base_tuple &tupl) {
+               if(args) {
+                       args->assign_to(static_cast<ref_tuple<A,B,C,D,E,F,G,H,I,J,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl));
+                       args->assign_from(static_cast<ref_tuple<A,B,C,D,E,F,G,H,I,J,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl));
+               }
+       }
+       template <typename CA, typename CB, typename CC, typename CD,
+                         typename CE, typename CF, typename CG, typename CH,
+                         typename CI, typename CJ>
+       TCall<void,A,B,C,D,E,F,G,H,I,J,NullType,NullType,NullType,NullType,NullType,NullType> &With(const CA & a, const CB & b, const CC & c, const CD & d, const CE & e, const CF & f, const CG & g, const CH & h, const CI & i, const CJ & j) {
+               args = new copy_tuple<A,B,C,D,E,F,G,H,I,J,NullType,NullType,NullType,NullType,NullType,NullType,
+                                                               const CA &,const CB &,const CC &,const CD &,const CE &,const CF &,const CG &,const CH &,const CI &,const CJ &,NullType,NullType,NullType,NullType,NullType,NullType>(a,b,c,d,e,f,g,h,i,j,NullType(),NullType(),NullType(),NullType(),NullType(),NullType());
+               return *this;
+       }
+       TCall<void,A,B,C,D,E,F,G,H,I,J,NullType,NullType,NullType,NullType,NullType,NullType> &After(Call &call) {
+               previousCalls.push_back(&call);
+               return *this;
+       }
+       template <typename T>
+       TCall<void,A,B,C,D,E,F,G,H,I,J,NullType,NullType,NullType,NullType,NullType,NullType> &Do(T function) { functor = new DoWrapper<T,void,A,B,C,D,E,F,G,H,I,J,NullType,NullType,NullType,NullType,NullType,NullType>(function); return *this; }
+       template <typename T>
+       TCall<void,A,B,C,D,E,F,G,H,I,J,NullType,NullType,NullType,NullType,NullType,NullType> &Match(T function) { matchFunctor = new DoWrapper<T,bool,A,B,C,D,E,F,G,H,I,J,NullType,NullType,NullType,NullType,NullType,NullType>(function); return *this; }
+#ifndef HM_NO_EXCEPTIONS
+       template <typename Ex>
+       Call &Throw(Ex exception) { eHolder = new ExceptionWrapper<Ex>(exception); return *this; }
+#endif
+};
+
+template <typename Y,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H,
+                 typename I>
+class TCall<Y,A,B,C,D,E,F,G,H,I,NullType,NullType,NullType,NullType,NullType,NullType,NullType> : public Call {
+private:
+       ref_comparable_assignable_tuple<A,B,C,D,E,F,G,H,I,NullType,NullType,NullType,NullType,NullType,NullType,NullType> *args;
+public:
+               const base_tuple *getArgs() const { return args; }
+       TCall(RegistrationType expect, base_mock *baseMock, std::pair<int, int> index, int X, const char *func, const char *file) : Call(expect, baseMock, index, X, func ,file), args(0) {}
+       ~TCall() { delete args; }
+       bool matchesArgs(const base_tuple &tupl) {
+               return (!args && !matchFunctor) ||
+                       (args && (*args == reinterpret_cast<const ref_tuple<A,B,C,D,E,F,G,H,I,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl))) ||
+                       (matchFunctor && (*(TupleInvocable<bool> *)(matchFunctor))(tupl));
+       }
+       void assignArgs(base_tuple &tupl) {
+               if(args) {
+                       args->assign_to(static_cast<ref_tuple<A,B,C,D,E,F,G,H,I,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl));
+                       args->assign_from(static_cast<ref_tuple<A,B,C,D,E,F,G,H,I,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl));
+               }
+       }
+       template <typename CA, typename CB, typename CC, typename CD,
+                         typename CE, typename CF, typename CG, typename CH,
+                         typename CI>
+       TCall<Y,A,B,C,D,E,F,G,H,I,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &With(const CA & a, const CB & b, const CC & c, const CD & d, const CE & e, const CF & f, const CG & g, const CH & h, const CI & i) {
+               args = new copy_tuple<A,B,C,D,E,F,G,H,I,NullType,NullType,NullType,NullType,NullType,NullType,NullType,
+                                                               const CA &,const CB &,const CC &,const CD &,const CE &,const CF &,const CG &,const CH &,const CI &,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(a,b,c,d,e,f,g,h,i,NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType());
+               return *this;
+       }
+       TCall<Y,A,B,C,D,E,F,G,H,I,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &After(Call &call) {
+               previousCalls.push_back(&call);
+               return *this;
+       }
+       template <typename T>
+       TCall<Y,A,B,C,D,E,F,G,H,I,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &Do(T function) { functor = new DoWrapper<T,Y,A,B,C,D,E,F,G,H,I,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(function); return *this; }
+       template <typename T>
+       TCall<Y,A,B,C,D,E,F,G,H,I,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &Match(T function) { matchFunctor = new DoWrapper<T,bool,A,B,C,D,E,F,G,H,I,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(function); return *this; }
+       Call &Return(Y obj) { retVal = new ReturnValueWrapperCopy<Y>(obj); return *this; }
+       Call &ReturnByRef(Y obj) { retVal = new ReturnValueWrapperRef<Y>(obj); return *this; }
+#ifndef HM_NO_EXCEPTIONS
+       template <typename Ex>
+       Call &Throw(Ex exception) { eHolder = new ExceptionWrapper<Ex>(exception); return *this; }
+#endif
+};
+template <typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H,
+                 typename I>
+class TCall<void,A,B,C,D,E,F,G,H,I,NullType,NullType,NullType,NullType,NullType,NullType,NullType> : public Call {
+private:
+       ref_comparable_assignable_tuple<A,B,C,D,E,F,G,H,I,NullType,NullType,NullType,NullType,NullType,NullType,NullType> *args;
+public:
+               const base_tuple *getArgs() const { return args; }
+       TCall(RegistrationType expect, base_mock *baseMock, std::pair<int, int> index, int X, const char *func, const char *file) : Call(expect, baseMock, index, X, func ,file), args(0) {}
+       ~TCall() { delete args; }
+       bool matchesArgs(const base_tuple &tupl) {
+               return (!args && !matchFunctor) ||
+                       (args && (*args == reinterpret_cast<const ref_tuple<A,B,C,D,E,F,G,H,I,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl))) ||
+                       (matchFunctor && (*(TupleInvocable<bool> *)(matchFunctor))(tupl));
+       }
+       void assignArgs(base_tuple &tupl) {
+               if(args) {
+                       args->assign_to(static_cast<ref_tuple<A,B,C,D,E,F,G,H,I,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl));
+                       args->assign_from(static_cast<ref_tuple<A,B,C,D,E,F,G,H,I,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl));
+               }
+       }
+       template <typename CA, typename CB, typename CC, typename CD,
+                         typename CE, typename CF, typename CG, typename CH,
+                         typename CI>
+       TCall<void,A,B,C,D,E,F,G,H,I,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &With(const CA & a, const CB & b, const CC & c, const CD & d, const CE & e, const CF & f, const CG & g, const CH & h, const CI & i) {
+               args = new copy_tuple<A,B,C,D,E,F,G,H,I,NullType,NullType,NullType,NullType,NullType,NullType,NullType,
+                                                               const CA &,const CB &,const CC &,const CD &,const CE &,const CF &,const CG &,const CH &,const CI &,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(a,b,c,d,e,f,g,h,i,NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType());
+               return *this;
+       }
+       TCall<void,A,B,C,D,E,F,G,H,I,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &After(Call &call) {
+               previousCalls.push_back(&call);
+               return *this;
+       }
+       template <typename T>
+       TCall<void,A,B,C,D,E,F,G,H,I,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &Do(T function) { functor = new DoWrapper<T,void,A,B,C,D,E,F,G,H,I,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(function); return *this; }
+       template <typename T>
+       TCall<void,A,B,C,D,E,F,G,H,I,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &Match(T function) { matchFunctor = new DoWrapper<T,bool,A,B,C,D,E,F,G,H,I,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(function); return *this; }
+#ifndef HM_NO_EXCEPTIONS
+       template <typename Ex>
+       Call &Throw(Ex exception) { eHolder = new ExceptionWrapper<Ex>(exception); return *this; }
+#endif
+};
+
+template <typename Y,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H>
+class TCall<Y,A,B,C,D,E,F,G,H,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> : public Call {
+private:
+       ref_comparable_assignable_tuple<A,B,C,D,E,F,G,H,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> *args;
+public:
+               const base_tuple *getArgs() const { return args; }
+       TCall(RegistrationType expect, base_mock *baseMock, std::pair<int, int> index, int X, const char *func, const char *file) : Call(expect, baseMock, index, X, func ,file), args(0) {}
+       ~TCall() { delete args; }
+       bool matchesArgs(const base_tuple &tupl) {
+               return (!args && !matchFunctor) ||
+                       (args && (*args == reinterpret_cast<const ref_tuple<A,B,C,D,E,F,G,H,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl))) ||
+                       (matchFunctor && (*(TupleInvocable<bool> *)(matchFunctor))(tupl));
+       }
+       void assignArgs(base_tuple &tupl) {
+               if(args) {
+                       args->assign_to(static_cast<ref_tuple<A,B,C,D,E,F,G,H,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl));
+                       args->assign_from(static_cast<ref_tuple<A,B,C,D,E,F,G,H,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl));
+               }
+       }
+       template <typename CA, typename CB, typename CC, typename CD,
+                         typename CE, typename CF, typename CG, typename CH>
+       TCall<Y,A,B,C,D,E,F,G,H,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &With(const CA & a, const CB & b, const CC & c, const CD & d, const CE & e, const CF & f, const CG & g, const CH & h) {
+               args = new copy_tuple<A,B,C,D,E,F,G,H,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,
+                                                               const CA &,const CB &,const CC &,const CD &,const CE &,const CF &,const CG &,const CH &,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(a,b,c,d,e,f,g,h,NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType());
+               return *this;
+       }
+       TCall<Y,A,B,C,D,E,F,G,H,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &After(Call &call) {
+               previousCalls.push_back(&call);
+               return *this;
+       }
+       template <typename T>
+       TCall<Y,A,B,C,D,E,F,G,H,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &Do(T function) { functor = new DoWrapper<T,Y,A,B,C,D,E,F,G,H,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(function); return *this; }
+       template <typename T>
+       TCall<Y,A,B,C,D,E,F,G,H,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &Match(T function) { matchFunctor = new DoWrapper<T,bool,A,B,C,D,E,F,G,H,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(function); return *this; }
+       Call &Return(Y obj) { retVal = new ReturnValueWrapperCopy<Y>(obj); return *this; }
+       Call &ReturnByRef(Y obj) { retVal = new ReturnValueWrapperRef<Y>(obj); return *this; }
+#ifndef HM_NO_EXCEPTIONS
+       template <typename Ex>
+       Call &Throw(Ex exception) { eHolder = new ExceptionWrapper<Ex>(exception); return *this; }
+#endif
+};
+template <typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H>
+class TCall<void,A,B,C,D,E,F,G,H,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> : public Call {
+private:
+       ref_comparable_assignable_tuple<A,B,C,D,E,F,G,H,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> *args;
+public:
+               const base_tuple *getArgs() const { return args; }
+       TCall(RegistrationType expect, base_mock *baseMock, std::pair<int, int> index, int X, const char *func, const char *file) : Call(expect, baseMock, index, X, func ,file), args(0) {}
+       ~TCall() { delete args; }
+       bool matchesArgs(const base_tuple &tupl) {
+               return (!args && !matchFunctor) ||
+                       (args && (*args == reinterpret_cast<const ref_tuple<A,B,C,D,E,F,G,H,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl))) ||
+                       (matchFunctor && (*(TupleInvocable<bool> *)(matchFunctor))(tupl));
+       }
+       void assignArgs(base_tuple &tupl) {
+               if(args) {
+                       args->assign_to(static_cast<ref_tuple<A,B,C,D,E,F,G,H,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl));
+                       args->assign_from(static_cast<ref_tuple<A,B,C,D,E,F,G,H,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl));
+               }
+       }
+       template <typename CA, typename CB, typename CC, typename CD,
+                         typename CE, typename CF, typename CG, typename CH>
+       TCall<void,A,B,C,D,E,F,G,H,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &With(const CA & a, const CB & b, const CC & c, const CD & d, const CE & e, const CF & f, const CG & g, const CH & h) {
+               args = new copy_tuple<A,B,C,D,E,F,G,H,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,
+                                                               const CA &,const CB &,const CC &,const CD &,const CE &,const CF &,const CG &,const CH &,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(a,b,c,d,e,f,g,h,NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType());
+               return *this;
+       }
+       TCall<void,A,B,C,D,E,F,G,H,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &After(Call &call) {
+               previousCalls.push_back(&call);
+               return *this;
+       }
+       template <typename T>
+       TCall<void,A,B,C,D,E,F,G,H,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &Do(T function) { functor = new DoWrapper<T,void,A,B,C,D,E,F,G,H,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(function); return *this; }
+       template <typename T>
+       TCall<void,A,B,C,D,E,F,G,H,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &Match(T function) { matchFunctor = new DoWrapper<T,bool,A,B,C,D,E,F,G,H,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(function); return *this; }
+#ifndef HM_NO_EXCEPTIONS
+       template <typename Ex>
+       Call &Throw(Ex exception) { eHolder = new ExceptionWrapper<Ex>(exception); return *this; }
+#endif
+};
+
+template <typename Y,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G>
+class TCall<Y,A,B,C,D,E,F,G,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> : public Call {
+private:
+       ref_comparable_assignable_tuple<A,B,C,D,E,F,G,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> *args;
+public:
+               const base_tuple *getArgs() const { return args; }
+       TCall(RegistrationType expect, base_mock *baseMock, std::pair<int, int> index, int X, const char *func, const char *file) : Call(expect, baseMock, index, X, func ,file), args(0) {}
+       ~TCall() { delete args; }
+       bool matchesArgs(const base_tuple &tupl) {
+               return (!args && !matchFunctor) ||
+                       (args && (*args == reinterpret_cast<const ref_tuple<A,B,C,D,E,F,G,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl))) ||
+                       (matchFunctor && (*(TupleInvocable<bool> *)(matchFunctor))(tupl));
+       }
+       void assignArgs(base_tuple &tupl) {
+               if(args) {
+                       args->assign_to(static_cast<ref_tuple<A,B,C,D,E,F,G,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl));
+                       args->assign_from(static_cast<ref_tuple<A,B,C,D,E,F,G,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl));
+               }
+       }
+       template <typename CA, typename CB, typename CC, typename CD,
+                         typename CE, typename CF, typename CG>
+       TCall<Y,A,B,C,D,E,F,G,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &With(const CA & a, const CB & b, const CC & c, const CD & d, const CE & e, const CF & f, const CG & g) {
+               args = new copy_tuple<A,B,C,D,E,F,G,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,
+                                                               const CA &,const CB &,const CC &,const CD &,const CE &,const CF &,const CG &,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(a,b,c,d,e,f,g,NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType());
+               return *this;
+       }
+       TCall<Y,A,B,C,D,E,F,G,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &After(Call &call) {
+               previousCalls.push_back(&call);
+               return *this;
+       }
+       template <typename T>
+       TCall<Y,A,B,C,D,E,F,G,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &Do(T function) { functor = new DoWrapper<T,Y,A,B,C,D,E,F,G,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(function); return *this; }
+       template <typename T>
+       TCall<Y,A,B,C,D,E,F,G,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &Match(T function) { matchFunctor = new DoWrapper<T,bool,A,B,C,D,E,F,G,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(function); return *this; }
+       Call &Return(Y obj) { retVal = new ReturnValueWrapperCopy<Y>(obj); return *this; }
+       Call &ReturnByRef(Y obj) { retVal = new ReturnValueWrapperRef<Y>(obj); return *this; }
+#ifndef HM_NO_EXCEPTIONS
+       template <typename Ex>
+       Call &Throw(Ex exception) { eHolder = new ExceptionWrapper<Ex>(exception); return *this; }
+#endif
+};
+template <typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G>
+class TCall<void,A,B,C,D,E,F,G,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> : public Call {
+private:
+       ref_comparable_assignable_tuple<A,B,C,D,E,F,G,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> *args;
+public:
+               const base_tuple *getArgs() const { return args; }
+       TCall(RegistrationType expect, base_mock *baseMock, std::pair<int, int> index, int X, const char *func, const char *file) : Call(expect, baseMock, index, X, func ,file), args(0) {}
+       ~TCall() { delete args; }
+       bool matchesArgs(const base_tuple &tupl) {
+               return (!args && !matchFunctor) ||
+                       (args && (*args == reinterpret_cast<const ref_tuple<A,B,C,D,E,F,G,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl))) ||
+                       (matchFunctor && (*(TupleInvocable<bool> *)(matchFunctor))(tupl));
+       }
+       void assignArgs(base_tuple &tupl) {
+               if(args) {
+                       args->assign_to(static_cast<ref_tuple<A,B,C,D,E,F,G,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl));
+                       args->assign_from(static_cast<ref_tuple<A,B,C,D,E,F,G,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl));
+               }
+       }
+       template <typename CA, typename CB, typename CC, typename CD,
+                         typename CE, typename CF, typename CG>
+       TCall<void,A,B,C,D,E,F,G,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &With(const CA & a, const CB & b, const CC & c, const CD & d, const CE & e, const CF & f, const CG & g) {
+               args = new copy_tuple<A,B,C,D,E,F,G,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,
+                                                               const CA &,const CB &,const CC &,const CD &,const CE &,const CF &,const CG &,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(a,b,c,d,e,f,g,NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType());
+               return *this;
+       }
+       TCall<void,A,B,C,D,E,F,G,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &After(Call &call) {
+               previousCalls.push_back(&call);
+               return *this;
+       }
+       template <typename T>
+       TCall<void,A,B,C,D,E,F,G,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &Do(T function) { functor = new DoWrapper<T,void,A,B,C,D,E,F,G,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(function); return *this; }
+       template <typename T>
+       TCall<void,A,B,C,D,E,F,G,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &Match(T function) { matchFunctor = new DoWrapper<T,bool,A,B,C,D,E,F,G,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(function); return *this; }
+#ifndef HM_NO_EXCEPTIONS
+       template <typename Ex>
+       Call &Throw(Ex exception) { eHolder = new ExceptionWrapper<Ex>(exception); return *this; }
+#endif
+};
+
+template <typename Y,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F>
+class TCall<Y,A,B,C,D,E,F,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> : public Call {
+private:
+       ref_comparable_assignable_tuple<A,B,C,D,E,F,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> *args;
+public:
+               const base_tuple *getArgs() const { return args; }
+       TCall(RegistrationType expect, base_mock *baseMock, std::pair<int, int> index, int X, const char *func, const char *file) : Call(expect, baseMock, index, X, func ,file), args(0) {}
+       ~TCall() { delete args; }
+       bool matchesArgs(const base_tuple &tupl) {
+               return (!args && !matchFunctor) ||
+                       (args && (*args == reinterpret_cast<const ref_tuple<A,B,C,D,E,F,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl))) ||
+                       (matchFunctor && (*(TupleInvocable<bool> *)(matchFunctor))(tupl));
+       }
+       void assignArgs(base_tuple &tupl) {
+               if(args) {
+                       args->assign_to(static_cast<ref_tuple<A,B,C,D,E,F,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl));
+                       args->assign_from(static_cast<ref_tuple<A,B,C,D,E,F,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl));
+               }
+       }
+       template <typename CA, typename CB, typename CC, typename CD,
+                         typename CE, typename CF>
+       TCall<Y,A,B,C,D,E,F,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &With(const CA & a, const CB & b, const CC & c, const CD & d, const CE & e, const CF & f) {
+               args = new copy_tuple<A,B,C,D,E,F,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,
+                                                               const CA &,const CB &,const CC &,const CD &,const CE &,const CF &,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(a,b,c,d,e,f,NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType());
+               return *this;
+       }
+       TCall<Y,A,B,C,D,E,F,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &After(Call &call) {
+               previousCalls.push_back(&call);
+               return *this;
+       }
+       template <typename T>
+       TCall<Y,A,B,C,D,E,F,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &Do(T function) { functor = new DoWrapper<T,Y,A,B,C,D,E,F,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(function); return *this; }
+       template <typename T>
+       TCall<Y,A,B,C,D,E,F,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &Match(T function) { matchFunctor = new DoWrapper<T,bool,A,B,C,D,E,F,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(function); return *this; }
+       Call &Return(Y obj) { retVal = new ReturnValueWrapperCopy<Y>(obj); return *this; }
+       Call &ReturnByRef(Y obj) { retVal = new ReturnValueWrapperRef<Y>(obj); return *this; }
+#ifndef HM_NO_EXCEPTIONS
+       template <typename Ex>
+       Call &Throw(Ex exception) { eHolder = new ExceptionWrapper<Ex>(exception); return *this; }
+#endif
+};
+template <typename A, typename B, typename C, typename D,
+                 typename E, typename F>
+class TCall<void,A,B,C,D,E,F,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> : public Call {
+private:
+       ref_comparable_assignable_tuple<A,B,C,D,E,F,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> *args;
+public:
+               const base_tuple *getArgs() const { return args; }
+       TCall(RegistrationType expect, base_mock *baseMock, std::pair<int, int> index, int X, const char *func, const char *file) : Call(expect, baseMock, index, X, func ,file), args(0) {}
+       ~TCall() { delete args; }
+       bool matchesArgs(const base_tuple &tupl) {
+               return (!args && !matchFunctor) ||
+                       (args && (*args == reinterpret_cast<const ref_tuple<A,B,C,D,E,F,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl))) ||
+                       (matchFunctor && (*(TupleInvocable<bool> *)(matchFunctor))(tupl));
+       }
+       void assignArgs(base_tuple &tupl) {
+               if(args) {
+                       args->assign_to(static_cast<ref_tuple<A,B,C,D,E,F,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl));
+                       args->assign_from(static_cast<ref_tuple<A,B,C,D,E,F,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl));
+               }
+       }
+       template <typename CA, typename CB, typename CC, typename CD,
+                         typename CE, typename CF>
+       TCall<void,A,B,C,D,E,F,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &With(const CA & a, const CB & b, const CC & c, const CD & d, const CE & e, const CF & f) {
+               args = new copy_tuple<A,B,C,D,E,F,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,
+                                                               const CA &,const CB &,const CC &,const CD &,const CE &,const CF &,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(a,b,c,d,e,f,NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType());
+               return *this;
+       }
+       TCall<void,A,B,C,D,E,F,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &After(Call &call) {
+               previousCalls.push_back(&call);
+               return *this;
+       }
+       template <typename T>
+       TCall<void,A,B,C,D,E,F,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &Do(T function) { functor = new DoWrapper<T,void,A,B,C,D,E,F,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(function); return *this; }
+       template <typename T>
+       TCall<void,A,B,C,D,E,F,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &Match(T function) { matchFunctor = new DoWrapper<T,bool,A,B,C,D,E,F,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(function); return *this; }
+#ifndef HM_NO_EXCEPTIONS
+       template <typename Ex>
+       Call &Throw(Ex exception) { eHolder = new ExceptionWrapper<Ex>(exception); return *this; }
+#endif
+};
+
+template <typename Y,
+                 typename A, typename B, typename C, typename D,
+                 typename E>
+class TCall<Y,A,B,C,D,E,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> : public Call {
+private:
+       ref_comparable_assignable_tuple<A,B,C,D,E,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> *args;
+public:
+               const base_tuple *getArgs() const { return args; }
+       TCall(RegistrationType expect, base_mock *baseMock, std::pair<int, int> index, int X, const char *func, const char *file) : Call(expect, baseMock, index, X, func ,file), args(0) {}
+       ~TCall() { delete args; }
+       bool matchesArgs(const base_tuple &tupl) {
+               return (!args && !matchFunctor) ||
+                       (args && (*args == reinterpret_cast<const ref_tuple<A,B,C,D,E,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl))) ||
+                       (matchFunctor && (*(TupleInvocable<bool> *)(matchFunctor))(tupl));
+       }
+       void assignArgs(base_tuple &tupl) {
+               if(args) {
+                       args->assign_to(static_cast<ref_tuple<A,B,C,D,E,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl));
+                       args->assign_from(static_cast<ref_tuple<A,B,C,D,E,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl));
+               }
+       }
+       template <typename CA, typename CB, typename CC, typename CD,
+                         typename CE>
+       TCall<Y,A,B,C,D,E,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &With(const CA & a, const CB & b, const CC & c, const CD & d, const CE & e) {
+               args = new copy_tuple<A,B,C,D,E,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,
+                                                               const CA &,const CB &,const CC &,const CD &,const CE &,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(a,b,c,d,e,NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType());
+               return *this;
+       }
+       TCall<Y,A,B,C,D,E,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &After(Call &call) {
+               previousCalls.push_back(&call);
+               return *this;
+       }
+       template <typename T>
+       TCall<Y,A,B,C,D,E,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &Do(T function) { functor = new DoWrapper<T,Y,A,B,C,D,E,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(function); return *this; }
+       template <typename T>
+       TCall<Y,A,B,C,D,E,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &Match(T function) { matchFunctor = new DoWrapper<T,bool,A,B,C,D,E,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(function); return *this; }
+       Call &Return(Y obj) { retVal = new ReturnValueWrapperCopy<Y>(obj); return *this; }
+       Call &ReturnByRef(Y obj) { retVal = new ReturnValueWrapperRef<Y>(obj); return *this; }
+#ifndef HM_NO_EXCEPTIONS
+       template <typename Ex>
+       Call &Throw(Ex exception) { eHolder = new ExceptionWrapper<Ex>(exception); return *this; }
+#endif
+};
+template <typename A, typename B, typename C, typename D,
+                 typename E>
+class TCall<void,A,B,C,D,E,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> : public Call {
+private:
+       ref_comparable_assignable_tuple<A,B,C,D,E,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> *args;
+public:
+               const base_tuple *getArgs() const { return args; }
+       TCall(RegistrationType expect, base_mock *baseMock, std::pair<int, int> index, int X, const char *func, const char *file) : Call(expect, baseMock, index, X, func ,file), args(0) {}
+       ~TCall() { delete args; }
+       bool matchesArgs(const base_tuple &tupl) {
+               return (!args && !matchFunctor) ||
+                       (args && (*args == reinterpret_cast<const ref_tuple<A,B,C,D,E,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl))) ||
+                       (matchFunctor && (*(TupleInvocable<bool> *)(matchFunctor))(tupl));
+       }
+       void assignArgs(base_tuple &tupl) {
+               if(args) {
+                       args->assign_to(static_cast<ref_tuple<A,B,C,D,E,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl));
+                       args->assign_from(static_cast<ref_tuple<A,B,C,D,E,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl));
+               }
+       }
+       template <typename CA, typename CB, typename CC, typename CD,
+                         typename CE>
+       TCall<void,A,B,C,D,E,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &With(const CA & a, const CB & b, const CC & c, const CD & d, const CE & e) {
+               args = new copy_tuple<A,B,C,D,E,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,
+                                                               const CA &,const CB &,const CC &,const CD &,const CE &,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(a,b,c,d,e,NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType());
+               return *this;
+       }
+       TCall<void,A,B,C,D,E,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &After(Call &call) {
+               previousCalls.push_back(&call);
+               return *this;
+       }
+       template <typename T>
+       TCall<void,A,B,C,D,E,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &Do(T function) { functor = new DoWrapper<T,void,A,B,C,D,E,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(function); return *this; }
+       template <typename T>
+       TCall<void,A,B,C,D,E,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &Match(T function) { matchFunctor = new DoWrapper<T,bool,A,B,C,D,E,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(function); return *this; }
+#ifndef HM_NO_EXCEPTIONS
+       template <typename Ex>
+       Call &Throw(Ex exception) { eHolder = new ExceptionWrapper<Ex>(exception); return *this; }
+#endif
+};
+
+template <typename Y,
+                 typename A, typename B, typename C, typename D>
+class TCall<Y,A,B,C,D,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> : public Call {
+private:
+       ref_comparable_assignable_tuple<A,B,C,D,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> *args;
+public:
+               const base_tuple *getArgs() const { return args; }
+       TCall(RegistrationType expect, base_mock *baseMock, std::pair<int, int> index, int X, const char *func, const char *file) : Call(expect, baseMock, index, X, func ,file), args(0) {}
+       ~TCall() { delete args; }
+       bool matchesArgs(const base_tuple &tupl) {
+               return (!args && !matchFunctor) ||
+                       (args && (*args == reinterpret_cast<const ref_tuple<A,B,C,D,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl))) ||
+                       (matchFunctor && (*(TupleInvocable<bool> *)(matchFunctor))(tupl));
+       }
+       void assignArgs(base_tuple &tupl) {
+               if(args) {
+                       args->assign_to(static_cast<ref_tuple<A,B,C,D,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl));
+                       args->assign_from(static_cast<ref_tuple<A,B,C,D,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl));
+               }
+       }
+       template <typename CA, typename CB, typename CC, typename CD>
+       TCall<Y,A,B,C,D,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &With(const CA & a, const CB & b, const CC & c, const CD & d) {
+               args = new copy_tuple<A,B,C,D,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,
+                                                               const CA &,const CB &,const CC &,const CD &,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(a,b,c,d,NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType());
+               return *this;
+       }
+       TCall<Y,A,B,C,D,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &After(Call &call) {
+               previousCalls.push_back(&call);
+               return *this;
+       }
+       template <typename T>
+       TCall<Y,A,B,C,D,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &Do(T function) { functor = new DoWrapper<T,Y,A,B,C,D,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(function); return *this; }
+       template <typename T>
+       TCall<Y,A,B,C,D,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &Match(T function) { matchFunctor = new DoWrapper<T,bool,A,B,C,D,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(function); return *this; }
+       Call &Return(Y obj) { retVal = new ReturnValueWrapperCopy<Y>(obj); return *this; }
+       Call &ReturnByRef(Y obj) { retVal = new ReturnValueWrapperRef<Y>(obj); return *this; }
+#ifndef HM_NO_EXCEPTIONS
+       template <typename Ex>
+       Call &Throw(Ex exception) { eHolder = new ExceptionWrapper<Ex>(exception); return *this; }
+#endif
+};
+template <typename A, typename B, typename C, typename D>
+class TCall<void,A,B,C,D,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> : public Call {
+private:
+       ref_comparable_assignable_tuple<A,B,C,D,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> *args;
+public:
+               const base_tuple *getArgs() const { return args; }
+       TCall(RegistrationType expect, base_mock *baseMock, std::pair<int, int> index, int X, const char *func, const char *file) : Call(expect, baseMock, index, X, func ,file), args(0) {}
+       ~TCall() { delete args; }
+       bool matchesArgs(const base_tuple &tupl) {
+               return (!args && !matchFunctor) ||
+                       (args && (*args == reinterpret_cast<const ref_tuple<A,B,C,D,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl))) ||
+                       (matchFunctor && (*(TupleInvocable<bool> *)(matchFunctor))(tupl));
+       }
+       void assignArgs(base_tuple &tupl) {
+               if(args) {
+                       args->assign_to(static_cast<ref_tuple<A,B,C,D,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl));
+                       args->assign_from(static_cast<ref_tuple<A,B,C,D,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl));
+               }
+       }
+       template <typename CA, typename CB, typename CC, typename CD>
+       TCall<void,A,B,C,D,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &With(const CA & a, const CB & b, const CC & c, const CD & d) {
+               args = new copy_tuple<A,B,C,D,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,
+                                                               const CA &,const CB &,const CC &,const CD &,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(a,b,c,d,NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType());
+               return *this;
+       }
+       TCall<void,A,B,C,D,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &After(Call &call) {
+               previousCalls.push_back(&call);
+               return *this;
+       }
+       template <typename T>
+       TCall<void,A,B,C,D,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &Do(T function) { functor = new DoWrapper<T,void,A,B,C,D,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(function); return *this; }
+       template <typename T>
+       TCall<void,A,B,C,D,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &Match(T function) { matchFunctor = new DoWrapper<T,bool,A,B,C,D,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(function); return *this; }
+#ifndef HM_NO_EXCEPTIONS
+       template <typename Ex>
+       Call &Throw(Ex exception) { eHolder = new ExceptionWrapper<Ex>(exception); return *this; }
+#endif
+};
+
+template <typename Y,
+                 typename A, typename B, typename C>
+class TCall<Y,A,B,C,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> : public Call {
+private:
+       ref_comparable_assignable_tuple<A,B,C,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> *args;
+public:
+               const base_tuple *getArgs() const { return args; }
+       TCall(RegistrationType expect, base_mock *baseMock, std::pair<int, int> index, int X, const char *func, const char *file) : Call(expect, baseMock, index, X, func ,file), args(0) {}
+       ~TCall() { delete args; }
+       bool matchesArgs(const base_tuple &tupl) {
+               return (!args && !matchFunctor) ||
+                       (args && (*args == reinterpret_cast<const ref_tuple<A,B,C,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl))) ||
+                       (matchFunctor && (*(TupleInvocable<bool> *)(matchFunctor))(tupl));
+       }
+       void assignArgs(base_tuple &tupl) {
+               if(args) {
+                       args->assign_to(static_cast<ref_tuple<A,B,C,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl));
+                       args->assign_from(static_cast<ref_tuple<A,B,C,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl));
+               }
+       }
+       template <typename CA, typename CB, typename CC>
+       TCall<Y,A,B,C,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &With(const CA & a, const CB & b, const CC & c) {
+               args = new copy_tuple<A,B,C,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,
+                                                               const CA &,const CB &,const CC &,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(a,b,c,NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType());
+               return *this;
+       }
+       TCall<Y,A,B,C,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &After(Call &call) {
+               previousCalls.push_back(&call);
+               return *this;
+       }
+       template <typename T>
+       TCall<Y,A,B,C,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &Do(T function) { functor = new DoWrapper<T,Y,A,B,C,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(function); return *this; }
+       template <typename T>
+       TCall<Y,A,B,C,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &Match(T function) { matchFunctor = new DoWrapper<T,bool,A,B,C,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(function); return *this; }
+       Call &Return(Y obj) { retVal = new ReturnValueWrapperCopy<Y>(obj); return *this; }
+       Call &ReturnByRef(Y obj) { retVal = new ReturnValueWrapperRef<Y>(obj); return *this; }
+#ifndef HM_NO_EXCEPTIONS
+       template <typename Ex>
+       Call &Throw(Ex exception) { eHolder = new ExceptionWrapper<Ex>(exception); return *this; }
+#endif
+};
+template <typename A, typename B, typename C>
+class TCall<void,A,B,C,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> : public Call {
+private:
+       ref_comparable_assignable_tuple<A,B,C,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> *args;
+public:
+               const base_tuple *getArgs() const { return args; }
+       TCall(RegistrationType expect, base_mock *baseMock, std::pair<int, int> index, int X, const char *func, const char *file) : Call(expect, baseMock, index, X, func ,file), args(0) {}
+       ~TCall() { delete args; }
+       bool matchesArgs(const base_tuple &tupl) {
+               return (!args && !matchFunctor) ||
+                       (args && (*args == reinterpret_cast<const ref_tuple<A,B,C,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl))) ||
+                       (matchFunctor && (*(TupleInvocable<bool> *)(matchFunctor))(tupl));
+       }
+       void assignArgs(base_tuple &tupl) {
+               if(args) {
+                       args->assign_to(static_cast<ref_tuple<A,B,C,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl));
+                       args->assign_from(static_cast<ref_tuple<A,B,C,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl));
+               }
+       }
+       template <typename CA, typename CB, typename CC>
+       TCall<void,A,B,C,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &With(const CA & a, const CB & b, const CC & c) {
+               args = new copy_tuple<A,B,C,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,
+                                                               const CA &,const CB &,const CC &,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(a,b,c,NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType());
+               return *this;
+       }
+       TCall<void,A,B,C,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &After(Call &call) {
+               previousCalls.push_back(&call);
+               return *this;
+       }
+       template <typename T>
+       TCall<void,A,B,C,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &Do(T function) { functor = new DoWrapper<T,void,A,B,C,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(function); return *this; }
+       template <typename T>
+       TCall<void,A,B,C,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &Match(T function) { matchFunctor = new DoWrapper<T,bool,A,B,C,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(function); return *this; }
+#ifndef HM_NO_EXCEPTIONS
+       template <typename Ex>
+       Call &Throw(Ex exception) { eHolder = new ExceptionWrapper<Ex>(exception); return *this; }
+#endif
+};
+
+template <typename Y,
+                 typename A, typename B>
+class TCall<Y,A,B,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> : public Call {
+private:
+       ref_comparable_assignable_tuple<A,B,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> *args;
+public:
+               const base_tuple *getArgs() const { return args; }
+       TCall(RegistrationType expect, base_mock *baseMock, std::pair<int, int> index, int X, const char *func, const char *file) : Call(expect, baseMock, index, X, func ,file), args(0) {}
+       ~TCall() { delete args; }
+       bool matchesArgs(const base_tuple &tupl) {
+               return (!args && !matchFunctor) ||
+                       (args && (*args == reinterpret_cast<const ref_tuple<A,B,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl))) ||
+                       (matchFunctor && (*(TupleInvocable<bool> *)(matchFunctor))(tupl));
+       }
+       void assignArgs(base_tuple &tupl) {
+               if(args) {
+                       args->assign_to(static_cast<ref_tuple<A,B,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl));
+                       args->assign_from(static_cast<ref_tuple<A,B,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl));
+               }
+       }
+       template <typename CA, typename CB>
+       TCall<Y,A,B,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &With(const CA & a, const CB & b) {
+               args = new copy_tuple<A,B,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,
+                                                               const CA &,const CB &,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(a,b,NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType());
+               return *this;
+       }
+       TCall<Y,A,B,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &After(Call &call) {
+               previousCalls.push_back(&call);
+               return *this;
+       }
+       template <typename T>
+       TCall<Y,A,B,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &Do(T function) { functor = new DoWrapper<T,Y,A,B,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(function); return *this; }
+       template <typename T>
+       TCall<Y,A,B,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &Match(T function) { matchFunctor = new DoWrapper<T,bool,A,B,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(function); return *this; }
+       Call &Return(Y obj) { retVal = new ReturnValueWrapperCopy<Y>(obj); return *this; }
+       Call &ReturnByRef(Y obj) { retVal = new ReturnValueWrapperRef<Y>(obj); return *this; }
+#ifndef HM_NO_EXCEPTIONS
+       template <typename Ex>
+       Call &Throw(Ex exception) { eHolder = new ExceptionWrapper<Ex>(exception); return *this; }
+#endif
+};
+template <typename A, typename B>
+class TCall<void,A,B,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> : public Call {
+private:
+       ref_comparable_assignable_tuple<A,B,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> *args;
+public:
+               const base_tuple *getArgs() const { return args; }
+       TCall(RegistrationType expect, base_mock *baseMock, std::pair<int, int> index, int X, const char *func, const char *file) : Call(expect, baseMock, index, X, func ,file), args(0) {}
+       ~TCall() { delete args; }
+       bool matchesArgs(const base_tuple &tupl) {
+               return (!args && !matchFunctor) ||
+                       (args && (*args == reinterpret_cast<const ref_tuple<A,B,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl))) ||
+                       (matchFunctor && (*(TupleInvocable<bool> *)(matchFunctor))(tupl));
+       }
+       void assignArgs(base_tuple &tupl) {
+               if(args) {
+                       args->assign_to(static_cast<ref_tuple<A,B,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl));
+                       args->assign_from(static_cast<ref_tuple<A,B,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl));
+               }
+       }
+       template <typename CA, typename CB>
+       TCall<void,A,B,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &With(const CA & a, const CB & b) {
+               args = new copy_tuple<A,B,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,
+                                                               const CA &,const CB &,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(a,b,NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType());
+               return *this;
+       }
+       TCall<void,A,B,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &After(Call &call) {
+               previousCalls.push_back(&call);
+               return *this;
+       }
+       template <typename T>
+       TCall<void,A,B,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &Do(T function) { functor = new DoWrapper<T,void,A,B,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(function); return *this; }
+       template <typename T>
+       TCall<void,A,B,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &Match(T function) { matchFunctor = new DoWrapper<T,bool,A,B,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(function); return *this; }
+#ifndef HM_NO_EXCEPTIONS
+       template <typename Ex>
+       Call &Throw(Ex exception) { eHolder = new ExceptionWrapper<Ex>(exception); return *this; }
+#endif
+};
+
+template <typename Y,
+                 typename A>
+class TCall<Y,A,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> : public Call {
+private:
+       ref_comparable_assignable_tuple<A,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> *args;
+public:
+               const base_tuple *getArgs() const { return args; }
+       TCall(RegistrationType expect, base_mock *baseMock, std::pair<int, int> index, int X, const char *func, const char *file) : Call(expect, baseMock, index, X, func ,file), args(0) {}
+       ~TCall() { delete args; }
+       bool matchesArgs(const base_tuple &tupl) {
+               return (!args && !matchFunctor) ||
+                       (args && (*args == reinterpret_cast<const ref_tuple<A,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl))) ||
+                       (matchFunctor && (*(TupleInvocable<bool> *)(matchFunctor))(tupl));
+       }
+       void assignArgs(base_tuple &tupl) {
+               if(args) {
+                       args->assign_to(static_cast<ref_tuple<A,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl));
+                       args->assign_from(static_cast<ref_tuple<A,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl));
+               }
+       }
+       template <typename CA>
+       TCall<Y,A,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &With(const CA & a) {
+               args = new copy_tuple<A,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,
+                                                               const CA &,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(a,NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType());
+               return *this;
+       }
+       TCall<Y,A,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &After(Call &call) {
+               previousCalls.push_back(&call);
+               return *this;
+       }
+       template <typename T>
+       TCall<Y,A,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &Do(T function) { functor = new DoWrapper<T,Y,A,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(function); return *this; }
+       template <typename T>
+       TCall<Y,A,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &Match(T function) { matchFunctor = new DoWrapper<T,bool,A,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(function); return *this; }
+       Call &Return(Y obj) { retVal = new ReturnValueWrapperCopy<Y>(obj); return *this; }
+       Call &ReturnByRef(Y obj) { retVal = new ReturnValueWrapperRef<Y>(obj); return *this; }
+#ifndef HM_NO_EXCEPTIONS
+       template <typename Ex>
+       Call &Throw(Ex exception) { eHolder = new ExceptionWrapper<Ex>(exception); return *this; }
+#endif
+};
+template <typename A>
+class TCall<void,A,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> : public Call {
+private:
+       ref_comparable_assignable_tuple<A,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> *args;
+public:
+               const base_tuple *getArgs() const { return args; }
+       TCall(RegistrationType expect, base_mock *baseMock, std::pair<int, int> index, int X, const char *func, const char *file) : Call(expect, baseMock, index, X, func ,file), args(0) {}
+       ~TCall() { delete args; }
+       bool matchesArgs(const base_tuple &tupl) {
+               return (!args && !matchFunctor) ||
+                       (args && (*args == reinterpret_cast<const ref_tuple<A,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl))) ||
+                       (matchFunctor && (*(TupleInvocable<bool> *)(matchFunctor))(tupl));
+       }
+       void assignArgs(base_tuple &tupl) {
+               if(args) {
+                       args->assign_to(static_cast<ref_tuple<A,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl));
+                       args->assign_from(static_cast<ref_tuple<A,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &>(tupl));
+               }
+       }
+       template <typename CA>
+       TCall<void,A,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &With(const CA &a) {
+               args = new copy_tuple<A,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,
+                                                               const CA &,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(a,NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType());
+               return *this;
+       }
+       TCall<void,A,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &After(Call &call) {
+               previousCalls.push_back(&call);
+               return *this;
+       }
+       template <typename T>
+       TCall<void,A,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &Do(T function) { functor = new DoWrapper<T,void,A,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(function); return *this; }
+       template <typename T>
+       TCall<void,A,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &Match(T function) { matchFunctor = new DoWrapper<T,bool,A,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(function); return *this; }
+#ifndef HM_NO_EXCEPTIONS
+       template <typename Ex>
+       Call &Throw(Ex exception) { eHolder = new ExceptionWrapper<Ex>(exception); return *this; }
+#endif
+};
+
+template <typename Y>
+class TCall<Y,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> : public Call {
+private:
+       ref_comparable_assignable_tuple<NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> *args;
+public:
+               const base_tuple *getArgs() const { return args; }
+       TCall(RegistrationType expect, base_mock *baseMock, std::pair<int, int> index, int X, const char *func, const char *file) : Call(expect, baseMock, index, X, func ,file) {
+               args = new copy_tuple<NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,
+                                                               NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType>
+                                                               (NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType());
+       }
+       ~TCall() { delete args; }
+       bool matchesArgs(const base_tuple &) { return true; }
+       void assignArgs(base_tuple &) {}
+       TCall<Y,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &After(Call &call) {
+               previousCalls.push_back(&call);
+               return *this;
+       }
+       template <typename T>
+       TCall<Y,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &Do(T function) { functor = new DoWrapper<T,Y,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(function); return *this; }
+       Call &Return(Y obj) { retVal = new ReturnValueWrapperCopy<Y>(obj); return *this; }
+       Call &ReturnByRef(Y obj) { retVal = new ReturnValueWrapperRef<Y>(obj); return *this; }
+#ifndef HM_NO_EXCEPTIONS
+       template <typename Ex>
+       Call &Throw(Ex exception) { eHolder = new ExceptionWrapper<Ex>(exception); return *this; }
+#endif
+};
+template <>
+class TCall<void,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> : public Call {
+private:
+       ref_comparable_assignable_tuple<NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> *args;
+public:
+               const base_tuple *getArgs() const { return args; }
+       TCall(RegistrationType expect, base_mock *baseMock, std::pair<int, int> index, int X, const char *func, const char *file) : Call(expect, baseMock, index, X, func ,file) {
+               args = new copy_tuple<NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,
+                                                       NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType>
+                                                       (NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType(),NullType());
+       }
+       ~TCall() { delete args; }
+       bool matchesArgs(const base_tuple &) { return true; }
+       void assignArgs(base_tuple &) { }
+       TCall<void,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &After(Call &call) {
+               previousCalls.push_back(&call);
+               return *this;
+       }
+       template <typename T>
+       TCall<void,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType> &Do(T function) { functor = new DoWrapper<T,void,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType,NullType>(function); return *this; }
+#ifndef HM_NO_EXCEPTIONS
+       template <typename Ex>
+       Call &Throw(Ex exception) { eHolder = new ExceptionWrapper<Ex>(exception); return *this; }
+#endif
+};
+
+template <int X>
+class MockRepoInstanceHolder {
+public:
+       static MockRepository *instance;
+};
+
+template <int X>
+MockRepository *MockRepoInstanceHolder<X>::instance;
+
+inline
+bool satisfied( std::list<Call *> const& previousCalls )
+{
+   for (std::list<Call *>::const_iterator callsBefore = previousCalls.begin();
+         callsBefore != previousCalls.end(); ++callsBefore)
+   {
+         if (!(*callsBefore)->satisfied)
+         {
+                return false;
+         }
+   }
+   return true;
+}
+
+
+class MockRepository {
+private:
+       friend inline std::ostream &operator<<(std::ostream &os, const MockRepository &repo);
+       std::list<base_mock *> mocks;
+       std::map<void (*)(), int> staticFuncMap;
+#ifdef _HIPPOMOCKS__ENABLE_CFUNC_MOCKING_SUPPORT
+       std::list<Replace *> staticReplaces;
+#endif
+
+       std::list<Call *> neverCalls;
+       std::list<Call *> expectations;
+       std::list<Call *> optionals;
+public:
+       bool autoExpect;
+private:
+
+       void addAutoExpectTo( Call* call )
+       {
+                if (autoExpect && expectations.size() > 0)
+                {
+                       call->previousCalls.push_back(expectations.back());
+                }
+       }
+
+
+       void addCall( Call* call, RegistrationType expect )
+       {
+          if( expect == Never ) {
+                 addAutoExpectTo( call );
+                 neverCalls.push_back(call);
+               }
+               else if( expect.minimum == expect.maximum )
+               {
+                  addAutoExpectTo( call );
+                  expectations.push_back(call);
+               }
+               else
+               {
+                  optionals.push_back(call);
+          }
+       }
+
+#ifndef HM_NO_EXCEPTIONS
+       ExceptionHolder *latentException;
+#endif
+public:
+#ifndef HM_NO_EXCEPTIONS
+       void SetLatentException(ExceptionHolder *holder)
+       {
+               latentException = holder;
+       }
+#endif
+#ifdef _MSC_VER
+#ifdef _HIPPOMOCKS__ENABLE_CFUNC_MOCKING_SUPPORT
+#define OnCallFunc(func) RegisterExpect_<__COUNTER__>(&func, HM_NS Any, #func, __FILE__, __LINE__)
+#define ExpectCallFunc(func) RegisterExpect_<__COUNTER__>(&func, HM_NS Once, #func, __FILE__, __LINE__)
+#define NeverCallFunc(func) RegisterExpect_<__COUNTER__>(&func, HM_NS Never, #func, __FILE__, __LINE__)
+#define OnCallFuncOverload(func) RegisterExpect_<__COUNTER__>(func, HM_NS Any, #func, __FILE__, __LINE__)
+#define ExpectCallFuncOverload(func) RegisterExpect_<__COUNTER__>(func, HM_NS Once, #func, __FILE__, __LINE__)
+#define NeverCallFuncOverload(func) RegisterExpect_<__COUNTER__>(func, HM_NS Never, #func, __FILE__, __LINE__)
+#endif
+#define OnCall(obj, func) RegisterExpect_<__COUNTER__>(obj, &func, HM_NS Any, #func, __FILE__, __LINE__)
+#define OnCalls(obj, func, minimum) RegisterExpect_<__COUNTER__>(obj, &func, HM_NS RegistrationType(minimum,(std::numeric_limits<unsigned>::max)()), #func, __FILE__, __LINE__)
+#define ExpectCall(obj, func) RegisterExpect_<__COUNTER__>(obj, &func, HM_NS Once, #func, __FILE__, __LINE__)
+#define ExpectCalls(obj, func, num) RegisterExpect_<__COUNTER__>(obj, &func, HM_NS RegistrationType(num,num), #func, __FILE__, __LINE__)
+#define NeverCall(obj, func) RegisterExpect_<__COUNTER__>(obj, &func, HM_NS Never, #func, __FILE__, __LINE__)
+#define OnCallOverload(obj, func) RegisterExpect_<__COUNTER__>(obj, func, HM_NS Any, #func, __FILE__, __LINE__)
+#define ExpectCallOverload(obj, func) RegisterExpect_<__COUNTER__>(obj, func, HM_NS Once, #func, __FILE__, __LINE__)
+#define NeverCallOverload(obj, func) RegisterExpect_<__COUNTER__>(obj, func, HM_NS Never, #func, __FILE__, __LINE__)
+#define OnCallDestructor(obj) RegisterExpectDestructor<__COUNTER__>(obj, HM_NS Any, __FILE__, __LINE__)
+#define ExpectCallDestructor(obj) RegisterExpectDestructor<__COUNTER__>(obj, HM_NS Once, __FILE__, __LINE__)
+#define NeverCallDestructor(obj) RegisterExpectDestructor<__COUNTER__>(obj, HM_NS Never, __FILE__, __LINE__)
+#else
+#ifdef _HIPPOMOCKS__ENABLE_CFUNC_MOCKING_SUPPORT
+#define OnCallFunc(func) RegisterExpect_<__LINE__>(&func, HM_NS Any, #func, __FILE__, __LINE__)
+#define ExpectCallFunc(func) RegisterExpect_<__LINE__>(&func, HM_NS Once, #func, __FILE__, __LINE__)
+#define NeverCallFunc(func) RegisterExpect_<__LINE__>(&func, HM_NS Never, #func, __FILE__, __LINE__)
+#define OnCallFuncOverload(func) RegisterExpect_<__LINE__>(func, HM_NS Any, #func,  __FILE__, __LINE__)
+#define ExpectCallFuncOverload(func) RegisterExpect_<__LINE__>(func, HM_NS Once, #func, __FILE__, __LINE__)
+#define NeverCallFuncOverload(func) RegisterExpect_<__LINE__>(func, HM_NS Never, #func, __FILE__, __LINE__)
+#endif
+#define OnCall(obj, func) RegisterExpect_<__LINE__>(obj, &func, HM_NS Any, #func, __FILE__, __LINE__)
+#define OnCalls(obj, func, minimum) RegisterExpect_<__LINE__>(obj, &func, HM_NS RegistrationType(minimum,(std::numeric_limits<unsigned>::max)()), #func, __FILE__, __LINE__)
+#define ExpectCall(obj, func) RegisterExpect_<__LINE__>(obj, &func, HM_NS Once, #func, __FILE__, __LINE__)
+#define ExpectCalls(obj, func, num) RegisterExpect_<__LINE__>(obj, &func, HM_NS RegistrationType(num,num), #func, __FILE__, __LINE__)
+#define NeverCall(obj, func) RegisterExpect_<__LINE__>(obj, &func, HM_NS Never, #func, __FILE__, __LINE__)
+#define OnCallOverload(obj, func) RegisterExpect_<__LINE__>(obj, func, HM_NS Any, #func, __FILE__, __LINE__)
+#define ExpectCallOverload(obj, func) RegisterExpect_<__LINE__>(obj, func, HM_NS Once, #func, __FILE__, __LINE__)
+#define NeverCallOverload(obj, func) RegisterExpect_<__LINE__>(obj, func, HM_NS Never, #func, __FILE__, __LINE__)
+#define OnCallDestructor(obj) RegisterExpectDestructor<__LINE__>(obj, HM_NS Any, __FILE__, __LINE__)
+#define ExpectCallDestructor(obj) RegisterExpectDestructor<__LINE__>(obj, HM_NS Once, __FILE__, __LINE__)
+#define NeverCallDestructor(obj) RegisterExpectDestructor<__LINE__>(obj, HM_NS Never, __FILE__, __LINE__)
+#endif
+       template <typename A, class B, typename C>
+       void Member(A *mck, C B::*member)
+       {
+               C A::*realMember = (C A::*)member;
+               C *realRealMember = &(mck->*realMember);
+               mock<A> *realMock = (mock<A> *)mck;
+               realMock->members.push_back(new MemberWrap<C>(realRealMember));
+       }
+  template <int X, typename Z2>
+       TCall<void> &RegisterExpectDestructor(Z2 *mck, RegistrationType expect, const char *fileName, unsigned long lineNo);
+
+#ifdef _HIPPOMOCKS__ENABLE_CFUNC_MOCKING_SUPPORT
+       template <int X, typename Y>
+       TCall<Y> &RegisterExpect_(Y (*func)(), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Y, typename A>
+       TCall<Y,A> &RegisterExpect_(Y (*func)(A), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Y,
+                         typename A, typename B>
+       TCall<Y,A,B> &RegisterExpect_(Y (*func)(A,B), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Y,
+                         typename A, typename B, typename C>
+       TCall<Y,A,B,C> &RegisterExpect_(Y (*func)(A,B,C), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Y,
+                         typename A, typename B, typename C, typename D>
+       TCall<Y,A,B,C,D> &RegisterExpect_(Y (*func)(A,B,C,D), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Y,
+                         typename A, typename B, typename C, typename D,
+                         typename E>
+       TCall<Y,A,B,C,D,E> &RegisterExpect_(Y (*func)(A,B,C,D,E), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Y,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F>
+       TCall<Y,A,B,C,D,E,F> &RegisterExpect_(Y (*func)(A,B,C,D,E,F), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Y,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G>
+       TCall<Y,A,B,C,D,E,F,G> &RegisterExpect_(Y (*func)(A,B,C,D,E,F,G), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Y,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H>
+       TCall<Y,A,B,C,D,E,F,G,H> &RegisterExpect_(Y (*func)(A,B,C,D,E,F,G,H), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Y,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I>
+       TCall<Y,A,B,C,D,E,F,G,H,I> &RegisterExpect_(Y (*func)(A,B,C,D,E,F,G,H,I), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Y,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J> &RegisterExpect_(Y (*func)(A,B,C,D,E,F,G,H,I,J), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Y,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K> &RegisterExpect_(Y (*func)(A,B,C,D,E,F,G,H,I,J,K), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Y,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K, typename L>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L> &RegisterExpect_(Y (*func)(A,B,C,D,E,F,G,H,I,J,K,L), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Y,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K, typename L,
+                         typename M>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M> &RegisterExpect_(Y (*func)(A,B,C,D,E,F,G,H,I,J,K,L,M), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Y,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K, typename L,
+                         typename M, typename N>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N> &RegisterExpect_(Y (*func)(A,B,C,D,E,F,G,H,I,J,K,L,M,N), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Y,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K, typename L,
+                         typename M, typename N, typename O>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O> &RegisterExpect_(Y (*func)(A,B,C,D,E,F,G,H,I,J,K,L,M,N,O), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Y,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K, typename L,
+                         typename M, typename N, typename O, typename P>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P> &RegisterExpect_(Y (*func)(A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+
+#if defined(_MSC_VER) && !defined(_WIN64)
+       template <int X, typename Y>
+       TCall<Y> &RegisterExpect_(Y (__stdcall *func)(), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Y, typename A>
+       TCall<Y,A> &RegisterExpect_(Y (__stdcall *func)(A), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Y,
+                         typename A, typename B>
+       TCall<Y,A,B> &RegisterExpect_(Y (__stdcall *func)(A,B), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Y,
+                         typename A, typename B, typename C>
+       TCall<Y,A,B,C> &RegisterExpect_(Y (__stdcall *func)(A,B,C), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Y,
+                         typename A, typename B, typename C, typename D>
+       TCall<Y,A,B,C,D> &RegisterExpect_(Y (__stdcall *func)(A,B,C,D), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Y,
+                         typename A, typename B, typename C, typename D,
+                         typename E>
+       TCall<Y,A,B,C,D,E> &RegisterExpect_(Y (__stdcall *func)(A,B,C,D,E), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Y,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F>
+       TCall<Y,A,B,C,D,E,F> &RegisterExpect_(Y (__stdcall *func)(A,B,C,D,E,F), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Y,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G>
+       TCall<Y,A,B,C,D,E,F,G> &RegisterExpect_(Y (__stdcall *func)(A,B,C,D,E,F,G), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Y,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H>
+       TCall<Y,A,B,C,D,E,F,G,H> &RegisterExpect_(Y (__stdcall *func)(A,B,C,D,E,F,G,H), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Y,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I>
+       TCall<Y,A,B,C,D,E,F,G,H,I> &RegisterExpect_(Y (__stdcall *func)(A,B,C,D,E,F,G,H,I), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Y,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J> &RegisterExpect_(Y (__stdcall *func)(A,B,C,D,E,F,G,H,I,J), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Y,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K> &RegisterExpect_(Y (__stdcall *func)(A,B,C,D,E,F,G,H,I,J,K), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Y,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K, typename L>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L> &RegisterExpect_(Y (__stdcall *func)(A,B,C,D,E,F,G,H,I,J,K,L), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Y,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K, typename L,
+                         typename M>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M> &RegisterExpect_(Y (__stdcall *func)(A,B,C,D,E,F,G,H,I,J,K,L,M), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Y,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K, typename L,
+                         typename M, typename N>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N> &RegisterExpect_(Y (__stdcall *func)(A,B,C,D,E,F,G,H,I,J,K,L,M,N), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Y,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K, typename L,
+                         typename M, typename N, typename O>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O> &RegisterExpect_(Y (__stdcall *func)(A,B,C,D,E,F,G,H,I,J,K,L,M,N,O), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Y,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K, typename L,
+                         typename M, typename N, typename O, typename P>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P> &RegisterExpect_(Y (__stdcall *func)(A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+#endif
+#endif
+
+       template <int X, typename Z2, typename Y, typename Z>
+       TCall<Y> &RegisterExpect_(Z2 *mck, Y (Z::*func)(), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Z2, typename Y, typename Z, typename A>
+       TCall<Y,A> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B>
+       TCall<Y,A,B> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C>
+       TCall<Y,A,B,C> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D>
+       TCall<Y,A,B,C,D> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E>
+       TCall<Y,A,B,C,D,E> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F>
+       TCall<Y,A,B,C,D,E,F> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G>
+       TCall<Y,A,B,C,D,E,F,G> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F,G), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H>
+       TCall<Y,A,B,C,D,E,F,G,H> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F,G,H), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I>
+       TCall<Y,A,B,C,D,E,F,G,H,I> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F,G,H,I), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F,G,H,I,J), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F,G,H,I,J,K), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K, typename L>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F,G,H,I,J,K,L), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K, typename L,
+                         typename M>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F,G,H,I,J,K,L,M), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K, typename L,
+                         typename M, typename N>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F,G,H,I,J,K,L,M,N), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K, typename L,
+                         typename M, typename N, typename O>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F,G,H,I,J,K,L,M,N,O), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K, typename L,
+                         typename M, typename N, typename O, typename P>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+
+       //GCC 3.x doesn't seem to understand overloading on const or non-const member function. Volatile appears to work though.
+#if !defined(__GNUC__) || __GNUC__ > 3
+       template <int X, typename Z2, typename Y, typename Z>
+       TCall<Y> &RegisterExpect_(Z2 *mck, Y (Z::*func)() volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(Z::*)())(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z, typename A>
+       TCall<Y,A> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A) volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(Z::*)(A))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B>
+       TCall<Y,A,B> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B) volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(Z::*)(A,B))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C>
+       TCall<Y,A,B,C> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C) volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(Z::*)(A,B,C))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D>
+       TCall<Y,A,B,C,D> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D) volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(Z::*)(A,B,C,D))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E>
+       TCall<Y,A,B,C,D,E> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E) volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(Z::*)(A,B,C,D,E))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F>
+       TCall<Y,A,B,C,D,E,F> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F) volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(Z::*)(A,B,C,D,E,F))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G>
+       TCall<Y,A,B,C,D,E,F,G> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F,G) volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(Z::*)(A,B,C,D,E,F,G))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H>
+       TCall<Y,A,B,C,D,E,F,G,H> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F,G,H) volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(Z::*)(A,B,C,D,E,F,G,H))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I>
+       TCall<Y,A,B,C,D,E,F,G,H,I> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F,G,H,I) volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(Z::*)(A,B,C,D,E,F,G,H,I))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F,G,H,I,J) volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(Z::*)(A,B,C,D,E,F,G,H,I,J))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F,G,H,I,J,K) volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(Z::*)(A,B,C,D,E,F,G,H,I,J,K))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K, typename L>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F,G,H,I,J,K,L) volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(Z::*)(A,B,C,D,E,F,G,H,I,J,K,L))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K, typename L,
+                         typename M>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F,G,H,I,J,K,L,M) volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(Z::*)(A,B,C,D,E,F,G,H,I,J,K,L,M))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K, typename L,
+                         typename M, typename N>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F,G,H,I,J,K,L,M,N) volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(Z::*)(A,B,C,D,E,F,G,H,I,J,K,L,M,N))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K, typename L,
+                         typename M, typename N, typename O>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F,G,H,I,J,K,L,M,N,O) volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(Z::*)(A,B,C,D,E,F,G,H,I,J,K,L,M,N,O))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K, typename L,
+                         typename M, typename N, typename O, typename P>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P) volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(Z::*)(A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P))(func), expect, functionName ,fileName, lineNo); }
+
+       template <int X, typename Z2, typename Y, typename Z>
+       TCall<Y> &RegisterExpect_(Z2 *mck, Y (Z::*func)() const volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(Z::*)())(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z, typename A>
+       TCall<Y,A> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A) const volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(Z::*)(A))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B>
+       TCall<Y,A,B> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B) const volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(Z::*)(A,B))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C>
+       TCall<Y,A,B,C> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C) const volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(Z::*)(A,B,C))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D>
+       TCall<Y,A,B,C,D> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D) const volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(Z::*)(A,B,C,D))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E>
+       TCall<Y,A,B,C,D,E> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E) const volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(Z::*)(A,B,C,D,E))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F>
+       TCall<Y,A,B,C,D,E,F> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F) const volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(Z::*)(A,B,C,D,E,F))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G>
+       TCall<Y,A,B,C,D,E,F,G> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F,G) const volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(Z::*)(A,B,C,D,E,F,G))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H>
+       TCall<Y,A,B,C,D,E,F,G,H> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F,G,H) const volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(Z::*)(A,B,C,D,E,F,G,H))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I>
+       TCall<Y,A,B,C,D,E,F,G,H,I> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F,G,H,I) const volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(Z::*)(A,B,C,D,E,F,G,H,I))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F,G,H,I,J) const volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(Z::*)(A,B,C,D,E,F,G,H,I,J))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F,G,H,I,J,K) const volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(Z::*)(A,B,C,D,E,F,G,H,I,J,K))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K, typename L>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F,G,H,I,J,K,L) const volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(Z::*)(A,B,C,D,E,F,G,H,I,J,K,L))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K, typename L,
+                         typename M>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F,G,H,I,J,K,L,M) const volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(Z::*)(A,B,C,D,E,F,G,H,I,J,K,L,M))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K, typename L,
+                         typename M, typename N>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F,G,H,I,J,K,L,M,N) const volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(Z::*)(A,B,C,D,E,F,G,H,I,J,K,L,M,N))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K, typename L,
+                         typename M, typename N, typename O>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F,G,H,I,J,K,L,M,N,O) const volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(Z::*)(A,B,C,D,E,F,G,H,I,J,K,L,M,N,O))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K, typename L,
+                         typename M, typename N, typename O, typename P>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P) const volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(Z::*)(A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P))(func), expect, functionName ,fileName, lineNo); }
+
+       template <int X, typename Z2, typename Y, typename Z>
+       TCall<Y> &RegisterExpect_(Z2 *mck, Y (Z::*func)() const, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo)
+       { return RegisterExpect_<X>(mck, (Y(Z::*)())(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z, typename A>
+       TCall<Y,A> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A) const, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo)
+       { return RegisterExpect_<X>(mck, (Y(Z::*)(A))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B>
+       TCall<Y,A,B> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B) const, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo)
+       { return RegisterExpect_<X>(mck, (Y(Z::*)(A,B))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C>
+       TCall<Y,A,B,C> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C) const, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(Z::*)(A,B,C))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D>
+       TCall<Y,A,B,C,D> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D) const, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(Z::*)(A,B,C,D))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E>
+       TCall<Y,A,B,C,D,E> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E) const, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(Z::*)(A,B,C,D,E))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F>
+       TCall<Y,A,B,C,D,E,F> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F) const, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(Z::*)(A,B,C,D,E,F))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G>
+       TCall<Y,A,B,C,D,E,F,G> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F,G) const, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(Z::*)(A,B,C,D,E,F,G))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H>
+       TCall<Y,A,B,C,D,E,F,G,H> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F,G,H) const, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(Z::*)(A,B,C,D,E,F,G,H))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I>
+       TCall<Y,A,B,C,D,E,F,G,H,I> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F,G,H,I) const, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(Z::*)(A,B,C,D,E,F,G,H,I))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F,G,H,I,J) const, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(Z::*)(A,B,C,D,E,F,G,H,I,J))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F,G,H,I,J,K) const, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(Z::*)(A,B,C,D,E,F,G,H,I,J,K))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K, typename L>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F,G,H,I,J,K,L) const, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(Z::*)(A,B,C,D,E,F,G,H,I,J,K,L))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K, typename L,
+                         typename M>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F,G,H,I,J,K,L,M) const, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(Z::*)(A,B,C,D,E,F,G,H,I,J,K,L,M))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K, typename L,
+                         typename M, typename N>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F,G,H,I,J,K,L,M,N) const, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(Z::*)(A,B,C,D,E,F,G,H,I,J,K,L,M,N))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K, typename L,
+                         typename M, typename N, typename O>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F,G,H,I,J,K,L,M,N,O) const, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(Z::*)(A,B,C,D,E,F,G,H,I,J,K,L,M,N,O))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K, typename L,
+                         typename M, typename N, typename O, typename P>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P> &RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P) const, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(Z::*)(A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P))(func), expect, functionName ,fileName, lineNo); }
+#endif
+
+#if defined(_MSC_VER) && !defined(_WIN64)
+       // COM only support - you can duplicate this for cdecl and fastcall if you want to, but those are not as common as COM.
+       template <int X, typename Z2, typename Y, typename Z>
+       TCall<Y> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::* func)(), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Z2, typename Y, typename Z, typename A>
+       TCall<Y,A> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B>
+       TCall<Y,A,B> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C>
+       TCall<Y,A,B,C> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D>
+       TCall<Y,A,B,C,D> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E>
+       TCall<Y,A,B,C,D,E> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F>
+       TCall<Y,A,B,C,D,E,F> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G>
+       TCall<Y,A,B,C,D,E,F,G> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F,G), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H>
+       TCall<Y,A,B,C,D,E,F,G,H> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F,G,H), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I>
+       TCall<Y,A,B,C,D,E,F,G,H,I> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F,G,H,I), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F,G,H,I,J), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F,G,H,I,J,K), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K, typename L>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F,G,H,I,J,K,L), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K, typename L,
+                         typename M>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F,G,H,I,J,K,L,M), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K, typename L,
+                         typename M, typename N>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F,G,H,I,J,K,L,M,N), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K, typename L,
+                         typename M, typename N, typename O>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F,G,H,I,J,K,L,M,N,O), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K, typename L,
+                         typename M, typename N, typename O, typename P>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo);
+
+       template <int X, typename Z2, typename Y, typename Z>
+       TCall<Y> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)() volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(__stdcall Z::*)())(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z, typename A>
+       TCall<Y,A> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A) volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(__stdcall Z::*)(A))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B>
+       TCall<Y,A,B> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B) volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(__stdcall Z::*)(A,B))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C>
+       TCall<Y,A,B,C> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C) volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(__stdcall Z::*)(A,B,C))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D>
+       TCall<Y,A,B,C,D> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D) volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(__stdcall Z::*)(A,B,C,D))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E>
+       TCall<Y,A,B,C,D,E> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E) volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(__stdcall Z::*)(A,B,C,D,E))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F>
+       TCall<Y,A,B,C,D,E,F> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F) volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(__stdcall Z::*)(A,B,C,D,E,F))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G>
+       TCall<Y,A,B,C,D,E,F,G> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F,G) volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(__stdcall Z::*)(A,B,C,D,E,F,G))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H>
+       TCall<Y,A,B,C,D,E,F,G,H> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F,G,H) volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(__stdcall Z::*)(A,B,C,D,E,F,G,H))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I>
+       TCall<Y,A,B,C,D,E,F,G,H,I> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F,G,H,I) volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(__stdcall Z::*)(A,B,C,D,E,F,G,H,I))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F,G,H,I,J) volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(__stdcall Z::*)(A,B,C,D,E,F,G,H,I,J))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F,G,H,I,J,K) volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(__stdcall Z::*)(A,B,C,D,E,F,G,H,I,J,K))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K, typename L>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F,G,H,I,J,K,L) volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(__stdcall Z::*)(A,B,C,D,E,F,G,H,I,J,K,L))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K, typename L,
+                         typename M>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F,G,H,I,J,K,L,M) volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(__stdcall Z::*)(A,B,C,D,E,F,G,H,I,J,K,L,M))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K, typename L,
+                         typename M, typename N>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F,G,H,I,J,K,L,M,N) volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(__stdcall Z::*)(A,B,C,D,E,F,G,H,I,J,K,L,M,N))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K, typename L,
+                         typename M, typename N, typename O>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F,G,H,I,J,K,L,M,N,O) volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(__stdcall Z::*)(A,B,C,D,E,F,G,H,I,J,K,L,M,N,O))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K, typename L,
+                         typename M, typename N, typename O, typename P>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P) volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(__stdcall Z::*)(A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P))(func), expect, functionName ,fileName, lineNo); }
+
+       template <int X, typename Z2, typename Y, typename Z>
+       TCall<Y> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)() const volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(__stdcall Z::*)())(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z, typename A>
+       TCall<Y,A> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A) const volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(__stdcall Z::*)(A))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B>
+       TCall<Y,A,B> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B) const volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(__stdcall Z::*)(A,B))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C>
+       TCall<Y,A,B,C> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C) const volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(__stdcall Z::*)(A,B,C))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D>
+       TCall<Y,A,B,C,D> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D) const volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(__stdcall Z::*)(A,B,C,D))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E>
+       TCall<Y,A,B,C,D,E> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E) const volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(__stdcall Z::*)(A,B,C,D,E))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F>
+       TCall<Y,A,B,C,D,E,F> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F) const volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(__stdcall Z::*)(A,B,C,D,E,F))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G>
+       TCall<Y,A,B,C,D,E,F,G> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F,G) const volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(__stdcall Z::*)(A,B,C,D,E,F,G))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H>
+       TCall<Y,A,B,C,D,E,F,G,H> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F,G,H) const volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(__stdcall Z::*)(A,B,C,D,E,F,G,H))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I>
+       TCall<Y,A,B,C,D,E,F,G,H,I> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F,G,H,I) const volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(__stdcall Z::*)(A,B,C,D,E,F,G,H,I))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F,G,H,I,J) const volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(__stdcall Z::*)(A,B,C,D,E,F,G,H,I,J))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F,G,H,I,J,K) const volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(__stdcall Z::*)(A,B,C,D,E,F,G,H,I,J,K))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K, typename L>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F,G,H,I,J,K,L) const volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(__stdcall Z::*)(A,B,C,D,E,F,G,H,I,J,K,L))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K, typename L,
+                         typename M>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F,G,H,I,J,K,L,M) const volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(__stdcall Z::*)(A,B,C,D,E,F,G,H,I,J,K,L,M))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K, typename L,
+                         typename M, typename N>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F,G,H,I,J,K,L,M,N) const volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(__stdcall Z::*)(A,B,C,D,E,F,G,H,I,J,K,L,M,N))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K, typename L,
+                         typename M, typename N, typename O>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F,G,H,I,J,K,L,M,N,O) const volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(__stdcall Z::*)(A,B,C,D,E,F,G,H,I,J,K,L,M,N,O))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K, typename L,
+                         typename M, typename N, typename O, typename P>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P) const volatile, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(__stdcall Z::*)(A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P))(func), expect, functionName ,fileName, lineNo); }
+
+       template <int X, typename Z2, typename Y, typename Z>
+       TCall<Y> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)() const, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(__stdcall Z::*)())(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z, typename A>
+       TCall<Y,A> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A) const, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(__stdcall Z::*)(A))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B>
+       TCall<Y,A,B> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B) const, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(__stdcall Z::*)(A,B))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C>
+       TCall<Y,A,B,C> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C) const, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(__stdcall Z::*)(A,B,C))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D>
+       TCall<Y,A,B,C,D> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D) const, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(__stdcall Z::*)(A,B,C,D))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E>
+       TCall<Y,A,B,C,D,E> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E) const, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(__stdcall Z::*)(A,B,C,D,E))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F>
+       TCall<Y,A,B,C,D,E,F> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F) const, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(__stdcall Z::*)(A,B,C,D,E,F))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G>
+       TCall<Y,A,B,C,D,E,F,G> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F,G) const, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(__stdcall Z::*)(A,B,C,D,E,F,G))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H>
+       TCall<Y,A,B,C,D,E,F,G,H> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F,G,H) const, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(__stdcall Z::*)(A,B,C,D,E,F,G,H))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I>
+       TCall<Y,A,B,C,D,E,F,G,H,I> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F,G,H,I) const, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(__stdcall Z::*)(A,B,C,D,E,F,G,H,I))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F,G,H,I,J) const, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(__stdcall Z::*)(A,B,C,D,E,F,G,H,I,J))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F,G,H,I,J,K) const, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(__stdcall Z::*)(A,B,C,D,E,F,G,H,I,J,K))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K, typename L>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F,G,H,I,J,K,L) const, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(__stdcall Z::*)(A,B,C,D,E,F,G,H,I,J,K,L))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K, typename L,
+                         typename M>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F,G,H,I,J,K,L,M) const, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(__stdcall Z::*)(A,B,C,D,E,F,G,H,I,J,K,L,M))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K, typename L,
+                         typename M, typename N>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F,G,H,I,J,K,L,M,N) const, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(__stdcall Z::*)(A,B,C,D,E,F,G,H,I,J,K,L,M,N))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K, typename L,
+                         typename M, typename N, typename O>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F,G,H,I,J,K,L,M,N,O) const, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(__stdcall Z::*)(A,B,C,D,E,F,G,H,I,J,K,L,M,N,O))(func), expect, functionName ,fileName, lineNo); }
+       template <int X, typename Z2, typename Y, typename Z,
+                         typename A, typename B, typename C, typename D,
+                         typename E, typename F, typename G, typename H,
+                         typename I, typename J, typename K, typename L,
+                         typename M, typename N, typename O, typename P>
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P> &RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P) const, RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo) { return RegisterExpect_<X>(mck, (Y(__stdcall Z::*)(A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P))(func), expect, functionName ,fileName, lineNo); }
+#endif
+
+
+       template <typename Z>
+       void BasicRegisterExpect(mock<Z> *zMock, int baseOffset, int funcIndex, void (base_mock::*func)(), int X);
+#ifdef _HIPPOMOCKS__ENABLE_CFUNC_MOCKING_SUPPORT
+  int BasicStaticRegisterExpect(void (*func)(), void (*fp)(), int X)
+  {
+       if (staticFuncMap.find(func) == staticFuncMap.end())
+       {
+         staticFuncMap[func] = X;
+         staticReplaces.push_back(new Replace(func, fp));
+       }
+       return staticFuncMap[func];
+  }
+#endif
+
+  void doCall( Call* call, const base_tuple &tuple )
+  {
+         ++call->called;
+
+         call->satisfied = call->called >= call->expectation.minimum;
+
+         call->assignArgs(const_cast<base_tuple &>(tuple));
+         #ifndef HM_NO_EXCEPTIONS
+         if (call->eHolder)
+                call->eHolder->rethrow();
+         #endif
+  }
+
+  void doVoidFunctor( Call* call, const base_tuple &tuple )
+  {
+         if (call->functor != NULL)
+                (*(TupleInvocable<void> *)(call->functor))(tuple);
+  }
+
+  template<typename Z>
+  Z doReturnFunctor( Call* call, const base_tuple &tuple )
+  {
+         if (call->functor != NULL)
+         {
+                       if(call->retVal == NULL)
+                       {
+                          return (*(TupleInvocable<Z> *)(call->functor))(tuple);
+                       }
+                       else
+                       {
+                          (*(TupleInvocable<Z> *)(call->functor))(tuple);
+                       }
+         }
+
+         if (call->retVal)
+                       return ((ReturnValueWrapper<Z> *)call->retVal)->value();
+
+         RAISEEXCEPTION(NoResultSetUpException(this, call->getArgs(), call->funcName));
+  }
+
+  void doVoidCall( Call* call, const base_tuple &tuple, bool const makeLatent )
+  {
+        if( call->called < call->expectation.maximum )
+        {
+                doCall( call, tuple );
+                doVoidFunctor( call, tuple );
+        }
+        else
+        {
+                doThrow( call, makeLatent );
+        }
+  }
+
+  template<typename Z>
+  Z doReturnCall( Call* call, const base_tuple &tuple )
+  {
+        if( call->called < call->expectation.maximum )
+        {
+                doCall( call, tuple );
+                return doReturnFunctor<Z>( call, tuple );
+        }
+         RAISEEXCEPTION(ExpectationException(this, call->getArgs(), call->funcName));
+  }
+
+
+  void doThrow( Call * call, bool const makeLatent )
+  {
+         call->satisfied = true;
+
+         if (makeLatent)
+         {
+         #ifndef HM_NO_EXCEPTIONS
+                if (latentException)
+                       return;
+         #endif
+                RAISELATENTEXCEPTION(ExpectationException(this, call->getArgs(), call->funcName));
+         }
+         else
+         {
+                RAISEEXCEPTION(ExpectationException(this, call->getArgs(), call->funcName));
+         }
+  }
+
+  const char *funcName( base_mock *mock, std::pair<int, int> funcno )
+  {
+         const char *name = NULL;
+         for (std::list<Call *>::iterator i = expectations.begin(); i != expectations.end() && !name; ++i)
+         {
+                Call *call = *i;
+                if (call->mock == mock &&
+                          call->funcIndex == funcno)
+                name = call->funcName;
+         }
+         for (std::list<Call *>::iterator i = optionals.begin(); i != optionals.end() && !name; ++i)
+         {
+                Call *call = *i;
+                if (call->mock == mock &&
+                          call->funcIndex == funcno)
+                name = call->funcName;
+         }
+         for (std::list<Call *>::iterator i = neverCalls.begin(); i != neverCalls.end() && !name; ++i)
+         {
+                Call *call = *i;
+                if (call->mock == mock &&
+                          call->funcIndex == funcno)
+                          name = call->funcName;
+         }
+         return name;
+  }
+
+  bool
+  matches( Call *call, base_mock *mock, std::pair<int, int> funcno, const base_tuple &tuple )
+  {
+   return call->mock == mock &&
+                 call->funcIndex == funcno &&
+                 call->matchesArgs(tuple) &&
+                 satisfied( call->previousCalls );
+
+ }
+
+   bool
+   isUnsatisfied( Call *call, base_mock *mock, std::pair<int, int> funcno, const base_tuple &tuple )
+   {
+         return ! call->satisfied && matches( call, mock, funcno, tuple );
+   }
+
+       template <typename Z>
+       Z DoExpectation(base_mock *mock, std::pair<int, int> funcno, const base_tuple &tuple);
+
+       void DoVoidExpectation(base_mock *mock, std::pair<int, int> funcno, const base_tuple &tuple, bool makeLatent = false)
+       {
+               for (std::list<Call *>::reverse_iterator i = neverCalls.rbegin(); i != neverCalls.rend(); ++i)
+               {
+                       Call *call = *i;
+                       if ( matches( call, mock, funcno, tuple ) )
+                       {
+                          doThrow( call, makeLatent );
+                          return;
+                       }
+               }
+          for (std::list<Call *>::reverse_iterator i = expectations.rbegin(); i != expectations.rend(); ++i)
+               {
+                       Call *call = *i;
+                       if ( isUnsatisfied( call, mock, funcno, tuple ) )
+                       {
+                               doVoidCall( call, tuple, makeLatent );
+                               return;
+                       }
+               }
+               for (std::list<Call *>::reverse_iterator i = optionals.rbegin(); i != optionals.rend(); ++i)
+               {
+                       Call *call = *i;
+                       if ( matches( call, mock, funcno, tuple ) )
+                       {
+                          doVoidCall( call, tuple, makeLatent );
+                          return;
+                       }
+               }
+
+               if (makeLatent)
+               {
+#ifndef HM_NO_EXCEPTIONS
+                       if (latentException)
+                               return;
+#endif
+                       RAISELATENTEXCEPTION(ExpectationException(this, &tuple, funcName(mock, funcno)));
+               }
+               else
+               {
+                       RAISEEXCEPTION(ExpectationException(this, &tuple, funcName(mock, funcno)));
+               }
+       }
+       MockRepository()
+               : autoExpect(DEFAULT_AUTOEXPECT)
+#ifndef HM_NO_EXCEPTIONS
+               , latentException(0)
+#endif
+       {
+               MockRepoInstanceHolder<0>::instance = this;
+       }
+       ~MockRepository()
+  // If we're on a recent enough compiler that's not VS2012 (as it doesn't have noexcept)
+#if __cplusplus > 199711L && (!defined(_MSC_VER) || _MSC_VER > 1700)
+noexcept(false)
+#endif
+       {
+               MockRepoInstanceHolder<0>::instance = 0;
+#ifndef HM_NO_EXCEPTIONS
+               if (!std::uncaught_exception())
+               {
+                       try
+                       {
+#endif
+                               VerifyAll();
+#ifndef HM_NO_EXCEPTIONS
+                       }
+                       catch(...)
+                       {
+                               delete latentException;
+                               reset();
+                               for (std::list<base_mock *>::iterator i = mocks.begin(); i != mocks.end(); i++)
+                               {
+                                       (*i)->destroy();
+                               }
+#ifdef _HIPPOMOCKS__ENABLE_CFUNC_MOCKING_SUPPORT
+                               for (std::list<Replace *>::iterator i = staticReplaces.begin(); i != staticReplaces.end(); i++)
+                               {
+                                       delete *i;
+                               }
+#endif
+                               throw;
+                       }
+               }
+               if (latentException)
+               {
+                       try
+                       {
+                               latentException->rethrow();
+                       }
+                       catch(BASE_EXCEPTION e)
+                       {
+                               printf("Latent exception masked!\nException:\n%s\n", e.what());
+                       }
+                       delete latentException;
+               }
+#endif
+               reset();
+               for (std::list<base_mock *>::iterator i = mocks.begin(); i != mocks.end(); i++)
+               {
+                       (*i)->destroy();
+               }
+#ifdef _HIPPOMOCKS__ENABLE_CFUNC_MOCKING_SUPPORT
+               for (std::list<Replace *>::iterator i = staticReplaces.begin(); i != staticReplaces.end(); i++)
+               {
+                       delete *i;
+               }
+#endif
+       }
+       void reset()
+       {
+          for (std::list<Call *>::iterator i = expectations.begin(); i != expectations.end(); i++)
+               {
+                       delete *i;
+               }
+               expectations.clear();
+               for (std::list<Call *>::iterator i = neverCalls.begin(); i != neverCalls.end(); i++)
+               {
+                       delete *i;
+               }
+               neverCalls.clear();
+               for (std::list<Call *>::iterator i = optionals.begin(); i != optionals.end(); i++)
+               {
+                       delete *i;
+               }
+               optionals.clear();
+               for (std::list<base_mock *>::iterator i = mocks.begin(); i != mocks.end(); i++)
+               {
+                       (*i)->reset();
+               }
+       }
+
+       void VerifyAll()
+       {
+#ifndef HM_NO_EXCEPTIONS
+               if (latentException)
+                       latentException->rethrow();
+#endif
+
+               for (std::list<Call *>::iterator i = expectations.begin(); i != expectations.end(); i++)
+               {
+                       if (!(*i)->satisfied) {
+                               RAISEEXCEPTION(CallMissingException(this));
+                       }
+               }
+       }
+       void VerifyPartial(base_mock *obj)
+       {
+#ifndef HM_NO_EXCEPTIONS
+               if (latentException)
+                       return;
+#endif
+               for (std::list<Call *>::iterator i = expectations.begin(); i != expectations.end(); i++)
+               {
+                       if ((*i)->mock == (base_mock *)obj &&
+                               !(*i)->satisfied )
+                       {
+                               RAISELATENTEXCEPTION(CallMissingException(this));
+                       }
+               }
+       }
+       template <typename base>
+       base *Mock();
+};
+
+// mock function providers
+template <typename Z, typename Y>
+class mockFuncs : public mock<Z> {
+private:
+       mockFuncs();
+public:
+       template <int X>
+       Y expectation0()
+       {
+               mock<Z> *realMock = mock<Z>::getRealThis();
+               if (realMock->isZombie)
+                       RAISEEXCEPTION(ZombieMockException(realMock->repo));
+               MockRepository *repo = realMock->repo;
+               return repo->template DoExpectation<Y>(realMock, realMock->translateX(X), ref_tuple<>());
+       }
+       template <int X, typename A>
+       Y expectation1(A a)
+       {
+               mock<Z> *realMock = mock<Z>::getRealThis();
+               if (realMock->isZombie)
+                       RAISEEXCEPTION(ZombieMockException(realMock->repo));
+               MockRepository *repo = realMock->repo;
+               return repo->template DoExpectation<Y>(realMock, realMock->translateX(X), ref_tuple<A>(a));
+       }
+       template <int X, typename A, typename B>
+       Y expectation2(A a, B b)
+       {
+               mock<Z> *realMock = mock<Z>::getRealThis();
+               if (realMock->isZombie)
+                       RAISEEXCEPTION(ZombieMockException(realMock->repo));
+               MockRepository *repo = realMock->repo;
+               return repo->template DoExpectation<Y>(realMock, realMock->translateX(X), ref_tuple<A,B>(a,b));
+       }
+       template <int X, typename A, typename B, typename C>
+       Y expectation3(A a, B b, C c)
+       {
+               mock<Z> *realMock = mock<Z>::getRealThis();
+               if (realMock->isZombie)
+                       RAISEEXCEPTION(ZombieMockException(realMock->repo));
+               MockRepository *repo = realMock->repo;
+               return repo->template DoExpectation<Y>(realMock, realMock->translateX(X), ref_tuple<A,B,C>(a,b,c));
+       }
+       template <int X, typename A, typename B, typename C, typename D>
+       Y expectation4(A a, B b, C c, D d)
+       {
+               mock<Z> *realMock = mock<Z>::getRealThis();
+               if (realMock->isZombie)
+                       RAISEEXCEPTION(ZombieMockException(realMock->repo));
+               MockRepository *repo = realMock->repo;
+               return repo->template DoExpectation<Y>(realMock, realMock->translateX(X), ref_tuple<A,B,C,D>(a,b,c,d));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E>
+       Y expectation5(A a, B b, C c, D d, E e)
+       {
+               mock<Z> *realMock = mock<Z>::getRealThis();
+               if (realMock->isZombie)
+                       RAISEEXCEPTION(ZombieMockException(realMock->repo));
+               MockRepository *repo = realMock->repo;
+               return repo->template DoExpectation<Y>(realMock, realMock->translateX(X), ref_tuple<A,B,C,D,E>(a,b,c,d,e));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F>
+       Y expectation6(A a, B b, C c, D d, E e, F f)
+       {
+               mock<Z> *realMock = mock<Z>::getRealThis();
+               if (realMock->isZombie)
+                       RAISEEXCEPTION(ZombieMockException(realMock->repo));
+               MockRepository *repo = realMock->repo;
+               return repo->template DoExpectation<Y>(realMock, realMock->translateX(X), ref_tuple<A,B,C,D,E,F>(a,b,c,d,e,f));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G>
+       Y expectation7(A a, B b, C c, D d, E e, F f, G g)
+       {
+               mock<Z> *realMock = mock<Z>::getRealThis();
+               if (realMock->isZombie)
+                       RAISEEXCEPTION(ZombieMockException(realMock->repo));
+               MockRepository *repo = realMock->repo;
+               return repo->template DoExpectation<Y>(realMock, realMock->translateX(X), ref_tuple<A,B,C,D,E,F,G>(a,b,c,d,e,f,g));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H>
+       Y expectation8(A a, B b, C c, D d, E e, F f, G g, H h)
+       {
+               mock<Z> *realMock = mock<Z>::getRealThis();
+               if (realMock->isZombie)
+                       RAISEEXCEPTION(ZombieMockException(realMock->repo));
+               MockRepository *repo = realMock->repo;
+               return repo->template DoExpectation<Y>(realMock, realMock->translateX(X), ref_tuple<A,B,C,D,E,F,G,H>(a,b,c,d,e,f,g,h));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I>
+       Y expectation9(A a, B b, C c, D d, E e, F f, G g, H h, I i)
+       {
+               mock<Z> *realMock = mock<Z>::getRealThis();
+               if (realMock->isZombie)
+                       RAISEEXCEPTION(ZombieMockException(realMock->repo));
+               MockRepository *repo = realMock->repo;
+               return repo->template DoExpectation<Y>(realMock, realMock->translateX(X), ref_tuple<A,B,C,D,E,F,G,H,I>(a,b,c,d,e,f,g,h,i));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J>
+       Y expectation10(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j)
+       {
+               mock<Z> *realMock = mock<Z>::getRealThis();
+               if (realMock->isZombie)
+                       RAISEEXCEPTION(ZombieMockException(realMock->repo));
+               MockRepository *repo = realMock->repo;
+               return repo->template DoExpectation<Y>(realMock, realMock->translateX(X), ref_tuple<A,B,C,D,E,F,G,H,I,J>(a,b,c,d,e,f,g,h,i,j));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K>
+       Y expectation11(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k)
+       {
+               mock<Z> *realMock = mock<Z>::getRealThis();
+               if (realMock->isZombie)
+                       RAISEEXCEPTION(ZombieMockException(realMock->repo));
+               MockRepository *repo = realMock->repo;
+               return repo->template DoExpectation<Y>(realMock, realMock->translateX(X), ref_tuple<A,B,C,D,E,F,G,H,I,J,K>(a,b,c,d,e,f,g,h,i,j,k));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K, typename L>
+       Y expectation12(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k, L l)
+       {
+               mock<Z> *realMock = mock<Z>::getRealThis();
+               if (realMock->isZombie)
+                       RAISEEXCEPTION(ZombieMockException(realMock->repo));
+               MockRepository *repo = realMock->repo;
+               return repo->template DoExpectation<Y>(realMock, realMock->translateX(X), ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L>(a,b,c,d,e,f,g,h,i,j,k,l));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K, typename L, typename M>
+       Y expectation13(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k, L l, M m)
+       {
+               mock<Z> *realMock = mock<Z>::getRealThis();
+               if (realMock->isZombie)
+                       RAISEEXCEPTION(ZombieMockException(realMock->repo));
+               MockRepository *repo = realMock->repo;
+               return repo->template DoExpectation<Y>(realMock, realMock->translateX(X), ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M>(a,b,c,d,e,f,g,h,i,j,k,l,m));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K, typename L, typename M, typename N>
+       Y expectation14(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k, L l, M m, N n)
+       {
+               mock<Z> *realMock = mock<Z>::getRealThis();
+               if (realMock->isZombie)
+                       RAISEEXCEPTION(ZombieMockException(realMock->repo));
+               MockRepository *repo = realMock->repo;
+               return repo->template DoExpectation<Y>(realMock, realMock->translateX(X), ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N>(a,b,c,d,e,f,g,h,i,j,k,l,m,n));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K, typename L, typename M, typename N, typename O>
+       Y expectation15(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k, L l, M m, N n, O o)
+       {
+               mock<Z> *realMock = mock<Z>::getRealThis();
+               if (realMock->isZombie)
+                       RAISEEXCEPTION(ZombieMockException(realMock->repo));
+               MockRepository *repo = realMock->repo;
+               return repo->template DoExpectation<Y>(realMock, realMock->translateX(X), ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,O>(a,b,c,d,e,f,g,h,i,j,k,l,m,n,o));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K, typename L, typename M, typename N, typename O, typename P>
+       Y expectation16(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k, L l, M m, N n, O o, P p)
+       {
+               mock<Z> *realMock = mock<Z>::getRealThis();
+               if (realMock->isZombie)
+                       RAISEEXCEPTION(ZombieMockException(realMock->repo));
+               MockRepository *repo = realMock->repo;
+               return repo->template DoExpectation<Y>(realMock, realMock->translateX(X), ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P>(a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p));
+       }
+
+       template <int X>
+       static Y static_expectation0()
+       {
+               return MockRepoInstanceHolder<0>::instance->template DoExpectation<Y>(NULL, std::pair<int, int>(0, X), ref_tuple<>());
+       }
+       template <int X, typename A>
+       static Y static_expectation1(A a)
+       {
+               return MockRepoInstanceHolder<0>::instance->template DoExpectation<Y>(NULL, std::pair<int, int>(0, X), ref_tuple<A>(a));
+       }
+       template <int X, typename A, typename B>
+       static Y static_expectation2(A a, B b)
+       {
+               return MockRepoInstanceHolder<0>::instance->template DoExpectation<Y>(NULL, std::pair<int, int>(0, X), ref_tuple<A,B>(a,b));
+       }
+       template <int X, typename A, typename B, typename C>
+       static Y static_expectation3(A a, B b, C c)
+       {
+               return MockRepoInstanceHolder<0>::instance->template DoExpectation<Y>(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C>(a,b,c));
+       }
+       template <int X, typename A, typename B, typename C, typename D>
+       static Y static_expectation4(A a, B b, C c, D d)
+       {
+               return MockRepoInstanceHolder<0>::instance->template DoExpectation<Y>(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C,D>(a,b,c,d));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E>
+       static Y static_expectation5(A a, B b, C c, D d, E e)
+       {
+               return MockRepoInstanceHolder<0>::instance->template DoExpectation<Y>(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C,D,E>(a,b,c,d,e));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F>
+       static Y static_expectation6(A a, B b, C c, D d, E e, F f)
+       {
+               return MockRepoInstanceHolder<0>::instance->template DoExpectation<Y>(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C,D,E,F>(a,b,c,d,e,f));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G>
+       static Y static_expectation7(A a, B b, C c, D d, E e, F f, G g)
+       {
+               return MockRepoInstanceHolder<0>::instance->template DoExpectation<Y>(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C,D,E,F,G>(a,b,c,d,e,f,g));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H>
+       static Y static_expectation8(A a, B b, C c, D d, E e, F f, G g, H h)
+       {
+               return MockRepoInstanceHolder<0>::instance->template DoExpectation<Y>(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C,D,E,F,G,H>(a,b,c,d,e,f,g,h));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I>
+       static Y static_expectation9(A a, B b, C c, D d, E e, F f, G g, H h, I i)
+       {
+               return MockRepoInstanceHolder<0>::instance->template DoExpectation<Y>(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C,D,E,F,G,H,I>(a,b,c,d,e,f,g,h,i));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J>
+       static Y static_expectation10(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j)
+       {
+               return MockRepoInstanceHolder<0>::instance->template DoExpectation<Y>(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C,D,E,F,G,H,I,J>(a,b,c,d,e,f,g,h,i,j));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K>
+       static Y static_expectation11(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k)
+       {
+               return MockRepoInstanceHolder<0>::instance->template DoExpectation<Y>(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C,D,E,F,G,H,I,J,K>(a,b,c,d,e,f,g,h,i,j,k));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K, typename L>
+       static Y static_expectation12(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k, L l)
+       {
+               return MockRepoInstanceHolder<0>::instance->template DoExpectation<Y>(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L>(a,b,c,d,e,f,g,h,i,j,k,l));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K, typename L, typename M>
+       static Y static_expectation13(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k, L l, M m)
+       {
+               return MockRepoInstanceHolder<0>::instance->template DoExpectation<Y>(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M>(a,b,c,d,e,f,g,h,i,j,k,l,m));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K, typename L, typename M, typename N>
+       static Y static_expectation14(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k, L l, M m, N n)
+       {
+               return MockRepoInstanceHolder<0>::instance->template DoExpectation<Y>(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N>(a,b,c,d,e,f,g,h,i,j,k,l,m,n));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K, typename L, typename M, typename N, typename O>
+       static Y static_expectation15(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k, L l, M m, N n, O o)
+       {
+               return MockRepoInstanceHolder<0>::instance->template DoExpectation<Y>(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,O>(a,b,c,d,e,f,g,h,i,j,k,l,m,n,o));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K, typename L, typename M, typename N, typename O, typename P>
+       static Y static_expectation16(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k, L l, M m, N n, O o, P p)
+       {
+               return MockRepoInstanceHolder<0>::instance->template DoExpectation<Y>(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P>(a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p));
+       }
+
+#ifdef _MSC_VER
+       template <int X>
+       Y __stdcall stdcallexpectation0()
+       {
+               MockRepository *repo = mock<Z>::repo;
+               return repo->template DoExpectation<Y>(this, mock<Z>::translateX(X), ref_tuple<>());
+       }
+       template <int X, typename A>
+       Y __stdcall stdcallexpectation1(A a)
+       {
+               MockRepository *repo = mock<Z>::repo;
+               return repo->template DoExpectation<Y>(this, mock<Z>::translateX(X), ref_tuple<A>(a));
+       }
+       template <int X, typename A, typename B>
+       Y __stdcall stdcallexpectation2(A a, B b)
+       {
+               MockRepository *repo = mock<Z>::repo;
+               return repo->template DoExpectation<Y>(this, mock<Z>::translateX(X), ref_tuple<A,B>(a,b));
+       }
+       template <int X, typename A, typename B, typename C>
+       Y __stdcall stdcallexpectation3(A a, B b, C c)
+       {
+               MockRepository *repo = mock<Z>::repo;
+               return repo->template DoExpectation<Y>(this, mock<Z>::translateX(X), ref_tuple<A,B,C>(a,b,c));
+       }
+       template <int X, typename A, typename B, typename C, typename D>
+       Y __stdcall stdcallexpectation4(A a, B b, C c, D d)
+       {
+               MockRepository *repo = mock<Z>::repo;
+               return repo->template DoExpectation<Y>(this, mock<Z>::translateX(X), ref_tuple<A,B,C,D>(a,b,c,d));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E>
+       Y __stdcall stdcallexpectation5(A a, B b, C c, D d, E e)
+       {
+               MockRepository *repo = mock<Z>::repo;
+               return repo->template DoExpectation<Y>(this, mock<Z>::translateX(X), ref_tuple<A,B,C,D,E>(a,b,c,d,e));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F>
+       Y __stdcall stdcallexpectation6(A a, B b, C c, D d, E e, F f)
+       {
+               MockRepository *repo = mock<Z>::repo;
+               return repo->template DoExpectation<Y>(this, mock<Z>::translateX(X), ref_tuple<A,B,C,D,E,F>(a,b,c,d,e,f));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G>
+       Y __stdcall stdcallexpectation7(A a, B b, C c, D d, E e, F f, G g)
+       {
+               MockRepository *repo = mock<Z>::repo;
+               return repo->template DoExpectation<Y>(this, mock<Z>::translateX(X), ref_tuple<A,B,C,D,E,F,G>(a,b,c,d,e,f,g));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H>
+       Y __stdcall stdcallexpectation8(A a, B b, C c, D d, E e, F f, G g, H h)
+       {
+               MockRepository *repo = mock<Z>::repo;
+               return repo->template DoExpectation<Y>(this, mock<Z>::translateX(X), ref_tuple<A,B,C,D,E,F,G,H>(a,b,c,d,e,f,g,h));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I>
+       Y __stdcall stdcallexpectation9(A a, B b, C c, D d, E e, F f, G g, H h, I i)
+       {
+               MockRepository *repo = mock<Z>::repo;
+               return repo->template DoExpectation<Y>(this, mock<Z>::translateX(X), ref_tuple<A,B,C,D,E,F,G,H,I>(a,b,c,d,e,f,g,h,i));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J>
+       Y __stdcall stdcallexpectation10(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j)
+       {
+               MockRepository *repo = mock<Z>::repo;
+               return repo->template DoExpectation<Y>(this, mock<Z>::translateX(X), ref_tuple<A,B,C,D,E,F,G,H,I,J>(a,b,c,d,e,f,g,h,i,j));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K>
+       Y __stdcall stdcallexpectation11(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k)
+       {
+               MockRepository *repo = mock<Z>::repo;
+               return repo->template DoExpectation<Y>(this, mock<Z>::translateX(X), ref_tuple<A,B,C,D,E,F,G,H,I,J,K>(a,b,c,d,e,f,g,h,i,j,k));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K, typename L>
+       Y __stdcall stdcallexpectation12(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k, L l)
+       {
+               MockRepository *repo = mock<Z>::repo;
+               return repo->template DoExpectation<Y>(this, mock<Z>::translateX(X), ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L>(a,b,c,d,e,f,g,h,i,j,k,l));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K, typename L, typename M>
+       Y __stdcall stdcallexpectation13(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k, L l, M m)
+       {
+               MockRepository *repo = mock<Z>::repo;
+               return repo->template DoExpectation<Y>(this, mock<Z>::translateX(X), ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M>(a,b,c,d,e,f,g,h,i,j,k,l,m));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K, typename L, typename M, typename N>
+       Y __stdcall stdcallexpectation14(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k, L l, M m, N n)
+       {
+               MockRepository *repo = mock<Z>::repo;
+               return repo->template DoExpectation<Y>(this, mock<Z>::translateX(X), ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N>(a,b,c,d,e,f,g,h,i,j,k,l,m,n));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K, typename L, typename M, typename N, typename O>
+       Y __stdcall stdcallexpectation15(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k, L l, M m, N n, O o)
+       {
+               MockRepository *repo = mock<Z>::repo;
+               return repo->template DoExpectation<Y>(this, mock<Z>::translateX(X), ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,O>(a,b,c,d,e,f,g,h,i,j,k,l,m,n,o));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K, typename L, typename M, typename N, typename O, typename P>
+       Y __stdcall stdcallexpectation16(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k, L l, M m, N n, O o, P p)
+       {
+               MockRepository *repo = mock<Z>::repo;
+               return repo->template DoExpectation<Y>(this, mock<Z>::translateX(X), ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P>(a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p));
+       }
+#if defined(_MSC_VER) && !defined(_WIN64)
+       template <int X>
+       static Y __stdcall static_stdcallexpectation0()
+       {
+               return MockRepoInstanceHolder<0>::instance->template DoExpectation<Y>(NULL, std::pair<int, int>(0, X), ref_tuple<>());
+       }
+       template <int X, typename A>
+       static Y __stdcall static_stdcallexpectation1(A a)
+       {
+               return MockRepoInstanceHolder<0>::instance->template DoExpectation<Y>(NULL, std::pair<int, int>(0, X), ref_tuple<A>(a));
+       }
+       template <int X, typename A, typename B>
+       static Y __stdcall static_stdcallexpectation2(A a, B b)
+       {
+               return MockRepoInstanceHolder<0>::instance->template DoExpectation<Y>(NULL, std::pair<int, int>(0, X), ref_tuple<A,B>(a,b));
+       }
+       template <int X, typename A, typename B, typename C>
+       static Y __stdcall static_stdcallexpectation3(A a, B b, C c)
+       {
+               return MockRepoInstanceHolder<0>::instance->template DoExpectation<Y>(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C>(a,b,c));
+       }
+       template <int X, typename A, typename B, typename C, typename D>
+       static Y __stdcall static_stdcallexpectation4(A a, B b, C c, D d)
+       {
+               return MockRepoInstanceHolder<0>::instance->template DoExpectation<Y>(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C,D>(a,b,c,d));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E>
+       static Y __stdcall static_stdcallexpectation5(A a, B b, C c, D d, E e)
+       {
+               return MockRepoInstanceHolder<0>::instance->template DoExpectation<Y>(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C,D,E>(a,b,c,d,e));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F>
+       static Y __stdcall static_stdcallexpectation6(A a, B b, C c, D d, E e, F f)
+       {
+               return MockRepoInstanceHolder<0>::instance->template DoExpectation<Y>(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C,D,E,F>(a,b,c,d,e,f));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G>
+       static Y __stdcall static_stdcallexpectation7(A a, B b, C c, D d, E e, F f, G g)
+       {
+               return MockRepoInstanceHolder<0>::instance->template DoExpectation<Y>(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C,D,E,F,G>(a,b,c,d,e,f,g));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H>
+       static Y __stdcall static_stdcallexpectation8(A a, B b, C c, D d, E e, F f, G g, H h)
+       {
+               return MockRepoInstanceHolder<0>::instance->template DoExpectation<Y>(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C,D,E,F,G,H>(a,b,c,d,e,f,g,h));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I>
+       static Y __stdcall static_stdcallexpectation9(A a, B b, C c, D d, E e, F f, G g, H h, I i)
+       {
+               return MockRepoInstanceHolder<0>::instance->template DoExpectation<Y>(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C,D,E,F,G,H,I>(a,b,c,d,e,f,g,h,i));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J>
+       static Y __stdcall static_stdcallexpectation10(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j)
+       {
+               return MockRepoInstanceHolder<0>::instance->template DoExpectation<Y>(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C,D,E,F,G,H,I,J>(a,b,c,d,e,f,g,h,i,j));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K>
+       static Y __stdcall static_stdcallexpectation11(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k)
+       {
+               return MockRepoInstanceHolder<0>::instance->template DoExpectation<Y>(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C,D,E,F,G,H,I,J,K>(a,b,c,d,e,f,g,h,i,j,k));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K, typename L>
+       static Y __stdcall static_stdcallexpectation12(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k, L l)
+       {
+               return MockRepoInstanceHolder<0>::instance->template DoExpectation<Y>(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L>(a,b,c,d,e,f,g,h,i,j,k,l));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K, typename L, typename M>
+       static Y __stdcall static_stdcallexpectation13(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k, L l, M m)
+       {
+               return MockRepoInstanceHolder<0>::instance->template DoExpectation<Y>(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M>(a,b,c,d,e,f,g,h,i,j,k,l,m));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K, typename L, typename M, typename N>
+       static Y __stdcall static_stdcallexpectation14(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k, L l, M m, N n)
+       {
+               return MockRepoInstanceHolder<0>::instance->template DoExpectation<Y>(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N>(a,b,c,d,e,f,g,h,i,j,k,l,m,n));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K, typename L, typename M, typename N, typename O>
+       static Y __stdcall static_stdcallexpectation15(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k, L l, M m, N n, O o)
+       {
+               return MockRepoInstanceHolder<0>::instance->template DoExpectation<Y>(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,O>(a,b,c,d,e,f,g,h,i,j,k,l,m,n,o));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K, typename L, typename M, typename N, typename O, typename P>
+       static Y __stdcall static_stdcallexpectation16(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k, L l, M m, N n, O o, P p)
+       {
+               return MockRepoInstanceHolder<0>::instance->template DoExpectation<Y>(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P>(a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p));
+       }
+#endif
+#endif
+};
+
+template <typename Z>
+class mockFuncs<Z, void> : public mock<Z> {
+private:
+               mockFuncs();
+public:
+       template <int X>
+       void expectation0()
+       {
+               mock<Z> *realMock = mock<Z>::getRealThis();
+               if (realMock->isZombie)
+                       RAISEEXCEPTION(ZombieMockException(realMock->repo));
+               MockRepository *repo = realMock->repo;
+               repo->DoVoidExpectation(realMock, realMock->translateX(X), ref_tuple<>());
+       }
+       template <int X, typename A>
+       void expectation1(A a)
+       {
+               mock<Z> *realMock = mock<Z>::getRealThis();
+               if (realMock->isZombie)
+                       RAISEEXCEPTION(ZombieMockException(realMock->repo));
+               MockRepository *repo = realMock->repo;
+               repo->DoVoidExpectation(realMock, realMock->translateX(X), ref_tuple<A>(a));
+       }
+       template <int X, typename A, typename B>
+       void expectation2(A a, B b)
+       {
+               mock<Z> *realMock = mock<Z>::getRealThis();
+               if (realMock->isZombie)
+                       RAISEEXCEPTION(ZombieMockException(realMock->repo));
+               MockRepository *repo = realMock->repo;
+               repo->DoVoidExpectation(realMock, realMock->translateX(X), ref_tuple<A,B>(a,b));
+       }
+       template <int X, typename A, typename B, typename C>
+       void expectation3(A a, B b, C c)
+       {
+               mock<Z> *realMock = mock<Z>::getRealThis();
+               if (realMock->isZombie)
+                       RAISEEXCEPTION(ZombieMockException(realMock->repo));
+               MockRepository *repo = realMock->repo;
+               repo->DoVoidExpectation(realMock, realMock->translateX(X), ref_tuple<A,B,C>(a,b,c));
+       }
+       template <int X, typename A, typename B, typename C, typename D>
+       void expectation4(A a, B b, C c, D d)
+       {
+               mock<Z> *realMock = mock<Z>::getRealThis();
+               if (realMock->isZombie)
+                       RAISEEXCEPTION(ZombieMockException(realMock->repo));
+               MockRepository *repo = realMock->repo;
+               repo->DoVoidExpectation(realMock, realMock->translateX(X), ref_tuple<A,B,C,D>(a,b,c,d));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E>
+       void expectation5(A a, B b, C c, D d, E e)
+       {
+               mock<Z> *realMock = mock<Z>::getRealThis();
+               if (realMock->isZombie)
+                       RAISEEXCEPTION(ZombieMockException(realMock->repo));
+               MockRepository *repo = realMock->repo;
+               repo->DoVoidExpectation(realMock, realMock->translateX(X), ref_tuple<A,B,C,D,E>(a,b,c,d,e));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F>
+       void expectation6(A a, B b, C c, D d, E e, F f)
+       {
+               mock<Z> *realMock = mock<Z>::getRealThis();
+               if (realMock->isZombie)
+                       RAISEEXCEPTION(ZombieMockException(realMock->repo));
+               MockRepository *repo = realMock->repo;
+               repo->DoVoidExpectation(realMock, realMock->translateX(X), ref_tuple<A,B,C,D,E,F>(a,b,c,d,e,f));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G>
+       void expectation7(A a, B b, C c, D d, E e, F f, G g)
+       {
+               mock<Z> *realMock = mock<Z>::getRealThis();
+               if (realMock->isZombie)
+                       RAISEEXCEPTION(ZombieMockException(realMock->repo));
+               MockRepository *repo = realMock->repo;
+               repo->DoVoidExpectation(realMock, realMock->translateX(X), ref_tuple<A,B,C,D,E,F,G>(a,b,c,d,e,f,g));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H>
+       void expectation8(A a, B b, C c, D d, E e, F f, G g, H h)
+       {
+               mock<Z> *realMock = mock<Z>::getRealThis();
+               if (realMock->isZombie)
+                       RAISEEXCEPTION(ZombieMockException(realMock->repo));
+               MockRepository *repo = realMock->repo;
+               repo->DoVoidExpectation(realMock, realMock->translateX(X), ref_tuple<A,B,C,D,E,F,G,H>(a,b,c,d,e,f,g,h));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I>
+       void expectation9(A a, B b, C c, D d, E e, F f, G g, H h, I i)
+       {
+               mock<Z> *realMock = mock<Z>::getRealThis();
+               if (realMock->isZombie)
+                       RAISEEXCEPTION(ZombieMockException(realMock->repo));
+               MockRepository *repo = realMock->repo;
+               repo->DoVoidExpectation(realMock, realMock->translateX(X), ref_tuple<A,B,C,D,E,F,G,H,I>(a,b,c,d,e,f,g,h,i));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J>
+       void expectation10(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j)
+       {
+               mock<Z> *realMock = mock<Z>::getRealThis();
+               if (realMock->isZombie)
+                       RAISEEXCEPTION(ZombieMockException(realMock->repo));
+               MockRepository *repo = realMock->repo;
+               repo->DoVoidExpectation(realMock, realMock->translateX(X), ref_tuple<A,B,C,D,E,F,G,H,I,J>(a,b,c,d,e,f,g,h,i,j));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K>
+       void expectation11(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k)
+       {
+               mock<Z> *realMock = mock<Z>::getRealThis();
+               if (realMock->isZombie)
+                       RAISEEXCEPTION(ZombieMockException(realMock->repo));
+               MockRepository *repo = realMock->repo;
+               repo->DoVoidExpectation(realMock, realMock->translateX(X), ref_tuple<A,B,C,D,E,F,G,H,I,J,K>(a,b,c,d,e,f,g,h,i,j,k));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K, typename L>
+       void expectation12(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k, L l)
+       {
+               mock<Z> *realMock = mock<Z>::getRealThis();
+               if (realMock->isZombie)
+                       RAISEEXCEPTION(ZombieMockException(realMock->repo));
+               MockRepository *repo = realMock->repo;
+               repo->DoVoidExpectation(realMock, realMock->translateX(X), ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L>(a,b,c,d,e,f,g,h,i,j,k,l));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K, typename L, typename M>
+       void expectation13(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k, L l, M m)
+       {
+               mock<Z> *realMock = mock<Z>::getRealThis();
+               if (realMock->isZombie)
+                       RAISEEXCEPTION(ZombieMockException(realMock->repo));
+               MockRepository *repo = realMock->repo;
+               repo->DoVoidExpectation(realMock, realMock->translateX(X), ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M>(a,b,c,d,e,f,g,h,i,j,k,l,m));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K, typename L, typename M, typename N>
+       void expectation14(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k, L l, M m, N n)
+       {
+               mock<Z> *realMock = mock<Z>::getRealThis();
+               if (realMock->isZombie)
+                       RAISEEXCEPTION(ZombieMockException(realMock->repo));
+               MockRepository *repo = realMock->repo;
+               repo->DoVoidExpectation(realMock, realMock->translateX(X), ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N>(a,b,c,d,e,f,g,h,i,j,k,l,m,n));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K, typename L, typename M, typename N, typename O>
+       void expectation15(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k, L l, M m, N n, O o)
+       {
+               mock<Z> *realMock = mock<Z>::getRealThis();
+               if (realMock->isZombie)
+                       RAISEEXCEPTION(ZombieMockException(realMock->repo));
+               MockRepository *repo = realMock->repo;
+               repo->DoVoidExpectation(realMock, realMock->translateX(X), ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,O>(a,b,c,d,e,f,g,h,i,j,k,l,m,n,o));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K, typename L, typename M, typename N, typename O, typename P>
+       void expectation16(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k, L l, M m, N n, O o, P p)
+       {
+               mock<Z> *realMock = mock<Z>::getRealThis();
+               if (realMock->isZombie)
+                       RAISEEXCEPTION(ZombieMockException(realMock->repo));
+               MockRepository *repo = realMock->repo;
+               repo->DoVoidExpectation(realMock, realMock->translateX(X), ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P>(a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p));
+       }
+       template <int X>
+       static void static_expectation0()
+       {
+               MockRepoInstanceHolder<0>::instance->DoVoidExpectation(NULL, std::pair<int, int>(0, X), ref_tuple<>());
+       }
+       template <int X, typename A>
+       static void static_expectation1(A a)
+       {
+               MockRepoInstanceHolder<0>::instance->DoVoidExpectation(NULL, std::pair<int, int>(0, X), ref_tuple<A>(a));
+       }
+       template <int X, typename A, typename B>
+       static void static_expectation2(A a, B b)
+       {
+               MockRepoInstanceHolder<0>::instance->DoVoidExpectation(NULL, std::pair<int, int>(0, X), ref_tuple<A,B>(a,b));
+       }
+       template <int X, typename A, typename B, typename C>
+       static void static_expectation3(A a, B b, C c)
+       {
+               MockRepoInstanceHolder<0>::instance->DoVoidExpectation(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C>(a,b,c));
+       }
+       template <int X, typename A, typename B, typename C, typename D>
+       static void static_expectation4(A a, B b, C c, D d)
+       {
+               MockRepoInstanceHolder<0>::instance->DoVoidExpectation(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C,D>(a,b,c,d));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E>
+       static void static_expectation5(A a, B b, C c, D d, E e)
+       {
+               MockRepoInstanceHolder<0>::instance->DoVoidExpectation(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C,D,E>(a,b,c,d,e));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F>
+       static void static_expectation6(A a, B b, C c, D d, E e, F f)
+       {
+               MockRepoInstanceHolder<0>::instance->DoVoidExpectation(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C,D,E,F>(a,b,c,d,e,f));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G>
+       static void static_expectation7(A a, B b, C c, D d, E e, F f, G g)
+       {
+               MockRepoInstanceHolder<0>::instance->DoVoidExpectation(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C,D,E,F,G>(a,b,c,d,e,f,g));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H>
+       static void static_expectation8(A a, B b, C c, D d, E e, F f, G g, H h)
+       {
+               MockRepoInstanceHolder<0>::instance->DoVoidExpectation(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C,D,E,F,G,H>(a,b,c,d,e,f,g,h));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I>
+       static void static_expectation9(A a, B b, C c, D d, E e, F f, G g, H h, I i)
+       {
+               MockRepoInstanceHolder<0>::instance->DoVoidExpectation(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C,D,E,F,G,H,I>(a,b,c,d,e,f,g,h,i));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J>
+       static void static_expectation10(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j)
+       {
+               MockRepoInstanceHolder<0>::instance->DoVoidExpectation(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C,D,E,F,G,H,I,J>(a,b,c,d,e,f,g,h,i,j));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K>
+       static void static_expectation11(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k)
+       {
+               MockRepoInstanceHolder<0>::instance->DoVoidExpectation(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C,D,E,F,G,H,I,J,K>(a,b,c,d,e,f,g,h,i,j,k));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K, typename L>
+       static void static_expectation12(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k, L l)
+       {
+               MockRepoInstanceHolder<0>::instance->DoVoidExpectation(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L>(a,b,c,d,e,f,g,h,i,j,k,l));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K, typename L, typename M>
+       static void static_expectation13(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k, L l, M m)
+       {
+               MockRepoInstanceHolder<0>::instance->DoVoidExpectation(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M>(a,b,c,d,e,f,g,h,i,j,k,l,m));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K, typename L, typename M, typename N>
+       static void static_expectation14(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k, L l, M m, N n)
+       {
+               MockRepoInstanceHolder<0>::instance->DoVoidExpectation(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N>(a,b,c,d,e,f,g,h,i,j,k,l,m,n));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K, typename L, typename M, typename N, typename O>
+       static void static_expectation15(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k, L l, M m, N n, O o)
+       {
+               MockRepoInstanceHolder<0>::instance->DoVoidExpectation(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,O>(a,b,c,d,e,f,g,h,i,j,k,l,m,n,o));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K, typename L, typename M, typename N, typename O, typename P>
+       static void static_expectation16(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k, L l, M m, N n, O o, P p)
+       {
+               MockRepoInstanceHolder<0>::instance->DoVoidExpectation(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P>(a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p));
+       }
+
+#ifdef _MSC_VER
+       template <int X>
+       void __stdcall stdcallexpectation0()
+       {
+               MockRepository *repo = mock<Z>::repo;
+               repo->DoVoidExpectation(this, mock<Z>::translateX(X), ref_tuple<>());
+       }
+       template <int X, typename A>
+       void __stdcall stdcallexpectation1(A a)
+       {
+               MockRepository *repo = mock<Z>::repo;
+               repo->DoVoidExpectation(this, mock<Z>::translateX(X), ref_tuple<A>(a));
+       }
+       template <int X, typename A, typename B>
+       void __stdcall stdcallexpectation2(A a, B b)
+       {
+               MockRepository *repo = mock<Z>::repo;
+               repo->DoVoidExpectation(this, mock<Z>::translateX(X), ref_tuple<A,B>(a,b));
+       }
+       template <int X, typename A, typename B, typename C>
+       void __stdcall stdcallexpectation3(A a, B b, C c)
+       {
+               MockRepository *repo = mock<Z>::repo;
+               repo->DoVoidExpectation(this, mock<Z>::translateX(X), ref_tuple<A,B,C>(a,b,c));
+       }
+       template <int X, typename A, typename B, typename C, typename D>
+       void __stdcall stdcallexpectation4(A a, B b, C c, D d)
+       {
+               MockRepository *repo = mock<Z>::repo;
+               repo->DoVoidExpectation(this, mock<Z>::translateX(X), ref_tuple<A,B,C,D>(a,b,c,d));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E>
+       void __stdcall stdcallexpectation5(A a, B b, C c, D d, E e)
+       {
+               MockRepository *repo = mock<Z>::repo;
+               repo->DoVoidExpectation(this, mock<Z>::translateX(X), ref_tuple<A,B,C,D,E>(a,b,c,d,e));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F>
+       void __stdcall stdcallexpectation6(A a, B b, C c, D d, E e, F f)
+       {
+               MockRepository *repo = mock<Z>::repo;
+               repo->DoVoidExpectation(this, mock<Z>::translateX(X), ref_tuple<A,B,C,D,E,F>(a,b,c,d,e,f));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G>
+       void __stdcall stdcallexpectation7(A a, B b, C c, D d, E e, F f, G g)
+       {
+               MockRepository *repo = mock<Z>::repo;
+               repo->DoVoidExpectation(this, mock<Z>::translateX(X), ref_tuple<A,B,C,D,E,F,G>(a,b,c,d,e,f,g));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H>
+       void __stdcall stdcallexpectation8(A a, B b, C c, D d, E e, F f, G g, H h)
+       {
+               MockRepository *repo = mock<Z>::repo;
+               repo->DoVoidExpectation(this, mock<Z>::translateX(X), ref_tuple<A,B,C,D,E,F,G,H>(a,b,c,d,e,f,g,h));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I>
+       void __stdcall stdcallexpectation9(A a, B b, C c, D d, E e, F f, G g, H h, I i)
+       {
+               MockRepository *repo = mock<Z>::repo;
+               repo->DoVoidExpectation(this, mock<Z>::translateX(X), ref_tuple<A,B,C,D,E,F,G,H,I>(a,b,c,d,e,f,g,h,i));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J>
+       void __stdcall stdcallexpectation10(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j)
+       {
+               MockRepository *repo = mock<Z>::repo;
+               repo->DoVoidExpectation(this, mock<Z>::translateX(X), ref_tuple<A,B,C,D,E,F,G,H,I,J>(a,b,c,d,e,f,g,h,i,j));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K>
+       void __stdcall stdcallexpectation11(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k)
+       {
+               MockRepository *repo = mock<Z>::repo;
+               repo->DoVoidExpectation(this, mock<Z>::translateX(X), ref_tuple<A,B,C,D,E,F,G,H,I,J,K>(a,b,c,d,e,f,g,h,i,j,k));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K, typename L>
+       void __stdcall stdcallexpectation12(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k, L l)
+       {
+               MockRepository *repo = mock<Z>::repo;
+               repo->DoVoidExpectation(this, mock<Z>::translateX(X), ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L>(a,b,c,d,e,f,g,h,i,j,k,l));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K, typename L, typename M>
+       void __stdcall stdcallexpectation13(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k, L l, M m)
+       {
+               MockRepository *repo = mock<Z>::repo;
+               repo->DoVoidExpectation(this, mock<Z>::translateX(X), ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M>(a,b,c,d,e,f,g,h,i,j,k,l,m));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K, typename L, typename M, typename N>
+       void __stdcall stdcallexpectation14(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k, L l, M m, N n)
+       {
+               MockRepository *repo = mock<Z>::repo;
+               repo->DoVoidExpectation(this, mock<Z>::translateX(X), ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N>(a,b,c,d,e,f,g,h,i,j,k,l,m,n));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K, typename L, typename M, typename N, typename O>
+       void __stdcall stdcallexpectation15(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k, L l, M m, N n, O o)
+       {
+               MockRepository *repo = mock<Z>::repo;
+               repo->DoVoidExpectation(this, mock<Z>::translateX(X), ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,O>(a,b,c,d,e,f,g,h,i,j,k,l,m,n,o));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K, typename L, typename M, typename N, typename O, typename P>
+       void __stdcall stdcallexpectation16(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k, L l, M m, N n, O o, P p)
+       {
+               MockRepository *repo = mock<Z>::repo;
+               repo->DoVoidExpectation(this, mock<Z>::translateX(X), ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P>(a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p));
+       }
+#if defined(_MSC_VER) && !defined(_WIN64)
+       template <int X>
+       static void __stdcall static_stdcallexpectation0()
+       {
+               return MockRepoInstanceHolder<0>::instance->DoVoidExpectation(NULL, std::pair<int, int>(0, X), ref_tuple<>());
+       }
+       template <int X, typename A>
+       static void __stdcall static_stdcallexpectation1(A a)
+       {
+               return MockRepoInstanceHolder<0>::instance->DoVoidExpectation(NULL, std::pair<int, int>(0, X), ref_tuple<A>(a));
+       }
+       template <int X, typename A, typename B>
+       static void __stdcall static_stdcallexpectation2(A a, B b)
+       {
+               return MockRepoInstanceHolder<0>::instance->DoVoidExpectation(NULL, std::pair<int, int>(0, X), ref_tuple<A,B>(a,b));
+       }
+       template <int X, typename A, typename B, typename C>
+       static void __stdcall static_stdcallexpectation3(A a, B b, C c)
+       {
+               return MockRepoInstanceHolder<0>::instance->DoVoidExpectation(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C>(a,b,c));
+       }
+       template <int X, typename A, typename B, typename C, typename D>
+       static void __stdcall static_stdcallexpectation4(A a, B b, C c, D d)
+       {
+               return MockRepoInstanceHolder<0>::instance->DoVoidExpectation(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C,D>(a,b,c,d));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E>
+       static void __stdcall static_stdcallexpectation5(A a, B b, C c, D d, E e)
+       {
+               return MockRepoInstanceHolder<0>::instance->DoVoidExpectation(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C,D,E>(a,b,c,d,e));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F>
+       static void __stdcall static_stdcallexpectation6(A a, B b, C c, D d, E e, F f)
+       {
+               return MockRepoInstanceHolder<0>::instance->DoVoidExpectation(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C,D,E,F>(a,b,c,d,e,f));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G>
+       static void __stdcall static_stdcallexpectation7(A a, B b, C c, D d, E e, F f, G g)
+       {
+               return MockRepoInstanceHolder<0>::instance->DoVoidExpectation(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C,D,E,F,G>(a,b,c,d,e,f,g));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H>
+       static void __stdcall static_stdcallexpectation8(A a, B b, C c, D d, E e, F f, G g, H h)
+       {
+               return MockRepoInstanceHolder<0>::instance->DoVoidExpectation(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C,D,E,F,G,H>(a,b,c,d,e,f,g,h));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I>
+       static void __stdcall static_stdcallexpectation9(A a, B b, C c, D d, E e, F f, G g, H h, I i)
+       {
+               return MockRepoInstanceHolder<0>::instance->DoVoidExpectation(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C,D,E,F,G,H,I>(a,b,c,d,e,f,g,h,i));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J>
+       static void __stdcall static_stdcallexpectation10(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j)
+       {
+               return MockRepoInstanceHolder<0>::instance->DoVoidExpectation(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C,D,E,F,G,H,I,J>(a,b,c,d,e,f,g,h,i,j));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K>
+       static void __stdcall static_stdcallexpectation11(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k)
+       {
+               return MockRepoInstanceHolder<0>::instance->DoVoidExpectation(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C,D,E,F,G,H,I,J,K>(a,b,c,d,e,f,g,h,i,j,k));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K, typename L>
+       static void __stdcall static_stdcallexpectation12(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k, L l)
+       {
+               return MockRepoInstanceHolder<0>::instance->DoVoidExpectation(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L>(a,b,c,d,e,f,g,h,i,j,k,l));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K, typename L, typename M>
+       static void __stdcall static_stdcallexpectation13(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k, L l, M m)
+       {
+               return MockRepoInstanceHolder<0>::instance->DoVoidExpectation(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M>(a,b,c,d,e,f,g,h,i,j,k,l,m));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K, typename L, typename M, typename N>
+       static void __stdcall static_stdcallexpectation14(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k, L l, M m, N n)
+       {
+               return MockRepoInstanceHolder<0>::instance->DoVoidExpectation(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N>(a,b,c,d,e,f,g,h,i,j,k,l,m,n));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K, typename L, typename M, typename N, typename O>
+       static void __stdcall static_stdcallexpectation15(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k, L l, M m, N n, O o)
+       {
+               return MockRepoInstanceHolder<0>::instance->DoVoidExpectation(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,O>(a,b,c,d,e,f,g,h,i,j,k,l,m,n,o));
+       }
+       template <int X, typename A, typename B, typename C, typename D, typename E, typename F, typename G, typename H, typename I, typename J, typename K, typename L, typename M, typename N, typename O, typename P>
+       static void __stdcall static_stdcallexpectation16(A a, B b, C c, D d, E e, F f, G g, H h, I i, J j, K k, L l, M m, N n, O o, P p)
+       {
+               return MockRepoInstanceHolder<0>::instance->DoVoidExpectation(NULL, std::pair<int, int>(0, X), ref_tuple<A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P>(a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p));
+       }
+#endif
+#endif
+};
+
+template <typename T>
+template <int X>
+void mock<T>::mockedDestructor(int)
+{
+       repo->DoVoidExpectation(this, translateX(X), ref_tuple<>(), true);
+       repo->VerifyPartial(this);
+       isZombie = true;
+}
+
+template <typename Z>
+void MockRepository::BasicRegisterExpect(mock<Z> *zMock, int baseOffset, int funcIndex, void (base_mock::*func)(), int X)
+{
+       if (funcIndex > VIRT_FUNC_LIMIT) RAISEEXCEPTION(NotImplementedException(this));
+       if ((unsigned int)baseOffset * sizeof(void*) + sizeof(void*)-1 > sizeof(Z)) RAISEEXCEPTION(NotImplementedException(this));
+       if (zMock->funcMap.find(std::make_pair(baseOffset, funcIndex)) == zMock->funcMap.end())
+       {
+               if (zMock->funcTables.find(baseOffset) == zMock->funcTables.end())
+               {
+                       typedef void (*funcptr)();
+                       funcptr *funcTable = new funcptr[VIRT_FUNC_LIMIT+1];
+                       memcpy(funcTable, zMock->notimplementedfuncs, sizeof(funcptr) * VIRT_FUNC_LIMIT);
+                       ((void **)funcTable)[VIRT_FUNC_LIMIT] = zMock;
+                       zMock->funcTables[baseOffset] = funcTable;
+                       ((void **)zMock)[baseOffset] = funcTable;
+               }
+               zMock->funcMap[std::make_pair(baseOffset, funcIndex)] = X+1;
+               zMock->funcTables[baseOffset][funcIndex] = getNonvirtualMemberFunctionAddress<void (*)()>(func);
+       }
+}
+
+template <int X, typename Z2>
+TCall<void> &MockRepository::RegisterExpectDestructor(Z2 *mck, RegistrationType expect, const char *fileName, unsigned long lineNo)
+{
+       func_index idx;
+       ((Z2 *)&idx)->~Z2();
+       int funcIndex = idx.lci * FUNCTION_STRIDE + FUNCTION_BASE;
+       void (mock<Z2>::*member)(int);
+       member = &mock<Z2>::template mockedDestructor<X>;
+       BasicRegisterExpect(reinterpret_cast<mock<Z2> *>(mck),
+                                               0, funcIndex,
+                                               reinterpret_cast<void (base_mock::*)()>(member), X);
+#ifdef EXTRA_DESTRUCTOR
+       BasicRegisterExpect(reinterpret_cast<mock<Z2> *>(mck),
+                                               0, funcIndex+1,
+                                               reinterpret_cast<void (base_mock::*)()>(member), X);
+#endif
+       TCall<void> *call = new TCall<void>(Once, reinterpret_cast<base_mock *>(mck), std::pair<int, int>(0, funcIndex), lineNo, "destructor", fileName);
+       addCall( call, expect );
+       return *call;
+}
+
+#if defined(_MSC_VER) && !defined(_WIN64)
+// Support for COM, see declarations
+template <int X, typename Z2, typename Y, typename Z>
+TCall<Y> &MockRepository::RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(), RegistrationType expect, const char *funcName, const char *fileName, unsigned long lineNo)
+{
+       std::pair<int, int> funcIndex = virtual_index((Y(__stdcall Z2::*)())func);
+       Y(__stdcall mockFuncs<Z2, Y>::*mfp)();
+       mfp = &mockFuncs<Z2, Y>::template stdcallexpectation0<X>;
+       BasicRegisterExpect(reinterpret_cast<mock<Z2> *>(mck),
+               funcIndex.first,
+               funcIndex.second,
+               reinterpret_cast<void (base_mock::*)()>(mfp), X);
+       TCall<Y> *call = new TCall<Y>(expect, reinterpret_cast<base_mock *>(mck), funcIndex, lineNo, funcName, fileName);
+
+       addCall( call, expect );
+       return *call;
+}
+template <int X, typename Z2, typename Y, typename Z, typename A>
+TCall<Y,A> &MockRepository::RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A), RegistrationType expect, const char *funcName, const char *fileName, unsigned long lineNo)
+{
+       std::pair<int, int> funcIndex = virtual_index((Y(__stdcall Z2::*)(A))func);
+       Y(__stdcall mockFuncs<Z2, Y>::*mfp)(A);
+       mfp = &mockFuncs<Z2, Y>::template stdcallexpectation1<X, A>;
+       BasicRegisterExpect(reinterpret_cast<mock<Z2> *>(mck),
+               funcIndex.first,
+               funcIndex.second,
+               reinterpret_cast<void (base_mock::*)()>(mfp), X);
+       TCall<Y, A> *call = new TCall<Y, A>(expect, reinterpret_cast<base_mock *>(mck), funcIndex, lineNo, funcName, fileName);
+       addCall( call, expect );
+       return *call;
+}
+template <int X, typename Z2, typename Y, typename Z,
+       typename A, typename B>
+TCall<Y,A,B> &MockRepository::RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B), RegistrationType expect, const char *funcName, const char *fileName, unsigned long lineNo)
+{
+               std::pair<int, int> funcIndex = virtual_index((Y(__stdcall Z2::*)(A, B))func);
+               Y(__stdcall mockFuncs<Z2, Y>::*mfp)(A, B);
+               mfp = &mockFuncs<Z2, Y>::template stdcallexpectation2<X, A, B>;
+               BasicRegisterExpect(reinterpret_cast<mock<Z2> *>(mck),
+                       funcIndex.first,
+                       funcIndex.second,
+                       reinterpret_cast<void (base_mock::*)()>(mfp), X);
+               TCall<Y, A, B> *call = new TCall<Y, A, B>(expect, reinterpret_cast<base_mock *>(mck), funcIndex, lineNo, funcName, fileName);
+       addCall( call, expect );
+               return *call;
+}
+template <int X, typename Z2, typename Y, typename Z,
+       typename A, typename B, typename C>
+TCall<Y,A,B,C> &MockRepository::RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C), RegistrationType expect, const char *funcName, const char *fileName, unsigned long lineNo)
+{
+               std::pair<int, int> funcIndex = virtual_index((Y(__stdcall Z2::*)(A, B, C))func);
+               Y(__stdcall mockFuncs<Z2, Y>::*mfp)(A, B, C);
+               mfp = &mockFuncs<Z2, Y>::template stdcallexpectation3<X, A, B, C>;
+               BasicRegisterExpect(reinterpret_cast<mock<Z2> *>(mck),
+                       funcIndex.first,
+                       funcIndex.second,
+                       reinterpret_cast<void (base_mock::*)()>(mfp), X);
+               TCall<Y, A, B, C> *call = new TCall<Y, A, B, C>(expect, reinterpret_cast<base_mock *>(mck), funcIndex, lineNo, funcName, fileName);
+       addCall( call, expect );
+               return *call;
+}
+template <int X, typename Z2, typename Y, typename Z,
+       typename A, typename B, typename C, typename D>
+TCall<Y,A,B,C,D> &MockRepository::RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D), RegistrationType expect, const char *funcName, const char *fileName, unsigned long lineNo)
+{
+               std::pair<int, int> funcIndex = virtual_index((Y(__stdcall Z2::*)(A, B, C, D))func);
+               Y(__stdcall mockFuncs<Z2, Y>::*mfp)(A, B, C, D);
+               mfp = &mockFuncs<Z2, Y>::template stdcallexpectation4<X, A, B, C, D>;
+               BasicRegisterExpect(reinterpret_cast<mock<Z2> *>(mck),
+                       funcIndex.first,
+                       funcIndex.second,
+                       reinterpret_cast<void (base_mock::*)()>(mfp), X);
+               TCall<Y, A, B, C, D> *call = new TCall<Y, A, B, C, D>(expect, reinterpret_cast<base_mock *>(mck), funcIndex, lineNo, funcName, fileName);
+       addCall( call, expect );
+               return *call;
+}
+template <int X, typename Z2, typename Y, typename Z,
+       typename A, typename B, typename C, typename D,
+       typename E>
+TCall<Y,A,B,C,D,E> &MockRepository::RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E), RegistrationType expect, const char *funcName, const char *fileName, unsigned long lineNo)
+{
+               std::pair<int, int> funcIndex = virtual_index((Y(__stdcall Z2::*)(A, B, C, D, E))func);
+               Y(__stdcall mockFuncs<Z2, Y>::*mfp)(A, B, C, D, E);
+               mfp = &mockFuncs<Z2, Y>::template stdcallexpectation5<X, A, B, C, D, E>;
+               BasicRegisterExpect(reinterpret_cast<mock<Z2> *>(mck),
+                       funcIndex.first,
+                       funcIndex.second,
+                       reinterpret_cast<void (base_mock::*)()>(mfp), X);
+               TCall<Y, A, B, C, D, E> *call = new TCall<Y, A, B, C, D, E>(expect, reinterpret_cast<base_mock *>(mck), funcIndex, lineNo, funcName, fileName);
+       addCall( call, expect );
+               return *call;
+}
+template <int X, typename Z2, typename Y, typename Z,
+       typename A, typename B, typename C, typename D,
+       typename E, typename F>
+TCall<Y,A,B,C,D,E,F> &MockRepository::RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F), RegistrationType expect, const char *funcName, const char *fileName, unsigned long lineNo)
+{
+               std::pair<int, int> funcIndex = virtual_index((Y(__stdcall Z2::*)(A, B, C, D, E, F))func);
+               Y(__stdcall mockFuncs<Z2, Y>::*mfp)(A, B, C, D, E, F);
+               mfp = &mockFuncs<Z2, Y>::template stdcallexpectation6<X, A, B, C, D, E, F>;
+               BasicRegisterExpect(reinterpret_cast<mock<Z2> *>(mck),
+                       funcIndex.first,
+                       funcIndex.second,
+                       reinterpret_cast<void (base_mock::*)()>(mfp), X);
+               TCall<Y, A, B, C, D, E, F> *call = new TCall<Y, A, B, C, D, E, F>(expect, reinterpret_cast<base_mock *>(mck), funcIndex, lineNo, funcName, fileName);
+       addCall( call, expect );
+               return *call;
+}
+template <int X, typename Z2, typename Y, typename Z,
+       typename A, typename B, typename C, typename D,
+       typename E, typename F, typename G>
+TCall<Y,A,B,C,D,E,F,G> &MockRepository::RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F,G), RegistrationType expect, const char *funcName, const char *fileName, unsigned long lineNo)
+{
+               std::pair<int, int> funcIndex = virtual_index((Y(__stdcall Z2::*)(A, B, C, D, E, F, G))func);
+               Y(__stdcall mockFuncs<Z2, Y>::*mfp)(A, B, C, D, E, F, G);
+               mfp = &mockFuncs<Z2, Y>::template stdcallexpectation7<X, A, B, C, D, E, F, G>;
+               BasicRegisterExpect(reinterpret_cast<mock<Z2> *>(mck),
+                       funcIndex.first,
+                       funcIndex.second,
+                       reinterpret_cast<void (base_mock::*)()>(mfp), X);
+               TCall<Y, A, B, C, D, E, F, G> *call = new TCall<Y, A, B, C, D, E, F, G>(expect, reinterpret_cast<base_mock *>(mck), funcIndex, lineNo, funcName, fileName);
+       addCall( call, expect );
+               return *call;
+}
+template <int X, typename Z2, typename Y, typename Z,
+       typename A, typename B, typename C, typename D,
+       typename E, typename F, typename G, typename H>
+TCall<Y,A,B,C,D,E,F,G,H> &MockRepository::RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F,G,H), RegistrationType expect, const char *funcName, const char *fileName, unsigned long lineNo)
+{
+               std::pair<int, int> funcIndex = virtual_index((Y(__stdcall Z2::*)(A, B, C, D, E, F, G, H))func);
+               Y(__stdcall mockFuncs<Z2, Y>::*mfp)(A, B, C, D, E, F, G, H);
+               mfp = &mockFuncs<Z2, Y>::template stdcallexpectation8<X, A, B, C, D, E, F, G, H>;
+               BasicRegisterExpect(reinterpret_cast<mock<Z2> *>(mck),
+                       funcIndex.first,
+                       funcIndex.second,
+                       reinterpret_cast<void (base_mock::*)()>(mfp), X);
+               TCall<Y, A, B, C, D, E, F, G, H> *call = new TCall<Y, A, B, C, D, E, F, G, H>(expect, reinterpret_cast<base_mock *>(mck), funcIndex, lineNo, funcName, fileName);
+       addCall( call, expect );
+               return *call;
+}
+template <int X, typename Z2, typename Y, typename Z,
+       typename A, typename B, typename C, typename D,
+       typename E, typename F, typename G, typename H,
+       typename I>
+TCall<Y,A,B,C,D,E,F,G,H,I> &MockRepository::RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F,G,H,I), RegistrationType expect, const char *funcName, const char *fileName, unsigned long lineNo)
+{
+               std::pair<int, int> funcIndex = virtual_index((Y(__stdcall Z2::*)(A, B, C, D, E, F, G, H, I))func);
+               Y(__stdcall mockFuncs<Z2, Y>::*mfp)(A, B, C, D, E, F, G, H, I);
+               mfp = &mockFuncs<Z2, Y>::template stdcallexpectation9<X, A, B, C, D, E, F, G, H, I>;
+               BasicRegisterExpect(reinterpret_cast<mock<Z2> *>(mck),
+                       funcIndex.first,
+                       funcIndex.second,
+                       reinterpret_cast<void (base_mock::*)()>(mfp), X);
+               TCall<Y, A, B, C, D, E, F, G, H, I> *call = new TCall<Y, A, B, C, D, E, F, G, H, I>(expect, reinterpret_cast<base_mock *>(mck), funcIndex, lineNo, funcName, fileName);
+       addCall( call, expect );
+               return *call;
+}
+template <int X, typename Z2, typename Y, typename Z,
+       typename A, typename B, typename C, typename D,
+       typename E, typename F, typename G, typename H,
+       typename I, typename J>
+TCall<Y,A,B,C,D,E,F,G,H,I,J> &MockRepository::RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F,G,H,I,J), RegistrationType expect, const char *funcName, const char *fileName, unsigned long lineNo)
+{
+               std::pair<int, int> funcIndex = virtual_index((Y(__stdcall Z2::*)(A, B, C, D, E, F, G, H, I, J))func);
+               Y(__stdcall mockFuncs<Z2, Y>::*mfp)(A, B, C, D, E, F, G, H, I, J);
+               mfp = &mockFuncs<Z2, Y>::template stdcallexpectation10<X, A, B, C, D, E, F, G, H, I, J>;
+               BasicRegisterExpect(reinterpret_cast<mock<Z2> *>(mck),
+                       funcIndex.first,
+                       funcIndex.second,
+                       reinterpret_cast<void (base_mock::*)()>(mfp), X);
+               TCall<Y, A, B, C, D, E, F, G, H, I, J> *call = new TCall<Y, A, B, C, D, E, F, G, H, I, J>(expect, reinterpret_cast<base_mock *>(mck), funcIndex, lineNo, funcName, fileName);
+       addCall( call, expect );
+               return *call;
+}
+template <int X, typename Z2, typename Y, typename Z,
+       typename A, typename B, typename C, typename D,
+       typename E, typename F, typename G, typename H,
+       typename I, typename J, typename K>
+TCall<Y,A,B,C,D,E,F,G,H,I,J,K> &MockRepository::RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F,G,H,I,J,K), RegistrationType expect, const char *funcName, const char *fileName, unsigned long lineNo)
+{
+               std::pair<int, int> funcIndex = virtual_index((Y(__stdcall Z2::*)(A, B, C, D, E, F, G, H, I, J, K))func);
+               Y(__stdcall mockFuncs<Z2, Y>::*mfp)(A, B, C, D, E, F, G, H, I, J, K);
+               mfp = &mockFuncs<Z2, Y>::template stdcallexpectation11<X, A, B, C, D, E, F, G, H, I, J, K>;
+               BasicRegisterExpect(reinterpret_cast<mock<Z2> *>(mck),
+                       funcIndex.first,
+                       funcIndex.second,
+                       reinterpret_cast<void (base_mock::*)()>(mfp), X);
+               TCall<Y, A, B, C, D, E, F, G, H, I, J, K> *call = new TCall<Y, A, B, C, D, E, F, G, H, I, J, K>(expect, reinterpret_cast<base_mock *>(mck), funcIndex, lineNo, funcName, fileName);
+       addCall( call, expect );
+               return *call;
+}
+template <int X, typename Z2, typename Y, typename Z,
+       typename A, typename B, typename C, typename D,
+       typename E, typename F, typename G, typename H,
+       typename I, typename J, typename K, typename L>
+TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L> &MockRepository::RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F,G,H,I,J,K,L), RegistrationType expect, const char *funcName, const char *fileName, unsigned long lineNo)
+{
+               std::pair<int, int> funcIndex = virtual_index((Y(__stdcall Z2::*)(A, B, C, D, E, F, G, H, I, J, K, L))func);
+               Y(__stdcall mockFuncs<Z2, Y>::*mfp)(A, B, C, D, E, F, G, H, I, J, K, L);
+               mfp = &mockFuncs<Z2, Y>::template stdcallexpectation12<X, A, B, C, D, E, F, G, H, I, J, K, L>;
+               BasicRegisterExpect(reinterpret_cast<mock<Z2> *>(mck),
+                       funcIndex.first,
+                       funcIndex.second,
+                       reinterpret_cast<void (base_mock::*)()>(mfp), X);
+               TCall<Y, A, B, C, D, E, F, G, H, I, J, K, L> *call = new TCall<Y, A, B, C, D, E, F, G, H, I, J, K, L>(expect, reinterpret_cast<base_mock *>(mck), funcIndex, lineNo, funcName, fileName);
+       addCall( call, expect );
+               return *call;
+}
+template <int X, typename Z2, typename Y, typename Z,
+       typename A, typename B, typename C, typename D,
+       typename E, typename F, typename G, typename H,
+       typename I, typename J, typename K, typename L,
+       typename M>
+TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M> &MockRepository::RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F,G,H,I,J,K,L,M), RegistrationType expect, const char *funcName, const char *fileName, unsigned long lineNo)
+{
+               std::pair<int, int> funcIndex = virtual_index((Y(__stdcall Z2::*)(A, B, C, D, E, F, G, H, I, J, K, L, M))func);
+               Y(__stdcall mockFuncs<Z2, Y>::*mfp)(A, B, C, D, E, F, G, H, I, J, K, L, M);
+               mfp = &mockFuncs<Z2, Y>::template stdcallexpectation13<X, A, B, C, D, E, F, G, H, I, J, K, L, M>;
+               BasicRegisterExpect(reinterpret_cast<mock<Z2> *>(mck),
+                       funcIndex.first,
+                       funcIndex.second,
+                       reinterpret_cast<void (base_mock::*)()>(mfp), X);
+               TCall<Y, A, B, C, D, E, F, G, H, I, J, K, L, M> *call = new TCall<Y, A, B, C, D, E, F, G, H, I, J, K, L, M>(expect, reinterpret_cast<base_mock *>(mck), funcIndex, lineNo, funcName, fileName);
+       addCall( call, expect );
+               return *call;
+}
+template <int X, typename Z2, typename Y, typename Z,
+       typename A, typename B, typename C, typename D,
+       typename E, typename F, typename G, typename H,
+       typename I, typename J, typename K, typename L,
+       typename M, typename N>
+TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N> &MockRepository::RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F,G,H,I,J,K,L,M,N), RegistrationType expect, const char *funcName, const char *fileName, unsigned long lineNo)
+{
+               std::pair<int, int> funcIndex = virtual_index((Y(__stdcall Z2::*)(A, B, C, D, E, F, G, H, I, J, K, L, M, N))func);
+               Y(__stdcall mockFuncs<Z2, Y>::*mfp)(A, B, C, D, E, F, G, H, I, J, K, L, M, N);
+               mfp = &mockFuncs<Z2, Y>::template stdcallexpectation14<X, A, B, C, D, E, F, G, H, I, J, K, L, M, N>;
+               BasicRegisterExpect(reinterpret_cast<mock<Z2> *>(mck),
+                       funcIndex.first,
+                       funcIndex.second,
+                       reinterpret_cast<void (base_mock::*)()>(mfp), X);
+               TCall<Y, A, B, C, D, E, F, G, H, I, J, K, L, M, N> *call = new TCall<Y, A, B, C, D, E, F, G, H, I, J, K, L, M, N>(expect, reinterpret_cast<base_mock *>(mck), funcIndex, lineNo, funcName, fileName);
+       addCall( call, expect );
+               return *call;
+}
+template <int X, typename Z2, typename Y, typename Z,
+       typename A, typename B, typename C, typename D,
+       typename E, typename F, typename G, typename H,
+       typename I, typename J, typename K, typename L,
+       typename M, typename N, typename O>
+TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O> &MockRepository::RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F,G,H,I,J,K,L,M,N,O), RegistrationType expect, const char *funcName, const char *fileName, unsigned long lineNo)
+{
+               std::pair<int, int> funcIndex = virtual_index((Y(__stdcall Z2::*)(A, B, C, D, E, F, G, H, I, J, K, L, M, N, O))func);
+               Y(__stdcall mockFuncs<Z2, Y>::*mfp)(A, B, C, D, E, F, G, H, I, J, K, L, M, N, O);
+               mfp = &mockFuncs<Z2, Y>::template stdcallexpectation15<X, A, B, C, D, E, F, G, H, I, J, K, L, M, N, O>;
+               BasicRegisterExpect(reinterpret_cast<mock<Z2> *>(mck),
+                       funcIndex.first,
+                       funcIndex.second,
+                       reinterpret_cast<void (base_mock::*)()>(mfp), X);
+               TCall<Y, A, B, C, D, E, F, G, H, I, J, K, L, M, N, O> *call = new TCall<Y, A, B, C, D, E, F, G, H, I, J, K, L, M, N, O>(expect, reinterpret_cast<base_mock *>(mck), funcIndex, lineNo, funcName, fileName);
+       addCall( call, expect );
+               return *call;
+}
+
+template <int X, typename Z2, typename Y, typename Z,
+       typename A, typename B, typename C, typename D,
+       typename E, typename F, typename G, typename H,
+       typename I, typename J, typename K, typename L,
+       typename M, typename N, typename O, typename P>
+TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P> &MockRepository::RegisterExpect_(Z2 *mck, Y (__stdcall Z::*func)(A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P), RegistrationType expect, const char *funcName, const char *fileName, unsigned long lineNo)
+{
+               std::pair<int, int> funcIndex = virtual_index((Y(__stdcall Z2::*)(A, B, C, D, E, F, G, H, I, J, K, L, M, N, O, P))func);
+               Y(__stdcall mockFuncs<Z2, Y>::*mfp)(A, B, C, D, E, F, G, H, I, J, K, L, M, N, O, P);
+               mfp = &mockFuncs<Z2, Y>::template stdcallexpectation16<X, A, B, C, D, E, F, G, H, I, J, K, L, M, N, O, P>;
+               BasicRegisterExpect(reinterpret_cast<mock<Z2> *>(mck),
+                       funcIndex.first,
+                       funcIndex.second,
+                       reinterpret_cast<void (base_mock::*)()>(mfp), X);
+               TCall<Y, A, B, C, D, E, F, G, H, I, J, K, L, M, N, O, P> *call = new TCall<Y, A, B, C, D, E, F, G, H, I, J, K, L, M, N, O, P>(expect, reinterpret_cast<base_mock *>(mck), funcIndex, lineNo, funcName, fileName);
+       addCall( call, expect );
+               return *call;
+}
+#endif
+
+#ifdef _HIPPOMOCKS__ENABLE_CFUNC_MOCKING_SUPPORT
+template <int X, typename Y>
+TCall<Y> &MockRepository::RegisterExpect_(Y (*func)(), RegistrationType expect, const char *funcName, const char *fileName, unsigned long lineNo)
+{
+  Y (*fp)();
+  fp = &mockFuncs<char, Y>::template static_expectation0<X>;
+  int index = BasicStaticRegisterExpect(reinterpret_cast<void (*)()>(func), reinterpret_cast<void (*)()>(fp),X);
+  TCall<Y> *call = new TCall<Y>(expect, NULL, std::pair<int, int>(0, index), lineNo, funcName ,fileName);
+  addCall( call, expect );
+  return *call;
+}
+template <int X, typename Y, typename A>
+TCall<Y,A> &MockRepository::RegisterExpect_(Y (*func)(A), RegistrationType expect, const char *funcName, const char *fileName, unsigned long lineNo)
+{
+  Y (*fp)(A);
+  fp = &mockFuncs<char, Y>::template static_expectation1<X,A>;
+  int index = BasicStaticRegisterExpect(reinterpret_cast<void (*)()>(func), reinterpret_cast<void (*)()>(fp),X);
+  TCall<Y,A> *call = new TCall<Y,A>(expect, NULL, std::pair<int, int>(0, index), lineNo, funcName ,fileName);
+  addCall( call, expect );
+  return *call;
+}
+template <int X, typename Y,
+                 typename A, typename B>
+TCall<Y,A,B> &MockRepository::RegisterExpect_(Y (*func)(A,B), RegistrationType expect, const char *funcName, const char *fileName, unsigned long lineNo)
+{
+  Y (*fp)(A,B);
+  fp = &mockFuncs<char, Y>::template static_expectation2<X,A,B>;
+  int index = BasicStaticRegisterExpect(reinterpret_cast<void (*)()>(func), reinterpret_cast<void (*)()>(fp),X);
+  TCall<Y,A,B> *call = new TCall<Y,A,B>(expect, NULL, std::pair<int, int>(0, index), lineNo, funcName ,fileName);
+  addCall( call, expect );
+  return *call;
+}
+template <int X, typename Y,
+                 typename A, typename B, typename C>
+TCall<Y,A,B,C> &MockRepository::RegisterExpect_(Y (*func)(A,B,C), RegistrationType expect, const char *funcName, const char *fileName, unsigned long lineNo)
+{
+  Y (*fp)(A,B,C);
+  fp = &mockFuncs<char, Y>::template static_expectation3<X,A,B,C>;
+  int index = BasicStaticRegisterExpect(reinterpret_cast<void (*)()>(func), reinterpret_cast<void (*)()>(fp),X);
+  TCall<Y,A,B,C> *call = new TCall<Y,A,B,C>(expect, NULL, std::pair<int, int>(0, index), lineNo, funcName ,fileName);
+  addCall( call, expect );
+  return *call;
+}
+template <int X, typename Y,
+                 typename A, typename B, typename C, typename D>
+TCall<Y,A,B,C,D> &MockRepository::RegisterExpect_(Y (*func)(A,B,C,D), RegistrationType expect, const char *funcName, const char *fileName, unsigned long lineNo)
+{
+  Y (*fp)(A,B,C,D);
+  fp = &mockFuncs<char, Y>::template static_expectation4<X,A,B,C,D>;
+  int index = BasicStaticRegisterExpect(reinterpret_cast<void (*)()>(func), reinterpret_cast<void (*)()>(fp),X);
+  TCall<Y,A,B,C,D> *call = new TCall<Y,A,B,C,D>(expect, NULL, std::pair<int, int>(0, index), lineNo, funcName ,fileName);
+  addCall( call, expect );
+  return *call;
+}
+template <int X, typename Y,
+                 typename A, typename B, typename C, typename D,
+                 typename E>
+TCall<Y,A,B,C,D,E> &MockRepository::RegisterExpect_(Y (*func)(A,B,C,D,E), RegistrationType expect, const char *funcName, const char *fileName, unsigned long lineNo)
+{
+  Y (*fp)(A,B,C,D,E);
+  fp = &mockFuncs<char, Y>::template static_expectation5<X,A,B,C,D,E>;
+  int index = BasicStaticRegisterExpect(reinterpret_cast<void (*)()>(func), reinterpret_cast<void (*)()>(fp),X);
+  TCall<Y,A,B,C,D,E> *call = new TCall<Y,A,B,C,D,E>(expect, NULL, std::pair<int, int>(0, index), lineNo, funcName ,fileName);
+  addCall( call, expect );
+  return *call;
+}
+template <int X, typename Y,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F>
+TCall<Y,A,B,C,D,E,F> &MockRepository::RegisterExpect_(Y (*func)(A,B,C,D,E,F), RegistrationType expect, const char *funcName, const char *fileName, unsigned long lineNo)
+{
+  Y (*fp)(A,B,C,D,E,F);
+  fp = &mockFuncs<char, Y>::template static_expectation6<X,A,B,C,D,E,F>;
+  int index = BasicStaticRegisterExpect(reinterpret_cast<void (*)()>(func), reinterpret_cast<void (*)()>(fp),X);
+  TCall<Y,A,B,C,D,E,F> *call = new TCall<Y,A,B,C,D,E,F>(expect, NULL, std::pair<int, int>(0, index), lineNo, funcName ,fileName);
+  addCall( call, expect );
+  return *call;
+}
+template <int X, typename Y,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G>
+TCall<Y,A,B,C,D,E,F,G> &MockRepository::RegisterExpect_(Y (*func)(A,B,C,D,E,F,G), RegistrationType expect, const char *funcName, const char *fileName, unsigned long lineNo)
+{
+  Y (*fp)(A,B,C,D,E,F,G);
+  fp = &mockFuncs<char, Y>::template static_expectation7<X,A,B,C,D,E,F,G>;
+  int index = BasicStaticRegisterExpect(reinterpret_cast<void (*)()>(func), reinterpret_cast<void (*)()>(fp),X);
+  TCall<Y,A,B,C,D,E,F,G> *call = new TCall<Y,A,B,C,D,E,F,G>(expect, NULL, std::pair<int, int>(0, index), lineNo, funcName ,fileName);
+   addCall( call, expect );
+  return *call;
+}
+template <int X, typename Y,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H>
+TCall<Y,A,B,C,D,E,F,G,H> &MockRepository::RegisterExpect_(Y (*func)(A,B,C,D,E,F,G,H), RegistrationType expect, const char *funcName, const char *fileName, unsigned long lineNo)
+{
+  Y (*fp)(A,B,C,D,E,F,G,H);
+  fp = &mockFuncs<char, Y>::template static_expectation8<X,A,B,C,D,E,F,G,H>;
+  int index = BasicStaticRegisterExpect(reinterpret_cast<void (*)()>(func), reinterpret_cast<void (*)()>(fp),X);
+  TCall<Y,A,B,C,D,E,F,G,H> *call = new TCall<Y,A,B,C,D,E,F,G,H>(expect, NULL, std::pair<int, int>(0, index), lineNo, funcName ,fileName);
+  addCall( call, expect );
+  return *call;
+}
+template <int X, typename Y,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H,
+                 typename I>
+TCall<Y,A,B,C,D,E,F,G,H,I> &MockRepository::RegisterExpect_(Y (*func)(A,B,C,D,E,F,G,H,I), RegistrationType expect, const char *funcName, const char *fileName, unsigned long lineNo)
+{
+  Y (*fp)(A,B,C,D,E,F,G,H,I);
+  fp = &mockFuncs<char, Y>::template static_expectation9<X,A,B,C,D,E,F,G,H,I>;
+  int index = BasicStaticRegisterExpect(reinterpret_cast<void (*)()>(func), reinterpret_cast<void (*)()>(fp),X);
+  TCall<Y,A,B,C,D,E,F,G,H,I> *call = new TCall<Y,A,B,C,D,E,F,G,H,I>(expect, NULL, std::pair<int, int>(0, index), lineNo, funcName ,fileName);
+  addCall( call, expect );
+  return *call;
+}
+template <int X, typename Y,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H,
+                 typename I, typename J>
+TCall<Y,A,B,C,D,E,F,G,H,I,J> &MockRepository::RegisterExpect_(Y (*func)(A,B,C,D,E,F,G,H,I,J), RegistrationType expect, const char *funcName, const char *fileName, unsigned long lineNo)
+{
+  Y (*fp)(A,B,C,D,E,F,G,H,I,J);
+  fp = &mockFuncs<char, Y>::template static_expectation10<X,A,B,C,D,E,F,G,H,I,J>;
+  int index = BasicStaticRegisterExpect(reinterpret_cast<void (*)()>(func), reinterpret_cast<void (*)()>(fp),X);
+  TCall<Y,A,B,C,D,E,F,G,H,I,J> *call = new TCall<Y,A,B,C,D,E,F,G,H,I,J>(expect, NULL, std::pair<int, int>(0, index), lineNo, funcName ,fileName);
+  addCall( call, expect );
+  return *call;
+}
+template <int X, typename Y,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H,
+                 typename I, typename J, typename K>
+TCall<Y,A,B,C,D,E,F,G,H,I,J,K> &MockRepository::RegisterExpect_(Y (*func)(A,B,C,D,E,F,G,H,I,J,K), RegistrationType expect, const char *funcName, const char *fileName, unsigned long lineNo)
+{
+  Y (*fp)(A,B,C,D,E,F,G,H,I,J,K);
+  fp = &mockFuncs<char, Y>::template static_expectation11<X,A,B,C,D,E,F,G,H,I,J,K>;
+  int index = BasicStaticRegisterExpect(reinterpret_cast<void (*)()>(func), reinterpret_cast<void (*)()>(fp),X);
+  TCall<Y,A,B,C,D,E,F,G,H,I,J,K> *call = new TCall<Y,A,B,C,D,E,F,G,H,I,J,K>(expect, NULL, std::pair<int, int>(0, index), lineNo, funcName ,fileName);
+  addCall( call, expect );
+  return *call;
+}
+template <int X, typename Y,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H,
+                 typename I, typename J, typename K, typename L>
+TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L> &MockRepository::RegisterExpect_(Y (*func)(A,B,C,D,E,F,G,H,I,J,K,L), RegistrationType expect, const char *funcName, const char *fileName, unsigned long lineNo)
+{
+  Y (*fp)(A,B,C,D,E,F,G,H,I,J,K,L);
+  fp = &mockFuncs<char, Y>::template static_expectation12<X,A,B,C,D,E,F,G,H,I,J,K,L>;
+  int index = BasicStaticRegisterExpect(reinterpret_cast<void (*)()>(func), reinterpret_cast<void (*)()>(fp),X);
+  TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L> *call = new TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L>(expect, NULL, std::pair<int, int>(0, index), lineNo, funcName ,fileName);
+  addCall( call, expect );
+  return *call;
+}
+template <int X, typename Y,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H,
+                 typename I, typename J, typename K, typename L,
+                 typename M>
+TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M> &MockRepository::RegisterExpect_(Y (*func)(A,B,C,D,E,F,G,H,I,J,K,L,M), RegistrationType expect, const char *funcName, const char *fileName, unsigned long lineNo)
+{
+  Y (*fp)(A,B,C,D,E,F,G,H,I,J,K,L,M);
+  fp = &mockFuncs<char, Y>::template static_expectation13<X,A,B,C,D,E,F,G,H,I,J,K,L,M>;
+  int index = BasicStaticRegisterExpect(reinterpret_cast<void (*)()>(func), reinterpret_cast<void (*)()>(fp),X);
+  TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M> *call = new TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M>(expect, NULL, std::pair<int, int>(0, index), lineNo, funcName ,fileName);
+  addCall( call, expect );
+  return *call;
+}
+template <int X, typename Y,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H,
+                 typename I, typename J, typename K, typename L,
+                 typename M, typename N>
+TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N> &MockRepository::RegisterExpect_(Y (*func)(A,B,C,D,E,F,G,H,I,J,K,L,M,N), RegistrationType expect, const char *funcName, const char *fileName, unsigned long lineNo)
+{
+  Y (*fp)(A,B,C,D,E,F,G,H,I,J,K,L,M,N);
+  fp = &mockFuncs<char, Y>::template static_expectation14<X,A,B,C,D,E,F,G,H,I,J,K,L,M,N>;
+  int index = BasicStaticRegisterExpect(reinterpret_cast<void (*)()>(func), reinterpret_cast<void (*)()>(fp),X);
+  TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N> *call = new TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N>(expect, NULL, std::pair<int, int>(0, index), lineNo, funcName ,fileName);
+  addCall( call, expect );
+  return *call;
+}
+template <int X, typename Y,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H,
+                 typename I, typename J, typename K, typename L,
+                 typename M, typename N, typename O>
+TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O> &MockRepository::RegisterExpect_(Y (*func)(A,B,C,D,E,F,G,H,I,J,K,L,M,N,O), RegistrationType expect, const char *funcName, const char *fileName, unsigned long lineNo)
+{
+  Y (*fp)(A,B,C,D,E,F,G,H,I,J,K,L,M,N,O);
+  fp = &mockFuncs<char, Y>::template static_expectation15<X,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O>;
+  int index = BasicStaticRegisterExpect(reinterpret_cast<void (*)()>(func), reinterpret_cast<void (*)()>(fp),X);
+  TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O> *call = new TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O>(expect, NULL, std::pair<int, int>(0, index), lineNo, funcName ,fileName);
+  addCall( call, expect );
+  return *call;
+}
+
+template <int X, typename Y,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H,
+                 typename I, typename J, typename K, typename L,
+                 typename M, typename N, typename O, typename P>
+TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P> &MockRepository::RegisterExpect_(Y (*func)(A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P), RegistrationType expect, const char *funcName, const char *fileName, unsigned long lineNo)
+{
+  Y (*fp)(A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P);
+  fp = &mockFuncs<char, Y>::template static_expectation16<X,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P>;
+  int index = BasicStaticRegisterExpect(reinterpret_cast<void (*)()>(func), reinterpret_cast<void (*)()>(fp),X);
+  TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P> *call = new TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P>(expect, NULL, std::pair<int, int>(0, index), lineNo, funcName ,fileName);
+  addCall( call, expect );
+  return *call;
+}
+
+#if defined(_MSC_VER) && !defined(_WIN64)
+template <int X, typename Y>
+TCall<Y> &MockRepository::RegisterExpect_(Y (__stdcall *func)(), RegistrationType expect, const char *funcName, const char *fileName, unsigned long lineNo)
+{
+  Y (__stdcall *fp)();
+  fp = &mockFuncs<char, Y>::template static_stdcallexpectation0<X>;
+  int index = BasicStaticRegisterExpect(reinterpret_cast<void (*)()>(func), reinterpret_cast<void (*)()>(fp),X);
+  TCall<Y> *call = new TCall<Y>(expect, NULL, std::pair<int, int>(0, index), lineNo, funcName ,fileName);
+  addCall( call, expect );
+  return *call;
+}
+template <int X, typename Y, typename A>
+TCall<Y,A> &MockRepository::RegisterExpect_(Y (__stdcall *func)(A), RegistrationType expect, const char *funcName, const char *fileName, unsigned long lineNo)
+{
+  Y (__stdcall *fp)(A);
+  fp = &mockFuncs<char, Y>::template static_stdcallexpectation1<X,A>;
+  int index = BasicStaticRegisterExpect(reinterpret_cast<void (*)()>(func), reinterpret_cast<void (*)()>(fp),X);
+  TCall<Y,A> *call = new TCall<Y,A>(expect, NULL, std::pair<int, int>(0, index), lineNo, funcName ,fileName);
+  addCall( call, expect );
+  return *call;
+}
+template <int X, typename Y,
+                 typename A, typename B>
+TCall<Y,A,B> &MockRepository::RegisterExpect_(Y (__stdcall *func)(A,B), RegistrationType expect, const char *funcName, const char *fileName, unsigned long lineNo)
+{
+  Y (__stdcall *fp)(A,B);
+  fp = &mockFuncs<char, Y>::template static_stdcallexpectation2<X,A,B>;
+  int index = BasicStaticRegisterExpect(reinterpret_cast<void (*)()>(func), reinterpret_cast<void (*)()>(fp),X);
+  TCall<Y,A,B> *call = new TCall<Y,A,B>(expect, NULL, std::pair<int, int>(0, index), lineNo, funcName ,fileName);
+  addCall( call, expect );
+  return *call;
+}
+template <int X, typename Y,
+                 typename A, typename B, typename C>
+TCall<Y,A,B,C> &MockRepository::RegisterExpect_(Y (__stdcall *func)(A,B,C), RegistrationType expect, const char *funcName, const char *fileName, unsigned long lineNo)
+{
+  Y (__stdcall *fp)(A,B,C);
+  fp = &mockFuncs<char, Y>::template static_stdcallexpectation3<X,A,B,C>;
+  int index = BasicStaticRegisterExpect(reinterpret_cast<void (*)()>(func), reinterpret_cast<void (*)()>(fp),X);
+  TCall<Y,A,B,C> *call = new TCall<Y,A,B,C>(expect, NULL, std::pair<int, int>(0, index), lineNo, funcName ,fileName);
+  addCall( call, expect );
+  return *call;
+}
+template <int X, typename Y,
+                 typename A, typename B, typename C, typename D>
+TCall<Y,A,B,C,D> &MockRepository::RegisterExpect_(Y (__stdcall *func)(A,B,C,D), RegistrationType expect, const char *funcName, const char *fileName, unsigned long lineNo)
+{
+  Y (__stdcall *fp)(A,B,C,D);
+  fp = &mockFuncs<char, Y>::template static_stdcallexpectation4<X,A,B,C,D>;
+  int index = BasicStaticRegisterExpect(reinterpret_cast<void (*)()>(func), reinterpret_cast<void (*)()>(fp),X);
+  TCall<Y,A,B,C,D> *call = new TCall<Y,A,B,C,D>(expect, NULL, std::pair<int, int>(0, index), lineNo, funcName ,fileName);
+  addCall( call, expect );
+  return *call;
+}
+template <int X, typename Y,
+                 typename A, typename B, typename C, typename D,
+                 typename E>
+TCall<Y,A,B,C,D,E> &MockRepository::RegisterExpect_(Y (__stdcall *func)(A,B,C,D,E), RegistrationType expect, const char *funcName, const char *fileName, unsigned long lineNo)
+{
+  Y (__stdcall *fp)(A,B,C,D,E);
+  fp = &mockFuncs<char, Y>::template static_stdcallexpectation5<X,A,B,C,D,E>;
+  int index = BasicStaticRegisterExpect(reinterpret_cast<void (*)()>(func), reinterpret_cast<void (*)()>(fp),X);
+  TCall<Y,A,B,C,D,E> *call = new TCall<Y,A,B,C,D,E>(expect, NULL, std::pair<int, int>(0, index), lineNo, funcName ,fileName);
+  addCall( call, expect );
+  return *call;
+}
+template <int X, typename Y,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F>
+TCall<Y,A,B,C,D,E,F> &MockRepository::RegisterExpect_(Y (__stdcall *func)(A,B,C,D,E,F), RegistrationType expect, const char *funcName, const char *fileName, unsigned long lineNo)
+{
+  Y (__stdcall *fp)(A,B,C,D,E,F);
+  fp = &mockFuncs<char, Y>::template static_stdcallexpectation6<X,A,B,C,D,E,F>;
+  int index = BasicStaticRegisterExpect(reinterpret_cast<void (*)()>(func), reinterpret_cast<void (*)()>(fp),X);
+  TCall<Y,A,B,C,D,E,F> *call = new TCall<Y,A,B,C,D,E,F>(expect, NULL, std::pair<int, int>(0, index), lineNo, funcName ,fileName);
+  addCall( call, expect );
+  return *call;
+}
+template <int X, typename Y,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G>
+TCall<Y,A,B,C,D,E,F,G> &MockRepository::RegisterExpect_(Y (__stdcall *func)(A,B,C,D,E,F,G), RegistrationType expect, const char *funcName, const char *fileName, unsigned long lineNo)
+{
+  Y (__stdcall *fp)(A,B,C,D,E,F,G);
+  fp = &mockFuncs<char, Y>::template static_stdcallexpectation7<X,A,B,C,D,E,F,G>;
+  int index = BasicStaticRegisterExpect(reinterpret_cast<void (*)()>(func), reinterpret_cast<void (*)()>(fp),X);
+  TCall<Y,A,B,C,D,E,F,G> *call = new TCall<Y,A,B,C,D,E,F,G>(expect, NULL, std::pair<int, int>(0, index), lineNo, funcName ,fileName);
+   addCall( call, expect );
+  return *call;
+}
+template <int X, typename Y,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H>
+TCall<Y,A,B,C,D,E,F,G,H> &MockRepository::RegisterExpect_(Y (__stdcall *func)(A,B,C,D,E,F,G,H), RegistrationType expect, const char *funcName, const char *fileName, unsigned long lineNo)
+{
+  Y (__stdcall *fp)(A,B,C,D,E,F,G,H);
+  fp = &mockFuncs<char, Y>::template static_stdcallexpectation8<X,A,B,C,D,E,F,G,H>;
+  int index = BasicStaticRegisterExpect(reinterpret_cast<void (*)()>(func), reinterpret_cast<void (*)()>(fp),X);
+  TCall<Y,A,B,C,D,E,F,G,H> *call = new TCall<Y,A,B,C,D,E,F,G,H>(expect, NULL, std::pair<int, int>(0, index), lineNo, funcName ,fileName);
+  addCall( call, expect );
+  return *call;
+}
+template <int X, typename Y,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H,
+                 typename I>
+TCall<Y,A,B,C,D,E,F,G,H,I> &MockRepository::RegisterExpect_(Y (__stdcall *func)(A,B,C,D,E,F,G,H,I), RegistrationType expect, const char *funcName, const char *fileName, unsigned long lineNo)
+{
+  Y (__stdcall *fp)(A,B,C,D,E,F,G,H,I);
+  fp = &mockFuncs<char, Y>::template static_stdcallexpectation9<X,A,B,C,D,E,F,G,H,I>;
+  int index = BasicStaticRegisterExpect(reinterpret_cast<void (*)()>(func), reinterpret_cast<void (*)()>(fp),X);
+  TCall<Y,A,B,C,D,E,F,G,H,I> *call = new TCall<Y,A,B,C,D,E,F,G,H,I>(expect, NULL, std::pair<int, int>(0, index), lineNo, funcName ,fileName);
+  addCall( call, expect );
+  return *call;
+}
+template <int X, typename Y,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H,
+                 typename I, typename J>
+TCall<Y,A,B,C,D,E,F,G,H,I,J> &MockRepository::RegisterExpect_(Y (__stdcall *func)(A,B,C,D,E,F,G,H,I,J), RegistrationType expect, const char *funcName, const char *fileName, unsigned long lineNo)
+{
+  Y (__stdcall *fp)(A,B,C,D,E,F,G,H,I,J);
+  fp = &mockFuncs<char, Y>::template static_stdcallexpectation10<X,A,B,C,D,E,F,G,H,I,J>;
+  int index = BasicStaticRegisterExpect(reinterpret_cast<void (*)()>(func), reinterpret_cast<void (*)()>(fp),X);
+  TCall<Y,A,B,C,D,E,F,G,H,I,J> *call = new TCall<Y,A,B,C,D,E,F,G,H,I,J>(expect, NULL, std::pair<int, int>(0, index), lineNo, funcName ,fileName);
+  addCall( call, expect );
+  return *call;
+}
+template <int X, typename Y,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H,
+                 typename I, typename J, typename K>
+TCall<Y,A,B,C,D,E,F,G,H,I,J,K> &MockRepository::RegisterExpect_(Y (__stdcall *func)(A,B,C,D,E,F,G,H,I,J,K), RegistrationType expect, const char *funcName, const char *fileName, unsigned long lineNo)
+{
+  Y (__stdcall *fp)(A,B,C,D,E,F,G,H,I,J,K);
+  fp = &mockFuncs<char, Y>::template static_stdcallexpectation11<X,A,B,C,D,E,F,G,H,I,J,K>;
+  int index = BasicStaticRegisterExpect(reinterpret_cast<void (*)()>(func), reinterpret_cast<void (*)()>(fp),X);
+  TCall<Y,A,B,C,D,E,F,G,H,I,J,K> *call = new TCall<Y,A,B,C,D,E,F,G,H,I,J,K>(expect, NULL, std::pair<int, int>(0, index), lineNo, funcName ,fileName);
+  addCall( call, expect );
+  return *call;
+}
+template <int X, typename Y,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H,
+                 typename I, typename J, typename K, typename L>
+TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L> &MockRepository::RegisterExpect_(Y (__stdcall *func)(A,B,C,D,E,F,G,H,I,J,K,L), RegistrationType expect, const char *funcName, const char *fileName, unsigned long lineNo)
+{
+  Y (__stdcall *fp)(A,B,C,D,E,F,G,H,I,J,K,L);
+  fp = &mockFuncs<char, Y>::template static_stdcallexpectation12<X,A,B,C,D,E,F,G,H,I,J,K,L>;
+  int index = BasicStaticRegisterExpect(reinterpret_cast<void (*)()>(func), reinterpret_cast<void (*)()>(fp),X);
+  TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L> *call = new TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L>(expect, NULL, std::pair<int, int>(0, index), lineNo, funcName ,fileName);
+  addCall( call, expect );
+  return *call;
+}
+template <int X, typename Y,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H,
+                 typename I, typename J, typename K, typename L,
+                 typename M>
+TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M> &MockRepository::RegisterExpect_(Y (__stdcall *func)(A,B,C,D,E,F,G,H,I,J,K,L,M), RegistrationType expect, const char *funcName, const char *fileName, unsigned long lineNo)
+{
+  Y (__stdcall *fp)(A,B,C,D,E,F,G,H,I,J,K,L,M);
+  fp = &mockFuncs<char, Y>::template static_stdcallexpectation13<X,A,B,C,D,E,F,G,H,I,J,K,L,M>;
+  int index = BasicStaticRegisterExpect(reinterpret_cast<void (*)()>(func), reinterpret_cast<void (*)()>(fp),X);
+  TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M> *call = new TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M>(expect, NULL, std::pair<int, int>(0, index), lineNo, funcName ,fileName);
+  addCall( call, expect );
+  return *call;
+}
+template <int X, typename Y,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H,
+                 typename I, typename J, typename K, typename L,
+                 typename M, typename N>
+TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N> &MockRepository::RegisterExpect_(Y (__stdcall *func)(A,B,C,D,E,F,G,H,I,J,K,L,M,N), RegistrationType expect, const char *funcName, const char *fileName, unsigned long lineNo)
+{
+  Y (__stdcall *fp)(A,B,C,D,E,F,G,H,I,J,K,L,M,N);
+  fp = &mockFuncs<char, Y>::template static_stdcallexpectation14<X,A,B,C,D,E,F,G,H,I,J,K,L,M,N>;
+  int index = BasicStaticRegisterExpect(reinterpret_cast<void (*)()>(func), reinterpret_cast<void (*)()>(fp),X);
+  TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N> *call = new TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N>(expect, NULL, std::pair<int, int>(0, index), lineNo, funcName ,fileName);
+  addCall( call, expect );
+  return *call;
+}
+template <int X, typename Y,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H,
+                 typename I, typename J, typename K, typename L,
+                 typename M, typename N, typename O>
+TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O> &MockRepository::RegisterExpect_(Y (__stdcall *func)(A,B,C,D,E,F,G,H,I,J,K,L,M,N,O), RegistrationType expect, const char *funcName, const char *fileName, unsigned long lineNo)
+{
+  Y (__stdcall *fp)(A,B,C,D,E,F,G,H,I,J,K,L,M,N,O);
+  fp = &mockFuncs<char, Y>::template static_stdcallexpectation15<X,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O>;
+  int index = BasicStaticRegisterExpect(reinterpret_cast<void (*)()>(func), reinterpret_cast<void (*)()>(fp),X);
+  TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O> *call = new TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O>(expect, NULL, std::pair<int, int>(0, index), lineNo, funcName ,fileName);
+  addCall( call, expect );
+  return *call;
+}
+
+template <int X, typename Y,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H,
+                 typename I, typename J, typename K, typename L,
+                 typename M, typename N, typename O, typename P>
+TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P> &MockRepository::RegisterExpect_(Y (__stdcall *func)(A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P), RegistrationType expect, const char *funcName, const char *fileName, unsigned long lineNo)
+{
+  Y (__stdcall *fp)(A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P);
+  fp = &mockFuncs<char, Y>::template static_stdcallexpectation16<X,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P>;
+  int index = BasicStaticRegisterExpect(reinterpret_cast<void (*)()>(func), reinterpret_cast<void (*)()>(fp),X);
+  TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P> *call = new TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P>(expect, NULL, std::pair<int, int>(0, index), lineNo, funcName ,fileName);
+  addCall( call, expect );
+  return *call;
+}
+#endif
+#endif
+
+template <int X, typename Z2, typename Y, typename Z>
+TCall<Y> &MockRepository::RegisterExpect_(Z2 *mck, Y (Z::*func)(), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo)
+{
+       std::pair<int, int> funcIndex = virtual_index((Y (Z2::*)())func);
+       Y (mockFuncs<Z2, Y>::*mfp)();
+       mfp = &mockFuncs<Z2, Y>::template expectation0<X>;
+       BasicRegisterExpect(reinterpret_cast<mock<Z2> *>(mck),
+                                               funcIndex.first, funcIndex.second,
+                                               reinterpret_cast<void (base_mock::*)()>(mfp),X);
+       TCall<Y> *call = new TCall<Y>(expect, reinterpret_cast<base_mock *>(mck), funcIndex, lineNo, functionName ,fileName);
+
+       addCall( call, expect );
+       return *call;
+}
+template <int X, typename Z2, typename Y, typename Z, typename A>
+TCall<Y,A> &MockRepository::RegisterExpect_(Z2 *mck, Y (Z::*func)(A), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo)
+{
+       std::pair<int, int> funcIndex = virtual_index((Y(Z2::*)(A))func);
+       Y (mockFuncs<Z2, Y>::*mfp)(A);
+       mfp = &mockFuncs<Z2, Y>::template expectation1<X,A>;
+       BasicRegisterExpect(reinterpret_cast<mock<Z2> *>(mck),
+                                               funcIndex.first, funcIndex.second,
+                                               reinterpret_cast<void (base_mock::*)()>(mfp),X);
+       TCall<Y,A> *call = new TCall<Y,A>(expect, reinterpret_cast<base_mock *>(mck), funcIndex, lineNo, functionName ,fileName);
+       addCall( call, expect );
+       return *call;
+}
+template <int X, typename Z2, typename Y, typename Z,
+                 typename A, typename B>
+TCall<Y,A,B> &MockRepository::RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo)
+{
+       std::pair<int, int> funcIndex = virtual_index((Y(Z2::*)(A,B))func);
+       Y (mockFuncs<Z2, Y>::*mfp)(A,B);
+       mfp = &mockFuncs<Z2, Y>::template expectation2<X,A,B>;
+       BasicRegisterExpect(reinterpret_cast<mock<Z2> *>(mck),
+                                               funcIndex.first, funcIndex.second,
+                                               reinterpret_cast<void (base_mock::*)()>(mfp),X);
+       TCall<Y,A,B> *call = new TCall<Y,A,B>(expect, reinterpret_cast<base_mock *>(mck), funcIndex, lineNo, functionName ,fileName);
+       addCall( call, expect );
+       return *call;
+}
+template <int X, typename Z2, typename Y, typename Z,
+                 typename A, typename B, typename C>
+TCall<Y,A,B,C> &MockRepository::RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo)
+{
+       std::pair<int, int> funcIndex = virtual_index((Y(Z2::*)(A,B,C))func);
+       Y (mockFuncs<Z2, Y>::*mfp)(A,B,C);
+       mfp = &mockFuncs<Z2, Y>::template expectation3<X,A,B,C>;
+       BasicRegisterExpect(reinterpret_cast<mock<Z2> *>(mck),
+                                               funcIndex.first, funcIndex.second,
+                                               reinterpret_cast<void (base_mock::*)()>(mfp),X);
+       TCall<Y,A,B,C> *call = new TCall<Y,A,B,C>(expect, reinterpret_cast<base_mock *>(mck), funcIndex, lineNo, functionName ,fileName);
+       addCall( call, expect );
+       return *call;
+}
+template <int X, typename Z2, typename Y, typename Z,
+                 typename A, typename B, typename C, typename D>
+TCall<Y,A,B,C,D> &MockRepository::RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo)
+{
+       std::pair<int, int> funcIndex = virtual_index((Y(Z2::*)(A,B,C,D))func);
+       Y (mockFuncs<Z2, Y>::*mfp)(A,B,C,D);
+       mfp = &mockFuncs<Z2, Y>::template expectation4<X,A,B,C,D>;
+       BasicRegisterExpect(reinterpret_cast<mock<Z2> *>(mck),
+                                               funcIndex.first, funcIndex.second,
+                                               reinterpret_cast<void (base_mock::*)()>(mfp),X);
+       TCall<Y,A,B,C,D> *call = new TCall<Y,A,B,C,D>(expect, reinterpret_cast<base_mock *>(mck), funcIndex, lineNo, functionName ,fileName);
+       addCall( call, expect );
+       return *call;
+}
+template <int X, typename Z2, typename Y, typename Z,
+                 typename A, typename B, typename C, typename D,
+                 typename E>
+TCall<Y,A,B,C,D,E> &MockRepository::RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo)
+{
+       std::pair<int, int> funcIndex = virtual_index((Y(Z2::*)(A,B,C,D,E))func);
+       Y (mockFuncs<Z2, Y>::*mfp)(A,B,C,D,E);
+       mfp = &mockFuncs<Z2, Y>::template expectation5<X,A,B,C,D,E>;
+       BasicRegisterExpect(reinterpret_cast<mock<Z2> *>(mck),
+                                               funcIndex.first, funcIndex.second,
+                                               reinterpret_cast<void (base_mock::*)()>(mfp),X);
+       TCall<Y,A,B,C,D,E> *call = new TCall<Y,A,B,C,D,E>(expect, reinterpret_cast<base_mock *>(mck), funcIndex, lineNo, functionName ,fileName);
+       addCall( call, expect );
+       return *call;
+}
+template <int X, typename Z2, typename Y, typename Z,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F>
+TCall<Y,A,B,C,D,E,F> &MockRepository::RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo)
+{
+       std::pair<int, int> funcIndex = virtual_index((Y(Z2::*)(A,B,C,D,E,F))func);
+       Y (mockFuncs<Z2, Y>::*mfp)(A,B,C,D,E,F);
+       mfp = &mockFuncs<Z2, Y>::template expectation6<X,A,B,C,D,E,F>;
+       BasicRegisterExpect(reinterpret_cast<mock<Z2> *>(mck),
+                                               funcIndex.first, funcIndex.second,
+                                               reinterpret_cast<void (base_mock::*)()>(mfp),X);
+       TCall<Y,A,B,C,D,E,F> *call = new TCall<Y,A,B,C,D,E,F>(expect, reinterpret_cast<base_mock *>(mck), funcIndex, lineNo, functionName ,fileName);
+       addCall( call, expect );
+       return *call;
+}
+template <int X, typename Z2, typename Y, typename Z,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G>
+TCall<Y,A,B,C,D,E,F,G> &MockRepository::RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F,G), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo)
+{
+       std::pair<int, int> funcIndex = virtual_index((Y(Z2::*)(A,B,C,D,E,F,G))func);
+       Y (mockFuncs<Z2, Y>::*mfp)(A,B,C,D,E,F,G);
+       mfp = &mockFuncs<Z2, Y>::template expectation7<X,A,B,C,D,E,F,G>;
+       BasicRegisterExpect(reinterpret_cast<mock<Z2> *>(mck),
+                                               funcIndex.first, funcIndex.second,
+                                               reinterpret_cast<void (base_mock::*)()>(mfp),X);
+       TCall<Y,A,B,C,D,E,F,G> *call = new TCall<Y,A,B,C,D,E,F,G>(expect, reinterpret_cast<base_mock *>(mck), funcIndex, lineNo, functionName ,fileName);
+       addCall( call, expect );
+       return *call;
+}
+template <int X, typename Z2, typename Y, typename Z,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H>
+TCall<Y,A,B,C,D,E,F,G,H> &MockRepository::RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F,G,H), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo)
+{
+       std::pair<int, int> funcIndex = virtual_index((Y(Z2::*)(A,B,C,D,E,F,G,H))func);
+       Y (mockFuncs<Z2, Y>::*mfp)(A,B,C,D,E,F,G,H);
+       mfp = &mockFuncs<Z2, Y>::template expectation8<X,A,B,C,D,E,F,G,H>;
+       BasicRegisterExpect(reinterpret_cast<mock<Z2> *>(mck),
+                                               funcIndex.first, funcIndex.second,
+                                               reinterpret_cast<void (base_mock::*)()>(mfp),X);
+       TCall<Y,A,B,C,D,E,F,G,H> *call = new TCall<Y,A,B,C,D,E,F,G,H>(expect, reinterpret_cast<base_mock *>(mck), funcIndex, lineNo, functionName ,fileName);
+       addCall( call, expect );
+       return *call;
+}
+template <int X, typename Z2, typename Y, typename Z,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H,
+                 typename I>
+TCall<Y,A,B,C,D,E,F,G,H,I> &MockRepository::RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F,G,H,I), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo)
+{
+       std::pair<int, int> funcIndex = virtual_index((Y(Z2::*)(A,B,C,D,E,F,G,H,I))func);
+       Y (mockFuncs<Z2, Y>::*mfp)(A,B,C,D,E,F,G,H,I);
+       mfp = &mockFuncs<Z2, Y>::template expectation9<X,A,B,C,D,E,F,G,H,I>;
+       BasicRegisterExpect(reinterpret_cast<mock<Z2> *>(mck),
+                                               funcIndex.first, funcIndex.second,
+                                               reinterpret_cast<void (base_mock::*)()>(mfp),X);
+       TCall<Y,A,B,C,D,E,F,G,H,I> *call = new TCall<Y,A,B,C,D,E,F,G,H,I>(expect, reinterpret_cast<base_mock *>(mck), funcIndex, lineNo, functionName ,fileName);
+       addCall( call, expect );
+       return *call;
+}
+template <int X, typename Z2, typename Y, typename Z,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H,
+                 typename I, typename J>
+TCall<Y,A,B,C,D,E,F,G,H,I,J> &MockRepository::RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F,G,H,I,J), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo)
+{
+       std::pair<int, int> funcIndex = virtual_index((Y(Z2::*)(A,B,C,D,E,F,G,H,I,J))func);
+       Y (mockFuncs<Z2, Y>::*mfp)(A,B,C,D,E,F,G,H,I,J);
+       mfp = &mockFuncs<Z2, Y>::template expectation10<X,A,B,C,D,E,F,G,H,I,J>;
+       BasicRegisterExpect(reinterpret_cast<mock<Z2> *>(mck),
+                                               funcIndex.first, funcIndex.second,
+                                               reinterpret_cast<void (base_mock::*)()>(mfp),X);
+       TCall<Y,A,B,C,D,E,F,G,H,I,J> *call = new TCall<Y,A,B,C,D,E,F,G,H,I,J>(expect, reinterpret_cast<base_mock *>(mck), funcIndex, lineNo, functionName ,fileName);
+       addCall( call, expect );
+       return *call;
+}
+template <int X, typename Z2, typename Y, typename Z,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H,
+                 typename I, typename J, typename K>
+TCall<Y,A,B,C,D,E,F,G,H,I,J,K> &MockRepository::RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F,G,H,I,J,K), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo)
+{
+       std::pair<int, int> funcIndex = virtual_index((Y(Z2::*)(A,B,C,D,E,F,G,H,I,J,K))func);
+       Y (mockFuncs<Z2, Y>::*mfp)(A,B,C,D,E,F,G,H,I,J,K);
+       mfp = &mockFuncs<Z2, Y>::template expectation11<X,A,B,C,D,E,F,G,H,I,J,K>;
+       BasicRegisterExpect(reinterpret_cast<mock<Z2> *>(mck),
+                                               funcIndex.first, funcIndex.second,
+                                               reinterpret_cast<void (base_mock::*)()>(mfp),X);
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K> *call = new TCall<Y,A,B,C,D,E,F,G,H,I,J,K>(expect, reinterpret_cast<base_mock *>(mck), funcIndex, lineNo, functionName ,fileName);
+       addCall( call, expect );
+       return *call;
+}
+template <int X, typename Z2, typename Y, typename Z,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H,
+                 typename I, typename J, typename K, typename L>
+TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L> &MockRepository::RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F,G,H,I,J,K,L), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo)
+{
+       std::pair<int, int> funcIndex = virtual_index((Y(Z2::*)(A,B,C,D,E,F,G,H,I,J,K,L))func);
+       Y (mockFuncs<Z2, Y>::*mfp)(A,B,C,D,E,F,G,H,I,J,K,L);
+       mfp = &mockFuncs<Z2, Y>::template expectation12<X,A,B,C,D,E,F,G,H,I,J,K,L>;
+       BasicRegisterExpect(reinterpret_cast<mock<Z2> *>(mck),
+                                               funcIndex.first, funcIndex.second,
+                                               reinterpret_cast<void (base_mock::*)()>(mfp),X);
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L> *call = new TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L>(expect, reinterpret_cast<base_mock *>(mck), funcIndex, lineNo, functionName ,fileName);
+       addCall( call, expect );
+       return *call;
+}
+template <int X, typename Z2, typename Y, typename Z,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H,
+                 typename I, typename J, typename K, typename L,
+                 typename M>
+TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M> &MockRepository::RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F,G,H,I,J,K,L,M), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo)
+{
+       std::pair<int, int> funcIndex = virtual_index((Y(Z2::*)(A,B,C,D,E,F,G,H,I,J,K,L,M))func);
+       Y (mockFuncs<Z2, Y>::*mfp)(A,B,C,D,E,F,G,H,I,J,K,L,M);
+       mfp = &mockFuncs<Z2, Y>::template expectation13<X,A,B,C,D,E,F,G,H,I,J,K,L,M>;
+       BasicRegisterExpect(reinterpret_cast<mock<Z2> *>(mck),
+                                               funcIndex.first, funcIndex.second,
+                                               reinterpret_cast<void (base_mock::*)()>(mfp),X);
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M> *call = new TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M>(expect, reinterpret_cast<base_mock *>(mck), funcIndex, lineNo, functionName ,fileName);
+       addCall( call, expect );
+       return *call;
+}
+template <int X, typename Z2, typename Y, typename Z,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H,
+                 typename I, typename J, typename K, typename L,
+                 typename M, typename N>
+TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N> &MockRepository::RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F,G,H,I,J,K,L,M,N), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo)
+{
+       std::pair<int, int> funcIndex = virtual_index((Y(Z2::*)(A,B,C,D,E,F,G,H,I,J,K,L,M,N))func);
+       Y (mockFuncs<Z2, Y>::*mfp)(A,B,C,D,E,F,G,H,I,J,K,L,M,N);
+       mfp = &mockFuncs<Z2, Y>::template expectation14<X,A,B,C,D,E,F,G,H,I,J,K,L,M,N>;
+       BasicRegisterExpect(reinterpret_cast<mock<Z2> *>(mck),
+                                               funcIndex.first, funcIndex.second,
+                                               reinterpret_cast<void (base_mock::*)()>(mfp),X);
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N> *call = new TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N>(expect, reinterpret_cast<base_mock *>(mck), funcIndex, lineNo, functionName ,fileName);
+       addCall( call, expect );
+       return *call;
+}
+template <int X, typename Z2, typename Y, typename Z,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H,
+                 typename I, typename J, typename K, typename L,
+                 typename M, typename N, typename O>
+TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O> &MockRepository::RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F,G,H,I,J,K,L,M,N,O), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo)
+{
+       std::pair<int, int> funcIndex = virtual_index((Y(Z2::*)(A,B,C,D,E,F,G,H,I,J,K,L,M,N,O))func);
+       Y (mockFuncs<Z2, Y>::*mfp)(A,B,C,D,E,F,G,H,I,J,K,L,M,N,O);
+       mfp = &mockFuncs<Z2, Y>::template expectation15<X,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O>;
+       BasicRegisterExpect(reinterpret_cast<mock<Z2> *>(mck),
+                                               funcIndex.first, funcIndex.second,
+                                               reinterpret_cast<void (base_mock::*)()>(mfp),X);
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O> *call = new TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O>(expect, reinterpret_cast<base_mock *>(mck), funcIndex, lineNo, functionName ,fileName);
+       addCall( call, expect );
+       return *call;
+}
+
+template <int X, typename Z2, typename Y, typename Z,
+                 typename A, typename B, typename C, typename D,
+                 typename E, typename F, typename G, typename H,
+                 typename I, typename J, typename K, typename L,
+                 typename M, typename N, typename O, typename P>
+TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P> &MockRepository::RegisterExpect_(Z2 *mck, Y (Z::*func)(A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P), RegistrationType expect, const char *functionName, const char *fileName, unsigned long lineNo)
+{
+       std::pair<int, int> funcIndex = virtual_index((Y(Z2::*)(A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P))func);
+       Y (mockFuncs<Z2, Y>::*mfp)(A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P);
+       mfp = &mockFuncs<Z2, Y>::template expectation16<X,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P>;
+       BasicRegisterExpect(reinterpret_cast<mock<Z2> *>(mck),
+                                               funcIndex.first, funcIndex.second,
+                                               reinterpret_cast<void (base_mock::*)()>(mfp),X);
+       TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P> *call = new TCall<Y,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P>(expect, reinterpret_cast<base_mock *>(mck), funcIndex, lineNo, functionName ,fileName);
+       addCall( call, expect );
+       return *call;
+}
+
+template <typename Z>
+Z MockRepository::DoExpectation(base_mock *mock, std::pair<int, int> funcno, const base_tuple &tuple)
+{
+       for (std::list<Call *>::reverse_iterator i = neverCalls.rbegin(); i != neverCalls.rend(); ++i)
+       {
+               Call *call = *i;
+               if ( matches( call, mock, funcno, tuple ) )
+               {
+                       call->satisfied = true;
+                       RAISEEXCEPTION(ExpectationException(this, call->getArgs(), call->funcName));
+               }
+       }
+   for (std::list<Call *>::reverse_iterator i = expectations.rbegin(); i != expectations.rend(); ++i)
+       {
+               Call *call = *i;
+               if( isUnsatisfied( call, mock, funcno, tuple ) )
+               {
+                       return doReturnCall<Z>( call, tuple );
+               }
+       }
+       for (std::list<Call *>::reverse_iterator i = optionals.rbegin(); i != optionals.rend(); ++i)
+       {
+               Call *call = *i;
+               if ( matches( call, mock, funcno, tuple ) )
+               {
+                  return doReturnCall<Z>( call, tuple );
+               }
+       }
+       RAISEEXCEPTION(ExpectationException(this, &tuple, funcName(mock,funcno)));
+}
+template <typename base>
+base *MockRepository::Mock() {
+       mock<base> *m = new mock<base>(this);
+               mocks.push_back(m);
+       return reinterpret_cast<base *>(m);
+}
+inline std::ostream &operator<<(std::ostream &os, const Call &call)
+{
+       os << call.fileName << "(" << call.lineno << ") ";
+       if (call.expectation == Once)
+               os << "Expectation for ";
+       else
+               os << "Result set for ";
+
+       os << call.funcName;
+
+               if (call.getArgs())
+                               call.getArgs()->printTo(os);
+               else
+                               os << "(...)";
+
+               os << " on the mock at 0x" << call.mock << " was ";
+
+       if (!call.satisfied)
+               os << "not ";
+
+       if (call.expectation == Once)
+               os << "satisfied." << std::endl;
+       else
+               os << "used." << std::endl;
+
+       return os;
+}
+
+inline std::ostream &operator<<(std::ostream &os, const MockRepository &repo)
+{
+   if (repo.expectations.size())
+       {
+               os << "Expections set:" << std::endl;
+               for (std::list<Call *>::const_iterator exp = repo.expectations.begin(); exp != repo.expectations.end(); ++exp)
+                       os << **exp;
+               os << std::endl;
+       }
+
+       if (repo.neverCalls.size())
+       {
+               os << "Functions explicitly expected to not be called:" << std::endl;
+               for (std::list<Call *>::const_iterator exp = repo.neverCalls.begin(); exp != repo.neverCalls.end(); ++exp)
+                       os << **exp;
+               os << std::endl;
+       }
+
+       if (repo.optionals.size())
+       {
+               os << "Optional results set up:" << std::endl;
+               for (std::list<Call *>::const_iterator exp = repo.optionals.begin(); exp != repo.optionals.end(); ++exp)
+                       os << **exp;
+               os << std::endl;
+       }
+       return os;
+}
+
+#ifdef _MSC_VER
+#pragma warning(pop)
+#endif
+
+#ifndef NO_HIPPOMOCKS_NAMESPACE
+}
+
+using HippoMocks::MockRepository;
+using HippoMocks::DONTCARE_NAME;
+using HippoMocks::Call;
+using HippoMocks::Out;
+using HippoMocks::In;
+#endif
+
+#undef DEBUGBREAK
+#undef BASE_EXCEPTION
+#undef RAISEEXCEPTION
+#undef RAISELATENTEXCEPTION
+#undef DONTCARE_NAME
+#undef VIRT_FUNC_LIMIT
+#undef EXTRA_DESTRUCTOR
+#undef FUNCTION_BASE
+#undef FUNCTION_STRIDE
+#undef CFUNC_MOCK_PLATFORMIS64BIT
+
+#endif
+
diff --git a/extlibs/hippomocks-master/HippoMocksTest/CMakeLists.txt b/extlibs/hippomocks-master/HippoMocksTest/CMakeLists.txt
new file mode 100644 (file)
index 0000000..7837c1d
--- /dev/null
@@ -0,0 +1,37 @@
+cmake_minimum_required(VERSION 3.0)
+project(HippoMocksTests CXX)
+include_directories(../HippoMocks)
+
+set(test_SOURCES 
+Framework.cpp
+is_virtual.cpp
+main.cpp
+test.cpp
+test_args.cpp
+test_array.cpp
+test_autoptr.cpp
+test_cfuncs.cpp
+test_class_args.cpp
+test_constref_params.cpp
+test_cv_funcs.cpp
+test_do.cpp
+test_dontcare.cpp
+test_except.cpp
+test_exception_quality.cpp
+test_filter.cpp
+test_inparam.cpp
+test_membermock.cpp
+test_mi.cpp
+test_nevercall.cpp
+test_optional.cpp
+test_outparam.cpp
+test_overload.cpp
+test_ref_args.cpp
+test_regression_arg_count.cpp
+test_retval.cpp
+test_transaction.cpp
+test_zombie.cpp)
+
+add_executable(HippoMocksTest ${test_SOURCES})
+add_test(test HippoMocksTest)
+
diff --git a/extlibs/hippomocks-master/HippoMocksTest/Framework.cpp b/extlibs/hippomocks-master/HippoMocksTest/Framework.cpp
new file mode 100644 (file)
index 0000000..efa5bb4
--- /dev/null
@@ -0,0 +1,37 @@
+#include "Framework.h"
+
+template <>
+void check_equal(float a, float b, const char *sa, const char *sb) {
+    if (a != b) throw BaseException("%s(%f) != %s(%f)", sa, a, sb, b);
+}
+
+template <>
+void check_equal<const char *, const char *>(const char *a, const char *b, const char *sa, const char *sb) {
+    if (strcmp(a, b) != 0) { throw BaseException("%s(%s) != %s(%s)", sa, a, sb, b); }
+}
+
+bool TestRegistry::RunTests() {
+    char spinner[5] = "\\|/-";
+    unsigned long i = 0, s = 0;
+    size_t spinidx = 0;
+    for (std::vector<Test *>::iterator it = tests.begin(); it != tests.end(); ++it) {
+        Test *t = *it;
+        i++;
+        try {
+            t->Run();
+            s++;
+        } catch (std::exception &e) {
+            printf("Test %s failed with exception: %s\n", t->name.c_str(), e.what());
+        } catch (int e) {
+            printf("Test %s failed with error code: %d\n", t->name.c_str(), e);
+        } catch (...) {
+            printf("Test %s failed with ellipsis-caught error\n", t->name.c_str());
+        }
+        printf("%c\r", spinner[spinidx]);
+        spinidx = (spinidx + 1) % 4;
+    }
+    printf("%lu of %lu tests successful\n", s, i);
+    return !(s == i);
+}
+
+
diff --git a/extlibs/hippomocks-master/HippoMocksTest/Framework.h b/extlibs/hippomocks-master/HippoMocksTest/Framework.h
new file mode 100644 (file)
index 0000000..12fb59a
--- /dev/null
@@ -0,0 +1,82 @@
+#ifndef TEST_H
+#define TEST_H
+
+#include <vector>
+#include <string.h>
+#include <string>
+#include <exception>
+#include <stdio.h>
+#include <stdarg.h>
+
+class BaseException : public std::exception {
+public:
+  BaseException(std::string fmt, ...) {
+    va_list l;
+    static char buffer[4096];
+    va_start(l, fmt);
+    vsnprintf(buffer, 4096, fmt.c_str(), l);
+    va_end(l);
+    error = buffer;
+  }
+
+  ~BaseException() throw() {}
+  const char *what() const throw() { return error.c_str(); }
+private:
+  std::string error;
+};
+
+class Test;
+
+class TestRegistry {
+    std::vector<Test *> tests;
+public:
+    static TestRegistry &Instance() { static TestRegistry registry; return registry; }
+    void AddTest(Test *test) {
+        tests.push_back(test);
+    }
+    bool RunTests();
+};
+
+class Test {
+public:
+    std::string name;
+    Test(std::string name) 
+    : name(name)
+    {
+    }
+    virtual void Run() = 0;
+};
+
+template <typename T, typename TB>
+void check_equal(T a, TB b, const char *sa, const char *sb) {
+    if (a != b) {
+        throw BaseException("%s(%d) != %s(%d)", sa, a, sb, b);
+    }
+}
+
+template <>
+void check_equal(float a, float b, const char *sa, const char *sb);
+
+template <typename T>
+void check_equal(const std::string &a, T b, const char *sa, const char *sb) {
+    return check_equal(a.c_str(), b, sa, sb);
+}
+
+template <typename T>
+void check_equal(T a, const std::string &b, const char *sa, const char *sb) {
+    return check_equal(a, b.c_str(), sa, sb);
+}
+
+template <>
+void check_equal<const char *, const char *>(const char *a, const char *b, const char *sa, const char *sb);
+
+#define CHECK(x) { if (!(x)) { throw BaseException("!(%s)", #x); } }
+#define EQUALS(x, y) check_equal(x, y, #x, #y)
+
+#define TEST(X) class Test##X : public Test { public: Test##X() : Test(#X) { TestRegistry::Instance().AddTest(this); } void Run(); };\
+static Test##X _Test##X;\
+void Test##X::Run()
+
+#endif
+
+
diff --git a/extlibs/hippomocks-master/HippoMocksTest/HippoMocks.dev b/extlibs/hippomocks-master/HippoMocksTest/HippoMocks.dev
new file mode 100644 (file)
index 0000000..e96bb3a
--- /dev/null
@@ -0,0 +1,169 @@
+[Project]\r
+FileName=HippoMocks.dev\r
+Name=HippoMocks\r
+UnitCount=12\r
+Type=1\r
+Ver=1\r
+ObjFiles=\r
+Includes=\r
+Libs=\r
+PrivateResource=\r
+ResourceIncludes=\r
+MakeIncludes=\r
+Compiler=\r
+CppCompiler=\r
+Linker=\r
+IsCpp=1\r
+Icon=\r
+ExeOutput=\r
+ObjectOutput=\r
+OverrideOutput=0\r
+OverrideOutputName=\r
+HostApplication=\r
+Folders=\r
+CommandLine=\r
+UseCustomMakefile=0\r
+CustomMakefile=\r
+IncludeVersionInfo=0\r
+SupportXPThemes=0\r
+CompilerSet=0\r
+CompilerSettings=\r
+\r
+[Unit1]\r
+FileName=yaffut.h\r
+CompileCpp=1\r
+Folder=HippoMocks\r
+Compile=1\r
+Link=1\r
+Priority=1000\r
+OverrideBuildCmd=0\r
+BuildCmd=\r
+\r
+[Unit2]\r
+FileName=test.cpp\r
+CompileCpp=1\r
+Folder=HippoMocks\r
+Compile=1\r
+Link=1\r
+Priority=1000\r
+OverrideBuildCmd=0\r
+BuildCmd=\r
+\r
+[Unit3]\r
+FileName=test_args.cpp\r
+CompileCpp=1\r
+Folder=HippoMocks\r
+Compile=1\r
+Link=1\r
+Priority=1000\r
+OverrideBuildCmd=0\r
+BuildCmd=\r
+\r
+[Unit4]\r
+FileName=test_class_args.cpp\r
+CompileCpp=1\r
+Folder=HippoMocks\r
+Compile=1\r
+Link=1\r
+Priority=1000\r
+OverrideBuildCmd=0\r
+BuildCmd=\r
+\r
+[Unit5]\r
+FileName=test_class_mock.cpp\r
+CompileCpp=1\r
+Folder=HippoMocks\r
+Compile=1\r
+Link=1\r
+Priority=1000\r
+OverrideBuildCmd=0\r
+BuildCmd=\r
+\r
+[Unit6]\r
+FileName=test_except.cpp\r
+CompileCpp=1\r
+Folder=HippoMocks\r
+Compile=1\r
+Link=1\r
+Priority=1000\r
+OverrideBuildCmd=0\r
+BuildCmd=\r
+\r
+[Unit7]\r
+FileName=test_functors.cpp\r
+CompileCpp=1\r
+Folder=HippoMocks\r
+Compile=1\r
+Link=1\r
+Priority=1000\r
+OverrideBuildCmd=0\r
+BuildCmd=\r
+\r
+[Unit8]\r
+FileName=test_optional.cpp\r
+CompileCpp=1\r
+Folder=HippoMocks\r
+Compile=1\r
+Link=1\r
+Priority=1000\r
+OverrideBuildCmd=0\r
+BuildCmd=\r
+\r
+[Unit9]\r
+FileName=test_retval.cpp\r
+CompileCpp=1\r
+Folder=HippoMocks\r
+Compile=1\r
+Link=1\r
+Priority=1000\r
+OverrideBuildCmd=0\r
+BuildCmd=\r
+\r
+[Unit10]\r
+FileName=yaffut.cpp\r
+CompileCpp=1\r
+Folder=HippoMocks\r
+Compile=1\r
+Link=1\r
+Priority=1000\r
+OverrideBuildCmd=0\r
+BuildCmd=\r
+\r
+[VersionInfo]\r
+Major=0\r
+Minor=1\r
+Release=1\r
+Build=1\r
+LanguageID=1033\r
+CharsetID=1252\r
+CompanyName=\r
+FileVersion=\r
+FileDescription=Developed using the Dev-C++ IDE\r
+InternalName=\r
+LegalCopyright=\r
+LegalTrademarks=\r
+OriginalFilename=\r
+ProductName=\r
+ProductVersion=\r
+AutoIncBuildNr=0\r
+\r
+[Unit11]\r
+FileName=test_ref_args.cpp\r
+CompileCpp=1\r
+Folder=HippoMocks\r
+Compile=1\r
+Link=1\r
+Priority=1000\r
+OverrideBuildCmd=0\r
+BuildCmd=\r
+\r
+[Unit12]\r
+FileName=hippomocks.h\r
+CompileCpp=1\r
+Folder=HippoMocks\r
+Compile=1\r
+Link=1\r
+Priority=1000\r
+OverrideBuildCmd=0\r
+BuildCmd=\r
+\r
diff --git a/extlibs/hippomocks-master/HippoMocksTest/HippoMocks.pro b/extlibs/hippomocks-master/HippoMocksTest/HippoMocks.pro
new file mode 100644 (file)
index 0000000..e355ac2
--- /dev/null
@@ -0,0 +1,46 @@
+QT       += core
+
+TARGET = Hippomocks
+CONFIG   += console static
+CONFIG   -= app_bundle
+
+TEMPLATE = app
+
+INCLUDEPATH += ../Hippomocks
+
+# Uncomment to enable test coverage data:
+#QMAKE_CXXFLAGS += -g -O0 -fprofile-arcs -ftest-coverage
+#QMAKE_LFLAGS += -g -O0 -fprofile-arcs -ftest-coverage
+
+
+HEADERS += Framework.h
+
+SOURCES += \
+  Framework.cpp \
+  is_virtual.cpp \
+  main.cpp \
+  test.cpp \
+  test_args.cpp \
+  test_array.cpp \
+  test_autoptr.cpp \
+  test_cfuncs.cpp \
+  test_class_args.cpp \
+  test_constref_params.cpp \
+  test_cv_funcs.cpp \
+  test_do.cpp \
+  test_dontcare.cpp \
+  test_except.cpp \
+  test_exception_quality.cpp \
+  test_filter.cpp \
+  test_inparam.cpp \
+  test_membermock.cpp \
+  test_mi.cpp \
+  test_nevercall.cpp \
+  test_optional.cpp \
+  test_outparam.cpp \
+  test_overload.cpp \
+  test_ref_args.cpp \
+  test_regression_arg_count.cpp \
+  test_retval.cpp \
+  test_transaction.cpp \
+  test_zombie.cpp
diff --git a/extlibs/hippomocks-master/HippoMocksTest/HippoMocksTest.sln b/extlibs/hippomocks-master/HippoMocksTest/HippoMocksTest.sln
new file mode 100644 (file)
index 0000000..d6a29e5
--- /dev/null
@@ -0,0 +1,26 @@
+\r
+Microsoft Visual Studio Solution File, Format Version 10.00\r
+# Visual C++ Express 2008\r
+Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "HippoMocksTest", "..\HippoMocksTest\HippoMocksTest.vcproj", "{231F5EB2-1F1D-4C41-9FC1-59118049524F}"\r
+EndProject\r
+Global\r
+       GlobalSection(SolutionConfigurationPlatforms) = preSolution\r
+               Debug|x64 = Debug|x64\r
+               Release|x64 = Release|x64\r
+               Debug|Win32 = Debug|Win32\r
+               Release|Win32 = Release|Win32\r
+       EndGlobalSection\r
+       GlobalSection(ProjectConfigurationPlatforms) = postSolution\r
+               {231F5EB2-1F1D-4C41-9FC1-59118049524F}.Debug|x64.ActiveCfg = Debug|x64\r
+               {231F5EB2-1F1D-4C41-9FC1-59118049524F}.Debug|x64.Build.0 = Debug|x64\r
+               {231F5EB2-1F1D-4C41-9FC1-59118049524F}.Release|x64.ActiveCfg = Release|x64\r
+               {231F5EB2-1F1D-4C41-9FC1-59118049524F}.Release|x64.Build.0 = Release|x64\r
+               {231F5EB2-1F1D-4C41-9FC1-59118049524F}.Debug|Win32.ActiveCfg = Debug|Win32\r
+               {231F5EB2-1F1D-4C41-9FC1-59118049524F}.Debug|Win32.Build.0 = Debug|Win32\r
+               {231F5EB2-1F1D-4C41-9FC1-59118049524F}.Release|Win32.ActiveCfg = Release|Win32\r
+               {231F5EB2-1F1D-4C41-9FC1-59118049524F}.Release|Win32.Build.0 = Release|Win32\r
+       EndGlobalSection\r
+       GlobalSection(SolutionProperties) = preSolution\r
+               HideSolutionNode = FALSE\r
+       EndGlobalSection\r
+EndGlobal\r
diff --git a/extlibs/hippomocks-master/HippoMocksTest/HippoMocksTest.vcproj b/extlibs/hippomocks-master/HippoMocksTest/HippoMocksTest.vcproj
new file mode 100644 (file)
index 0000000..97d52f2
--- /dev/null
@@ -0,0 +1,443 @@
+<?xml version="1.0" encoding="Windows-1252"?>\r
+<VisualStudioProject\r
+       ProjectType="Visual C++"\r
+       Version="9.00"\r
+       Name="HippoMocksTest"\r
+       ProjectGUID="{231F5EB2-1F1D-4C41-9FC1-59118049524F}"\r
+       RootNamespace="HippoMocksTest"\r
+       TargetFrameworkVersion="131072"\r
+       >\r
+       <Platforms>\r
+               <Platform\r
+                       Name="Win32"\r
+               />\r
+               <Platform\r
+                       Name="x64"\r
+               />\r
+       </Platforms>\r
+       <ToolFiles>\r
+               <DefaultToolFile\r
+                       FileName="masm.rules"\r
+               />\r
+       </ToolFiles>\r
+       <Configurations>\r
+               <Configuration\r
+                       Name="Debug|Win32"\r
+                       OutputDirectory="$(SolutionDir)$(ConfigurationName)"\r
+                       IntermediateDirectory="$(ConfigurationName)"\r
+                       ConfigurationType="1"\r
+                       CharacterSet="2"\r
+                       >\r
+                       <Tool\r
+                               Name="VCPreBuildEventTool"\r
+                       />\r
+                       <Tool\r
+                               Name="VCCustomBuildTool"\r
+                       />\r
+                       <Tool\r
+                               Name="MASM"\r
+                       />\r
+                       <Tool\r
+                               Name="VCXMLDataGeneratorTool"\r
+                       />\r
+                       <Tool\r
+                               Name="VCWebServiceProxyGeneratorTool"\r
+                       />\r
+                       <Tool\r
+                               Name="VCMIDLTool"\r
+                       />\r
+                       <Tool\r
+                               Name="VCCLCompilerTool"\r
+                               AdditionalOptions="/vmg"\r
+                               Optimization="0"\r
+                               AdditionalIncludeDirectories="../HippoMocks/"\r
+                               MinimalRebuild="true"\r
+                               BasicRuntimeChecks="3"\r
+                               RuntimeLibrary="3"\r
+                               EnableEnhancedInstructionSet="2"\r
+                               WarningLevel="4"\r
+                               DebugInformationFormat="4"\r
+                       />\r
+                       <Tool\r
+                               Name="VCManagedResourceCompilerTool"\r
+                       />\r
+                       <Tool\r
+                               Name="VCResourceCompilerTool"\r
+                       />\r
+                       <Tool\r
+                               Name="VCPreLinkEventTool"\r
+                       />\r
+                       <Tool\r
+                               Name="VCLinkerTool"\r
+                               GenerateDebugInformation="true"\r
+                               TargetMachine="1"\r
+                       />\r
+                       <Tool\r
+                               Name="VCALinkTool"\r
+                       />\r
+                       <Tool\r
+                               Name="VCManifestTool"\r
+                       />\r
+                       <Tool\r
+                               Name="VCXDCMakeTool"\r
+                       />\r
+                       <Tool\r
+                               Name="VCBscMakeTool"\r
+                       />\r
+                       <Tool\r
+                               Name="VCFxCopTool"\r
+                       />\r
+                       <Tool\r
+                               Name="VCAppVerifierTool"\r
+                       />\r
+                       <Tool\r
+                               Name="VCPostBuildEventTool"\r
+                       />\r
+               </Configuration>\r
+               <Configuration\r
+                       Name="Release|Win32"\r
+                       OutputDirectory="$(SolutionDir)$(ConfigurationName)"\r
+                       IntermediateDirectory="$(ConfigurationName)"\r
+                       ConfigurationType="1"\r
+                       CharacterSet="2"\r
+                       WholeProgramOptimization="1"\r
+                       >\r
+                       <Tool\r
+                               Name="VCPreBuildEventTool"\r
+                       />\r
+                       <Tool\r
+                               Name="VCCustomBuildTool"\r
+                       />\r
+                       <Tool\r
+                               Name="MASM"\r
+                       />\r
+                       <Tool\r
+                               Name="VCXMLDataGeneratorTool"\r
+                       />\r
+                       <Tool\r
+                               Name="VCWebServiceProxyGeneratorTool"\r
+                       />\r
+                       <Tool\r
+                               Name="VCMIDLTool"\r
+                       />\r
+                       <Tool\r
+                               Name="VCCLCompilerTool"\r
+                               AdditionalOptions="/vmg"\r
+                               Optimization="2"\r
+                               EnableIntrinsicFunctions="true"\r
+                               AdditionalIncludeDirectories="../hippo mocks"\r
+                               RuntimeLibrary="2"\r
+                               EnableFunctionLevelLinking="true"\r
+                               WarningLevel="4"\r
+                               DebugInformationFormat="3"\r
+                       />\r
+                       <Tool\r
+                               Name="VCManagedResourceCompilerTool"\r
+                       />\r
+                       <Tool\r
+                               Name="VCResourceCompilerTool"\r
+                       />\r
+                       <Tool\r
+                               Name="VCPreLinkEventTool"\r
+                       />\r
+                       <Tool\r
+                               Name="VCLinkerTool"\r
+                               GenerateDebugInformation="true"\r
+                               OptimizeReferences="2"\r
+                               EnableCOMDATFolding="2"\r
+                               TargetMachine="1"\r
+                       />\r
+                       <Tool\r
+                               Name="VCALinkTool"\r
+                       />\r
+                       <Tool\r
+                               Name="VCManifestTool"\r
+                       />\r
+                       <Tool\r
+                               Name="VCXDCMakeTool"\r
+                       />\r
+                       <Tool\r
+                               Name="VCBscMakeTool"\r
+                       />\r
+                       <Tool\r
+                               Name="VCFxCopTool"\r
+                       />\r
+                       <Tool\r
+                               Name="VCAppVerifierTool"\r
+                       />\r
+                       <Tool\r
+                               Name="VCPostBuildEventTool"\r
+                       />\r
+               </Configuration>\r
+               <Configuration\r
+                       Name="Debug|x64"\r
+                       OutputDirectory="$(SolutionDir)$(ConfigurationName)"\r
+                       IntermediateDirectory="$(ConfigurationName)"\r
+                       ConfigurationType="1"\r
+                       CharacterSet="2"\r
+                       >\r
+                       <Tool\r
+                               Name="VCPreBuildEventTool"\r
+                       />\r
+                       <Tool\r
+                               Name="VCCustomBuildTool"\r
+                       />\r
+                       <Tool\r
+                               Name="MASM"\r
+                       />\r
+                       <Tool\r
+                               Name="VCXMLDataGeneratorTool"\r
+                       />\r
+                       <Tool\r
+                               Name="VCWebServiceProxyGeneratorTool"\r
+                       />\r
+                       <Tool\r
+                               Name="VCMIDLTool"\r
+                       />\r
+                       <Tool\r
+                               Name="VCCLCompilerTool"\r
+                               AdditionalOptions="/vmg"\r
+                               Optimization="0"\r
+                               AdditionalIncludeDirectories="../HippoMocks/"\r
+                               MinimalRebuild="true"\r
+                               BasicRuntimeChecks="3"\r
+                               RuntimeLibrary="3"\r
+                               EnableEnhancedInstructionSet="2"\r
+                               WarningLevel="4"\r
+                               DebugInformationFormat="4"\r
+                       />\r
+                       <Tool\r
+                               Name="VCManagedResourceCompilerTool"\r
+                       />\r
+                       <Tool\r
+                               Name="VCResourceCompilerTool"\r
+                       />\r
+                       <Tool\r
+                               Name="VCPreLinkEventTool"\r
+                       />\r
+                       <Tool\r
+                               Name="VCLinkerTool"\r
+                               GenerateDebugInformation="true"\r
+                               TargetMachine="1"\r
+                       />\r
+                       <Tool\r
+                               Name="VCALinkTool"\r
+                       />\r
+                       <Tool\r
+                               Name="VCManifestTool"\r
+                       />\r
+                       <Tool\r
+                               Name="VCXDCMakeTool"\r
+                       />\r
+                       <Tool\r
+                               Name="VCBscMakeTool"\r
+                       />\r
+                       <Tool\r
+                               Name="VCFxCopTool"\r
+                       />\r
+                       <Tool\r
+                               Name="VCAppVerifierTool"\r
+                       />\r
+                       <Tool\r
+                               Name="VCPostBuildEventTool"\r
+                       />\r
+               </Configuration>\r
+               <Configuration\r
+                       Name="Release|x64"\r
+                       OutputDirectory="$(SolutionDir)$(ConfigurationName)"\r
+                       IntermediateDirectory="$(ConfigurationName)"\r
+                       ConfigurationType="1"\r
+                       CharacterSet="2"\r
+                       WholeProgramOptimization="1"\r
+                       >\r
+                       <Tool\r
+                               Name="VCPreBuildEventTool"\r
+                       />\r
+                       <Tool\r
+                               Name="VCCustomBuildTool"\r
+                       />\r
+                       <Tool\r
+                               Name="MASM"\r
+                       />\r
+                       <Tool\r
+                               Name="VCXMLDataGeneratorTool"\r
+                       />\r
+                       <Tool\r
+                               Name="VCWebServiceProxyGeneratorTool"\r
+                       />\r
+                       <Tool\r
+                               Name="VCMIDLTool"\r
+                       />\r
+                       <Tool\r
+                               Name="VCCLCompilerTool"\r
+                               AdditionalOptions="/vmg"\r
+                               Optimization="2"\r
+                               EnableIntrinsicFunctions="true"\r
+                               AdditionalIncludeDirectories="../hippo mocks"\r
+                               RuntimeLibrary="2"\r
+                               EnableFunctionLevelLinking="true"\r
+                               WarningLevel="4"\r
+                               DebugInformationFormat="3"\r
+                       />\r
+                       <Tool\r
+                               Name="VCManagedResourceCompilerTool"\r
+                       />\r
+                       <Tool\r
+                               Name="VCResourceCompilerTool"\r
+                       />\r
+                       <Tool\r
+                               Name="VCPreLinkEventTool"\r
+                       />\r
+                       <Tool\r
+                               Name="VCLinkerTool"\r
+                               GenerateDebugInformation="true"\r
+                               OptimizeReferences="2"\r
+                               EnableCOMDATFolding="2"\r
+                               TargetMachine="1"\r
+                       />\r
+                       <Tool\r
+                               Name="VCALinkTool"\r
+                       />\r
+                       <Tool\r
+                               Name="VCManifestTool"\r
+                       />\r
+                       <Tool\r
+                               Name="VCXDCMakeTool"\r
+                       />\r
+                       <Tool\r
+                               Name="VCBscMakeTool"\r
+                       />\r
+                       <Tool\r
+                               Name="VCFxCopTool"\r
+                       />\r
+                       <Tool\r
+                               Name="VCAppVerifierTool"\r
+                       />\r
+                       <Tool\r
+                               Name="VCPostBuildEventTool"\r
+                       />\r
+               </Configuration>\r
+       </Configurations>\r
+       <References>\r
+       </References>\r
+       <Files>\r
+               <File\r
+                       RelativePath=".\Framework.cpp"\r
+                       >\r
+               </File>\r
+               <File\r
+                       RelativePath=".\Framework.h"\r
+                       >\r
+               </File>\r
+               <File\r
+                       RelativePath=".\is_virtual.cpp"\r
+                       >\r
+               </File>\r
+               <File\r
+                       RelativePath=".\main.cpp"\r
+                       >\r
+               </File>\r
+               <File\r
+                       RelativePath=".\test.cpp"\r
+                       >\r
+               </File>\r
+               <File\r
+                       RelativePath=".\test_args.cpp"\r
+                       >\r
+               </File>\r
+               <File\r
+                       RelativePath=".\test_array.cpp"\r
+                       >\r
+               </File>\r
+               <File\r
+                       RelativePath=".\test_autoptr.cpp"\r
+                       >\r
+               </File>\r
+               <File\r
+                       RelativePath=".\test_cfuncs.cpp"\r
+                       >\r
+               </File>\r
+               <File\r
+                       RelativePath=".\test_class_args.cpp"\r
+                       >\r
+               </File>\r
+               <File\r
+                       RelativePath=".\test_constref_params.cpp"\r
+                       >\r
+               </File>\r
+               <File\r
+                       RelativePath=".\test_cv_funcs.cpp"\r
+                       >\r
+               </File>\r
+               <File\r
+                       RelativePath=".\test_do.cpp"\r
+                       >\r
+               </File>\r
+               <File\r
+                       RelativePath=".\test_dontcare.cpp"\r
+                       >\r
+               </File>\r
+               <File\r
+                       RelativePath=".\test_except.cpp"\r
+                       >\r
+               </File>\r
+               <File\r
+                       RelativePath=".\test_exception_quality.cpp"\r
+                       >\r
+               </File>\r
+               <File\r
+                       RelativePath=".\test_filter.cpp"\r
+                       >\r
+               </File>\r
+               <File\r
+                       RelativePath=".\test_inparam.cpp"\r
+                       >\r
+               </File>\r
+               <File\r
+                       RelativePath=".\test_membermock.cpp"\r
+                       >\r
+               </File>\r
+               <File\r
+                       RelativePath=".\test_mi.cpp"\r
+                       >\r
+               </File>\r
+               <File\r
+                       RelativePath=".\test_nevercall.cpp"\r
+                       >\r
+               </File>\r
+               <File\r
+                       RelativePath=".\test_optional.cpp"\r
+                       >\r
+               </File>\r
+               <File\r
+                       RelativePath=".\test_outparam.cpp"\r
+                       >\r
+               </File>\r
+               <File\r
+                       RelativePath=".\test_overload.cpp"\r
+                       >\r
+               </File>\r
+               <File\r
+                       RelativePath=".\test_ref_args.cpp"\r
+                       >\r
+               </File>\r
+               <File\r
+                       RelativePath=".\test_regression_arg_count.cpp"\r
+                       >\r
+               </File>\r
+               <File\r
+                       RelativePath=".\test_retval.cpp"\r
+                       >\r
+               </File>\r
+               <File\r
+                       RelativePath=".\test_transaction.cpp"\r
+                       >\r
+               </File>\r
+               <File\r
+                       RelativePath=".\test_zombie.cpp"\r
+                       >\r
+               </File>\r
+       </Files>\r
+       <Globals>\r
+       </Globals>\r
+</VisualStudioProject>\r
diff --git a/extlibs/hippomocks-master/HippoMocksTest/HippoMocksTest_2012.sln b/extlibs/hippomocks-master/HippoMocksTest/HippoMocksTest_2012.sln
new file mode 100644 (file)
index 0000000..8a1c13f
--- /dev/null
@@ -0,0 +1,26 @@
+
+Microsoft Visual Studio Solution File, Format Version 12.00
+# Visual Studio 2012
+Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "HippoMocksTest", "HippoMocksTest_2012.vcxproj", "{231F5EB2-1F1D-4C41-9FC1-59118049524F}"
+EndProject
+Global
+       GlobalSection(SolutionConfigurationPlatforms) = preSolution
+               Debug|Win32 = Debug|Win32
+               Debug|x64 = Debug|x64
+               Release|Win32 = Release|Win32
+               Release|x64 = Release|x64
+       EndGlobalSection
+       GlobalSection(ProjectConfigurationPlatforms) = postSolution
+               {231F5EB2-1F1D-4C41-9FC1-59118049524F}.Debug|Win32.ActiveCfg = Debug|Win32
+               {231F5EB2-1F1D-4C41-9FC1-59118049524F}.Debug|Win32.Build.0 = Debug|Win32
+               {231F5EB2-1F1D-4C41-9FC1-59118049524F}.Debug|x64.ActiveCfg = Debug|x64
+               {231F5EB2-1F1D-4C41-9FC1-59118049524F}.Debug|x64.Build.0 = Debug|x64
+               {231F5EB2-1F1D-4C41-9FC1-59118049524F}.Release|Win32.ActiveCfg = Release|Win32
+               {231F5EB2-1F1D-4C41-9FC1-59118049524F}.Release|Win32.Build.0 = Release|Win32
+               {231F5EB2-1F1D-4C41-9FC1-59118049524F}.Release|x64.ActiveCfg = Release|x64
+               {231F5EB2-1F1D-4C41-9FC1-59118049524F}.Release|x64.Build.0 = Release|x64
+       EndGlobalSection
+       GlobalSection(SolutionProperties) = preSolution
+               HideSolutionNode = FALSE
+       EndGlobalSection
+EndGlobal
diff --git a/extlibs/hippomocks-master/HippoMocksTest/HippoMocksTest_2012.vcxproj b/extlibs/hippomocks-master/HippoMocksTest/HippoMocksTest_2012.vcxproj
new file mode 100644 (file)
index 0000000..8950ede
--- /dev/null
@@ -0,0 +1,199 @@
+<?xml version="1.0" encoding="utf-8"?>
+<Project DefaultTargets="Build" ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
+  <ItemGroup Label="ProjectConfigurations">
+    <ProjectConfiguration Include="Debug|Win32">
+      <Configuration>Debug</Configuration>
+      <Platform>Win32</Platform>
+    </ProjectConfiguration>
+    <ProjectConfiguration Include="Debug|x64">
+      <Configuration>Debug</Configuration>
+      <Platform>x64</Platform>
+    </ProjectConfiguration>
+    <ProjectConfiguration Include="Release|Win32">
+      <Configuration>Release</Configuration>
+      <Platform>Win32</Platform>
+    </ProjectConfiguration>
+    <ProjectConfiguration Include="Release|x64">
+      <Configuration>Release</Configuration>
+      <Platform>x64</Platform>
+    </ProjectConfiguration>
+  </ItemGroup>
+  <PropertyGroup Label="Globals">
+    <ProjectGuid>{231F5EB2-1F1D-4C41-9FC1-59118049524F}</ProjectGuid>
+    <RootNamespace>HippoMocksTest</RootNamespace>
+  </PropertyGroup>
+  <Import Project="$(VCTargetsPath)\Microsoft.Cpp.Default.props" />
+  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'" Label="Configuration">
+    <ConfigurationType>Application</ConfigurationType>
+    <PlatformToolset>v110</PlatformToolset>
+    <CharacterSet>MultiByte</CharacterSet>
+    <WholeProgramOptimization>true</WholeProgramOptimization>
+  </PropertyGroup>
+  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'" Label="Configuration">
+    <ConfigurationType>Application</ConfigurationType>
+    <PlatformToolset>v110</PlatformToolset>
+    <CharacterSet>MultiByte</CharacterSet>
+  </PropertyGroup>
+  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'" Label="Configuration">
+    <ConfigurationType>Application</ConfigurationType>
+    <PlatformToolset>v110</PlatformToolset>
+    <CharacterSet>MultiByte</CharacterSet>
+    <WholeProgramOptimization>true</WholeProgramOptimization>
+  </PropertyGroup>
+  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'" Label="Configuration">
+    <ConfigurationType>Application</ConfigurationType>
+    <PlatformToolset>v110</PlatformToolset>
+    <CharacterSet>MultiByte</CharacterSet>
+  </PropertyGroup>
+  <Import Project="$(VCTargetsPath)\Microsoft.Cpp.props" />
+  <ImportGroup Label="ExtensionSettings">
+    <Import Project="$(VCTargetsPath)\BuildCustomizations\masm.props" />
+  </ImportGroup>
+  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'" Label="PropertySheets">
+    <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
+  </ImportGroup>
+  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'" Label="PropertySheets">
+    <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
+  </ImportGroup>
+  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'" Label="PropertySheets">
+    <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
+  </ImportGroup>
+  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'" Label="PropertySheets">
+    <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
+  </ImportGroup>
+  <PropertyGroup Label="UserMacros" />
+  <PropertyGroup>
+    <_ProjectFileVersion>11.0.50727.1</_ProjectFileVersion>
+  </PropertyGroup>
+  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">
+    <OutDir>$(SolutionDir)$(Configuration)\</OutDir>
+    <IntDir>$(Configuration)\</IntDir>
+  </PropertyGroup>
+  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">
+    <OutDir>$(SolutionDir)$(Configuration)\</OutDir>
+    <IntDir>$(Configuration)\</IntDir>
+  </PropertyGroup>
+  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">
+    <OutDir>$(SolutionDir)$(Configuration)\</OutDir>
+    <IntDir>$(Configuration)\</IntDir>
+  </PropertyGroup>
+  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'">
+    <OutDir>$(SolutionDir)$(Configuration)\</OutDir>
+    <IntDir>$(Configuration)\</IntDir>
+  </PropertyGroup>
+  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">
+    <ClCompile>
+      <AdditionalOptions>/vmg %(AdditionalOptions)</AdditionalOptions>
+      <Optimization>Disabled</Optimization>
+      <AdditionalIncludeDirectories>../HippoMocks/;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>
+      <MinimalRebuild>true</MinimalRebuild>
+      <BasicRuntimeChecks>EnableFastChecks</BasicRuntimeChecks>
+      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary>
+      <EnableEnhancedInstructionSet>StreamingSIMDExtensions2</EnableEnhancedInstructionSet>
+      <WarningLevel>Level4</WarningLevel>
+      <DebugInformationFormat>EditAndContinue</DebugInformationFormat>
+    </ClCompile>
+    <Link>
+      <GenerateDebugInformation>true</GenerateDebugInformation>
+      <TargetMachine>MachineX86</TargetMachine>
+    </Link>
+    <PostBuildEvent>
+      <Command>$(TargetDir)$(TargetFileName)</Command>
+    </PostBuildEvent>
+  </ItemDefinitionGroup>
+  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">
+    <ClCompile>
+      <AdditionalOptions>/vmg %(AdditionalOptions)</AdditionalOptions>
+      <Optimization>MaxSpeed</Optimization>
+      <IntrinsicFunctions>true</IntrinsicFunctions>
+      <AdditionalIncludeDirectories>../hippo mocks;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>
+      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary>
+      <FunctionLevelLinking>true</FunctionLevelLinking>
+      <WarningLevel>Level4</WarningLevel>
+      <DebugInformationFormat>ProgramDatabase</DebugInformationFormat>
+    </ClCompile>
+    <Link>
+      <GenerateDebugInformation>true</GenerateDebugInformation>
+      <OptimizeReferences>true</OptimizeReferences>
+      <EnableCOMDATFolding>true</EnableCOMDATFolding>
+      <TargetMachine>MachineX86</TargetMachine>
+    </Link>
+  </ItemDefinitionGroup>
+  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">
+    <ClCompile>
+      <AdditionalOptions>/vmg %(AdditionalOptions)</AdditionalOptions>
+      <Optimization>Disabled</Optimization>
+      <AdditionalIncludeDirectories>../HippoMocks/;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>
+      <MinimalRebuild>true</MinimalRebuild>
+      <BasicRuntimeChecks>EnableFastChecks</BasicRuntimeChecks>
+      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary>
+      <EnableEnhancedInstructionSet>NotSet</EnableEnhancedInstructionSet>
+      <WarningLevel>Level4</WarningLevel>
+      <DebugInformationFormat>ProgramDatabase</DebugInformationFormat>
+      <PreprocessorDefinitions>_MBCS;%(PreprocessorDefinitions);_CRT_SECURE_NO_WARNINGS</PreprocessorDefinitions>
+    </ClCompile>
+    <Link>
+      <GenerateDebugInformation>true</GenerateDebugInformation>
+      <TargetMachine>MachineX64</TargetMachine>
+    </Link>
+    <PostBuildEvent>
+      <Command>$(TargetDir)$(TargetFileName)</Command>
+    </PostBuildEvent>
+  </ItemDefinitionGroup>
+  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'">
+    <ClCompile>
+      <AdditionalOptions>/vmg %(AdditionalOptions)</AdditionalOptions>
+      <Optimization>MaxSpeed</Optimization>
+      <IntrinsicFunctions>true</IntrinsicFunctions>
+      <AdditionalIncludeDirectories>../hippo mocks;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>
+      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary>
+      <FunctionLevelLinking>true</FunctionLevelLinking>
+      <WarningLevel>Level4</WarningLevel>
+      <DebugInformationFormat>ProgramDatabase</DebugInformationFormat>
+    </ClCompile>
+    <Link>
+      <GenerateDebugInformation>true</GenerateDebugInformation>
+      <OptimizeReferences>true</OptimizeReferences>
+      <EnableCOMDATFolding>true</EnableCOMDATFolding>
+      <TargetMachine>MachineX86</TargetMachine>
+    </Link>
+  </ItemDefinitionGroup>
+  <ItemGroup>
+    <ClCompile Include="Framework.cpp" />
+    <ClCompile Include="is_virtual.cpp" />
+    <ClCompile Include="main.cpp" />
+    <ClCompile Include="test.cpp" />
+    <ClCompile Include="test_args.cpp" />
+    <ClCompile Include="test_array.cpp" />
+    <ClCompile Include="test_autoptr.cpp" />
+    <ClCompile Include="test_cfuncs.cpp" />
+    <ClCompile Include="test_class_args.cpp" />
+    <ClCompile Include="test_constref_params.cpp" />
+    <ClCompile Include="test_cv_funcs.cpp" />
+    <ClCompile Include="test_do.cpp" />
+    <ClCompile Include="test_dontcare.cpp" />
+    <ClCompile Include="test_except.cpp" />
+    <ClCompile Include="test_exception_quality.cpp" />
+    <ClCompile Include="test_filter.cpp" />
+    <ClCompile Include="test_inparam.cpp" />
+    <ClCompile Include="test_membermock.cpp" />
+    <ClCompile Include="test_mi.cpp" />
+    <ClCompile Include="test_nevercall.cpp" />
+    <ClCompile Include="test_optional.cpp" />
+    <ClCompile Include="test_outparam.cpp" />
+    <ClCompile Include="test_overload.cpp" />
+    <ClCompile Include="test_ref_args.cpp" />
+    <ClCompile Include="test_regression_arg_count.cpp" />
+    <ClCompile Include="test_retval.cpp" />
+    <ClCompile Include="test_com_support_stdcall.cpp" />
+    <ClCompile Include="test_transaction.cpp" />
+    <ClCompile Include="test_zombie.cpp" />
+  </ItemGroup>
+  <ItemGroup>
+    <ClInclude Include="Framework.h" />
+  </ItemGroup>
+  <Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" />
+  <ImportGroup Label="ExtensionTargets">
+    <Import Project="$(VCTargetsPath)\BuildCustomizations\masm.targets" />
+  </ImportGroup>
+</Project>
\ No newline at end of file
diff --git a/extlibs/hippomocks-master/HippoMocksTest/is_virtual.cpp b/extlibs/hippomocks-master/HippoMocksTest/is_virtual.cpp
new file mode 100644 (file)
index 0000000..5632530
--- /dev/null
@@ -0,0 +1,65 @@
+#include "Framework.h"
+#include <iostream>
+#include "hippomocks.h"
+
+class IL { 
+public:
+       void f() { std::cout << "0" << std::endl; }
+       virtual void g() { std::cout << "1" << std::endl; }
+       virtual void h() { std::cout << "2" << std::endl; }
+};
+
+class SecondBase
+{
+public:
+       virtual void k() { std::cout << "3" << std::endl; }
+       int x;
+};
+
+class ThirdBase
+{
+public:
+       virtual void l() { std::cout << "4" << std::endl; }
+       virtual void m() { std::cout << "4" << std::endl; }
+};
+
+class ILD : public IL, public SecondBase, public ThirdBase
+{
+};
+
+TEST(checkNonVirtual) 
+{
+       EQUALS(HippoMocks::virtual_index(&ILD::f).first, -1);
+}
+
+TEST(checkFirstVirtual) 
+{
+       EQUALS(HippoMocks::virtual_index(&ILD::g).first, 0);
+       EQUALS(HippoMocks::virtual_index(&ILD::g).second, 0);
+}
+
+TEST(checkSecondVirtual) 
+{
+       EQUALS(HippoMocks::virtual_index(&ILD::h).first, 0);
+       EQUALS(HippoMocks::virtual_index(&ILD::h).second, 1);
+}
+
+TEST(checkSecondBaseFirstVirtual) 
+{
+       EQUALS(HippoMocks::virtual_index((void (ILD::*)())&ILD::k).first, 1);
+       EQUALS(HippoMocks::virtual_index((void (ILD::*)())&ILD::k).second, 0);
+}
+
+TEST(checkThirdBaseSecondVirtualAfterInt) 
+{
+       EQUALS(HippoMocks::virtual_index((void (ILD::*)())&ILD::m).first, 3);
+       EQUALS(HippoMocks::virtual_index((void (ILD::*)())&ILD::m).second, 1);
+}
+
+TEST(checkPointerConversionIsOk) 
+{
+       void (ThirdBase::*f)() = &ThirdBase::m;
+       EQUALS(HippoMocks::virtual_index((void (ILD::*)())f).first, 3);
+       EQUALS(HippoMocks::virtual_index((void (ILD::*)())f).second, 1);
+}
+
diff --git a/extlibs/hippomocks-master/HippoMocksTest/main.cpp b/extlibs/hippomocks-master/HippoMocksTest/main.cpp
new file mode 100644 (file)
index 0000000..d0f4516
--- /dev/null
@@ -0,0 +1,8 @@
+#include "Framework.h"\r
+\r
+int main(int , char **) {\r
+    return TestRegistry::Instance().RunTests();\r
+}\r
+\r
+\r
+\r
diff --git a/extlibs/hippomocks-master/HippoMocksTest/makefile b/extlibs/hippomocks-master/HippoMocksTest/makefile
new file mode 100644 (file)
index 0000000..2a0d46e
--- /dev/null
@@ -0,0 +1,25 @@
+CXX?=g++
+STDVER?=c++98
+WARNFLAGS = -Wall -Wextra -pedantic -Wno-long-long
+CXXOPTS = -I../HippoMocks/ $(WARNFLAGS) -g
+TARGET = $(PREFIX)test.exe 
+
+OBJECTS = $(patsubst %,$(PREFIX)%,is_virtual.o test.o test_args.o test_array.o test_autoptr.o test_cfuncs.o test_class_args.o test_constref_params.o test_cv_funcs.o test_do.o test_dontcare.o test_except.o test_exception_quality.o test_filter.o test_inparam.o test_membermock.o test_mi.o test_nevercall.o test_optional.o test_outparam.o test_overload.o test_ref_args.o test_regression_arg_count.o test_retval.o test_transaction.o test_zombie.o Framework.o main.o)
+
+all: $(TARGETS)
+
+clean:
+       $(RM) $(OBJECTS) $(TARGETS) $(OBJECTS:%.o=%.d)
+
+runtest: $(TARGET)
+       ./$(TARGET)
+
+%.o: %.cpp makefile
+       $(CXX) $(CFLAGS) $(CXXOPTS) -std=$(STDVER) -c -o $@ $< -MMD -MP
+
+$(TARGET): $(OBJECTS)
+       $(CXX) $(CFLAGS) $(CXXOPTS) -std=$(STDVER) -o $@ $^
+
+-include $(OBJECTS:%.o=%.d)
+
+
diff --git a/extlibs/hippomocks-master/HippoMocksTest/test.cpp b/extlibs/hippomocks-master/HippoMocksTest/test.cpp
new file mode 100644 (file)
index 0000000..55ffed7
--- /dev/null
@@ -0,0 +1,124 @@
+#include "hippomocks.h"
+#include "Framework.h"
+
+class IA { 
+public:
+       virtual ~IA() {}
+       virtual void f() {}
+       virtual void g() = 0;
+};
+
+TEST (checkBaseCase)
+{
+       MockRepository mocks;
+       IA *iamock = mocks.Mock<IA>();
+       mocks.ExpectCall(iamock, IA::f);
+       mocks.ExpectCall(iamock, IA::g);
+       iamock->f();
+       iamock->g();
+}
+
+TEST (checkMultiCall)
+{
+       MockRepository mocks;
+       IA *iamock = mocks.Mock<IA>();
+       mocks.ExpectCall(iamock, IA::f);
+       mocks.ExpectCall(iamock, IA::g);
+       mocks.ExpectCall(iamock, IA::f);
+       iamock->f();
+       iamock->g();
+       iamock->f();
+}
+
+TEST (checkMultiCallNotCalled)
+{
+       bool exceptionCaught = false;
+       try {
+               MockRepository mocks;
+               IA *iamock = mocks.Mock<IA>();
+               mocks.ExpectCall(iamock, IA::f);
+               mocks.ExpectCall(iamock, IA::g);
+               mocks.ExpectCall(iamock, IA::f);
+               iamock->f();
+               iamock->g();
+       }
+       catch (HippoMocks::CallMissingException &) 
+       {
+               exceptionCaught = true;
+       }
+       CHECK(exceptionCaught);
+}
+
+TEST (checkMultiCallWrongOrder)
+{
+       MockRepository mocks;
+       IA *iamock = mocks.Mock<IA>();
+       mocks.ExpectCall(iamock, IA::f);
+       mocks.ExpectCall(iamock, IA::g);
+       mocks.ExpectCall(iamock, IA::f);
+       iamock->f();
+       bool exceptionCaught = false;
+       try {
+               iamock->f();
+       }
+       catch (HippoMocks::ExpectationException &) 
+       {
+               exceptionCaught = true;
+       }
+       CHECK(exceptionCaught);
+       mocks.reset();
+}
+
+TEST (checkExpectationsNotCompleted)
+{
+       bool exceptionCaught = false;
+       try {
+               MockRepository mocks;
+               IA *iamock = mocks.Mock<IA>();
+               mocks.ExpectCall(iamock, IA::f);
+               mocks.ExpectCall(iamock, IA::g);
+               iamock->f();
+       }
+       catch (HippoMocks::CallMissingException &) 
+       {
+               exceptionCaught = true;
+       }
+       CHECK(exceptionCaught);
+}
+
+TEST (checkOvercompleteExpectations)
+{
+       bool exceptionCaught = false;
+       try {
+               MockRepository mocks;
+               IA *iamock = mocks.Mock<IA>();
+               mocks.ExpectCall(iamock, IA::f);
+               mocks.ExpectCall(iamock, IA::g);
+               iamock->f();
+               iamock->g();
+               iamock->f();
+       }
+       catch (HippoMocks::ExpectationException &) 
+       {
+               exceptionCaught = true;
+       }
+       CHECK(exceptionCaught);
+}
+
+TEST (checkExpectationsAreInOrder)
+{
+       bool exceptionCaught = false;
+       try {
+               MockRepository mocks;
+               IA *iamock = mocks.Mock<IA>();
+               mocks.ExpectCall(iamock, IA::f);
+               mocks.ExpectCall(iamock, IA::g);
+               iamock->g();
+       }
+       catch (HippoMocks::ExpectationException &) 
+       {
+               exceptionCaught = true;
+       }
+       CHECK(exceptionCaught);
+}
+
diff --git a/extlibs/hippomocks-master/HippoMocksTest/test_args.cpp b/extlibs/hippomocks-master/HippoMocksTest/test_args.cpp
new file mode 100644 (file)
index 0000000..4e473ac
--- /dev/null
@@ -0,0 +1,39 @@
+#include "hippomocks.h"
+#include "Framework.h"
+
+class IB {
+public:
+       virtual ~IB() {}
+       virtual void f(int);
+       virtual void g(int) = 0;
+};
+
+TEST (checkArgumentsAccepted)
+{
+       MockRepository mocks;
+       IB *iamock = mocks.Mock<IB>();
+       mocks.ExpectCall(iamock, IB::f).With(1);
+       mocks.ExpectCall(iamock, IB::g).With(2);
+       iamock->f(1);
+       iamock->g(2);
+}
+
+TEST (checkArgumentsChecked)
+{
+       MockRepository mocks;
+       IB *iamock = mocks.Mock<IB>();
+       mocks.ExpectCall(iamock, IB::f).With(1);
+       mocks.ExpectCall(iamock, IB::g).With(1);
+       bool exceptionCaught = false;
+       try 
+       {
+               iamock->f(2);
+       }
+       catch (HippoMocks::ExpectationException)
+       {
+               exceptionCaught = true;
+       }
+       CHECK(exceptionCaught);
+       mocks.reset();
+}
+
diff --git a/extlibs/hippomocks-master/HippoMocksTest/test_array.cpp b/extlibs/hippomocks-master/HippoMocksTest/test_array.cpp
new file mode 100644 (file)
index 0000000..141dbcf
--- /dev/null
@@ -0,0 +1,21 @@
+#include "hippomocks.h"
+#include "Framework.h"
+
+class IArrayArgs {
+public:
+       virtual ~IArrayArgs() {}
+       virtual void f(std::string);
+       virtual void g(std::wstring) = 0;
+};
+
+TEST (checkArrayArgumentsAccepted)
+{
+       MockRepository mocks;
+       IArrayArgs *iamock = mocks.Mock<IArrayArgs>();
+       mocks.ExpectCall(iamock, IArrayArgs::f).With("Hello");
+       mocks.ExpectCall(iamock, IArrayArgs::g).With(L"World");
+       iamock->f("Hello");
+       iamock->g(L"World");
+}
+
+
diff --git a/extlibs/hippomocks-master/HippoMocksTest/test_autoptr.cpp b/extlibs/hippomocks-master/HippoMocksTest/test_autoptr.cpp
new file mode 100644 (file)
index 0000000..0ebd178
--- /dev/null
@@ -0,0 +1,69 @@
+#include "hippomocks.h"
+#include "Framework.h"
+#include <utility>
+using std::auto_ptr;
+
+class X {};
+
+class IQ {
+public:
+       virtual ~IQ() {}
+       virtual void f();
+       virtual auto_ptr<X> g();
+       virtual auto_ptr<IQ> getSelf();
+};
+
+TEST (checkAutoptrReturnable)
+{
+       X *_t = new X;
+
+       MockRepository mocks;
+       IQ *iamock = mocks.Mock<IQ>();
+       mocks.ExpectCall(iamock, IQ::g).Return(auto_ptr<X>(_t));
+       CHECK(_t == iamock->g().get());
+}
+
+TEST (checkAutoptrCanReturnMock)
+{
+       MockRepository mocks;
+       IQ *iamock = mocks.Mock<IQ>();
+       mocks.ExpectCall(iamock, IQ::getSelf).Return(auto_ptr<IQ>(iamock));
+       mocks.ExpectCallDestructor(iamock);
+       CHECK(iamock == iamock->getSelf().get());
+}
+
+TEST(checkCanDestroyMock)
+{
+       MockRepository mocks;
+       IQ *iamock = mocks.Mock<IQ>();
+       mocks.ExpectCallDestructor(iamock);
+       delete iamock;
+}
+
+TEST(checkAutoptrStability)
+{
+       int exceptionsCaught = 0;
+       try
+       {
+               MockRepository mocks;
+               try
+               {
+                       IQ *iamock = mocks.Mock<IQ>();
+                       auto_ptr<IQ> auto_ptr(iamock);
+                       mocks.ExpectCall(iamock, IQ::f);
+                       mocks.ExpectCallDestructor(iamock);
+                       throw 42;
+                       // implicit: destructor for iamock, that may not throw
+               }
+               catch(int)
+               {
+                       exceptionsCaught++;
+               }
+       }
+       catch(HippoMocks::ExpectationException)
+       {
+               exceptionsCaught++;
+       }
+       CHECK(exceptionsCaught == 2);
+}
+
diff --git a/extlibs/hippomocks-master/HippoMocksTest/test_cfuncs.cpp b/extlibs/hippomocks-master/HippoMocksTest/test_cfuncs.cpp
new file mode 100644 (file)
index 0000000..d472037
--- /dev/null
@@ -0,0 +1,45 @@
+#include "hippomocks.h"
+#include "Framework.h"
+
+// If it's not supported, then don't test it.
+#ifdef _HIPPOMOCKS__ENABLE_CFUNC_MOCKING_SUPPORT
+int a()
+{
+  return 1;
+}
+
+TEST (checkFunctionReplacedAndChecked)
+{
+       EQUALS(a(), 1);
+       MockRepository mocks;
+       mocks.ExpectCallFunc(a).Return(2);
+       EQUALS(a(), 2);
+}
+
+TEST (checkFunctionReturnedToOriginal)
+{
+       {
+               EQUALS(a(), 1);
+               MockRepository mocks;
+               mocks.ExpectCallFunc(a).Return(2);
+               EQUALS(a(), 2);
+       }
+       EQUALS(a(), 1);
+}
+
+#ifdef _WIN32
+#include <windows.h>
+TEST (checkCanMockGetSystemTime) {
+       MockRepository mocks;
+       SYSTEMTIME outtime;
+       outtime.wDay = 1;
+       SYSTEMTIME systime;
+       systime.wDay = 0;
+       mocks.ExpectCallFunc(GetSystemTime).With(Out(outtime));
+       GetSystemTime(&systime);
+       EQUALS(systime.wDay, 1);
+}
+#endif
+
+#endif
+
diff --git a/extlibs/hippomocks-master/HippoMocksTest/test_class_args.cpp b/extlibs/hippomocks-master/HippoMocksTest/test_class_args.cpp
new file mode 100644 (file)
index 0000000..22dac9c
--- /dev/null
@@ -0,0 +1,49 @@
+#include "hippomocks.h"
+#include "Framework.h"
+#include <string>
+
+// non-reference is bad, but should work
+class IC {
+public:
+       virtual ~IC() {}
+       virtual void f(std::string s);
+       virtual void g(std::string s) = 0;
+};
+
+TEST (checkClassArgumentsAccepted)
+{
+       MockRepository mocks;
+       IC *iamock = mocks.Mock<IC>();
+       mocks.OnCall(iamock, IC::f).With("hi");
+       mocks.OnCall(iamock, IC::g).With("bye");
+       iamock->f("hi");
+       iamock->g("bye");
+}
+
+TEST (checkClassArgumentsChecked)
+{
+       MockRepository mocks;
+       IC *iamock = mocks.Mock<IC>();
+       mocks.OnCall(iamock, IC::f).With("hi");
+       mocks.OnCall(iamock, IC::g).With("bye");
+       bool exceptionCaught = false;
+       try 
+       {
+               iamock->f("bye");
+       }
+       catch (HippoMocks::ExpectationException)
+       {
+               exceptionCaught = true;
+       }
+       CHECK(exceptionCaught);
+       mocks.reset();
+}
+
+TEST (checkClassArgumentsIgnored)
+{
+       MockRepository mocks;
+       IC *iamock = mocks.Mock<IC>();
+       mocks.OnCall(iamock, IC::f);
+       iamock->f("bye");
+}
+
diff --git a/extlibs/hippomocks-master/HippoMocksTest/test_com_support_stdcall.cpp b/extlibs/hippomocks-master/HippoMocksTest/test_com_support_stdcall.cpp
new file mode 100644 (file)
index 0000000..821eac4
--- /dev/null
@@ -0,0 +1,256 @@
+#include "Framework.h"
+#include <hippomocks.h>
+
+#ifdef _MSC_VER
+
+#include <ComSupport.h>
+#include <atlbase.h>
+#include <atlcom.h>
+
+
+namespace ComSupportTests
+{
+
+class ICom 
+{
+public:
+       virtual ~ICom() {}
+       virtual long __stdcall A(void) = 0;
+       virtual long __stdcall B(int) = 0;
+       virtual long __stdcall C(int, int) = 0;
+       virtual long __stdcall D(int, int, int) = 0;
+       virtual long __stdcall E(int, int, int, int) = 0;
+       virtual long __stdcall F(int, int, int, int, int) = 0;
+       virtual long __stdcall G(int, int, int, int, int, int) = 0;
+       virtual long __stdcall H(int, int, int, int, int, int, int) = 0;
+       virtual long __stdcall I(int, int, int, int, int, int, int, int) = 0;
+       virtual long __stdcall J(int, int, int, int, int, int, int, int, int ) = 0;
+       virtual long __stdcall K(int, int, int, int, int, int, int, int, int, int) = 0;
+       virtual long __stdcall L(int, int, int, int, int, int, int, int, int, int, int) = 0;
+       virtual long __stdcall M(int, int, int, int, int, int, int, int, int, int, int, int) = 0;
+       virtual long __stdcall N(int, int, int, int, int, int, int, int, int, int, int, int, int) = 0;
+       virtual long __stdcall O(int, int, int, int, int, int, int, int, int, int, int, int, int, int) = 0;
+       virtual long __stdcall P(int, int, int, int, int, int, int, int, int, int, int, int, int, int, int) = 0;
+};
+
+
+TEST(checkStdCallBase)
+{
+       MockRepository mocks;
+
+       ICom* ic = mocks.Mock<ICom>();
+       mocks.ExpectCall(ic, ICom::A)
+               .Return(1);
+
+       long actual = ic->A();
+       EQUALS(1, actual);
+}
+
+TEST(checkStdCallTemplateWithArgumentsImplementations)
+{
+       MockRepository mocks;
+
+       ICom* ic = mocks.Mock<ICom>();
+
+       mocks.ExpectCall(ic, ICom::B)
+               .Return(2);
+       mocks.ExpectCall(ic, ICom::C)
+               .Return(3);
+       mocks.ExpectCall(ic, ICom::D)
+               .Return(4);
+       mocks.ExpectCall(ic, ICom::E)
+               .Return(5);
+       mocks.ExpectCall(ic, ICom::F)
+               .Return(6);
+       mocks.ExpectCall(ic, ICom::G)
+               .Return(7);
+       mocks.ExpectCall(ic, ICom::H)
+               .Return(8);
+       mocks.ExpectCall(ic, ICom::I)
+               .Return(9);
+       mocks.ExpectCall(ic, ICom::J)
+               .Return(10);
+       mocks.ExpectCall(ic, ICom::K)
+               .Return(11);
+       mocks.ExpectCall(ic, ICom::L)
+               .Return(12);
+       mocks.ExpectCall(ic, ICom::M)
+               .Return(13);
+       mocks.ExpectCall(ic, ICom::N)
+               .Return(14);
+       mocks.ExpectCall(ic, ICom::O)
+               .Return(15);
+       mocks.ExpectCall(ic, ICom::P)
+               .Return(16);
+
+       ic->B(1);
+       ic->C(1,2);
+       ic->D(1,2,3);
+       ic->E(1,2,3,4);
+       ic->F(1,2,3,4,5);
+       ic->G(1,2,3,4,5,6);
+       ic->H(1,2,3,4,5,6,7);
+       ic->I(1,2,3,4,5,6,7,8);
+       ic->J(1,2,3,4,5,6,7,8,9);
+       ic->K(1,2,3,4,5,6,7,8,9,10);
+       ic->L(1,2,3,4,5,6,7,8,9,10,11);
+       ic->M(1,2,3,4,5,6,7,8,9,10,11,12);
+       ic->N(1,2,3,4,5,6,7,8,9,10,11,12,13);
+       ic->O(1,2,3,4,5,6,7,8,9,10,11,12,13,14);
+       ic->P(1,2,3,4,5,6,7,8,9,10,11,12,13,14,15);
+}
+
+TEST(checkUnexpectedMethodCallThrowsException)
+{
+       //MockRepository mocks;
+
+       //ICom* ic = mocks.Mock<ICom>();
+
+       //ic->A();
+}
+
+
+template <int s>
+int virtual_function_index(unsigned char* pb)
+{
+       if (*pb == 0xE9)
+       {
+               return virtual_function_index<0>(pb + 5 + *(unsigned int *)(pb+1));
+       }
+       if (!pb) return -1;
+       int pboff = -1;
+       if (pb[0] == 0x8b && pb[1] == 0x01) 
+       {       //mov eax, [ecx]
+               pboff = 2;
+       }
+       else if (pb[0] == 0x8b && pb[1] == 0x44 && pb[2] == 0x24 && pb[3] == 0x04 &&            //mov eax, [esp+arg0]
+               pb[4] == 0x8b && pb[5] == 0x00) //mov eax, [eax]
+       {                                                                               
+               pboff = 6;
+       }
+
+       if (pboff > 0) 
+       {
+               if (pb[pboff] == 0xff) 
+               {
+                       switch (pb[pboff + 1]) 
+                       {
+                       case 0x20:      //jmp dword ptr [eax]
+                               return 0;
+                       case 0x60:      //jmp dword ptr [eax+0xNN]
+                               return (((int)pb[pboff + 2]) & 0xff) / 4;
+                       case 0xa0:      //jmp dword ptr [eax+0xNNN]
+                               return (*(unsigned int*)(pb + (pboff + 2))) / 4;
+                       default:
+                               break;
+                       }
+               }
+       }
+       return -1;
+}
+
+template <class T>
+int VirtualFIndex(T func)
+{
+       union {
+               T pfn;
+               unsigned char* pb;
+       };
+       pfn = func;
+       return virtual_function_index<0>(pb);
+}
+
+struct AA
+{
+       virtual int Get1() = 0;
+       virtual int Get2() {}
+};
+
+//class with only 1 virtual method
+class IAA {
+public:
+       virtual int f(int a);
+};
+
+
+MIDL_INTERFACE("4745C05E-23E6-4c6d-B9F2-E483359A8B89")
+COMInterface1 : public IUnknown
+{
+public:
+    virtual HRESULT STDMETHODCALLTYPE getTObjectCount( 
+        /* [out] */ unsigned long *pCount) = 0;
+};
+typedef GUID ESTypeID;
+
+MIDL_INTERFACE("356D44D9-980A-4149-A586-C5CB8B191437")
+COMInterface2 : public IUnknown
+{
+public:
+    virtual HRESULT STDMETHODCALLTYPE getMappablePackages( 
+        /* [out] */ long *pSize,
+        /* [size_is][size_is][out] */ ESTypeID **pIdList) = 0;
+};
+#if 0
+TEST(EnsureThat_VirtualFunctionIndexGenericWorksforAllCases)
+{
+       EQUALS(1, VirtualFIndex(&AA::Get2));
+       EQUALS(0, VirtualFIndex(&AA::Get1));
+       EQUALS(0, VirtualFIndex(&IAA::f));
+               
+       EQUALS(0, VirtualFIndex(&IUnknown::QueryInterface));
+       EQUALS(1, VirtualFIndex(&IUnknown::AddRef));
+       EQUALS(2, VirtualFIndex(&IUnknown::Release));
+               
+       EQUALS(0, VirtualFIndex(&COMInterface1::QueryInterface));
+       EQUALS(1, VirtualFIndex(&COMInterface1::AddRef));
+       EQUALS(2, VirtualFIndex(&COMInterface1::Release));
+}
+#endif
+
+TEST(CheckThat_AddCommExpectations_Stubs_QueryInterface_AddRef_Release)
+{
+       MockRepository mocks; 
+       COMInterface1* deviceMock = mocks.Mock<COMInterface1>();
+
+       AddComExpectations(mocks, deviceMock);
+                       
+       {
+               CComPtr<IUnknown> pUnk = deviceMock; 
+               CComQIPtr<COMInterface1> pDevice = pUnk;
+
+               CHECK(pDevice == pUnk);
+
+               IUnknown* p = NULL;
+               pDevice->QueryInterface(__uuidof(IUnknown), (void**)&p);
+
+               CHECK(p == deviceMock);
+
+       }
+}
+
+TEST(CheckThat_ConnectComInterfaces_Stubs_QueryInterface_ToEachOther)
+{
+       MockRepository mocks; 
+       COMInterface1* deviceMock = mocks.Mock<COMInterface1>();
+       COMInterface2* devMappingMock = mocks.Mock<COMInterface2>();
+
+       ConnectComInterfaces(mocks, deviceMock, devMappingMock);
+
+       {
+               //Com objects can reach each other
+               CComQIPtr<COMInterface2> pDevMapping = deviceMock;
+                       
+               CHECK(pDevMapping != NULL);
+               CHECK(pDevMapping == devMappingMock);
+
+               CComQIPtr<COMInterface1> pDevNavigate = devMappingMock;
+
+               CHECK(pDevNavigate != NULL);
+               CHECK(pDevNavigate == deviceMock);
+       }
+
+}
+} // end of namespace
+
+#endif
diff --git a/extlibs/hippomocks-master/HippoMocksTest/test_constref_params.cpp b/extlibs/hippomocks-master/HippoMocksTest/test_constref_params.cpp
new file mode 100644 (file)
index 0000000..6e2eeb8
--- /dev/null
@@ -0,0 +1,54 @@
+#include "hippomocks.h"\r
+#include "Framework.h"\r
+#include <string>\r
+\r
+using HippoMocks::byRef;\r
+\r
+class IR {\r
+public:\r
+       virtual void func() = 0;\r
+};\r
+\r
+class R : public IR {\r
+public:\r
+       virtual void func() {}\r
+};\r
+\r
+class IM { \r
+public:\r
+       virtual ~IM() {}\r
+       virtual void d(std::string var) = 0;\r
+       virtual void e(const std::string &var) = 0;\r
+       virtual void f(const IR &arg) = 0;\r
+};\r
+\r
+TEST (checkTemporaryClassParam)\r
+{\r
+  MockRepository mocks;\r
+       IM *iamock = mocks.Mock<IM>();\r
+       mocks.ExpectCall(iamock, IM::d).With("Hello");\r
+       iamock->d("Hello");\r
+}\r
+\r
+TEST (checkConstRefClassParam)\r
+{\r
+       MockRepository mocks;\r
+       IM *iamock = mocks.Mock<IM>();\r
+       mocks.ExpectCall(iamock, IM::e).With("Hello");\r
+       iamock->e("Hello");\r
+}\r
+\r
+bool operator==(const IR &objA, const IR &objB)\r
+{\r
+       return &objA == &objB;\r
+}\r
+\r
+TEST (checkConstRefAbstractClassParam)\r
+{\r
+       R r;\r
+       MockRepository mocks;\r
+       IM *iamock = mocks.Mock<IM>();\r
+       mocks.ExpectCall(iamock, IM::f).With(byRef(r));\r
+       iamock->f(r);\r
+}\r
+\r
diff --git a/extlibs/hippomocks-master/HippoMocksTest/test_cv_funcs.cpp b/extlibs/hippomocks-master/HippoMocksTest/test_cv_funcs.cpp
new file mode 100644 (file)
index 0000000..ea43bd0
--- /dev/null
@@ -0,0 +1,26 @@
+#include "hippomocks.h"\r
+#include "Framework.h"\r
+\r
+class IM { \r
+public:\r
+       virtual ~IM() {}\r
+       virtual void e() = 0;\r
+       virtual void f() const = 0;\r
+       virtual void g() volatile = 0;\r
+       virtual void h() const volatile = 0;\r
+};\r
+\r
+TEST (checkCVQualifiedMemberFunctions)\r
+{\r
+       MockRepository mocks;\r
+       IM *iamock = mocks.Mock<IM>();\r
+       mocks.ExpectCall(iamock, IM::e);\r
+       mocks.ExpectCall(iamock, IM::f);\r
+       mocks.ExpectCall(iamock, IM::g);\r
+       mocks.ExpectCall(iamock, IM::h);\r
+       iamock->e();\r
+       iamock->f();\r
+       iamock->g();\r
+       iamock->h();\r
+}\r
+\r
diff --git a/extlibs/hippomocks-master/HippoMocksTest/test_do.cpp b/extlibs/hippomocks-master/HippoMocksTest/test_do.cpp
new file mode 100644 (file)
index 0000000..3d35ab9
--- /dev/null
@@ -0,0 +1,104 @@
+#include <string>\r
+#include "hippomocks.h"\r
+#include "Framework.h"\r
+\r
+using HippoMocks::byRef;\r
+\r
+class IDoFunctor { \r
+public:\r
+       virtual ~IDoFunctor() {}\r
+       virtual void a(std::string arg) = 0;\r
+};\r
+\r
+#if __cplusplus > 199711L\r
+TEST (checkDoFunctorCanBeLambdaWithContent)\r
+{\r
+       MockRepository mocks;\r
+       IDoFunctor *iamock = mocks.Mock<IDoFunctor>();\r
+  {\r
+    std::string value = "Hello World";\r
+    mocks.ExpectCall(iamock, IDoFunctor::a).Do([=](std::string arg){\r
+      CHECK(arg == value);\r
+    });\r
+  }\r
+\r
+  iamock->a("Hello World");\r
+}\r
+#endif\r
+\r
+class II { \r
+public:\r
+       virtual ~II() {}\r
+       virtual void f() {}\r
+       virtual void g() = 0;\r
+};\r
+\r
+bool checked;\r
+void setChecked() { checked = true; }\r
+\r
+class functorClass {\r
+public:\r
+       functorClass() : calls(0) {}\r
+       int calls;\r
+       void operator()() { ++calls; }\r
+};\r
+\r
+TEST (checkFunctorsCalled)\r
+{\r
+       MockRepository mocks;\r
+       II *iamock = mocks.Mock<II>();\r
+       mocks.ExpectCall(iamock, II::f).Do(setChecked);\r
+       mocks.OnCall(iamock, II::g).Do(setChecked);\r
+       checked = false;\r
+       iamock->g();\r
+       CHECK(checked == true);\r
+       checked = false;\r
+       iamock->f();\r
+       CHECK(checked == true);\r
+       checked = false;\r
+       iamock->g();\r
+       CHECK(checked == true);\r
+}\r
+\r
+TEST (checkFunctorObjectCalled)\r
+{\r
+       MockRepository mocks;\r
+       II *iamock = mocks.Mock<II>();\r
+       functorClass obj;\r
+       mocks.ExpectCall(iamock, II::f).Do(byRef(obj));\r
+       mocks.OnCall(iamock, II::g).Do(byRef(obj));\r
+       CHECK(obj.calls == 0);\r
+       iamock->g();\r
+       CHECK(obj.calls == 1);\r
+       iamock->f();\r
+       CHECK(obj.calls == 2);\r
+       iamock->g();\r
+       CHECK(obj.calls == 3);\r
+}\r
+\r
+class functorByVal {\r
+public:\r
+  functorByVal(int &count) : count(count) {}\r
+  void operator()() { count++; }\r
+  int &count;\r
+private:\r
+  functorByVal &operator=(const functorByVal&); // Silence VS\r
+};\r
+\r
+TEST (checkFunctorObjectByvalCalled)\r
+{\r
+  int count = 0;\r
+       MockRepository mocks;\r
+       II *iamock = mocks.Mock<II>();\r
+       mocks.ExpectCall(iamock, II::f).Do(functorByVal(count));\r
+       mocks.OnCall(iamock, II::g).Do(functorByVal(count));\r
+       CHECK(count == 0);\r
+       iamock->g();\r
+       CHECK(count == 1);\r
+       iamock->f();\r
+       CHECK(count == 2);\r
+       iamock->g();\r
+       CHECK(count == 3);\r
+}\r
+\r
+\r
diff --git a/extlibs/hippomocks-master/HippoMocksTest/test_dontcare.cpp b/extlibs/hippomocks-master/HippoMocksTest/test_dontcare.cpp
new file mode 100644 (file)
index 0000000..82065af
--- /dev/null
@@ -0,0 +1,29 @@
+#include "Framework.h"
+#include "hippomocks.h"
+
+class IZ { 
+public:
+       virtual ~IZ() {}
+};
+
+class IY {
+public:
+       virtual bool test(int a, IZ &b);
+};
+
+bool operator==(const IZ &, const IZ &)
+{
+       return false;
+}
+
+TEST (checkDontcareIsIgnored)
+{
+       MockRepository mocks;
+       IY *iamock = mocks.Mock<IY>();
+       mocks.OnCall(iamock, IY::test).Return(false);
+       mocks.OnCall(iamock, IY::test).With(42, _).Return(true);
+       IZ iz;
+       EQUALS(true, iamock->test(42, iz));
+       EQUALS(false, iamock->test(40, iz));
+}
+
diff --git a/extlibs/hippomocks-master/HippoMocksTest/test_except.cpp b/extlibs/hippomocks-master/HippoMocksTest/test_except.cpp
new file mode 100644 (file)
index 0000000..7644174
--- /dev/null
@@ -0,0 +1,87 @@
+#include "hippomocks.h"
+#include "Framework.h"
+
+// For obvious reasons, the Throw is not present when you disable exceptions.
+#ifndef HM_NO_EXCEPTIONS
+class IE {
+public:
+       virtual ~IE() {}
+       virtual int f();
+       virtual std::string g() = 0;
+};
+
+TEST (checkPrimitiveExceptionAcceptedAndThrown)
+{
+       MockRepository mocks;
+       IE *iamock = mocks.Mock<IE>();
+       mocks.ExpectCall(iamock, IE::f).Throw(42);
+       bool exceptionCaught = false;
+       try 
+       {
+               iamock->f();
+       }
+       catch(int a)
+       {
+               CHECK(a == 42);
+               exceptionCaught = true;
+       }
+       CHECK(exceptionCaught);
+}
+
+class SomeException : public std::exception {
+private:
+       const char *text;
+public:
+       SomeException(const char *txt) : text(txt) {}
+       const char *what() const throw() { return text; }
+};
+
+TEST (checkClassTypeExceptionWithContent)
+{
+       const char *sText = "someText";
+       MockRepository mocks;
+       IE *iamock = mocks.Mock<IE>();
+       mocks.ExpectCall(iamock, IE::f).Throw(SomeException(sText));
+       bool exceptionCaught = false;
+       try 
+       {
+               iamock->f();
+       }
+       catch(SomeException &a)
+       {
+               CHECK(a.what() == sText);
+               exceptionCaught = true;
+       }
+       CHECK(exceptionCaught);
+}
+
+TEST(checkMockRepoVerifyDoesNotThrowDuringException)
+{
+       bool exceptionCaught = false;
+       try
+       {
+               MockRepository mocks;
+               IE *iamock = mocks.Mock<IE>();
+               mocks.ExpectCall(iamock, IE::f);
+       }
+       catch (HippoMocks::CallMissingException &)
+       {
+               exceptionCaught = true;
+       }
+       CHECK(exceptionCaught);
+       exceptionCaught = false;
+       try
+       {
+               MockRepository mocks;
+               IE *iamock = mocks.Mock<IE>();
+               mocks.ExpectCall(iamock, IE::f);
+               throw 42;
+       }
+       catch (int)
+       {
+               exceptionCaught = true;
+       }
+       CHECK(exceptionCaught);
+}
+#endif
+
diff --git a/extlibs/hippomocks-master/HippoMocksTest/test_exception_quality.cpp b/extlibs/hippomocks-master/HippoMocksTest/test_exception_quality.cpp
new file mode 100644 (file)
index 0000000..b7627fc
--- /dev/null
@@ -0,0 +1,182 @@
+#include "Framework.h"
+#include "hippomocks.h"
+#include <stdio.h>
+
+struct X {};
+
+bool operator==(const X &, const X &)
+{
+       return true;
+}
+
+class IS {
+public:
+       virtual ~IS() {}
+       virtual int f() { return 1; }
+       virtual int g(int, int) { return 2; }
+       virtual void h() = 0;
+       virtual void i(int, const X &) = 0;
+};
+
+TEST (checkNoResultContainsFuncName)
+{
+       bool exceptionCaught = false;
+       MockRepository mocks;
+       IS *iamock = mocks.Mock<IS>();
+       mocks.ExpectCall(iamock, IS::f);
+       try {
+               iamock->f();
+       } catch(HippoMocks::NoResultSetUpException &ex) {
+               exceptionCaught = true;
+               CHECK(strstr(ex.what(), "IS::f") != NULL);
+       }
+       CHECK(exceptionCaught);
+}
+
+TEST (checkNoResultContainsBlankArgSpec)
+{
+       bool exceptionCaught = false;
+       MockRepository mocks;
+       IS *iamock = mocks.Mock<IS>();
+       mocks.ExpectCall(iamock, IS::g);
+       try {
+               iamock->g(1,2);
+       } catch(HippoMocks::NoResultSetUpException &ex) {
+               exceptionCaught = true;
+               CHECK(strstr(ex.what(), "IS::g") != NULL);
+               CHECK(strstr(ex.what(), "(...)") != NULL);
+       }
+       CHECK(exceptionCaught);
+}
+
+TEST (checkNoResultContainsActualArgSpec)
+{
+       bool exceptionCaught = false;
+       MockRepository mocks;
+       IS *iamock = mocks.Mock<IS>();
+       mocks.ExpectCall(iamock, IS::g).With(1,2);
+       try {
+               iamock->g(1,2);
+       } catch(HippoMocks::NoResultSetUpException &ex) {
+               exceptionCaught = true;
+               CHECK(strstr(ex.what(), "IS::g") != NULL);
+               CHECK(strstr(ex.what(), "(1,2)") != NULL);
+       }
+       CHECK(exceptionCaught);
+}
+
+TEST (checkNoResultContainsActualUnprintableArgSpec)
+{
+       bool exceptionCaught = false;
+       MockRepository mocks;
+       IS *iamock = mocks.Mock<IS>();
+       mocks.NeverCall(iamock, IS::i).With(42, X());
+       try {
+               iamock->h();
+       } catch(HippoMocks::NotImplementedException &ex) {
+               exceptionCaught = true;
+               CHECK(strstr(ex.what(), "IS::i") != NULL);
+               CHECK(strstr(ex.what(), "(42,??\?)") != NULL);
+       }
+       CHECK(exceptionCaught);
+}
+
+TEST (checkNoResultDoesNotComplainIfNotCalled)
+{
+       MockRepository mocks;
+       IS *iamock = mocks.Mock<IS>();
+       mocks.OnCall(iamock, IS::g).With(1,2);
+       mocks.OnCall(iamock, IS::g).With(3,4).Return(42);
+       iamock->g(3,4);
+}
+
+TEST(checkNotImplementedExceptionToContainInfo)
+{
+       bool exceptionCaught = false;
+       MockRepository mocks;
+       mocks.autoExpect = false;
+       IS *ismock = mocks.Mock<IS>();
+       mocks.ExpectCall(ismock, IS::f).Return(1);
+       mocks.OnCall(ismock, IS::f).Return(2);
+       mocks.ExpectCall(ismock, IS::g).With(1,2).Return(2);
+       mocks.OnCall(ismock, IS::g).Return(3);
+       mocks.NeverCall(ismock, IS::g).With(3,4);
+
+       try
+       {
+               ismock->h();
+       }
+       catch (HippoMocks::NotImplementedException &ex)
+       {
+               CHECK(strstr(ex.what(), "Expectation for IS::f()") != NULL);
+               CHECK(strstr(ex.what(), "Result set for IS::f()") != NULL);
+               CHECK(strstr(ex.what(), "Expectation for IS::g(1,2)") != NULL);
+               CHECK(strstr(ex.what(), "Result set for IS::g(...)") != NULL);
+               CHECK(strstr(ex.what(), "Result set for IS::g(3,4)") != NULL);
+               CHECK(strstr(ex.what(), __FILE__) != NULL);
+               exceptionCaught = true;
+       }
+       mocks.reset();
+       CHECK(exceptionCaught);
+}
+
+TEST(checkExpectationExceptionToContainInfo)
+{
+       bool exceptionCaught = false;
+       MockRepository mocks;
+       mocks.autoExpect = false;
+       IS *ismock = mocks.Mock<IS>();
+       mocks.ExpectCall(ismock, IS::f).Return(1);
+       mocks.OnCall(ismock, IS::f).Return(2);
+       mocks.ExpectCall(ismock, IS::g).With(1,2).Return(2);
+       mocks.OnCall(ismock, IS::g).With(2,3).Return(3);
+       mocks.NeverCall(ismock, IS::g).With(3,4);
+       mocks.NeverCall(ismock, IS::h);
+
+       try
+       {
+               ismock->g(0,1);
+       }
+       catch (HippoMocks::ExpectationException &ex)
+       {
+               CHECK(strstr(ex.what(), "Function IS::g(0,1) called") != NULL);
+               CHECK(strstr(ex.what(), "Expectation for IS::f()") != NULL);
+               CHECK(strstr(ex.what(), "Result set for IS::f()") != NULL);
+               CHECK(strstr(ex.what(), "Expectation for IS::g(1,2)") != NULL);
+               CHECK(strstr(ex.what(), "Result set for IS::g(2,3)") != NULL);
+               CHECK(strstr(ex.what(), "Result set for IS::g(3,4)") != NULL);
+               CHECK(strstr(ex.what(), "Result set for IS::h()") != NULL);
+               CHECK(strstr(ex.what(), __FILE__) != NULL);
+               exceptionCaught = true;
+       }
+       mocks.reset();
+       CHECK(exceptionCaught);
+}
+
+TEST(checkCallMissingExceptionToContainInfo)
+{
+       bool exceptionCaught = false;
+       try
+       {
+               MockRepository mocks;
+               mocks.autoExpect = false;
+               IS *ismock = mocks.Mock<IS>();
+               mocks.ExpectCall(ismock, IS::f).Return(1);
+               mocks.OnCall(ismock, IS::f).Return(2);
+               mocks.ExpectCall(ismock, IS::g).With(1,2).Return(2);
+               mocks.OnCall(ismock, IS::g).Return(3);
+               mocks.NeverCall(ismock, IS::g).With(3,4);
+       }
+       catch (HippoMocks::CallMissingException &ex)
+       {
+               CHECK(strstr(ex.what(), "Expectation for IS::f()") != NULL);
+               CHECK(strstr(ex.what(), "Result set for IS::f()") != NULL);
+               CHECK(strstr(ex.what(), "Expectation for IS::g(1,2)") != NULL);
+               CHECK(strstr(ex.what(), "Result set for IS::g(...)") != NULL);
+               CHECK(strstr(ex.what(), "Result set for IS::g(3,4)") != NULL);
+               CHECK(strstr(ex.what(), __FILE__) != NULL);
+               exceptionCaught = true;
+       }
+       CHECK(exceptionCaught);
+}
+
diff --git a/extlibs/hippomocks-master/HippoMocksTest/test_filter.cpp b/extlibs/hippomocks-master/HippoMocksTest/test_filter.cpp
new file mode 100644 (file)
index 0000000..84ccc58
--- /dev/null
@@ -0,0 +1,32 @@
+#include "Framework.h"
+#include "hippomocks.h"
+
+class IAA { 
+public:
+       virtual int f(int a, int b, int c);
+};
+
+bool allEven(int a, int b, int c) { return (a % 2 == 0) && (b % 2 == 0) && (c % 2 == 0); }
+bool oeo(int a, int b, int c) { return (a % 2 == 1) && (b % 2 == 0) && (c % 2 == 1); }
+bool eod(int a, int b, int) { return (a % 2 == 0) && (b % 2 == 1); }
+bool never(int, int, int) { return false; }
+
+TEST (checkFilterIsApplied)
+{
+       MockRepository mocks;
+       IAA *iamock = mocks.Mock<IAA>();
+       mocks.OnCall(iamock, IAA::f).Return(4);
+       mocks.OnCall(iamock, IAA::f).Match(never).Return(3);
+       mocks.OnCall(iamock, IAA::f).Match(eod).Return(2);
+       mocks.OnCall(iamock, IAA::f).Match(oeo).Return(1);
+       mocks.OnCall(iamock, IAA::f).Match(allEven).Return(5);
+       EQUALS(5, iamock->f(0, 0, 0));
+       EQUALS(4, iamock->f(0, 0, 1));
+       EQUALS(2, iamock->f(0, 1, 0));
+       EQUALS(2, iamock->f(0, 1, 1));
+       EQUALS(4, iamock->f(1, 0, 0));
+       EQUALS(1, iamock->f(1, 0, 1));
+       EQUALS(4, iamock->f(1, 1, 0));
+       EQUALS(4, iamock->f(1, 1, 1));
+}
+
diff --git a/extlibs/hippomocks-master/HippoMocksTest/test_inparam.cpp b/extlibs/hippomocks-master/HippoMocksTest/test_inparam.cpp
new file mode 100644 (file)
index 0000000..17f5929
--- /dev/null
@@ -0,0 +1,62 @@
+#include <string>\r
+#include "hippomocks.h"\r
+#include "Framework.h"\r
+\r
+class IInParam { \r
+public:\r
+       virtual ~IInParam() {}\r
+       virtual void a(const std::string& in) = 0;\r
+       virtual void b(std::string* in) = 0;\r
+       virtual void c(const char* in) = 0;\r
+};\r
+\r
+TEST (checkInParamsAreFilledIn_ConstChar)\r
+{\r
+       MockRepository mocks;\r
+       IInParam *iamock = mocks.Mock<IInParam>();\r
+       std::string teststring;\r
+       mocks.ExpectCall(iamock, IInParam::a).With(In(teststring));\r
+       \r
+       iamock->a("Hello World");\r
+\r
+       CHECK(teststring == "Hello World");\r
+}\r
+\r
+TEST (checkInParamsAreFilledIn_String)\r
+{\r
+       MockRepository mocks;\r
+       IInParam *iamock = mocks.Mock<IInParam>();\r
+       std::string teststring;\r
+       mocks.ExpectCall(iamock, IInParam::a).With(In(teststring));\r
+       \r
+       std::string in("Hello World");\r
+       iamock->a(in);\r
+\r
+       CHECK(teststring == in);\r
+}\r
+\r
+TEST (checkInParamsAreFilledIn_PointerToString)\r
+{\r
+       MockRepository mocks;\r
+       IInParam *iamock = mocks.Mock<IInParam>();\r
+       std::string* teststring = NULL;\r
+       mocks.ExpectCall(iamock, IInParam::b).With(In(teststring));\r
+       \r
+       std::string in("Hello World");\r
+       iamock->b(&in);\r
+\r
+       CHECK(teststring == &in);\r
+}\r
+\r
+TEST (checkInParamsAreFilledIn_Char)\r
+{\r
+       MockRepository mocks;\r
+       IInParam *iamock = mocks.Mock<IInParam>();\r
+       const char* teststring = NULL;\r
+       mocks.ExpectCall(iamock, IInParam::c).With(In(teststring));\r
+       \r
+       const char* in = "Hello World";\r
+       iamock->c(in);\r
+\r
+       CHECK(strcmp(teststring, in) == 0);\r
+}\r
diff --git a/extlibs/hippomocks-master/HippoMocksTest/test_membermock.cpp b/extlibs/hippomocks-master/HippoMocksTest/test_membermock.cpp
new file mode 100644 (file)
index 0000000..acba6cf
--- /dev/null
@@ -0,0 +1,19 @@
+#include "hippomocks.h"\r
+#include "Framework.h"\r
+#include <string>\r
+\r
+class IT {\r
+public:\r
+       std::string text;\r
+       virtual std::string getText() { return text; }\r
+};\r
+\r
+TEST (checkMemberWorks)\r
+{\r
+       MockRepository mocks;\r
+       IT *iamock = mocks.Mock<IT>();\r
+       mocks.Member(iamock, &IT::text);\r
+       iamock->text = "helloworld";\r
+       EQUALS("helloworld", iamock->text);\r
+}\r
+\r
diff --git a/extlibs/hippomocks-master/HippoMocksTest/test_mi.cpp b/extlibs/hippomocks-master/HippoMocksTest/test_mi.cpp
new file mode 100644 (file)
index 0000000..f041337
--- /dev/null
@@ -0,0 +1,30 @@
+#include "hippomocks.h"\r
+#include "Framework.h"\r
+\r
+class BaseA { \r
+public:\r
+       virtual void a() = 0;\r
+};\r
+\r
+class BaseB { \r
+public:\r
+       virtual void b() = 0;\r
+};\r
+\r
+class ClassC : public BaseA, public BaseB { \r
+public:\r
+       virtual void c() = 0;\r
+};\r
+\r
+TEST (checkMICallsWork)\r
+{\r
+       MockRepository mocks;\r
+       ClassC *iamock = mocks.Mock<ClassC>();\r
+       mocks.ExpectCall(iamock, ClassC::a);\r
+       mocks.ExpectCall(iamock, ClassC::c);\r
+       mocks.ExpectCall(iamock, ClassC::b);\r
+       iamock->a();\r
+       iamock->c();\r
+       iamock->b();\r
+}\r
+\r
diff --git a/extlibs/hippomocks-master/HippoMocksTest/test_nevercall.cpp b/extlibs/hippomocks-master/HippoMocksTest/test_nevercall.cpp
new file mode 100644 (file)
index 0000000..f370af8
--- /dev/null
@@ -0,0 +1,81 @@
+#include "Framework.h"
+#include "hippomocks.h"
+
+class IR { 
+public:
+       virtual ~IR() {}
+       virtual void f() {}
+       virtual void g() {}
+       virtual int h() { return 0; }
+};
+
+TEST (checkNeverCallWorks)
+{
+       bool exceptionCaught = false;
+       MockRepository mocks;
+       IR *iamock = mocks.Mock<IR>();
+       Call &callF = mocks.ExpectCall(iamock, IR::f);
+       mocks.OnCall(iamock, IR::g);
+       mocks.NeverCall(iamock, IR::g).After(callF);
+       iamock->g();
+       iamock->g();
+       iamock->f();
+       try 
+       {
+               iamock->g();
+       }
+       catch (HippoMocks::ExpectationException &)
+       {
+               exceptionCaught = true;
+       }
+       CHECK(exceptionCaught);
+}
+
+TEST (checkNeverCallExceptionDetail)
+{
+       bool exceptionCaught = false;
+       MockRepository mocks;
+       IR *iamock = mocks.Mock<IR>();
+       mocks.NeverCall(iamock, IR::g);
+       try
+       {
+               iamock->g();
+       }
+       catch (HippoMocks::ExpectationException &ex)
+       {
+               exceptionCaught = true;
+               CHECK(strstr(ex.what(), "IR::g") != NULL);
+       }
+       CHECK(exceptionCaught);
+}
+
+TEST (checkInteractionBetweenCallTypesWorks)
+{
+       bool exceptionCaught = false;
+       MockRepository mocks;
+       mocks.autoExpect = false;
+       IR *iamock = mocks.Mock<IR>();
+       Call &callF = mocks.ExpectCall(iamock, IR::f);
+       Call &onCallG = mocks.OnCall(iamock, IR::g);
+       mocks.OnCall(iamock, IR::h).Return(2);
+       Call &returnThree = mocks.ExpectCall(iamock, IR::h).After(onCallG).Return(3);
+       Call &returnFour = mocks.ExpectCall(iamock, IR::h).After(callF).Return(4);
+       mocks.NeverCall(iamock, IR::h).After(returnThree).After(returnFour);
+       CHECK(iamock->h() == 2);
+       CHECK(iamock->h() == 2);
+       iamock->f();
+       CHECK(iamock->h() == 4);
+       CHECK(iamock->h() == 2);
+       iamock->g();
+       CHECK(iamock->h() == 3);
+       try 
+       {
+               iamock->h();
+       }
+       catch (HippoMocks::ExpectationException &)
+       {
+               exceptionCaught = true;
+       }
+       CHECK(exceptionCaught);
+}
+
diff --git a/extlibs/hippomocks-master/HippoMocksTest/test_optional.cpp b/extlibs/hippomocks-master/HippoMocksTest/test_optional.cpp
new file mode 100644 (file)
index 0000000..aa651a3
--- /dev/null
@@ -0,0 +1,40 @@
+#include "hippomocks.h"\r
+#include "Framework.h"\r
+\r
+class II { \r
+public:\r
+       virtual ~II() {}\r
+       virtual void f() {}\r
+       virtual void g() = 0;\r
+};\r
+\r
+TEST (checkBaseCaseOptionalOk)\r
+{\r
+       MockRepository mocks;\r
+       II *iamock = mocks.Mock<II>();\r
+       mocks.ExpectCall(iamock, II::f);\r
+       mocks.OnCall(iamock, II::g);\r
+       iamock->g();\r
+       iamock->f();\r
+}\r
+\r
+TEST (checkBaseCaseOptionalNotRequired)\r
+{\r
+       MockRepository mocks;\r
+       II *iamock = mocks.Mock<II>();\r
+       mocks.ExpectCall(iamock, II::f);\r
+       mocks.OnCall(iamock, II::g);\r
+       iamock->f();\r
+}\r
+\r
+TEST (checkBaseCaseOptionalTwiceIsOK)\r
+{\r
+       MockRepository mocks;\r
+       II *iamock = mocks.Mock<II>();\r
+       mocks.ExpectCall(iamock, II::f);\r
+       mocks.OnCall(iamock, II::g);\r
+       iamock->g();\r
+       iamock->f();\r
+       iamock->g();\r
+}\r
+\r
diff --git a/extlibs/hippomocks-master/HippoMocksTest/test_outparam.cpp b/extlibs/hippomocks-master/HippoMocksTest/test_outparam.cpp
new file mode 100644 (file)
index 0000000..21068ee
--- /dev/null
@@ -0,0 +1,65 @@
+#include <string>\r
+#include "hippomocks.h"\r
+#include "Framework.h"\r
+\r
+class IOutParam { \r
+public:\r
+       virtual ~IOutParam() {}\r
+       virtual void a(std::string& out) = 0;\r
+       virtual void b(std::string** out) = 0;\r
+       virtual void c(char** out) = 0;\r
+};\r
+\r
+TEST (checkOutParamsAreFilledIn_ConstChar)\r
+{\r
+       MockRepository mocks;\r
+       IOutParam *iamock = mocks.Mock<IOutParam>();\r
+       mocks.ExpectCall(iamock, IOutParam::a).With(Out("Hello World"));\r
+       \r
+       std::string out;\r
+       iamock->a(out);\r
+\r
+       CHECK(out == "Hello World");\r
+}\r
+\r
+TEST (checkOutParamsAreFilledIn_String)\r
+{\r
+       MockRepository mocks;\r
+       IOutParam *iamock = mocks.Mock<IOutParam>();\r
+       std::string teststring("Hello World");\r
+       mocks.ExpectCall(iamock, IOutParam::a).With(Out(teststring));\r
+       \r
+       std::string out;\r
+       iamock->a(out);\r
+\r
+       CHECK(out == teststring);\r
+}\r
+\r
+TEST (checkOutParamsAreFilledIn_PointerToString)\r
+{\r
+       MockRepository mocks;\r
+       IOutParam *iamock = mocks.Mock<IOutParam>();\r
+       std::string teststring("Hello World");\r
+  std::string *outString = new std::string(teststring);\r
+       mocks.ExpectCall(iamock, IOutParam::b).With(Out(outString));\r
+       \r
+       std::string* out = 0;\r
+       iamock->b(&out);\r
+\r
+       CHECK(*out == teststring);\r
+\r
+  delete outString;\r
+}\r
+\r
+TEST (checkOutParamsAreFilledIn_Char)\r
+{\r
+       MockRepository mocks;\r
+       IOutParam *iamock = mocks.Mock<IOutParam>();\r
+       const char* teststring = "Hello World";\r
+       mocks.ExpectCall(iamock, IOutParam::c).With(Out((char*)teststring));\r
+       \r
+       char* out = 0;\r
+       iamock->c(&out);\r
+\r
+       CHECK(strcmp(out, teststring) == 0);\r
+}\r
diff --git a/extlibs/hippomocks-master/HippoMocksTest/test_overload.cpp b/extlibs/hippomocks-master/HippoMocksTest/test_overload.cpp
new file mode 100644 (file)
index 0000000..a085082
--- /dev/null
@@ -0,0 +1,20 @@
+#include "hippomocks.h"\r
+#include "Framework.h"\r
+\r
+class IA { \r
+public:\r
+       virtual ~IA() {}\r
+       virtual void f() = 0;\r
+       virtual void f(int) = 0;\r
+};\r
+\r
+typedef void (IA::*mf)();\r
+\r
+TEST (checkOverloadWithCastWorks)\r
+{\r
+       MockRepository mocks;\r
+       IA *iamock = mocks.Mock<IA>();\r
+       mocks.ExpectCallOverload(iamock, (mf)&IA::f);\r
+       iamock->f();\r
+}\r
+\r
diff --git a/extlibs/hippomocks-master/HippoMocksTest/test_ref_args.cpp b/extlibs/hippomocks-master/HippoMocksTest/test_ref_args.cpp
new file mode 100644 (file)
index 0000000..297668e
--- /dev/null
@@ -0,0 +1,135 @@
+#include "hippomocks.h"
+#include "Framework.h"
+
+using HippoMocks::byRef;
+
+class IRefArg {
+public:
+       virtual void test() = 0;
+};
+
+class IK {
+public:
+       virtual ~IK() {}
+       virtual void f(int &);
+       virtual void g(int &) = 0;
+       virtual int &h() = 0;
+       virtual const std::string &k() = 0;
+       virtual void l(IRefArg &refArg) { refArg.test();}
+};
+
+TEST (checkRefArgumentsAccepted)
+{
+       MockRepository mocks;
+       IK *iamock = mocks.Mock<IK>();
+       int x = 42;
+       mocks.ExpectCall(iamock, IK::f).With(x);
+       mocks.ExpectCall(iamock, IK::g).With(x);
+       iamock->f(x);
+       iamock->g(x);
+}
+
+
+TEST (checkRefArgumentsChecked)
+{
+       MockRepository mocks;
+       IK *iamock = mocks.Mock<IK>();
+       int x = 1, y = 2;
+       mocks.ExpectCall(iamock, IK::f).With(x);
+       mocks.ExpectCall(iamock, IK::g).With(y);
+       bool exceptionCaught = false;
+       try 
+       {
+               iamock->f(y);
+       }
+       catch (HippoMocks::ExpectationException)
+       {
+               exceptionCaught = true;
+       }
+       CHECK(exceptionCaught);
+       mocks.reset();
+}
+
+void plusplus(int &x) 
+{ 
+       x++; 
+}
+void plusequals2(int &x) 
+{
+       x+=2; 
+}
+
+TEST (checkRefArgumentsPassedAsRef)
+{
+       MockRepository mocks;
+       IK *iamock = mocks.Mock<IK>();
+       int x = 1, y = 2;
+       mocks.ExpectCall(iamock, IK::f).Do(plusplus);
+       mocks.ExpectCall(iamock, IK::g).Do(plusequals2);
+       iamock->f(x);
+       iamock->g(y);
+       CHECK(x == 2);
+       CHECK(y == 4);
+}
+
+TEST (checkRefReturnValues)
+{
+       MockRepository mocks;
+       IK *iamock = mocks.Mock<IK>();
+       int x = 0;
+       mocks.ExpectCall(iamock, IK::h).Return(x);
+       mocks.ExpectCall(iamock, IK::k).Return("Hello World");
+       iamock->h() = 1;
+       EQUALS(iamock->k(), "Hello World");
+       EQUALS(x, 1);
+}
+
+bool operator==(const IRefArg &a, const IRefArg &b)
+{
+       return (&a == &b);
+}
+
+TEST (checkRefArgCheckedAsReference)
+{
+       MockRepository mocks;
+       IK *iamock = mocks.Mock<IK>();
+       IRefArg *refArg = mocks.Mock<IRefArg>();
+
+       mocks.ExpectCall(iamock, IK::l).With(byRef(*refArg));
+       iamock->l(*refArg);
+}
+
+class IB {
+public:
+   virtual ~IB() {}
+
+   virtual void doSomething() const = 0;
+
+};
+
+class IA {
+public:
+   virtual ~IA() {}
+
+   virtual const IB & getB() const = 0;
+   
+};
+
+TEST (checkRefReturnAsReference)
+{
+   MockRepository mocks;
+
+   IB * b = mocks.Mock<IB>();
+
+   IA * a = mocks.Mock<IA>();
+
+   mocks.OnCall(a, IA::getB).ReturnByRef(*b);
+   mocks.ExpectCall(b, IB::doSomething);
+
+   CHECK(b == &a->getB());
+   a->getB().doSomething();
+
+   mocks.VerifyAll();
+}
+
+
diff --git a/extlibs/hippomocks-master/HippoMocksTest/test_regression_arg_count.cpp b/extlibs/hippomocks-master/HippoMocksTest/test_regression_arg_count.cpp
new file mode 100644 (file)
index 0000000..c9373b7
--- /dev/null
@@ -0,0 +1,65 @@
+#include "Framework.h"\r
+#include "hippomocks.h"\r
+\r
+class IR { \r
+public:\r
+       virtual ~IR() {}\r
+       virtual void f0() {}\r
+       virtual void f1(int) {}\r
+       virtual void f2(int, int) {}\r
+       virtual void f3(int, int, int) {}\r
+       virtual void f4(int, int, int, int) {}\r
+       virtual void f5(int, int, int, int, int) {}\r
+       virtual void f6(int, int, int, int, int, int) {}\r
+       virtual void f7(int, int, int, int, int, int, int) {}\r
+       virtual void f8(int, int, int, int, int, int, int, int) {}\r
+       virtual void f9(int, int, int, int, int, int, int, int, int) {}\r
+       virtual void f10(int, int, int, int, int, int, int, int, int, int) {}\r
+       virtual void f11(int, int, int, int, int, int, int, int, int, int, int) {}\r
+       virtual void f12(int, int, int, int, int, int, int, int, int, int, int, int) {}\r
+       virtual void f13(int, int, int, int, int, int, int, int, int, int, int, int, int) {}\r
+       virtual void f14(int, int, int, int, int, int, int, int, int, int, int, int, int, int) {}\r
+       virtual void f15(int, int, int, int, int, int, int, int, int, int, int, int, int, int, int) {}\r
+       virtual void f16(int, int, int, int, int, int, int, int, int, int, int, int, int, int, int, int) {}\r
+};\r
+\r
+TEST (checkArgCount16SupportedAndWorking)\r
+{\r
+       MockRepository mocks;\r
+       IR *iamock = mocks.Mock<IR>();\r
+       mocks.ExpectCall(iamock, IR::f0);\r
+       mocks.ExpectCall(iamock, IR::f1).With(0);\r
+       mocks.ExpectCall(iamock, IR::f2).With(1,2);\r
+       mocks.ExpectCall(iamock, IR::f3).With(3,4,5);\r
+       mocks.ExpectCall(iamock, IR::f4).With(6,7,8,9);\r
+       mocks.ExpectCall(iamock, IR::f5).With(10,11,12,13,14);\r
+       mocks.ExpectCall(iamock, IR::f6).With(15,16,17,18,19,20);\r
+       mocks.ExpectCall(iamock, IR::f7).With(21,22,23,24,25,26,27);\r
+       mocks.ExpectCall(iamock, IR::f8).With(28,29,30,31,32,33,34,35);\r
+       mocks.ExpectCall(iamock, IR::f9).With(36,37,38,39,40,41,42,43,44);\r
+       mocks.ExpectCall(iamock, IR::f10).With(45,46,47,48,49,50,51,52,53,54);\r
+       mocks.ExpectCall(iamock, IR::f11).With(55,56,57,58,59,60,61,62,63,64,65);\r
+       mocks.ExpectCall(iamock, IR::f12).With(66,67,68,69,70,71,72,73,74,75,76,77);\r
+       mocks.ExpectCall(iamock, IR::f13).With(78,79,80,81,82,83,84,85,86,87,88,89,90);\r
+       mocks.ExpectCall(iamock, IR::f14).With(91,92,93,94,95,96,97,98,99,100,101,102,103,104);\r
+       mocks.ExpectCall(iamock, IR::f15).With(105,106,107,108,109,110,111,112,113,114,115,116,117,118,119);\r
+       mocks.ExpectCall(iamock, IR::f16).With(120,121,122,123,124,125,126,127,128,129,130,131,132,133,134,135);\r
+       iamock->f0();\r
+       iamock->f1(0);\r
+       iamock->f2(1,2);\r
+       iamock->f3(3,4,5);\r
+       iamock->f4(6,7,8,9);\r
+       iamock->f5(10,11,12,13,14);\r
+       iamock->f6(15,16,17,18,19,20);\r
+       iamock->f7(21,22,23,24,25,26,27);\r
+       iamock->f8(28,29,30,31,32,33,34,35);\r
+       iamock->f9(36,37,38,39,40,41,42,43,44);\r
+       iamock->f10(45,46,47,48,49,50,51,52,53,54);\r
+       iamock->f11(55,56,57,58,59,60,61,62,63,64,65);\r
+       iamock->f12(66,67,68,69,70,71,72,73,74,75,76,77);\r
+       iamock->f13(78,79,80,81,82,83,84,85,86,87,88,89,90);\r
+       iamock->f14(91,92,93,94,95,96,97,98,99,100,101,102,103,104);\r
+       iamock->f15(105,106,107,108,109,110,111,112,113,114,115,116,117,118,119);\r
+       iamock->f16(120,121,122,123,124,125,126,127,128,129,130,131,132,133,134,135);\r
+}\r
+\r
diff --git a/extlibs/hippomocks-master/HippoMocksTest/test_retval.cpp b/extlibs/hippomocks-master/HippoMocksTest/test_retval.cpp
new file mode 100644 (file)
index 0000000..5aa4eec
--- /dev/null
@@ -0,0 +1,48 @@
+#include "hippomocks.h"\r
+#include "Framework.h"\r
+\r
+class ID {\r
+public:\r
+       virtual ~ID() {}\r
+       virtual int f();\r
+       virtual std::string g() = 0;\r
+};\r
+\r
+TEST (checkRetvalAccepted)\r
+{\r
+       MockRepository mocks;\r
+       ID *iamock = mocks.Mock<ID>();\r
+       mocks.ExpectCall(iamock, ID::f).Return(1);\r
+       mocks.ExpectCall(iamock, ID::g).Return("fsck");\r
+       iamock->f();\r
+       iamock->g();\r
+}\r
+\r
+TEST (checkRetvalProper)\r
+{\r
+       MockRepository mocks;\r
+       ID *iamock = mocks.Mock<ID>();\r
+       mocks.ExpectCall(iamock, ID::f).Return(1);\r
+       mocks.ExpectCall(iamock, ID::g).Return("fsck");\r
+       CHECK(iamock->f() == 1);\r
+       CHECK(iamock->g() == "fsck");\r
+}\r
+\r
+bool replace_g_called = false;\r
+std::string replace_g() \r
+{\r
+       replace_g_called = true;\r
+       return "";\r
+}\r
+\r
+TEST (checkRetvalAfterDo)\r
+{\r
+       MockRepository mocks;\r
+       ID *iamock = mocks.Mock<ID>();\r
+       mocks.ExpectCall(iamock, ID::g).Do(replace_g).Return("fsck");\r
+       replace_g_called = false;\r
+       CHECK(iamock->g() == "fsck");\r
+       CHECK(replace_g_called);\r
+}\r
+\r
+\r
diff --git a/extlibs/hippomocks-master/HippoMocksTest/test_transaction.cpp b/extlibs/hippomocks-master/HippoMocksTest/test_transaction.cpp
new file mode 100644 (file)
index 0000000..4ba2674
--- /dev/null
@@ -0,0 +1,50 @@
+#include "hippomocks.h"
+#include "Framework.h"
+
+class IM { 
+public:
+       virtual ~IM() {}
+       virtual void begin() = 0;
+       virtual void end() = 0;
+       virtual void a() = 0;
+       virtual void b() = 0;
+};
+
+TEST (checkTransactionStyleWorks)
+{
+       MockRepository mocks;
+       IM *iamock = mocks.Mock<IM>();
+       mocks.autoExpect = false;
+       Call &beginCall = mocks.ExpectCall(iamock, IM::begin);
+       Call &aCall = mocks.ExpectCall(iamock, IM::a).After(beginCall);
+       Call &bCall = mocks.ExpectCall(iamock, IM::b).After(beginCall);
+       mocks.ExpectCall(iamock, IM::end).After(aCall).After(bCall);
+       iamock->begin();
+       iamock->b();
+       iamock->a();
+       iamock->end();
+}
+
+TEST (checkTransactionStyleFailIfOneSkipped)
+{
+       MockRepository mocks;
+       IM *iamock = mocks.Mock<IM>();
+       mocks.autoExpect = false;
+       Call &beginCall = mocks.ExpectCall(iamock, IM::begin);
+       Call &aCall = mocks.ExpectCall(iamock, IM::a).After(beginCall);
+       Call &bCall = mocks.ExpectCall(iamock, IM::b).After(beginCall);
+       mocks.ExpectCall(iamock, IM::end).After(aCall).After(bCall);
+       iamock->begin();
+       iamock->b();
+       bool exceptionCaught = false;
+       try {
+               iamock->end();
+       }
+       catch (HippoMocks::ExpectationException &) 
+       {
+               exceptionCaught = true;
+       }
+       CHECK(exceptionCaught);
+       mocks.reset();
+}
+
diff --git a/extlibs/hippomocks-master/HippoMocksTest/test_zombie.cpp b/extlibs/hippomocks-master/HippoMocksTest/test_zombie.cpp
new file mode 100644 (file)
index 0000000..f1e5422
--- /dev/null
@@ -0,0 +1,29 @@
+#include "hippomocks.h"
+#include "Framework.h"
+
+class IZombie { 
+public:
+       virtual ~IZombie() {}
+       virtual void a() = 0;
+};
+
+TEST (checkZombieCallsAreReported)
+{
+       bool exceptionCaught = false;
+       MockRepository mocks;
+       IZombie *iamock = mocks.Mock<IZombie>();
+       mocks.ExpectCall(iamock, IZombie::a);
+       mocks.ExpectCallDestructor(iamock);
+       iamock->a();
+       delete iamock;
+       try
+       {
+               iamock->a();
+       }
+       catch(HippoMocks::ZombieMockException &)
+       {
+               exceptionCaught = true;
+       }
+       CHECK(exceptionCaught);
+}
+
diff --git a/extlibs/hippomocks-master/README.md b/extlibs/hippomocks-master/README.md
new file mode 100644 (file)
index 0000000..20fb2fb
--- /dev/null
@@ -0,0 +1,5 @@
+Hippomocks
+==========
+
+Single-header mocking framework.
+
diff --git a/extlibs/hippomocks-master/makefile b/extlibs/hippomocks-master/makefile
new file mode 100644 (file)
index 0000000..25fe57d
--- /dev/null
@@ -0,0 +1,9 @@
+all:
+       $(MAKE) -C HippoMocksTest/ all
+
+clean:
+       $(MAKE) -C HippoMocksTest/ clean
+
+test:
+       $(MAKE) -C HippoMocksTest/ runtest
+