Containers (STL-compatible) StateMachines MessageBus and more for Embedded Systems. See www.etlcpp.com

Revision:
0:b47c2a7920c2
diff -r 000000000000 -r b47c2a7920c2 nullptr.h
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/nullptr.h	Fri Mar 16 16:34:18 2018 +0000
@@ -0,0 +1,97 @@
+///\file
+
+/******************************************************************************
+The MIT License(MIT)
+
+Embedded Template Library.
+https://github.com/ETLCPP/etl
+http://www.etlcpp.com
+
+Copyright(c) 2014 jwellbelove
+
+Permission is hereby granted, free of charge, to any person obtaining a copy
+of this software and associated documentation files(the "Software"), to deal
+in the Software without restriction, including without limitation the rights
+to use, copy, modify, merge, publish, distribute, sublicense, and / or sell
+copies of the Software, and to permit persons to whom the Software is
+furnished to do so, subject to the following conditions :
+
+The above copyright notice and this permission notice shall be included in all
+copies or substantial portions of the Software.
+
+THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.IN NO EVENT SHALL THE
+AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
+SOFTWARE.
+******************************************************************************/
+
+#ifndef __ETL_NULLPTR__
+#define __ETL_NULLPTR__
+
+#include "platform.h"
+
+///\defgroup nullptr nullptr
+/// A definition of nullptr for compilers that don't support it as standard.
+///\ingroup utilities
+
+#if (ETL_NO_NULLPTR_SUPPORT && !defined(ARDUINO))
+namespace std
+{
+  //*****************************************************************************
+  /// A null pointer type.
+  ///\ingroup nullptr
+  //*****************************************************************************
+  class nullptr_t
+  {
+  public:
+
+    // Convertible to any type of null non-member pointer.
+    template<typename T>
+    operator T*() const
+    {
+      return 0;
+    }
+
+    // Or any type of null member pointer.
+    template<typename ANYCLASS, typename T>
+    operator T ANYCLASS::*() const
+    {
+      return 0;
+    }
+
+  private:
+
+    // Can't take address of nullptr.
+    void operator&() const;
+  };
+
+  //*****************************************************************************
+  /// A null pointer.
+  ///\ingroup nullptr
+  //*****************************************************************************
+  const nullptr_t nullptr = {};
+}
+
+//*****************************************************************************
+/// A null pointer.
+///\ingroup nullptr
+//*****************************************************************************
+const std::nullptr_t nullptr = {};
+
+#else 
+    #include <cstddef>
+#endif
+
+#if defined(ARDUINO)
+namespace std
+{
+  typedef ::nullptr_t nullptr_t;
+}
+#endif
+
+#endif
+
+