Skip site navigation (1)Skip section navigation (2)
Date:      Sun, 18 Dec 2022 17:43:51 GMT
From:      Dimitry Andric <dim@FreeBSD.org>
To:        ports-committers@FreeBSD.org, dev-commits-ports-all@FreeBSD.org, dev-commits-ports-main@FreeBSD.org
Subject:   git: 9f8385f9876a - main - lang/gjs: fix build with libc++ 15
Message-ID:  <202212181743.2BIHhp7q006470@gitrepo.freebsd.org>

next in thread | raw e-mail | index | archive | help
The branch main has been updated by dim (src committer):

URL: https://cgit.FreeBSD.org/ports/commit/?id=9f8385f9876a46d8566cd655062c8ba24efac2f5

commit 9f8385f9876a46d8566cd655062c8ba24efac2f5
Author:     Dimitry Andric <dim@FreeBSD.org>
AuthorDate: 2022-12-12 13:49:23 +0000
Commit:     Dimitry Andric <dim@FreeBSD.org>
CommitDate: 2022-12-18 17:34:13 +0000

    lang/gjs: fix build with libc++ 15
    
    During an exp-run for llvm 15 (see bug 265425), it turned out that
    lang/gjs failed to build with clang and libc++ 15:
    
      In file included from ../test/gjs-tests.cpp:11:
      In file included from /usr/include/c++/v1/random:1689:
      In file included from /usr/include/c++/v1/__random/discrete_distribution.h:18:
      In file included from /usr/include/c++/v1/numeric:167:
      In file included from /usr/include/c++/v1/functional:515:
      In file included from /usr/include/c++/v1/__functional/boyer_moore_searcher.h:24:
      In file included from /usr/include/c++/v1/array:127:
      In file included from /usr/include/c++/v1/algorithm:1851:
      In file included from /usr/include/c++/v1/__algorithm/ranges_sample.h:13:
      In file included from /usr/include/c++/v1/__algorithm/sample.h:18:
      /usr/include/c++/v1/__random/uniform_int_distribution.h:162:5: error: static assertion failed due to requirement '__libcpp_random_is_valid_inttype<char32_t>::value': IntType must be a supported integer type
          static_assert(__libcpp_random_is_valid_inttype<_IntType>::value, "IntType must be a supported integer type");
          ^             ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
      ../test/gjs-tests.cpp:71:16: note: in instantiation of template class 'std::uniform_int_distribution<char32_t>' requested here
              return std::uniform_int_distribution<T>(lowest_value)(gen);
                     ^
      ../test/gjs-tests.cpp:942:30: note: in instantiation of function template specialization 'Gjs::Test::get_random_number<char32_t>' requested here
          char32_t random_char32 = get_random_number<char32_t>();
                                   ^
    
    This is because std::uniform_int_distribution is only defined for strict
    integer types, such as short, int, etc. Use
    std::uniform_int_distribution<uint32_t> instead, and cast the result
    back to a char32_t.
    
    PR:             268329
    Approved by:    portmgr (tcberner)
    MFH:            2022Q4
---
 lang/gjs/files/patch-test_gjs-tests.cpp | 11 +++++++++++
 1 file changed, 11 insertions(+)

diff --git a/lang/gjs/files/patch-test_gjs-tests.cpp b/lang/gjs/files/patch-test_gjs-tests.cpp
new file mode 100644
index 000000000000..e5287370143d
--- /dev/null
+++ b/lang/gjs/files/patch-test_gjs-tests.cpp
@@ -0,0 +1,11 @@
+--- test/gjs-tests.cpp.orig	2022-08-08 05:05:12 UTC
++++ test/gjs-tests.cpp
+@@ -939,7 +939,7 @@ static void gjstest_test_args_set_get_unset() {
+     assert_equal(arg.v_uint64, random_uint64);
+     assert_equal(gjs_arg_get<uint64_t>(&arg), random_uint64);
+ 
+-    char32_t random_char32 = get_random_number<char32_t>();
++    char32_t random_char32 = static_cast<char32_t>(get_random_number<uint32_t>());
+     gjs_arg_set(&arg, random_char32);
+     assert_equal(static_cast<char32_t>(arg.v_uint32), random_char32);
+     assert_equal(gjs_arg_get<char32_t>(&arg), random_char32);



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?202212181743.2BIHhp7q006470>