forked from OSchip/llvm-project
Fix invalid shift operator overload in Scalar
Summary: This also fixes an infinite recursion between lldb_private::operator>> () and Scalar::operator>>= (). Reviewers: sagar, tberghammer, labath Subscribers: lldb-commits Differential Revision: http://reviews.llvm.org/D16868 Patch by Marianne Mailhot-Sarrasin llvm-svn: 260239
This commit is contained in:
parent
470ee61e01
commit
b625a0e1bc
|
@ -1875,7 +1875,7 @@ Scalar::operator>>= (const Scalar& rhs)
|
|||
case e_sint128:
|
||||
case e_uint128:
|
||||
{
|
||||
m_integer >> *rhs.m_integer.getRawData();
|
||||
m_integer = m_integer.ashr(*(const uint_t *)rhs.m_integer.getRawData());
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -23,6 +23,7 @@ function(add_lldb_unittest test_name)
|
|||
llvm_config(${test_name} ${LLVM_LINK_COMPONENTS})
|
||||
endfunction()
|
||||
|
||||
add_subdirectory(Core)
|
||||
add_subdirectory(Editline)
|
||||
add_subdirectory(Expression)
|
||||
add_subdirectory(Host)
|
||||
|
|
|
@ -0,0 +1,3 @@
|
|||
add_lldb_unittest(CoreTests
|
||||
ScalarTest.cpp
|
||||
)
|
|
@ -0,0 +1,32 @@
|
|||
//===-- ScalarTest.cpp ------------------------------------------*- C++ -*-===//
|
||||
//
|
||||
// The LLVM Compiler Infrastructure
|
||||
//
|
||||
// This file is distributed under the University of Illinois Open Source
|
||||
// License. See LICENSE.TXT for details.
|
||||
//
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
#if defined(_MSC_VER) && (_HAS_EXCEPTIONS == 0)
|
||||
// Workaround for MSVC standard library bug, which fails to include <thread> when
|
||||
// exceptions are disabled.
|
||||
#include <eh.h>
|
||||
#endif
|
||||
|
||||
#include "gtest/gtest.h"
|
||||
|
||||
#include "lldb/Core/Scalar.h"
|
||||
|
||||
using namespace lldb_private;
|
||||
|
||||
TEST(ScalarTest, RightShiftOperator)
|
||||
{
|
||||
int a = 0x00001000;
|
||||
int b = 0xFFFFFFFF;
|
||||
int c = 4;
|
||||
Scalar a_scalar(a);
|
||||
Scalar b_scalar(b);
|
||||
Scalar c_scalar(c);
|
||||
ASSERT_EQ(a >> c, a_scalar >> c_scalar);
|
||||
ASSERT_EQ(b >> c, b_scalar >> c_scalar);
|
||||
}
|
Loading…
Reference in New Issue