<div dir="ltr">This happens to fire in practice in protobuf. It's probably a true positive and it's cool that this warning found it, but it means we have to disable Wuser-defined-warnings for a bit -- which then disables all of these user-defined warnings. Right now there aren't any others, but it feels like we'd want to have the ability to turn individual user-defined warnings on or off instead of just having a single toggle for all of them. Are there plans for something like that?</div><div class="gmail_extra"><br><div class="gmail_quote">On Fri, Jan 13, 2017 at 5:02 PM, Eric Fiselier via cfe-commits <span dir="ltr"><<a href="mailto:cfe-commits@lists.llvm.org" target="_blank">cfe-commits@lists.llvm.org</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Author: ericwf<br>
Date: Fri Jan 13 16:02:08 2017<br>
New Revision: 291961<br>
<br>
URL: <a href="http://llvm.org/viewvc/llvm-project?rev=291961&view=rev" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-<wbr>project?rev=291961&view=rev</a><br>
Log:<br>
Add _LIBCPP_DIAGNOSE_WARNING and _LIBCPP_DIAGNOSE_ERROR macros.<br>
<br>
Clang recently added a `diagnose_if(cond, msg, type)` attribute<br>
which can be used to generate diagnostics when `cond` is a constant<br>
expression that evaluates to true. Otherwise no attribute has no<br>
effect.<br>
<br>
This patch adds _LIBCPP_DIAGNOSE_ERROR/WARNING macros which<br>
use this new attribute. Additionally this patch implements<br>
a diagnostic message when a non-const-callable comparator is<br>
given to a container.<br>
<br>
Note: For now the warning version of the diagnostic is useless<br>
within libc++ since warning diagnostics are suppressed by the<br>
system header pragma. I'm going to work on fixing this.<br>
<br>
Added:<br>
    libcxx/trunk/test/libcxx/<wbr>containers/associative/non_<wbr>const_comparator.fail.cpp<br>
Modified:<br>
    libcxx/trunk/docs/UsingLibcxx.<wbr>rst<br>
    libcxx/trunk/include/__config<br>
    libcxx/trunk/include/__tree<br>
    libcxx/trunk/include/map<br>
    libcxx/trunk/include/type_<wbr>traits<br>
    libcxx/trunk/test/libcxx/<wbr>compiler.py<br>
    libcxx/trunk/test/libcxx/test/<wbr>config.py<br>
    libcxx/trunk/test/libcxx/test/<wbr>format.py<br>
    libcxx/trunk/test/libcxx/<wbr>utilities/tuple/tuple.tuple/<wbr>diagnose_reference_binding.<wbr>fail.cpp<br>
<br>
Modified: libcxx/trunk/docs/UsingLibcxx.<wbr>rst<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/libcxx/trunk/docs/UsingLibcxx.rst?rev=291961&r1=291960&r2=291961&view=diff" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-<wbr>project/libcxx/trunk/docs/<wbr>UsingLibcxx.rst?rev=291961&r1=<wbr>291960&r2=291961&view=diff</a><br>
==============================<wbr>==============================<wbr>==================<br>
--- libcxx/trunk/docs/UsingLibcxx.<wbr>rst (original)<br>
+++ libcxx/trunk/docs/UsingLibcxx.<wbr>rst Fri Jan 13 16:02:08 2017<br>
@@ -173,3 +173,10 @@ thread safety annotations.<br>
       return Tup{"hello world", 42}; // explicit constructor called. OK.<br>
     }<br>
