8300260: Remove metaprogramming/isSame.hpp
Reviewed-by: tschatzl, kbarrett
This commit is contained in:
parent
a6c2a2ae79
commit
c8dd7583a9
@ -1,38 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (c) 2017, 2019, Oracle and/or its affiliates. All rights reserved.
|
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
|
||||||
*
|
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
|
||||||
* under the terms of the GNU General Public License version 2 only, as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This code is distributed in the hope that it will be useful, but WITHOUT
|
|
||||||
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
||||||
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
||||||
* version 2 for more details (a copy is included in the LICENSE file that
|
|
||||||
* accompanied this code).
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License version
|
|
||||||
* 2 along with this work; if not, write to the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
||||||
*
|
|
||||||
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
|
||||||
* or visit www.oracle.com if you need additional information or have any
|
|
||||||
* questions.
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
|
|
||||||
#ifndef SHARE_METAPROGRAMMING_ISSAME_HPP
|
|
||||||
#define SHARE_METAPROGRAMMING_ISSAME_HPP
|
|
||||||
|
|
||||||
#include "metaprogramming/integralConstant.hpp"
|
|
||||||
|
|
||||||
// This trait returns true iff the two types X and Y are the same
|
|
||||||
|
|
||||||
template <typename X, typename Y>
|
|
||||||
struct IsSame: public FalseType {};
|
|
||||||
|
|
||||||
template <typename X>
|
|
||||||
struct IsSame<X, X>: public TrueType {};
|
|
||||||
|
|
||||||
#endif // SHARE_METAPROGRAMMING_ISSAME_HPP
|
|
@ -29,7 +29,6 @@
|
|||||||
#include "memory/allocation.hpp"
|
#include "memory/allocation.hpp"
|
||||||
#include "metaprogramming/enableIf.hpp"
|
#include "metaprogramming/enableIf.hpp"
|
||||||
#include "metaprogramming/integralConstant.hpp"
|
#include "metaprogramming/integralConstant.hpp"
|
||||||
#include "metaprogramming/isSame.hpp"
|
|
||||||
#include "oops/accessDecorators.hpp"
|
#include "oops/accessDecorators.hpp"
|
||||||
#include "oops/oopsHierarchy.hpp"
|
#include "oops/oopsHierarchy.hpp"
|
||||||
#include "runtime/globals.hpp"
|
#include "runtime/globals.hpp"
|
||||||
@ -64,8 +63,8 @@ namespace AccessInternal {
|
|||||||
template <DecoratorSet decorators, typename T>
|
template <DecoratorSet decorators, typename T>
|
||||||
struct MustConvertCompressedOop: public IntegralConstant<bool,
|
struct MustConvertCompressedOop: public IntegralConstant<bool,
|
||||||
HasDecorator<decorators, INTERNAL_VALUE_IS_OOP>::value &&
|
HasDecorator<decorators, INTERNAL_VALUE_IS_OOP>::value &&
|
||||||
IsSame<typename HeapOopType<decorators>::type, narrowOop>::value &&
|
std::is_same<typename HeapOopType<decorators>::type, narrowOop>::value &&
|
||||||
IsSame<T, oop>::value> {};
|
std::is_same<T, oop>::value> {};
|
||||||
|
|
||||||
// This metafunction returns an appropriate oop type if the value is oop-like
|
// This metafunction returns an appropriate oop type if the value is oop-like
|
||||||
// and otherwise returns the same type T.
|
// and otherwise returns the same type T.
|
||||||
@ -1211,7 +1210,7 @@ namespace AccessInternal {
|
|||||||
arrayOop dst_obj, size_t dst_offset_in_bytes, T* dst_raw,
|
arrayOop dst_obj, size_t dst_offset_in_bytes, T* dst_raw,
|
||||||
size_t length) {
|
size_t length) {
|
||||||
STATIC_ASSERT((HasDecorator<decorators, INTERNAL_VALUE_IS_OOP>::value ||
|
STATIC_ASSERT((HasDecorator<decorators, INTERNAL_VALUE_IS_OOP>::value ||
|
||||||
(IsSame<T, void>::value || std::is_integral<T>::value) ||
|
(std::is_same<T, void>::value || std::is_integral<T>::value) ||
|
||||||
std::is_floating_point<T>::value)); // arraycopy allows type erased void elements
|
std::is_floating_point<T>::value)); // arraycopy allows type erased void elements
|
||||||
using DecayedT = std::decay_t<T>;
|
using DecayedT = std::decay_t<T>;
|
||||||
const DecoratorSet expanded_decorators = DecoratorFixup<decorators | IS_ARRAY | IN_HEAP>::value;
|
const DecoratorSet expanded_decorators = DecoratorFixup<decorators | IS_ARRAY | IN_HEAP>::value;
|
||||||
|
@ -27,7 +27,6 @@
|
|||||||
|
|
||||||
#include "memory/allocation.hpp"
|
#include "memory/allocation.hpp"
|
||||||
#include "metaprogramming/enableIf.hpp"
|
#include "metaprogramming/enableIf.hpp"
|
||||||
#include "metaprogramming/isSame.hpp"
|
|
||||||
#include "metaprogramming/isSigned.hpp"
|
#include "metaprogramming/isSigned.hpp"
|
||||||
#include "metaprogramming/primitiveConversions.hpp"
|
#include "metaprogramming/primitiveConversions.hpp"
|
||||||
#include "runtime/orderAccess.hpp"
|
#include "runtime/orderAccess.hpp"
|
||||||
@ -791,8 +790,8 @@ template<typename D, typename U, typename T>
|
|||||||
struct Atomic::CmpxchgImpl<
|
struct Atomic::CmpxchgImpl<
|
||||||
D*, U*, T*,
|
D*, U*, T*,
|
||||||
typename EnableIf<Atomic::IsPointerConvertible<T*, D*>::value &&
|
typename EnableIf<Atomic::IsPointerConvertible<T*, D*>::value &&
|
||||||
IsSame<std::remove_cv_t<D>,
|
std::is_same<std::remove_cv_t<D>,
|
||||||
std::remove_cv_t<U>>::value>::type>
|
std::remove_cv_t<U>>::value>::type>
|
||||||
{
|
{
|
||||||
D* operator()(D* volatile* dest, U* compare_value, T* exchange_value,
|
D* operator()(D* volatile* dest, U* compare_value, T* exchange_value,
|
||||||
atomic_memory_order order) const {
|
atomic_memory_order order) const {
|
||||||
|
@ -31,6 +31,8 @@
|
|||||||
#include "oops/access.inline.hpp"
|
#include "oops/access.inline.hpp"
|
||||||
#include "utilities/debug.hpp"
|
#include "utilities/debug.hpp"
|
||||||
|
|
||||||
|
#include <type_traits>
|
||||||
|
|
||||||
// Implementation of the non-virtual do_oop dispatch.
|
// Implementation of the non-virtual do_oop dispatch.
|
||||||
//
|
//
|
||||||
// The same implementation is used for do_metadata, do_klass, and do_cld.
|
// The same implementation is used for do_metadata, do_klass, and do_cld.
|
||||||
@ -73,16 +75,16 @@
|
|||||||
// p - The oop (or narrowOop) field to pass to the closure
|
// p - The oop (or narrowOop) field to pass to the closure
|
||||||
|
|
||||||
template <typename T, typename Receiver, typename Base, typename OopClosureType>
|
template <typename T, typename Receiver, typename Base, typename OopClosureType>
|
||||||
static typename EnableIf<IsSame<Receiver, Base>::value, void>::type
|
static typename EnableIf<std::is_same<Receiver, Base>::value, void>::type
|
||||||
call_do_oop(void (Receiver::*)(T*), void (Base::*)(T*), OopClosureType* closure, T* p) {
|
call_do_oop(void (Receiver::*)(T*), void (Base::*)(T*), OopClosureType* closure, T* p) {
|
||||||
closure->do_oop(p);
|
closure->do_oop(p);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T, typename Receiver, typename Base, typename OopClosureType>
|
template <typename T, typename Receiver, typename Base, typename OopClosureType>
|
||||||
static typename EnableIf<!IsSame<Receiver, Base>::value, void>::type
|
static typename EnableIf<!std::is_same<Receiver, Base>::value, void>::type
|
||||||
call_do_oop(void (Receiver::*)(T*), void (Base::*)(T*), OopClosureType* closure, T* p) {
|
call_do_oop(void (Receiver::*)(T*), void (Base::*)(T*), OopClosureType* closure, T* p) {
|
||||||
// Sanity check
|
// Sanity check
|
||||||
STATIC_ASSERT((!IsSame<OopClosureType, OopIterateClosure>::value));
|
STATIC_ASSERT((!std::is_same<OopClosureType, OopIterateClosure>::value));
|
||||||
closure->OopClosureType::do_oop(p);
|
closure->OopClosureType::do_oop(p);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -94,13 +96,13 @@ inline void Devirtualizer::do_oop(OopClosureType* closure, T* p) {
|
|||||||
// Implementation of the non-virtual do_metadata dispatch.
|
// Implementation of the non-virtual do_metadata dispatch.
|
||||||
|
|
||||||
template <typename Receiver, typename Base, typename OopClosureType>
|
template <typename Receiver, typename Base, typename OopClosureType>
|
||||||
static typename EnableIf<IsSame<Receiver, Base>::value, bool>::type
|
static typename EnableIf<std::is_same<Receiver, Base>::value, bool>::type
|
||||||
call_do_metadata(bool (Receiver::*)(), bool (Base::*)(), OopClosureType* closure) {
|
call_do_metadata(bool (Receiver::*)(), bool (Base::*)(), OopClosureType* closure) {
|
||||||
return closure->do_metadata();
|
return closure->do_metadata();
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename Receiver, typename Base, typename OopClosureType>
|
template <typename Receiver, typename Base, typename OopClosureType>
|
||||||
static typename EnableIf<!IsSame<Receiver, Base>::value, bool>::type
|
static typename EnableIf<!std::is_same<Receiver, Base>::value, bool>::type
|
||||||
call_do_metadata(bool (Receiver::*)(), bool (Base::*)(), OopClosureType* closure) {
|
call_do_metadata(bool (Receiver::*)(), bool (Base::*)(), OopClosureType* closure) {
|
||||||
return closure->OopClosureType::do_metadata();
|
return closure->OopClosureType::do_metadata();
|
||||||
}
|
}
|
||||||
@ -113,13 +115,13 @@ inline bool Devirtualizer::do_metadata(OopClosureType* closure) {
|
|||||||
// Implementation of the non-virtual do_klass dispatch.
|
// Implementation of the non-virtual do_klass dispatch.
|
||||||
|
|
||||||
template <typename Receiver, typename Base, typename OopClosureType>
|
template <typename Receiver, typename Base, typename OopClosureType>
|
||||||
static typename EnableIf<IsSame<Receiver, Base>::value, void>::type
|
static typename EnableIf<std::is_same<Receiver, Base>::value, void>::type
|
||||||
call_do_klass(void (Receiver::*)(Klass*), void (Base::*)(Klass*), OopClosureType* closure, Klass* k) {
|
call_do_klass(void (Receiver::*)(Klass*), void (Base::*)(Klass*), OopClosureType* closure, Klass* k) {
|
||||||
closure->do_klass(k);
|
closure->do_klass(k);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename Receiver, typename Base, typename OopClosureType>
|
template <typename Receiver, typename Base, typename OopClosureType>
|
||||||
static typename EnableIf<!IsSame<Receiver, Base>::value, void>::type
|
static typename EnableIf<!std::is_same<Receiver, Base>::value, void>::type
|
||||||
call_do_klass(void (Receiver::*)(Klass*), void (Base::*)(Klass*), OopClosureType* closure, Klass* k) {
|
call_do_klass(void (Receiver::*)(Klass*), void (Base::*)(Klass*), OopClosureType* closure, Klass* k) {
|
||||||
closure->OopClosureType::do_klass(k);
|
closure->OopClosureType::do_klass(k);
|
||||||
}
|
}
|
||||||
@ -132,13 +134,13 @@ inline void Devirtualizer::do_klass(OopClosureType* closure, Klass* k) {
|
|||||||
// Implementation of the non-virtual do_cld dispatch.
|
// Implementation of the non-virtual do_cld dispatch.
|
||||||
|
|
||||||
template <typename Receiver, typename Base, typename OopClosureType>
|
template <typename Receiver, typename Base, typename OopClosureType>
|
||||||
static typename EnableIf<IsSame<Receiver, Base>::value, void>::type
|
static typename EnableIf<std::is_same<Receiver, Base>::value, void>::type
|
||||||
call_do_cld(void (Receiver::*)(ClassLoaderData*), void (Base::*)(ClassLoaderData*), OopClosureType* closure, ClassLoaderData* cld) {
|
call_do_cld(void (Receiver::*)(ClassLoaderData*), void (Base::*)(ClassLoaderData*), OopClosureType* closure, ClassLoaderData* cld) {
|
||||||
closure->do_cld(cld);
|
closure->do_cld(cld);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename Receiver, typename Base, typename OopClosureType>
|
template <typename Receiver, typename Base, typename OopClosureType>
|
||||||
static typename EnableIf<!IsSame<Receiver, Base>::value, void>::type
|
static typename EnableIf<!std::is_same<Receiver, Base>::value, void>::type
|
||||||
call_do_cld(void (Receiver::*)(ClassLoaderData*), void (Base::*)(ClassLoaderData*), OopClosureType* closure, ClassLoaderData* cld) {
|
call_do_cld(void (Receiver::*)(ClassLoaderData*), void (Base::*)(ClassLoaderData*), OopClosureType* closure, ClassLoaderData* cld) {
|
||||||
closure->OopClosureType::do_cld(cld);
|
closure->OopClosureType::do_cld(cld);
|
||||||
}
|
}
|
||||||
@ -151,13 +153,13 @@ void Devirtualizer::do_cld(OopClosureType* closure, ClassLoaderData* cld) {
|
|||||||
// Implementation of the non-virtual do_derived_oop dispatch.
|
// Implementation of the non-virtual do_derived_oop dispatch.
|
||||||
|
|
||||||
template <typename Receiver, typename Base, typename DerivedOopClosureType>
|
template <typename Receiver, typename Base, typename DerivedOopClosureType>
|
||||||
static typename EnableIf<IsSame<Receiver, Base>::value, void>::type
|
static typename EnableIf<std::is_same<Receiver, Base>::value, void>::type
|
||||||
call_do_derived_oop(void (Receiver::*)(oop*, derived_pointer*), void (Base::*)(oop*, derived_pointer*), DerivedOopClosureType* closure, oop* base, derived_pointer* derived) {
|
call_do_derived_oop(void (Receiver::*)(oop*, derived_pointer*), void (Base::*)(oop*, derived_pointer*), DerivedOopClosureType* closure, oop* base, derived_pointer* derived) {
|
||||||
closure->do_derived_oop(base, derived);
|
closure->do_derived_oop(base, derived);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename Receiver, typename Base, typename DerivedOopClosureType>
|
template <typename Receiver, typename Base, typename DerivedOopClosureType>
|
||||||
static typename EnableIf<!IsSame<Receiver, Base>::value, void>::type
|
static typename EnableIf<!std::is_same<Receiver, Base>::value, void>::type
|
||||||
call_do_derived_oop(void (Receiver::*)(oop*, derived_pointer*), void (Base::*)(oop*, derived_pointer*), DerivedOopClosureType* closure, oop* base, derived_pointer* derived) {
|
call_do_derived_oop(void (Receiver::*)(oop*, derived_pointer*), void (Base::*)(oop*, derived_pointer*), DerivedOopClosureType* closure, oop* base, derived_pointer* derived) {
|
||||||
closure->DerivedOopClosureType::do_derived_oop(base, derived);
|
closure->DerivedOopClosureType::do_derived_oop(base, derived);
|
||||||
}
|
}
|
||||||
|
@ -1,51 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved.
|
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
|
||||||
*
|
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
|
||||||
* under the terms of the GNU General Public License version 2 only, as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This code is distributed in the hope that it will be useful, but WITHOUT
|
|
||||||
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
||||||
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
||||||
* version 2 for more details (a copy is included in the LICENSE file that
|
|
||||||
* accompanied this code).
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License version
|
|
||||||
* 2 along with this work; if not, write to the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
||||||
*
|
|
||||||
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
|
||||||
* or visit www.oracle.com if you need additional information or have any
|
|
||||||
* questions.
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "precompiled.hpp"
|
|
||||||
#include "memory/allocation.hpp"
|
|
||||||
#include "metaprogramming/isSame.hpp"
|
|
||||||
#include "utilities/debug.hpp"
|
|
||||||
|
|
||||||
class IsSameTest: AllStatic {
|
|
||||||
class A: AllStatic {};
|
|
||||||
class B: AllStatic {};
|
|
||||||
|
|
||||||
static const bool const_A_is_A = IsSame<const A, A>::value;
|
|
||||||
STATIC_ASSERT(!const_A_is_A);
|
|
||||||
|
|
||||||
static const bool volatile_A_is_A = IsSame<volatile A, A>::value;
|
|
||||||
STATIC_ASSERT(!volatile_A_is_A);
|
|
||||||
|
|
||||||
static const bool Aref_is_A = IsSame<A&, A>::value;
|
|
||||||
STATIC_ASSERT(!Aref_is_A);
|
|
||||||
|
|
||||||
static const bool Aptr_is_A = IsSame<A*, A>::value;
|
|
||||||
STATIC_ASSERT(!Aptr_is_A);
|
|
||||||
|
|
||||||
static const bool A_is_B = IsSame<A, B>::value;
|
|
||||||
STATIC_ASSERT(!A_is_B);
|
|
||||||
|
|
||||||
static const bool A_is_A = IsSame<A, A>::value;
|
|
||||||
STATIC_ASSERT(A_is_A);
|
|
||||||
};
|
|
@ -24,7 +24,6 @@
|
|||||||
|
|
||||||
#include "precompiled.hpp"
|
#include "precompiled.hpp"
|
||||||
#include "memory/allocation.hpp"
|
#include "memory/allocation.hpp"
|
||||||
#include "metaprogramming/isSame.hpp"
|
|
||||||
#include "metaprogramming/isSigned.hpp"
|
#include "metaprogramming/isSigned.hpp"
|
||||||
#include "utilities/debug.hpp"
|
#include "utilities/debug.hpp"
|
||||||
|
|
||||||
|
@ -24,7 +24,6 @@
|
|||||||
|
|
||||||
#include "precompiled.hpp"
|
#include "precompiled.hpp"
|
||||||
#include "memory/allocation.hpp"
|
#include "memory/allocation.hpp"
|
||||||
#include "metaprogramming/isSame.hpp"
|
|
||||||
#include "metaprogramming/primitiveConversions.hpp"
|
#include "metaprogramming/primitiveConversions.hpp"
|
||||||
#include "unittest.hpp"
|
#include "unittest.hpp"
|
||||||
#include "utilities/debug.hpp"
|
#include "utilities/debug.hpp"
|
||||||
|
Loading…
Reference in New Issue
Block a user