| 
							- /*
 -   ==============================================================================
 - 
 -    This file is part of the JUCE library.
 -    Copyright (c) 2022 - Raw Material Software Limited
 - 
 -    JUCE is an open source library subject to commercial or open-source
 -    licensing.
 - 
 -    The code included in this file is provided under the terms of the ISC license
 -    http://www.isc.org/downloads/software-support-policy/isc-license. Permission
 -    To use, copy, modify, and/or distribute this software for any purpose with or
 -    without fee is hereby granted provided that the above copyright notice and
 -    this permission notice appear in all copies.
 - 
 -    JUCE IS PROVIDED "AS IS" WITHOUT ANY WARRANTY, AND ALL WARRANTIES, WHETHER
 -    EXPRESSED OR IMPLIED, INCLUDING MERCHANTABILITY AND FITNESS FOR PURPOSE, ARE
 -    DISCLAIMED.
 - 
 -   ==============================================================================
 - */
 - 
 - namespace juce
 - {
 - 
 - #ifndef DOXYGEN
 - namespace detail
 - {
 -     template <typename...>
 -     using Void = void;
 - 
 -     template <typename, typename = void>
 -     struct EqualityComparableToNullptr
 -         : std::false_type {};
 - 
 -     template <typename T>
 -     struct EqualityComparableToNullptr<T, Void<decltype (std::declval<T>() != nullptr)>>
 -         : std::true_type {};
 - 
 -     template <typename T>
 -     constexpr bool shouldCheckAgainstNullptr = EqualityComparableToNullptr<T>::value;
 - } // namespace detail
 - #endif
 - 
 - //==============================================================================
 - /** Some helper methods for checking a callable object before invoking with
 -     the specified arguments.
 - 
 -     If the object provides a comparison operator for nullptr it will check before
 -     calling. For other objects it will just invoke the function call operator.
 - 
 -     @tags{Core}
 - */
 - struct NullCheckedInvocation
 - {
 -     template <typename Callable, typename... Args,
 -               std::enable_if_t<detail::shouldCheckAgainstNullptr<Callable>, int> = 0>
 -     static void invoke (Callable&& fn, Args&&... args)
 -     {
 -         JUCE_BEGIN_IGNORE_WARNINGS_GCC_LIKE ("-Waddress")
 - 
 -         if (fn != nullptr)
 -             fn (std::forward<Args> (args)...);
 - 
 -         JUCE_END_IGNORE_WARNINGS_GCC_LIKE
 -     }
 - 
 -     template <typename Callable, typename... Args,
 -               std::enable_if_t<! detail::shouldCheckAgainstNullptr<Callable>, int> = 0>
 -     static void invoke (Callable&& fn, Args&&... args)
 -     {
 -         fn (std::forward<Args> (args)...);
 -     }
 - 
 -     template <typename... Args>
 -     static void invoke (std::nullptr_t, Args&&...) {}
 - };
 - 
 - /** Can be used to disable template constructors that would otherwise cause ambiguity with
 -     compiler-generated copy and move constructors.
 - 
 -     Adapted from https://ericniebler.com/2013/08/07/universal-references-and-the-copy-constructo/
 - */
 - template <typename A, typename B>
 - using DisableIfSameOrDerived = typename std::enable_if_t<! std::is_base_of<A, std::remove_reference_t<B>>::value>;
 - 
 - /** Copies an object, sets one of the copy's members to the specified value, and then returns the copy. */
 - template <typename Object, typename OtherObject, typename Member>
 - Object withMember (Object copy, Member OtherObject::* member, Member&& value)
 - {
 -     copy.*member = std::forward<Member> (value);
 -     return copy;
 - }
 - 
 - } // namespace juce
 
 
  |