<br>
+**_LIBCPP_DISABLE_ADDITIONAL_<wbr>DIAGNOSTICS**:<br>
+  This macro disables the additional diagnostics generated by libc++ using the<br>
+  `diagnose_if` attribute. These additional diagnostics include checks for:<br>
+<br>
+    * Giving `set`, `map`, `multiset`, `multimap` a comparator which is not<br>
+      const callable.<br>
+<br>
<br>
Modified: libcxx/trunk/include/__config<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/libcxx/trunk/include/__config?rev=291961&r1=291960&r2=291961&view=diff" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-<wbr>project/libcxx/trunk/include/_<wbr>_config?rev=291961&r1=291960&<wbr>r2=291961&view=diff</a><br>
==============================<wbr>==============================<wbr>==================<br>
--- libcxx/trunk/include/__config (original)<br>
+++ libcxx/trunk/include/__config Fri Jan 13 16:02:08 2017<br>
@@ -1006,6 +1006,16 @@ _LIBCPP_FUNC_VIS extern "C" void __sanit<br>
 #endif<br>
 #endif<br>
<br>
+#if __has_attribute(diagnose_if) && !defined(_LIBCPP_DISABLE_<wbr>ADDITIONAL_DIAGNOSTICS)<br>
+# define _LIBCPP_DIAGNOSE_WARNING(...) \<br>
+    __attribute__((__diagnose_if__<wbr>(__VA_ARGS__, "warning")))<br>
+# define _LIBCPP_DIAGNOSE_ERROR(...) \<br>
+    __attribute__((__diagnose_if__<wbr>(__VA_ARGS__, "error")))<br>
+#else<br>
+# define _LIBCPP_DIAGNOSE_WARNING(...)<br>
+# define _LIBCPP_DIAGNOSE_ERROR(...)<br>
+#endif<br>
+<br>
 #endif // __cplusplus<br>
<br>
 #endif // _LIBCPP_CONFIG<br>
<br>
Modified: libcxx/trunk/include/__tree<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/libcxx/trunk/include/__tree?rev=291961&r1=291960&r2=291961&view=diff" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-<wbr>project/libcxx/trunk/include/_<wbr>_tree?rev=291961&r1=291960&r2=<wbr>291961&view=diff</a><br>
==============================<wbr>==============================<wbr>==================<br>
--- libcxx/trunk/include/__tree (original)<br>
+++ libcxx/trunk/include/__tree Fri Jan 13 16:02:08 2017<br>
@@ -41,6 +41,10 @@ template <class _Key, class _Value><br>
 struct __value_type;<br>
 #endif<br>
<br>
+template <class _Key, class _CP, class _Compare,<br>
+    bool = is_empty<_Compare>::value && !__libcpp_is_final<_Compare>::<wbr>value><br>
+class __map_value_compare;<br>
+<br>
 template <class _Allocator> class __map_node_destructor;<br>
 template <class _TreeIterator> class _LIBCPP_TEMPLATE_VIS __map_iterator;<br>
 template <class _TreeIterator> class _LIBCPP_TEMPLATE_VIS __map_const_iterator;<br>
@@ -955,6 +959,30 @@ private:<br>
<br>
 };<br>
