mirror of
https://github.com/roytam1/UXP.git
synced 2026-05-26 13:58:49 +00:00
Issue #1956 - Allow building with newer MSVC versions.
(P.S.: this rev is partly imported from upstream, without binaries. -Roy)
This commit is contained in:
@@ -17,12 +17,6 @@
|
||||
# define MOZ_INCLUDE_MOZALLOC_H_FROM_${HEADER}
|
||||
#endif
|
||||
|
||||
// Code built with !_HAS_EXCEPTIONS calls std::_Throw(), but the win2k
|
||||
// CRT doesn't export std::_Throw(). So we define it.
|
||||
#ifndef mozilla_Throw_h
|
||||
# include "mozilla/throw_msvc.h"
|
||||
#endif
|
||||
|
||||
#ifdef _DEBUG
|
||||
// From
|
||||
// http://msdn.microsoft.com/en-us/library/aa985982%28VS.80%29.aspx
|
||||
|
||||
@@ -16,10 +16,6 @@ if CONFIG['WRAP_STL_INCLUDES']:
|
||||
elif CONFIG['_MSC_VER']:
|
||||
DEFINES['_HAS_EXCEPTIONS'] = 0
|
||||
if CONFIG['MOZ_MSVC_STL_WRAP_RAISE']:
|
||||
EXPORTS.mozilla += [
|
||||
'msvc_raise_wrappers.h',
|
||||
'throw_msvc.h',
|
||||
]
|
||||
SOURCES += [
|
||||
'msvc_raise_wrappers.cpp',
|
||||
]
|
||||
|
||||
@@ -3,59 +3,18 @@
|
||||
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
||||
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
||||
|
||||
#include <stdio.h>
|
||||
|
||||
#include <exception>
|
||||
#include "mozalloc_abort.h"
|
||||
|
||||
__declspec(noreturn) static void abort_from_exception(const char* const which,
|
||||
const char* const what);
|
||||
static void
|
||||
abort_from_exception(const char* const which, const char* const what)
|
||||
{
|
||||
fprintf(stderr, "fatal: STL threw %s: ", which);
|
||||
mozalloc_abort(what);
|
||||
}
|
||||
|
||||
namespace std {
|
||||
|
||||
// NB: user code is not supposed to touch the std:: namespace. We're
|
||||
// doing this after careful review because we want to define our own
|
||||
// exception throwing semantics. Don't try this at home!
|
||||
|
||||
MFBT_API __declspec(noreturn) void
|
||||
moz_Xinvalid_argument(const char* what)
|
||||
{
|
||||
abort_from_exception("invalid_argument", what);
|
||||
}
|
||||
|
||||
MFBT_API __declspec(noreturn) void
|
||||
moz_Xlength_error(const char* what)
|
||||
{
|
||||
abort_from_exception("length_error", what);
|
||||
}
|
||||
|
||||
MFBT_API __declspec(noreturn) void
|
||||
moz_Xout_of_range(const char* what)
|
||||
{
|
||||
abort_from_exception("out_of_range", what);
|
||||
}
|
||||
|
||||
MFBT_API __declspec(noreturn) void
|
||||
moz_Xoverflow_error(const char* what)
|
||||
{
|
||||
abort_from_exception("overflow_error", what);
|
||||
}
|
||||
|
||||
MFBT_API __declspec(noreturn) void
|
||||
moz_Xruntime_error(const char* what)
|
||||
{
|
||||
abort_from_exception("runtime_error", what);
|
||||
}
|
||||
|
||||
MFBT_API __declspec(noreturn) void
|
||||
moz_Xbad_function_call()
|
||||
{
|
||||
static void __cdecl
|
||||
RaiseHandler(const std::exception& e)
|
||||
{
|
||||
abort_from_exception("bad_function_call", "bad function call");
|
||||
}
|
||||
mozalloc_abort(e.what());
|
||||
}
|
||||
|
||||
} // namespace std
|
||||
static struct StaticScopeStruct final {
|
||||
StaticScopeStruct() {
|
||||
std::exception::_Set_raise_handler(RaiseHandler);
|
||||
}
|
||||
} StaticScopeInvoke;
|
||||
|
||||
@@ -1,41 +0,0 @@
|
||||
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*-
|
||||
* vim: sw=4 ts=4 et :
|
||||
*/
|
||||
/* This Source Code Form is subject to the terms of the Mozilla Public
|
||||
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
||||
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
||||
|
||||
#ifndef mozilla_msvc_raise_wrappers_h
|
||||
#define mozilla_msvc_raise_wrappers_h
|
||||
|
||||
#ifdef _XSTDDEF_
|
||||
# error "Unable to wrap _RAISE(); CRT _RAISE() already defined"
|
||||
#endif
|
||||
#ifdef _XUTILITY_
|
||||
# error "Unable to wrap _X[exception](); CRT versions already declared"
|
||||
#endif
|
||||
#ifdef _FUNCTIONAL_
|
||||
# error "Unable to wrap _Xbad_function_call(); CRT version already declared"
|
||||
#endif
|
||||
|
||||
#include "mozilla/mozalloc_abort.h"
|
||||
|
||||
// xutility will declare the following functions in the std namespace.
|
||||
// We #define them to be named differently so we can ensure the exception
|
||||
// throwing semantics of these functions work exactly the way we want, by
|
||||
// defining our own versions in msvc_raise_wrappers.cpp.
|
||||
# define _Xinvalid_argument moz_Xinvalid_argument
|
||||
# define _Xlength_error moz_Xlength_error
|
||||
# define _Xout_of_range moz_Xout_of_range
|
||||
# define _Xoverflow_error moz_Xoverflow_error
|
||||
# define _Xruntime_error moz_Xruntime_error
|
||||
// used by <functional>
|
||||
# define _Xbad_function_call moz_Xbad_function_call
|
||||
|
||||
# include <xstddef>
|
||||
# include <xutility>
|
||||
|
||||
# undef _RAISE
|
||||
# define _RAISE(x) mozalloc_abort((x).what())
|
||||
|
||||
#endif // ifndef mozilla_msvc_raise_wrappers_h
|
||||
@@ -1,17 +0,0 @@
|
||||
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*-
|
||||
* vim: sw=4 ts=4 et :
|
||||
*/
|
||||
/* This Source Code Form is subject to the terms of the Mozilla Public
|
||||
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
||||
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
||||
|
||||
#ifndef mozilla_throw_msvc_h
|
||||
#define mozilla_throw_msvc_h
|
||||
|
||||
#if defined(MOZ_MSVC_STL_WRAP_RAISE)
|
||||
# include "msvc_raise_wrappers.h"
|
||||
#else
|
||||
# error "Unknown STL wrapper tactic"
|
||||
#endif
|
||||
|
||||
#endif // mozilla_throw_msvc_h
|
||||
+2
-30
@@ -265,35 +265,8 @@ case "$target" in
|
||||
|
||||
unset _MSVC_VER_FILTER
|
||||
|
||||
AC_CACHE_CHECK(for overridable _RAISE,
|
||||
ac_cv_have__RAISE,
|
||||
[
|
||||
AC_LANG_SAVE
|
||||
AC_LANG_CPLUSPLUS
|
||||
_SAVE_CXXFLAGS="$CXXFLAGS"
|
||||
CXXFLAGS="${CXXFLAGS} -D_HAS_EXCEPTIONS=0"
|
||||
AC_TRY_COMPILE([#include <xstddef>
|
||||
#undef _RAISE
|
||||
#define _RAISE(x) externallyDefinedFunction((x).what())
|
||||
#include <vector>
|
||||
],
|
||||
[std::vector<int> v; return v.at(1);],
|
||||
ac_cv_have__RAISE="no",
|
||||
ac_cv_have__RAISE="yes")
|
||||
CXXFLAGS="$_SAVE_CXXFLAGS"
|
||||
AC_LANG_RESTORE
|
||||
])
|
||||
if test "$ac_cv_have__RAISE" = "yes"; then
|
||||
WRAP_STL_INCLUDES=1
|
||||
MOZ_MSVC_STL_WRAP_RAISE=1
|
||||
AC_DEFINE(MOZ_MSVC_STL_WRAP_RAISE)
|
||||
else
|
||||
AC_MSG_ERROR([Gecko exception wrapping doesn't understand your your MSVC/SDK. Please file a bug describing this error and your build configuration.])
|
||||
fi
|
||||
|
||||
if test "$WRAP_STL_INCLUDES" = "1"; then
|
||||
STL_FLAGS="-I${DIST}/stl_wrappers"
|
||||
fi
|
||||
WRAP_STL_INCLUDES=1
|
||||
STL_FLAGS="-I${DIST}/stl_wrappers"
|
||||
CFLAGS="$CFLAGS -D_HAS_EXCEPTIONS=0"
|
||||
CXXFLAGS="$CXXFLAGS -D_HAS_EXCEPTIONS=0"
|
||||
else
|
||||
@@ -380,7 +353,6 @@ AC_SUBST(GNU_CXX)
|
||||
|
||||
AC_SUBST(STL_FLAGS)
|
||||
AC_SUBST(WRAP_STL_INCLUDES)
|
||||
AC_SUBST(MOZ_MSVC_STL_WRAP_RAISE)
|
||||
|
||||
dnl ========================================================
|
||||
dnl Checks for programs.
|
||||
|
||||
Reference in New Issue
Block a user