<div dir="ltr">I should have made it more clear that this change actually caused 100's of assertions to be turned on. And good news! They found bugs!<div>On initial inspection in appears that the new path parser implementation has some issues. I'll work on fixing them in the coming days.</div><div>After I commit the fixes I'll setup bots to test with assertions enabled. For now I would suggest disabling assertions if you need the test suite to be clean. </div><div><br></div><div>Thanks,</div><div><br></div><div>/Eric</div></div><div class="gmail_extra"><br><div class="gmail_quote">On Mon, Feb 6, 2017 at 3:10 AM, Hahnfeld, Jonas <span dir="ltr"><<a href="mailto:Hahnfeld@itc.rwth-aachen.de" target="_blank">Hahnfeld@itc.rwth-aachen.de</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Hi Eric,<br>
<br>
I'm getting quite a few failures with LIBCXX_ENABLE_ASSERTIONS=On (didn't do a<br>
clean build at first):<br>
Failing Tests (32):<br>
    libc++ ::<br>
std/experimental/filesystem/<wbr>class.directory_entry/<wbr>directory_entry.cons.pass.cpp<br>
    libc++ ::<br>
std/experimental/filesystem/<wbr>class.directory_entry/<wbr>directory_entry.mods.pass.cpp<br>
    libc++ ::<br>
std/experimental/filesystem/<wbr>class.directory_entry/<wbr>directory_entry.obs/<wbr>comparisons.pass.cpp<br>
    libc++ ::<br>
std/experimental/filesystem/<wbr>class.directory_iterator/<wbr>directory_iterator.members/<wbr>ctor.pass.cpp<br>
    libc++ ::<br>
std/experimental/filesystem/<wbr>class.directory_iterator/<wbr>directory_iterator.members/<wbr>increment.pass.cpp<br>
    libc++ ::<br>
std/experimental/filesystem/<wbr>class.directory_iterator/<wbr>directory_iterator.nonmembers/<wbr>begin_end.pass.cpp<br>
    libc++ ::<br>
std/experimental/filesystem/<wbr>class.path/path.itr/iterator.<wbr>pass.cpp<br>
    libc++ ::<br>
std/experimental/filesystem/<wbr>class.path/path.member/path.<wbr>append.pass.cpp<br>
    libc++ ::<br>
std/experimental/filesystem/<wbr>class.path/path.member/path.<wbr>assign/source.pass.cpp<br>
    libc++ ::<br>
std/experimental/filesystem/<wbr>class.path/path.member/path.<wbr>compare.pass.cpp<br>
    libc++ ::<br>
std/experimental/filesystem/<wbr>class.path/path.member/path.<wbr>concat.pass.cpp<br>
    libc++ ::<br>
std/experimental/filesystem/<wbr>class.path/path.member/path.<wbr>decompose/path.decompose.pass.<wbr>cpp<br>
    libc++ ::<br>
std/experimental/filesystem/<wbr>class.path/path.member/path.<wbr>modifiers/make_preferred.pass.<wbr>cpp<br>
    libc++ ::<br>
std/experimental/filesystem/<wbr>class.path/path.member/path.<wbr>modifiers/remove_filename.<wbr>pass.cpp<br>
    libc++ ::<br>
std/experimental/filesystem/<wbr>class.path/path.member/path.<wbr>modifiers/replace_extension.<wbr>pass.cpp<br>
    libc++ ::<br>
std/experimental/filesystem/<wbr>class.path/path.member/path.<wbr>modifiers/swap.pass.cpp<br>
    libc++ ::<br>
std/experimental/filesystem/<wbr>class.rec.dir.itr/rec.dir.itr.<wbr>members/ctor.pass.cpp<br>
    libc++ ::<br>
std/experimental/filesystem/<wbr>class.rec.dir.itr/rec.dir.itr.<wbr>members/depth.pass.cpp<br>
    libc++ ::<br>