<br>
+#ifndef _LIBCPP_CXX03_LANG<br>
+template <class _Tp, class _Compare, class _Allocator><br>
+struct __diagnose_tree_helper {<br>
+  static constexpr bool __trigger_diagnostics()<br>
+      _LIBCPP_DIAGNOSE_WARNING(!__<wbr>is_const_comparable<_Compare, _Tp>::value,<br>
+            "the specified comparator type does not provide a const call operator")<br>
+  { return true; }<br>
+};<br>
+<br>
+template <class _Key, class _Value, class _KeyComp, class _Alloc><br>
+struct __diagnose_tree_helper<<br>
+    __value_type<_Key, _Value>,<br>
+    __map_value_compare<_Key, __value_type<_Key, _Value>, _KeyComp>,<br>
+    _Alloc<br>
+><br>
+{<br>
+  static constexpr bool __trigger_diagnostics()<br>
+      _LIBCPP_DIAGNOSE_WARNING(!__<wbr>is_const_comparable<_KeyComp, _Key>::value,<br>
+            "the specified comparator type does not provide a const call operator")<br>
+  { return true; }<br>
+};<br>
+<br>
+#endif<br>
+<br>
 template <class _Tp, class _Compare, class _Allocator><br>
 class __tree<br>
 {<br>
@@ -1787,7 +1815,11 @@ __tree<_Tp, _Compare, _Allocator>::~__tr<br>
 {<br>
     static_assert((is_copy_<wbr>constructible<value_compare>::<wbr>value),<br>
                  "Comparator must be copy-constructible.");<br>
-    destroy(__root());<br>
+#ifndef _LIBCPP_CXX03_LANG<br>
+    static_assert((__diagnose_<wbr>tree_helper<_Tp, _Compare, _Allocator>::<br>
+                     __trigger_diagnostics()), "");<br>
+#endif<br>
+  destroy(__root());<br>
 }<br>
<br>
 template <class _Tp, class _Compare, class _Allocator><br>
<br>
Modified: libcxx/trunk/include/map<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/libcxx/trunk/include/map?rev=291961&r1=291960&r2=291961&view=diff" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-<wbr>project/libcxx/trunk/include/<wbr>map?rev=291961&r1=291960&r2=<wbr>291961&view=diff</a><br>
==============================<wbr>==============================<wbr>==================<br>
--- libcxx/trunk/include/map (original)<br>
+++ libcxx/trunk/include/map Fri Jan 13 16:02:08 2017<br>
@@ -453,9 +453,7 @@ swap(multimap<Key, T, Compare, Allocator<br>
<br>
 _LIBCPP_BEGIN_NAMESPACE_STD<br>
<br>
-template <class _Key, class _CP, class _Compare,<br>
-          bool = is_empty<_Compare>::value && !__libcpp_is_final<_Compare>::<wbr>value<br>
-         ><br>
+template <class _Key, class _CP, class _Compare, bool _IsSmall><br>
 class __map_value_compare<br>
     : private _Compare<br>
 {<br>
<br>
Modified: libcxx/trunk/include/type_<wbr>traits<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/libcxx/trunk/include/type_traits?rev=291961&r1=291960&r2=291961&view=diff" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-<wbr>project/libcxx/trunk/include/<wbr>type_traits?rev=291961&r1=<wbr>291960&r2=291961&view=diff</a><br>
==============================<wbr>==============================<wbr>==================<br>
--- libcxx/trunk/include/type_<wbr>traits (original)<br>
+++ libcxx/trunk/include/type_<wbr>traits Fri Jan 13 16:02:08 2017<br>
@@ -4715,6 +4715,15 @@ struct __can_extract_map_key<_ValTy, _Ke<br>
<br>
 #endif<br>
<br>
+template <class _Comp, class _ValueType, class = void><br>
+struct __is_const_comparable : false_type {};<br>
+<br>
+template <class _Comp, class _ValueType><br>
+struct __is_const_comparable<_Comp, _ValueType, typename __void_t<<br>
+    decltype(_VSTD::declval<_Comp const&>()(_VSTD::declval<_<wbr>ValueType const&>(),<br>
+                                            _VSTD::declval<_ValueType const&>()))<br>
+  >::type> : true_type {};<br>
+<br>
 _LIBCPP_END_NAMESPACE_STD<br>
<br>
 #endif  // _LIBCPP_TYPE_TRAITS<br>
<br>
Modified: libcxx/trunk/test/libcxx/<wbr>compiler.py<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/libcxx/trunk/test/libcxx/compiler.py?rev=291961&r1=291960&r2=291961&view=diff" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-<wbr>project/libcxx/trunk/test/<wbr>libcxx/compiler.py?rev=291961&<wbr>r1=291960&r2=291961&view=diff</a><br>
==============================<wbr>==============================<wbr>==================<br>
--- libcxx/trunk/test/libcxx/<wbr>compiler.py (original)<br>
+++ libcxx/trunk/test/libcxx/<wbr>compiler.py Fri Jan 13 16:02:08 2017<br>
@@ -296,7 +296,7 @@ class CXXCompiler(object):<br>
<br>
     def addWarningFlagIfSupported(<wbr>self, flag):<br>
         if self.hasWarningFlag(flag):<br>
-            assert flag not in self.warning_flags<br>
-            self.warning_flags += [flag]<br>
+            if flag not in self.warning_flags:<br>
+                self.warning_flags += [flag]<br>
             return True<br>
         return False<br>
<br>
Added: libcxx/trunk/test/libcxx/<wbr>containers/associative/non_<wbr>const_comparator.fail.cpp<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/libcxx/trunk/test/libcxx/containers/associative/non_const_comparator.fail.cpp?rev=291961&view=auto" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-<wbr>project/libcxx/trunk/test/<wbr>libcxx/containers/associative/<wbr>non_const_comparator.fail.cpp?<wbr>rev=291961&view=auto</a><br>
==============================<wbr>==============================<wbr>==================<br>
--- libcxx/trunk/test/libcxx/<wbr>containers/associative/non_<wbr>const_comparator.fail.cpp (added)<br>
+++ libcxx/trunk/test/libcxx/<wbr>containers/associative/non_<wbr>const_comparator.fail.cpp Fri Jan 13 16:02:08 2017<br>
@@ -0,0 +1,45 @@<br>
+//===------------------------<wbr>------------------------------<wbr>----------------===//<br>
+//<br>
+//                     The LLVM Compiler Infrastructure<br>
+//<br>
+// This file is dual licensed under the MIT and the University of Illinois Open<br>
+// Source Licenses. See LICENSE.TXT for details.<br>
+//<br>
+//===------------------------<wbr>------------------------------<wbr>----------------===//<br>
+<br>
+// UNSUPPORTED: c++98, c++03<br>
+// REQUIRES: diagnose-if-support, verify-support<br>
+<br>
+// Test that libc++ generates a warning diagnostic when the container is<br>
+// provided a non-const callable comparator.<br>
+<br>
+#include <set><br>
+#include <map><br>
+<br>
+struct BadCompare {<br>
+  template <class T, class U><br>
+  bool operator()(T const& t, U const& u) {<br>
+    return t < u;<br>
+  }<br>
+};<br>
+<br>
+int main() {<br>
+  static_assert(!std::__is_<wbr>const_comparable<BadCompare, int>::value, "");<br>
+  // expected-warning@__tree:* 4 {{the specified comparator type does not provide a const call operator}}<br>
+  {<br>
+    using C = std::set<int, BadCompare>;<br>
+    C s;<br>
+  }<br>
+  {<br>
+    using C = std::multiset<long, BadCompare>;<br>
+    C s;<br>
+  }<br>
+  {<br>
+    using C = std::map<int, int, BadCompare>;<br>
+    C s;<br>
+  }<br>
+  {<br>
+    using C = std::multimap<long, int, BadCompare>;<br>
+    C s;<br>
+  }<br>
+}<br>
<br>
Modified: libcxx/trunk/test/libcxx/test/<wbr>config.py<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/libcxx/trunk/test/libcxx/test/config.py?rev=291961&r1=291960&r2=291961&view=diff" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-<wbr>project/libcxx/trunk/test/<wbr>libcxx/test/config.py?rev=<wbr>291961&r1=291960&r2=291961&<wbr>view=diff</a><br>
==============================<wbr>==============================<wbr>==================<br>
--- libcxx/trunk/test/libcxx/test/<wbr>config.py (original)<br>
+++ libcxx/trunk/test/libcxx/test/<wbr>config.py Fri Jan 13 16:02:08 2017<br>
@@ -712,33 +712,35 @@ class Configuration(object):<br>
                 ['c++11', 'c++14', 'c++1z'])) != 0<br>
         enable_warnings = self.get_lit_bool('enable_<wbr>warnings',<br>
                                             default_enable_warnings)<br>
-        if enable_warnings:<br>
-            self.cxx.useWarnings(True)<br>
-            self.cxx.warning_flags += [<br>
-                '-D_LIBCPP_HAS_NO_PRAGMA_<wbr>SYSTEM_HEADER',<br>
-                '-Wall', '-Wextra', '-Werror'<br>
-            ]<br>
-            self.cxx.<wbr>addWarningFlagIfSupported('-<wbr>Wshadow')<br>
-            self.cxx.<wbr>addWarningFlagIfSupported('-<wbr>Wno-unused-command-line-<wbr>argument')<br>
-            self.cxx.<wbr>addWarningFlagIfSupported('-<wbr>Wno-attributes')<br>
-            self.cxx.<wbr>addWarningFlagIfSupported('-<wbr>Wno-pessimizing-move')<br>
-            self.cxx.<wbr>addWarningFlagIfSupported('-<wbr>Wno-c++11-extensions')<br>
-            self.cxx.<wbr>addWarningFlagIfSupported('-<wbr>Wno-user-defined-literals')<br>
-            # These warnings should be enabled in order to support the MSVC<br>
-            # team using the test suite; They enable the warnings below and<br>
-            # expect the test suite to be clean.<br>
-            self.cxx.<wbr>addWarningFlagIfSupported('-<wbr>Wsign-compare')<br>
-            self.cxx.<wbr>addWarningFlagIfSupported('-<wbr>Wunused-variable')<br>
-            self.cxx.<wbr>addWarningFlagIfSupported('-<wbr>Wunused-parameter')<br>
-            self.cxx.<wbr>addWarningFlagIfSupported('-<wbr>Wunreachable-code')<br>
-            # FIXME: Enable the two warnings below.<br>
-            self.cxx.<wbr>addWarningFlagIfSupported('-<wbr>Wno-conversion')<br>
+        self.cxx.useWarnings(enable_<wbr>warnings)<br>
+        self.cxx.warning_flags += [<br>
+            '-D_LIBCPP_HAS_NO_PRAGMA_<wbr>SYSTEM_HEADER',<br>
+            '-Wall', '-Wextra', '-Werror'<br>
+        ]<br>
+        if self.cxx.hasWarningFlag('-<wbr>Wuser-defined-warnings'):<br>
+            self.cxx.warning_flags += ['-Wuser-defined-warnings']<br>
+            self.config.available_<wbr>features.add('diagnose-if-<wbr>support')<br>
+        self.cxx.<wbr>addWarningFlagIfSupported('-<wbr>Wshadow')<br>
+        self.cxx.<wbr>addWarningFlagIfSupported('-<wbr>Wno-unused-command-line-<wbr>argument')<br>
+        self.cxx.<wbr>addWarningFlagIfSupported('-<wbr>Wno-attributes')<br>
+        self.cxx.<wbr>addWarningFlagIfSupported('-<wbr>Wno-pessimizing-move')<br>
+        self.cxx.<wbr>addWarningFlagIfSupported('-<wbr>Wno-c++11-extensions')<br>
+        self.cxx.<wbr>addWarningFlagIfSupported('-<wbr>Wno-user-defined-literals')<br>
+        # These warnings should be enabled in order to support the MSVC<br>
+        # team using the test suite; They enable the warnings below and<br>
+        # expect the test suite to be clean.<br>
+        self.cxx.<wbr>addWarningFlagIfSupported('-<wbr>Wsign-compare')<br>
+        self.cxx.<wbr>addWarningFlagIfSupported('-<wbr>Wunused-variable')<br>
+        self.cxx.<wbr>addWarningFlagIfSupported('-<wbr>Wunused-parameter')<br>
+        self.cxx.<wbr>addWarningFlagIfSupported('-<wbr>Wunreachable-code')<br>
+        # FIXME: Enable the two warnings below.<br>
+        self.cxx.<wbr>addWarningFlagIfSupported('-<wbr>Wno-conversion')<br>
+        self.cxx.<wbr>addWarningFlagIfSupported('-<wbr>Wno-unused-local-typedef')<br>
+        std = self.get_lit_conf('std', None)<br>
+        if std in ['c++98', 'c++03']:<br>
+            # The '#define static_assert' provided by libc++ in C++03 mode<br>
+            # causes an unused local typedef whenever it is used.<br>
             self.cxx.<wbr>addWarningFlagIfSupported('-<wbr>Wno-unused-local-typedef')<br>
-            std = self.get_lit_conf('std', None)<br>
-            if std in ['c++98', 'c++03']:<br>
-                # The '#define static_assert' provided by libc++ in C++03 mode<br>
-                # causes an unused local typedef whenever it is used.<br>
-                self.cxx.<wbr>addWarningFlagIfSupported('-<wbr>Wno-unused-local-typedef')<br>
<br>
     def configure_sanitizer(self):<br>
         san = self.get_lit_conf('use_<wbr>sanitizer', '').strip()<br>
<br>
Modified: libcxx/trunk/test/libcxx/test/<wbr>format.py<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/libcxx/trunk/test/libcxx/test/format.py?rev=291961&r1=291960&r2=291961&view=diff" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-<wbr>project/libcxx/trunk/test/<wbr>libcxx/test/format.py?rev=<wbr>291961&r1=291960&r2=291961&<wbr>view=diff</a><br>
==============================<wbr>==============================<wbr>==================<br>
--- libcxx/trunk/test/libcxx/test/<wbr>format.py (original)<br>
+++ libcxx/trunk/test/libcxx/test/<wbr>format.py Fri Jan 13 16:02:08 2017<br>
@@ -223,6 +223,10 @@ class LibcxxTestFormat(object):<br>
             test_cxx.flags += ['-fsyntax-only']<br>
         if use_verify:<br>
             test_cxx.useVerify()<br>
+            test_cxx.useWarnings()<br>
+            if '-Wuser-defined-warnings' in test_cxx.warning_flags:<br>
+                test_cxx.warning_flags += ['-Wno-error=user-defined-<wbr>warnings']<br>
+<br>
         cmd, out, err, rc = test_cxx.compile(source_path, out=os.devnull)<br>
         expected_rc = 0 if use_verify else 1<br>
         if rc == expected_rc:<br>
<br>
Modified: libcxx/trunk/test/libcxx/<wbr>utilities/tuple/tuple.tuple/<wbr>diagnose_reference_binding.<wbr>fail.cpp<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/libcxx/trunk/test/libcxx/utilities/tuple/tuple.tuple/diagnose_reference_binding.fail.cpp?rev=291961&r1=291960&r2=291961&view=diff" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-<wbr>project/libcxx/trunk/test/<wbr>libcxx/utilities/tuple/tuple.<wbr>tuple/diagnose_reference_<wbr>binding.fail.cpp?rev=291961&<wbr>r1=291960&r2=291961&view=diff</a><br>
==============================<wbr>==============================<wbr>==================<br>
--- libcxx/trunk/test/libcxx/<wbr>utilities/tuple/tuple.tuple/<wbr>diagnose_reference_binding.<wbr>fail.cpp (original)<br>
+++ libcxx/trunk/test/libcxx/<wbr>utilities/tuple/tuple.tuple/<wbr>diagnose_reference_binding.<wbr>fail.cpp Fri Jan 13 16:02:08 2017<br>
@@ -30,4 +30,11 @@ int main() {<br>
     // bind rvalue to constructed non-rvalue<br>
     std::tuple<std::string &&> t2("hello"); // expected-note {{requested here}}<br>
     std::tuple<std::string &&> t3(std::allocator_arg, alloc, "hello"); // expected-note {{requested here}}<br>
+<br>
+    // FIXME: The below warnings may get emitted as an error, a warning, or not emitted at all<br>
+    // depending on the flags used to compile this test.<br>
+  {<br>
+    // expected-warning@tuple:* 0+ {{binding reference member 'value' to a temporary value}}<br>
+    // expected-error@tuple:* 0+ {{binding reference member 'value' to a temporary value}}<br>
+  }<br>
 }<br>
<br>
<br>
______________________________<wbr>_________________<br>
cfe-commits mailing list<br>
<a href="mailto:cfe-commits@lists.llvm.org">cfe-commits@lists.llvm.org</a><br>
<a href="http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits" rel="noreferrer" target="_blank">http://lists.llvm.org/cgi-bin/<wbr>mailman/listinfo/cfe-commits</a><br>
</blockquote></div><br></div>