Mercurial > vim
view src/kword_test.c @ 33583:123acdc8e64c v9.0.2036
patch 9.0.2036: if_python: rework python3.12 build dependency
Commit: https://github.com/vim/vim/commit/396058acd0cc66e5071d052e03d2067b134952af
Author: Yee Cheng Chin <ychin.git@gmail.com>
Date: Tue Oct 17 10:38:11 2023 +0200
patch 9.0.2036: if_python: rework python3.12 build dependency
Problem: if_python: rework python3.12 build dependency
(after 9.0.1996)
Solution: use PyTuple_Size instead of inlining the Py_SIZE
into the Vim code base
Use a simpler fix for Python 3.12 build issues
Python 3.12 introduced link dependencies to their `Py_SIZE()` inline
function, which #13290 fixed by copying the inline function to Vim's
Python binding code. This works but it's fragile, as a future update may
change the implementation of `Py_SIZE` and there is no way for us to
know.
The reason we need `Py_SIZE` to begin with is that we use
`PyTuple_GET_SIZE()` which calls that. Just fix it by mapping that to
(confusingly similarly named) `PyTuple_Size()`, which we already do in
the stable ABI implementation. There's a minor performance cost in that
it's not inlined and it does error checking but that's fine as we only
call this function rarely (in an error handler).
related: #13290
closes: #13359
Signed-off-by: Christian Brabandt <cb@256bit.org>
Co-authored-by: Yee Cheng Chin <ychin.git@gmail.com>
author | Christian Brabandt <cb@256bit.org> |
---|---|
date | Tue, 17 Oct 2023 10:45:04 +0200 |
parents | aadd1cae2ff5 |
children |
line wrap: on
line source
/* vi:set ts=8 sts=4 sw=4 noet: * * VIM - Vi IMproved by Bram Moolenaar * * Do ":help uganda" in Vim to read copying and usage conditions. * Do ":help credits" in Vim to see a list of people who contributed. * See README.txt for an overview of the Vim source code. */ /* * kword_test.c: Unittests for vim_iswordc() and vim_iswordp(). */ #undef NDEBUG #include <assert.h> // Must include main.c because it contains much more than just main() #define NO_VIM_MAIN #include "main.c" // This file has to be included because the tested functions are static #include "charset.c" /* * Test the results of vim_iswordc() and vim_iswordp() are matched. */ static void test_isword_funcs_utf8(void) { buf_T buf; int c; CLEAR_FIELD(buf); p_enc = (char_u *)"utf-8"; p_isi = (char_u *)""; p_isp = (char_u *)""; p_isf = (char_u *)""; buf.b_p_isk = (char_u *)"@,48-57,_,128-167,224-235"; curbuf = &buf; mb_init(); // calls init_chartab() for (c = 0; c < 0x10000; ++c) { char_u p[4] = {0}; int c1; int retc; int retp; utf_char2bytes(c, p); c1 = utf_ptr2char(p); if (c != c1) { fprintf(stderr, "Failed: "); fprintf(stderr, "[c = %#04x, p = {%#02x, %#02x, %#02x}] ", c, p[0], p[1], p[2]); fprintf(stderr, "c != utf_ptr2char(p) (=%#04x)\n", c1); abort(); } retc = vim_iswordc_buf(c, &buf); retp = vim_iswordp_buf(p, &buf); if (retc != retp) { fprintf(stderr, "Failed: "); fprintf(stderr, "[c = %#04x, p = {%#02x, %#02x, %#02x}] ", c, p[0], p[1], p[2]); fprintf(stderr, "vim_iswordc(c) (=%d) != vim_iswordp(p) (=%d)\n", retc, retp); abort(); } } } int main(void) { estack_init(); test_isword_funcs_utf8(); return 0; }