Mercurial > vim
view src/iid_ole.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 | 82c732e8d23d |
children |
line wrap: on
line source
// this file contains the actual definitions of // the IIDs and CLSIDs // link this file in with the server and any clients // File created by MIDL compiler version 3.00.44 // at Sat Jan 03 16:34:55 1998 // Compiler settings for if_ole.idl: // Os (OptLev=s), W1, Zp8, env=Win32, ms_ext, c_ext // error checks: none //@@MIDL_FILE_HEADING( ) #ifdef __cplusplus extern "C"{ #endif #ifdef __MINGW32__ # include <w32api.h> # if __W32API_MAJOR_VERSION == 3 && __W32API_MINOR_VERSION < 10 // This define is missing from older MingW versions of w32api, even though // IID is defined. # define __IID_DEFINED__ # endif #endif #ifndef __IID_DEFINED__ # define __IID_DEFINED__ typedef struct _IID { unsigned long x; unsigned short s1; unsigned short s2; unsigned char c[8]; } IID; #endif #ifndef CLSID_DEFINED # define CLSID_DEFINED typedef IID CLSID; #endif const IID IID_IVim = {0x0F0BFAE2,0x4C90,0x11d1,{0x82,0xD7,0x00,0x04,0xAC,0x36,0x85,0x19}}; const IID LIBID_Vim = {0x0F0BFAE0,0x4C90,0x11d1,{0x82,0xD7,0x00,0x04,0xAC,0x36,0x85,0x19}}; const CLSID CLSID_Vim = {0x0F0BFAE1,0x4C90,0x11d1,{0x82,0xD7,0x00,0x04,0xAC,0x36,0x85,0x19}}; #ifdef __cplusplus } #endif