std/experimental/filesystem/<wbr>class.rec.dir.itr/rec.dir.itr.<wbr>members/increment.pass.cpp<br>
    libc++ ::<br>
std/experimental/filesystem/<wbr>class.rec.dir.itr/rec.dir.itr.<wbr>nonmembers/begin_end.pass.cpp<br>
    libc++ ::<br>
std/experimental/filesystem/<wbr>fs.op.funcs/fs.op.canonical/<wbr>canonical.pass.cpp<br>
    libc++ :: std/experimental/filesystem/<wbr>fs.op.funcs/fs.op.copy/copy.<wbr>pass.cpp<br>
    libc++ ::<br>
std/experimental/filesystem/<wbr>fs.op.funcs/fs.op.is_empty/is_<wbr>empty.pass.cpp<br>
    libc++ ::<br>
std/experimental/filesystem/<wbr>fs.op.funcs/fs.op.permissions/<wbr>permissions.pass.cpp<br>
    libc++ ::<br>
std/experimental/filesystem/<wbr>fs.op.funcs/fs.op.read_<wbr>symlink/read_symlink.pass.cpp<br>
    libc++ ::<br>
std/experimental/filesystem/<wbr>fs.op.funcs/fs.op.remove/<wbr>remove.pass.cpp<br>
    libc++ ::<br>
std/experimental/filesystem/<wbr>fs.op.funcs/fs.op.remove_all/<wbr>remove_all.pass.cpp<br>
    libc++ ::<br>
std/experimental/filesystem/<wbr>fs.op.funcs/fs.op.resize_file/<wbr>resize_file.pass.cpp<br>
    libc++ ::<br>
std/experimental/filesystem/<wbr>fs.op.funcs/fs.op.space/space.<wbr>pass.cpp<br>
    libc++ ::<br>
std/experimental/filesystem/<wbr>fs.op.funcs/fs.op.status/<wbr>status.pass.cpp<br>
    libc++ ::<br>
std/experimental/filesystem/<wbr>fs.op.funcs/fs.op.symlink_<wbr>status/symlink_status.pass.cpp<br>
    libc++ ::<br>
