epoc32/include/symcpp.h
branchSymbian3
changeset 4 837f303aceeb
parent 2 2fe1408b6811
--- a/epoc32/include/symcpp.h	Wed Mar 31 12:27:01 2010 +0100
+++ b/epoc32/include/symcpp.h	Wed Mar 31 12:33:34 2010 +0100
@@ -1,9 +1,9 @@
 // Copyright (c) 2005-2009 Nokia Corporation and/or its subsidiary(-ies).
 // All rights reserved.
 // This component and the accompanying materials are made available
-// under the terms of the License "Symbian Foundation License v1.0" to Symbian Foundation members and "Symbian Foundation End User License Agreement v1.0" to non-members
+// under the terms of the License "ARM EABI LICENCE.txt"
 // which accompanies this distribution, and is available
-// at the URL "http://www.symbianfoundation.org/legal/licencesv10.html".
+// in kernel/eka/compsupp.
 //
 // Initial Contributors:
 // Nokia Corporation - initial contribution.
@@ -11,17 +11,10 @@
 // Contributors:
 //
 // Description:
-// e32\compsupp\symcpp\symcpp.h
-// This is a preinclude file for the symbian cpp specific defintions from RVCT2.2 onwards
+// This is a preinclude file for the Symbian C++ specific defintions for RVCT.
 // 
 //
 
-#ifdef __ARMCC_VERSION
-#if (__ARMCC_VERSION < 220000 || __ARMCC_VERSION >= 230000)
-#error This instantiation of the build requires use of RVCT 2.2
-#endif
-#endif
-
 // Deal with operator new issues here
 #ifdef __cplusplus
 namespace std {
@@ -29,20 +22,35 @@
 	extern const nothrow_t nothrow;
 }
 
+#ifndef __OPERATOR_NEW_DECLARED__
+#define __OPERATOR_NEW_DECLARED__
+
+/* e32cmn.h also declares these five overloads, but slightly differently, so use
+ * __OPERATOR_NEW_DECLARED__ to avoid the declarations here (included by compiler-specific
+ * pre-include files) from conflicting.
+ */
+
 IMPORT_C void* operator new(unsigned int aSize) __NO_THROW;
 
 IMPORT_C void* operator new(unsigned int aSize,unsigned int aSize1) __NO_THROW;
 
 IMPORT_C void* operator new[](unsigned int aSize) __NO_THROW;
 
+IMPORT_C void operator delete(void* aPtr) __NO_THROW;
+
+IMPORT_C void operator delete[](void* aPtr) __NO_THROW;
+
+#endif // !__OPERATOR_NEW_DECLARED__
+
+
+/* The following four overloads are not declared by the generic Symbian headers, so
+ * do not need to be protected by __OPERATOR_NEW_DECLARED__.
+ */
+
 IMPORT_C void* operator new(unsigned int aSize, const std::nothrow_t& aNoThrow) __NO_THROW;
 
 IMPORT_C void* operator new[](unsigned int aSize, const std::nothrow_t& aNoThrow) __NO_THROW;
 
-IMPORT_C void operator delete(void* aPtr) __NO_THROW;
-
-IMPORT_C void operator delete[](void* aPtr) __NO_THROW;
-
 IMPORT_C void operator delete(void* aPtr, const std::nothrow_t& aNoThrow) __NO_THROW;
 
 IMPORT_C void operator delete[](void* aPtr, const std::nothrow_t& aNoThrow) __NO_THROW;