kernel/eka/compsupp/symaehabi/cxxabi.h
changeset 0 a41df078684a
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/kernel/eka/compsupp/symaehabi/cxxabi.h	Mon Oct 19 15:55:17 2009 +0100
@@ -0,0 +1,272 @@
+/* Copyright (c) Edison Design Group, 2002-2004. */
+/*
+cxxabi.h -- Include file for IA-64 ABI entry points.
+*/
+
+#ifndef __CXXABI_H
+#define __CXXABI_H
+
+#ifndef __STDDEF_H
+#include <stddef.h>
+#endif  /* ifndef __STDDEF_H */
+
+namespace std
+{
+	#ifdef __EDG__
+	#pragma define_type_info
+	#endif
+
+	class type_info
+		{
+	public:
+		IMPORT_C virtual ~type_info();
+		IMPORT_C bool operator==(const type_info&) const;
+		IMPORT_C bool operator!=(const type_info&) const;
+		IMPORT_C bool before(const type_info&) const;
+		IMPORT_C const char* name() const;
+	private:
+		type_info(const type_info&);
+		type_info& operator=(const type_info&);
+	private:
+		const char *__type_name;
+		};
+
+	class exception
+		{
+	public:
+		IMPORT_C exception() throw ();
+		IMPORT_C exception(const exception&) throw ();
+		IMPORT_C exception& operator=(const exception&) throw ();
+		IMPORT_C virtual ~exception() throw ();
+		IMPORT_C virtual const char* what() const throw ();
+		};
+
+	class bad_exception : public exception
+		{
+	public:
+		bad_exception() throw ();
+		bad_exception(const bad_exception&) throw ();
+		bad_exception& operator=(const bad_exception&) throw ();
+
+		virtual ~bad_exception() throw ();
+
+		virtual const char* what() const throw ();
+		};
+
+	class bad_cast : public exception
+		{
+	public:
+		IMPORT_C bad_cast() throw ();
+		IMPORT_C bad_cast(const bad_cast&) throw ();
+		IMPORT_C bad_cast& operator=(const bad_cast&) throw ();
+		IMPORT_C virtual ~bad_cast() throw ();
+		IMPORT_C virtual const char* what() const throw ();
+		};
+
+	class bad_typeid : public exception
+		{
+	public:
+		IMPORT_C bad_typeid() throw ();
+		IMPORT_C bad_typeid(const bad_typeid&) throw ();
+		IMPORT_C bad_typeid& operator=(const bad_typeid&) throw ();
+		IMPORT_C virtual ~bad_typeid() throw ();
+		IMPORT_C virtual const char* what() const throw ();
+		};
+}
+
+
+
+#ifdef __EDG_RUNTIME_USES_NAMESPACES
+namespace __cxxabiv1 {
+  using namespace std;
+#endif /* ifdef __EDG_RUNTIME_USES_NAMESPACES */
+
+  /* type_info implementation classes */
+
+#pragma define_type_info
+  class __fundamental_type_info : public type_info {
+  public:
+    virtual ~__fundamental_type_info();
+  };
+
+#pragma define_type_info
+  class __array_type_info : public type_info {
+  public:
+    virtual ~__array_type_info();
+  };
+
+#pragma define_type_info
+  class __function_type_info : public type_info {
+  public:
+    virtual ~__function_type_info();
+  };
+
+#pragma define_type_info
+  class __enum_type_info : public type_info {
+  public:
+    virtual ~__enum_type_info();
+  };
+
+#pragma define_type_info
+  class __class_type_info : public type_info {
+  public:
+    virtual ~__class_type_info();
+  };
+
+#pragma define_type_info
+  class __si_class_type_info : public __class_type_info {
+  public:
+    virtual ~__si_class_type_info();
+    const __class_type_info *__base_type;
+  };
+
+  struct __base_class_type_info {
+    const __class_type_info *__base_type;
+    long __offset_flags;
+
+    enum __offset_flags_masks {
+      __virtual_mask = 0x1,
+      __public_mask = 0x2,
+      __offset_shift = 8
+    };
+  };
+
+#pragma define_type_info
+  class __vmi_class_type_info : public __class_type_info {
+  public:
+    virtual ~__vmi_class_type_info();
+    unsigned int __flags;
+    unsigned int __base_count;
+    __base_class_type_info __base_info[1];
+
+    enum __flags_masks {
+      __non_diamond_repeat_mask = 0x1,
+      __diamond_shaped_mask = 0x2
+    };
+  };
+
+#pragma define_type_info
+  class __pbase_type_info : public type_info {
+  public:
+    virtual ~__pbase_type_info();
+    unsigned int __flags;
+    const type_info *__pointee;
+    
+    enum __masks {
+      __const_mask = 0x1,
+      __volatile_mask = 0x2,
+      __restrict_mask = 0x4,
+      __incomplete_mask = 0x8,
+      __incomplete_class_mask = 0x10
+    };
+  }; 
+
+#pragma define_type_info
+  class __pointer_type_info : public __pbase_type_info {
+    virtual ~__pointer_type_info();
+  };
+
+#pragma define_type_info
+  class __pointer_to_member_type_info : public __pbase_type_info {
+    virtual ~__pointer_to_member_type_info();
+    const __class_type_info *__context;
+  };
+
+  extern "C" {
+    /* Pure virtual function calls. */
+    void __cxa_pure_virtual();
+
+    /* Constructors return void in the IA-64 ABI.  But in the ARM EABI
+       variant, they return void*. */
+#ifdef __EDG_IA64_ABI_VARIANT_CTORS_AND_DTORS_RETURN_THIS
+    typedef void* __ctor_dtor_return_type;
+#else /* ifndef __EDG_IA64_ABI_VARIANT_CTORS_AND_DTORS_RETURN_THIS */
+    typedef void __ctor_dtor_return_type;
+#endif /* ifdef __EDG_IA64_ABI_VARIANT_CTORS_AND_DTORS_RETURN_THIS */
+
+    /* Guard variables are 64 bits in the IA-64 ABI but only 32 bits in
+       the ARM EABI. */
+#ifdef __EDG_IA64_ABI_USE_INT_STATIC_INIT_GUARD
+    typedef int __guard_variable_type;
+#else /* ifndef __EDG_IA64_ABI_USE_INT_STATIC_INIT_GUARD */
+    typedef unsigned long long __guard_variable_type;
+#endif /* ifdef __EDG_IA64_ABI_USE_INT_STATIC_INIT_GUARD */
+  
+    /* Guard variables for the initialization of variables with static storage
+       duration. */
+    int __cxa_guard_acquire(__guard_variable_type *);
+    void __cxa_guard_release(__guard_variable_type *);
+    void __cxa_guard_abort(__guard_variable_type *);
+
+    /* Construction and destruction of arrays. */
+    void *__cxa_vec_new(size_t, size_t, size_t,
+                        __ctor_dtor_return_type (*)(void *),
+                        __ctor_dtor_return_type (*)(void *));
+    void *__cxa_vec_new2(size_t, size_t, size_t,
+                         __ctor_dtor_return_type (*)(void *),
+                         __ctor_dtor_return_type (*)(void *),
+                         void *(*)(size_t),
+                         void (*)(void *));
+    void *__cxa_vec_new3(size_t, size_t, size_t,
+                         __ctor_dtor_return_type (*)(void *),
+                         __ctor_dtor_return_type (*)(void *),
+                         void *(*)(size_t),
+                         void (*)(void *, size_t));
+#ifndef CXXABI_VEC_CTOR_RETURNS_VOID
+    /* The C++ ABI says this returns 'void' but we actually return
+       'void *' to remain compatible with RVCT 2.0 objects.  But the
+       compiler no longer assumes it. */
+    void *
+#else /* def CXXABI_VEC_CTOR_RETURNS_VOID */
+    void
+#endif /* def CXXABI_VEC_CTOR_RETURNS_VOID */
+         __cxa_vec_ctor(void *, size_t, size_t,
+                        __ctor_dtor_return_type (*)(void *),
+                        __ctor_dtor_return_type (*)(void *));
+    void __cxa_vec_dtor(void *, size_t, size_t,
+                        __ctor_dtor_return_type (*)(void *));
+    void __cxa_vec_cleanup(void *, size_t, size_t,
+                           __ctor_dtor_return_type (*)(void *));
+    void __cxa_vec_delete(void *, size_t, size_t,
+                          __ctor_dtor_return_type (*)(void *));
+    void __cxa_vec_delete2(void *, size_t, size_t,
+                           __ctor_dtor_return_type (*)(void *),
+                           void (*)(void *));
+    void __cxa_vec_delete3(void *, size_t, size_t,
+                           __ctor_dtor_return_type (*)(void *),
+                           void (*)(void *, size_t));
+#ifndef CXXABI_VEC_CTOR_RETURNS_VOID
+    /* The C++ ABI says this returns 'void' but we actually return
+       'void *' to remain compatible with RVCT 2.0 objects.  But the
+       compiler no longer assumes it. */
+    void *
+#else /* def CXXABI_VEC_CTOR_RETURNS_VOID */
+    void
+#endif /* def CXXABI_VEC_CTOR_RETURNS_VOID */
+         __cxa_vec_cctor(void *, void *, size_t, size_t, 
+                         __ctor_dtor_return_type (*)(void *, void *),
+                         __ctor_dtor_return_type (*)(void *));
+
+    /* Finalization. */
+    int __cxa_atexit(void (*)(void *), void *, void *);
+    void __cxa_finalize(void *);
+
+    /* Exception-handling support. */
+    void __cxa_bad_cast();
+    void __cxa_bad_typeid();
+
+    /* Demangling interface. */
+    char *__cxa_demangle(const char* __mangled_name,
+                         char        *__buf,
+                         size_t      *__n,
+                         int         *__status);
+
+  }  /* extern "C" */
+#ifdef __EDG_RUNTIME_USES_NAMESPACES
+}  /* namespace __cxxabiv1 */
+
+/* Create the "abi" namespace alias. */
+namespace abi = __cxxabiv1;
+#endif /* ifdef __EDG_RUNTIME_USES_NAMESPACES */
+
+#endif /* ifndef __CXXABI_H */