From 986d59e27e9bfd6a8fa77e83958e601498a8c567 Mon Sep 17 00:00:00 2001 From: Vadim Zeitlin Date: Tue, 29 Jan 2008 18:37:38 +0000 Subject: [PATCH] fix compilation with VC6 git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@51449 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775 --- include/wx/meta/if.h | 28 ++++++++++++++++++++++------ 1 file changed, 22 insertions(+), 6 deletions(-) diff --git a/include/wx/meta/if.h b/include/wx/meta/if.h index 64532e6e5d..9b533a5ab1 100644 --- a/include/wx/meta/if.h +++ b/include/wx/meta/if.h @@ -11,6 +11,8 @@ #ifndef _WX_META_IF_H_ #define _WX_META_IF_H_ +#include "wx/defs.h" + // NB: This code is intentionally written without partial templates // specialization, because some older compilers (notably VC6) don't // support it. @@ -18,10 +20,27 @@ namespace wxPrivate { -template struct wxIfImpl {}; +template +struct wxIfImpl + +// broken VC6 needs not just an incomplete template class declaration but a +// "skeleton" declaration of the specialized versions below as it apparently +// tries to look up the types in the generic template definition at some moment +// even though it ends up by using the correct specialization in the end -- but +// without this skeleton it doesn't recognize Result as a class at all below +#if defined(__VISUALC__) && !wxCHECK_VISUALC_VERSION(7) +{ + template struct Result + { + // intentionally don't define value here, this shouldn't be actually + // used, it's here just to work around a compiler bug + }; +} +#endif // VC++ <= 6 +; // specialization for true: -template<> +template <> struct wxIfImpl { template struct Result @@ -48,11 +67,8 @@ struct wxIfImpl // // See wxVector in vector.h for usage example template -struct wxIf +struct wxIf : wxPrivate::wxIfImpl::template Result { - typedef typename wxPrivate::wxIfImpl - ::template Result::value - value; }; #endif // _WX_META_IF_H_ -- 2.45.2