Arquivos
hhvm/hphp/util/assertions.cpp
T
Jordan DeLong ecc6a44af6 Hoist CheckType instructions above generic IncRef/LdMem @override-unit-failures
Because we normally find out about a type prediction at hhbc
bounderies, sometimes we generate type checks after we've already done
some generic operations on Cells.  This optimizes a specific pattern
of this that occurs in vector translations.  The code is set up as if
there is more than one since I have another case partially
implemented, but it currently hits issues in both linearscan and
codegen that need to be addressed first, so I split the diff for now.
2013-05-23 20:02:42 -07:00

42 linhas
1.6 KiB
C++

/*
+----------------------------------------------------------------------+
| HipHop for PHP |
+----------------------------------------------------------------------+
| Copyright (c) 2010- Facebook, Inc. (http://www.facebook.com) |
+----------------------------------------------------------------------+
| This source file is subject to version 3.01 of the PHP license, |
| that is bundled with this package in the file LICENSE, and is |
| available through the world-wide-web at the following url: |
| http://www.php.net/license/3_01.txt |
| If you did not receive a copy of the PHP license and are unable to |
| obtain it through the world-wide-web, please send a note to |
| license@php.net so we can mail you a copy immediately. |
+----------------------------------------------------------------------+
*/
#include "hphp/util/assertions.h"
namespace HPHP {
static AssertFailLogger s_logger;
// In builds without NDEBUG, we don't have __assert_fail from the GNU
// library, so we implement it here for always_assert().
void impl_assert_fail(const char* e, const char* file,
unsigned int line, const char* func) {
fprintf(stderr, "%s:%d: %s: assertion `%s' failed.", file, line, func, e);
std::abort();
}
void assert_fail_log(const char* title, const std::string& msg) {
if (s_logger) {
s_logger(title, msg);
}
fprintf(stderr, "Assertion failure: %s\n", msg.c_str());
}
void register_assert_fail_logger(AssertFailLogger l) {
s_logger = l;
}
}