std/experimental/filesystem/<wbr>fs.op.funcs/fs.op.temp_dir_<wbr>path/temp_directory_path.pass.<wbr>cpp<br>
<br>
They go away with LIBCXX_ENABLE_ASSERTIONS=Off which is the new default. Is<br>
this expected to happen?<br>
<br>
Thanks,<br>
Jonas<br>
<div><div class="h5"><br>
> -----Original Message-----<br>
> From: cfe-commits [mailto:<a href="mailto:cfe-commits-bounces@lists.llvm.org">cfe-commits-bounces@<wbr>lists.llvm.org</a>] On Behalf<br>
> Of Eric Fiselier via cfe-commits<br>
> Sent: Sunday, February 05, 2017 12:22 AM<br>
> To: <a href="mailto:cfe-commits@lists.llvm.org">cfe-commits@lists.llvm.org</a><br>
> Subject: [libcxx] r294107 - Recommit [libcxx] Never use <cassert> within<br>
> libc++<br>
><br>
> Author: ericwf<br>
> Date: Sat Feb  4 17:22:28 2017<br>
> New Revision: 294107<br>
><br>
> URL: <a href="http://llvm.org/viewvc/llvm-project?rev=294107&view=rev" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-<wbr>project?rev=294107&view=rev</a><br>
> Log:<br>
> Recommit [libcxx] Never use <cassert> within libc++<br>
><br>
> It is my opinion that libc++ should never use `<cassert>`, including in the<br>
> `dylib`.<br>
> This patch remove all uses of `assert` from within libc++ and replaces most<br>
> of<br>
> them with `_LIBCPP_ASSERT` instead.<br>
><br>
> Additionally this patch turn `LIBCXX_ENABLE_ASSERTIONS`  off by default,<br>
> because the standard library should not be aborting user programs unless<br>
> explicitly asked to.<br>
><br>
> Modified:<br>
>     libcxx/trunk/CMakeLists.txt<br>
>     libcxx/trunk/include/__config<br>
>     libcxx/trunk/include/__<wbr>threading_support<br>
>     libcxx/trunk/src/condition_<wbr>variable.cpp<br>
>     libcxx/trunk/src/experimental/<wbr>filesystem/path.cpp<br>
>     libcxx/trunk/src/mutex.cpp<br>
>     libcxx/trunk/src/system_error.<wbr>cpp<br>
><br>
> Modified: libcxx/trunk/CMakeLists.txt<br>
> URL: <a href="http://llvm.org/viewvc/llvm-" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-</a><br>
> project/libcxx/trunk/<wbr>CMakeLists.txt?rev=294107&r1=<wbr>294106&r2=294107&vie<br>
> w=diff<br>
> ==============================<wbr>============================<br>
> ====================<br>
> --- libcxx/trunk/CMakeLists.txt (original)<br>
> +++ libcxx/trunk/CMakeLists.txt Sat Feb  4 17:22:28 2017<br>
> @@ -60,7 +60,7 @@ endif()<br>
>  include(CMakeDependentOption)<br>
><br>
>  # Basic<br>
> options ------------------------------<wbr>------------------------------<wbr>---<br>
> -option(LIBCXX_ENABLE_<wbr>ASSERTIONS "Enable assertions independent of<br>
> build mode." ON)<br>
> +option(LIBCXX_ENABLE_<wbr>ASSERTIONS "Enable assertions independent of<br>
> build<br>
</div></div>> +mode." OFF)<br>
<div><div class="h5">>  option(LIBCXX_ENABLE_SHARED "Build libc++ as a shared library." ON)<br>
> option(LIBCXX_ENABLE_STATIC "Build libc++ as a static library." ON)<br>
> option(LIBCXX_ENABLE_<wbr>EXPERIMENTAL_LIBRARY "Build<br>
> libc++experimental.a" ON) @@ -501,6 +501,7 @@ endif()  # Assertion flags<br>
> ==============================<wbr>============================<br>
> ===<br>
>  define_if(LIBCXX_ENABLE_<wbr>ASSERTIONS -UNDEBUG)<br>
> define_if_not(LIBCXX_ENABLE_<wbr>ASSERTIONS -DNDEBUG)<br>
> +define_if(LIBCXX_ENABLE_<wbr>ASSERTIONS -D_LIBCPP_DEBUG=0)<br>
>  define_if(LIBCXX_DEBUG_BUILD -D_DEBUG)<br>
>  if (LIBCXX_ENABLE_ASSERTIONS AND NOT LIBCXX_DEBUG_BUILD)<br>
>    # MSVC doesn't like _DEBUG on release builds. See PR 4379.<br>
><br>
> Modified: libcxx/trunk/include/__config<br>
> URL: <a href="http://llvm.org/viewvc/llvm-" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-</a><br>
> project/libcxx/trunk/include/_<wbr>_config?rev=294107&r1=294106&<wbr>r2=294107&v<br>
> iew=diff<br>
> ==============================<wbr>============================<br>
> ====================<br>
> --- libcxx/trunk/include/__config (original)<br>
> +++ libcxx/trunk/include/__config Sat Feb  4 17:22:28 2017<br>
> @@ -817,7 +817,9 @@ template <unsigned> struct __static_asse<br>
>  #   else<br>
>  #       error Supported values for _LIBCPP_DEBUG are 0 and 1<br>
>  #   endif<br>
> +# if !defined(_LIBCPP_BUILDING_<wbr>LIBRARY)<br>
>  #   define _LIBCPP_EXTERN_TEMPLATE(...)<br>
> +# endif<br>
>  #endif<br>
><br>
>  #ifndef _LIBCPP_EXTERN_TEMPLATE<br>
><br>
> Modified: libcxx/trunk/include/__<wbr>threading_support<br>
> URL: <a href="http://llvm.org/viewvc/llvm-" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-</a><br>
> project/libcxx/trunk/include/_<wbr>_threading_support?rev=294107&<wbr>r1=294106&<br>
> r2=294107&view=diff<br>
> ==============================<wbr>============================<br>
> ====================<br>
> --- libcxx/trunk/include/__<wbr>threading_support (original)<br>
> +++ libcxx/trunk/include/__<wbr>threading_support Sat Feb  4 17:22:28 2017<br>
> @@ -25,7 +25,6 @@<br>
>  # include <pthread.h><br>
>  # include <sched.h><br>
>  #elif defined(_LIBCPP_HAS_THREAD_<wbr>API_WIN32)<br>
> -#include <assert.h><br>
>  #include <Windows.h><br>
>  #include <process.h><br>
>  #include <fibersapi.h><br>
><br>
> Modified: libcxx/trunk/src/condition_<wbr>variable.cpp<br>
> URL: <a href="http://llvm.org/viewvc/llvm-" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-</a><br>
> project/libcxx/trunk/src/<wbr>condition_variable.cpp?rev=<wbr>294107&r1=294106&r2=<br>
> 294107&view=diff<br>
> ==============================<wbr>============================<br>
> ====================<br>
> --- libcxx/trunk/src/condition_<wbr>variable.cpp (original)<br>
> +++ libcxx/trunk/src/condition_<wbr>variable.cpp Sat Feb  4 17:22:28 2017<br>
> @@ -14,7 +14,6 @@<br>
>  #include "condition_variable"<br>
>  #include "thread"<br>
>  #include "system_error"<br>
> -#include "cassert"<br>
><br>
>  _LIBCPP_BEGIN_NAMESPACE_STD<br>
><br>
><br>
> Modified: libcxx/trunk/src/experimental/<wbr>filesystem/path.cpp<br>
> URL: <a href="http://llvm.org/viewvc/llvm-" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-</a><br>
> project/libcxx/trunk/src/<wbr>experimental/filesystem/path.<wbr>cpp?rev=294107&r1=<br>
> 294106&r2=294107&view=diff<br>
> ==============================<wbr>============================<br>
> ====================<br>
> --- libcxx/trunk/src/experimental/<wbr>filesystem/path.cpp (original)<br>
> +++ libcxx/trunk/src/experimental/<wbr>filesystem/path.cpp Sat Feb  4<br>
</div></div>> +++ 17:22:28 2017<br>
<div><div class="h5">> @@ -6,11 +6,9 @@<br>
>  // Source Licenses. See LICENSE.TXT for details.<br>
>  //<br>
><br>
> //===-------------------------<wbr>------------------------------<wbr>---------------===//<br>
> -#undef NDEBUG<br>
>  #include "experimental/filesystem"<br>
>  #include "string_view"<br>
>  #include "utility"<br>
> -#include "cassert"<br>
><br>
>  namespace { namespace parser<br>
>  {<br>
> @@ -113,7 +111,6 @@ public:<br>
>    void decrement() noexcept {<br>
>      const PosPtr REnd = &Path.front() - 1;<br>
>      const PosPtr RStart = getCurrentTokenStartPos() - 1;<br>
> -    assert(RStart != REnd);<br>
><br>
>      switch (State) {<br>
>      case PS_AtEnd: {<br>
> @@ -322,7 +319,6 @@ string_view_t path::__root_path_raw() co<br>
>        auto NextCh = PP.peek();<br>
>        if (NextCh && *NextCh == '/') {<br>
>          ++PP;<br>
> -        assert(PP.State == PathParser::PS_InRootDir);<br>
>          return createView(__pn_.data(), &PP.RawEntry.back());<br>
>        }<br>
>        return PP.RawEntry;<br>
><br>
> Modified: libcxx/trunk/src/mutex.cpp<br>
> URL: <a href="http://llvm.org/viewvc/llvm-" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-</a><br>
> project/libcxx/trunk/src/<wbr>mutex.cpp?rev=294107&r1=<wbr>294106&r2=294107&vie<br>
> w=diff<br>
> ==============================<wbr>============================<br>
> ====================<br>
> --- libcxx/trunk/src/mutex.cpp (original)<br>
> +++ libcxx/trunk/src/mutex.cpp Sat Feb  4 17:22:28 2017<br>
> @@ -11,7 +11,6 @@<br>
>  #include "mutex"<br>
>  #include "limits"<br>
>  #include "system_error"<br>
> -#include "cassert"<br>
>  #include "include/atomic_support.h"<br>
><br>
>  _LIBCPP_BEGIN_NAMESPACE_STD<br>
> @@ -45,7 +44,7 @@ mutex::unlock() _NOEXCEPT  {<br>
>      int ec = __libcpp_mutex_unlock(&__m_);<br>
>      (void)ec;<br>
> -    assert(ec == 0);<br>
> +    _LIBCPP_ASSERT(ec == 0, "call to mutex::unlock failed");<br>
>  }<br>
><br>
>  // recursive_mutex<br>
> @@ -61,7 +60,7 @@ recursive_mutex::~recursive_<wbr>mutex()<br>
>  {<br>
>      int e = __libcpp_recursive_mutex_<wbr>destroy(&__m_);<br>
>      (void)e;<br>
> -    assert(e == 0);<br>
> +    _LIBCPP_ASSERT(e == 0, "call to ~recursive_mutex() failed");<br>
>  }<br>
><br>
>  void<br>
> @@ -77,7 +76,7 @@ recursive_mutex::unlock() _NOEXCEPT  {<br>
>      int e = __libcpp_recursive_mutex_<wbr>unlock(&__m_);<br>
>      (void)e;<br>
> -    assert(e == 0);<br>
> +    _LIBCPP_ASSERT(e == 0, "call to recursive_mutex::unlock() failed");<br>
>  }<br>
><br>
>  bool<br>
><br>
> Modified: libcxx/trunk/src/system_error.<wbr>cpp<br>
> URL: <a href="http://llvm.org/viewvc/llvm-" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-</a><br>
> project/libcxx/trunk/src/<wbr>system_error.cpp?rev=294107&<wbr>r1=294106&r2=2941<br>
> 07&view=diff<br>
> ==============================<wbr>============================<br>
> ====================<br>
> --- libcxx/trunk/src/system_error.<wbr>cpp (original)<br>
> +++ libcxx/trunk/src/system_error.<wbr>cpp Sat Feb  4 17:22:28 2017<br>
> @@ -17,9 +17,9 @@<br>
>  #include "cstring"<br>
>  #include "cstdio"<br>
>  #include "cstdlib"<br>
> -#include "cassert"<br>
>  #include "string"<br>
>  #include "string.h"<br>
> +#include "__debug"<br>
><br>
>  #if defined(__ANDROID__)<br>
>  #include <android/api-level.h><br>
> @@ -96,7 +96,7 @@ string do_strerror_r(int ev) {<br>
>              std::snprintf(buffer, strerror_buff_size, "Unknown error %d",<br>
> ev);<br>
>              return string(buffer);<br>
>          } else {<br>
> -            assert(new_errno == ERANGE);<br>
> +            _LIBCPP_ASSERT(new_errno == ERANGE, "unexpected error from<br>
</div></div>> + ::strerr_r");<br>
<div class="HOEnZb"><div class="h5">>              // FIXME maybe? 'strerror_buff_size' is likely to exceed the<br>
>              // maximum error size so ERANGE shouldn't be returned.<br>
>              std::abort();<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>
</div></div></blockquote></div><br></div>