7045717
--- blender-3.6.1/source/blender/freestyle/intern/python/BPy_IntegrationType.cpp.pyorig	2023-05-18 08:04:44.000000000 +0900
7045717
+++ blender-3.6.1/source/blender/freestyle/intern/python/BPy_IntegrationType.cpp	2023-08-01 16:30:13.609640614 +0900
7045717
@@ -186,6 +186,7 @@ PyTypeObject IntegrationType_Type = {
7045717
 
7045717
 /*-----------------------BPy_IntegrationType instance definitions -------------------------*/
7045717
 
7045717
+#if PY_VERSION_HEX < 0x030c0000 /* older than Python 3.12 */
7045717
 static PyLongObject _IntegrationType_MEAN = {
7045717
     PyVarObject_HEAD_INIT(&IntegrationType_Type, 1){MEAN}};
7045717
 static PyLongObject _IntegrationType_MIN = {PyVarObject_HEAD_INIT(&IntegrationType_Type, 1){MIN}};
7045717
@@ -194,6 +195,26 @@ static PyLongObject _IntegrationType_FIR
7045717
     PyVarObject_HEAD_INIT(&IntegrationType_Type, 1){FIRST}};
7045717
 static PyLongObject _IntegrationType_LAST = {
7045717
     PyVarObject_HEAD_INIT(&IntegrationType_Type, 1){LAST}};
7045717
+#else
7045717
+#define NON_SIZE_BITS 3
7045717
+#define TAG_FROM_SIGN_AND_SIZE(sign, size) ((1 - (sign)) | ((size) << NON_SIZE_BITS))
7045717
+#define _Py_IntegrationTypeType_DIGIT_INIT(val) \
7045717
+    { \
7045717
+        .ob_base = PyObject_HEAD_INIT(&IntegrationType_Type) \
7045717
+        .long_value  = { \
7045717
+            .lv_tag = TAG_FROM_SIGN_AND_SIZE( \
7045717
+                (val) == 0 ? 0 : ((val) < 0 ? -1 : 1), \
7045717
+                (val) == 0 ? 0 : 1), \
7045717
+            { ((val) >= 0 ? (val) : -(val)) }, \
7045717
+        } \
7045717
+    }
7045717
+
7045717
+static PyLongObject _IntegrationType_MEAN = _Py_IntegrationTypeType_DIGIT_INIT(MEAN);
7045717
+static PyLongObject _IntegrationType_MIN = _Py_IntegrationTypeType_DIGIT_INIT(MIN);
7045717
+static PyLongObject _IntegrationType_MAX = _Py_IntegrationTypeType_DIGIT_INIT(MAX);
7045717
+static PyLongObject _IntegrationType_FIRST = _Py_IntegrationTypeType_DIGIT_INIT(FIRST);
7045717
+static PyLongObject _IntegrationType_LAST = _Py_IntegrationTypeType_DIGIT_INIT(LAST);
7045717
+#endif
7045717
 
7045717
 #define BPy_IntegrationType_MEAN ((PyObject *)&_IntegrationType_MEAN)
7045717
 #define BPy_IntegrationType_MIN ((PyObject *)&_IntegrationType_MIN)
7045717
--- blender-3.6.1/source/blender/freestyle/intern/python/BPy_MediumType.cpp.pyorig	2023-05-18 08:04:44.000000000 +0900
7045717
+++ blender-3.6.1/source/blender/freestyle/intern/python/BPy_MediumType.cpp	2023-08-01 16:30:18.875628797 +0900
7045717
@@ -71,6 +71,7 @@ PyTypeObject MediumType_Type = {
7045717
 
7045717
 /*-----------------------BPy_IntegrationType instance definitions -------------------------*/
7045717
 
7045717
+#if PY_VERSION_HEX < 0x030c0000 /* older than Python 3.12 */
7045717
 PyLongObject _BPy_MediumType_DRY_MEDIUM = {
7045717
     PyVarObject_HEAD_INIT(&MediumType_Type, 1){Stroke::DRY_MEDIUM},
7045717
 };
7045717
@@ -80,6 +81,24 @@ PyLongObject _BPy_MediumType_HUMID_MEDIU
7045717
 PyLongObject _BPy_MediumType_OPAQUE_MEDIUM = {
7045717
     PyVarObject_HEAD_INIT(&MediumType_Type, 1){Stroke::OPAQUE_MEDIUM},
7045717
 };
7045717
+#else
7045717
+#define NON_SIZE_BITS 3
7045717
+#define TAG_FROM_SIGN_AND_SIZE(sign, size) ((1 - (sign)) | ((size) << NON_SIZE_BITS))
7045717
+#define _Py_MediumType_DIGIT_INIT(val) \
7045717
+    { \
7045717
+        .ob_base = PyObject_HEAD_INIT(&MediumType_Type) \
7045717
+        .long_value  = { \
7045717
+            .lv_tag = TAG_FROM_SIGN_AND_SIZE( \
7045717
+                (val) == 0 ? 0 : ((val) < 0 ? -1 : 1), \
7045717
+                (val) == 0 ? 0 : 1), \
7045717
+            { ((val) >= 0 ? (val) : -(val)) }, \
7045717
+        } \
7045717
+    }
7045717
+
7045717
+PyLongObject _BPy_MediumType_DRY_MEDIUM = _Py_MediumType_DIGIT_INIT(Stroke::DRY_MEDIUM);
7045717
+PyLongObject _BPy_MediumType_HUMID_MEDIUM = _Py_MediumType_DIGIT_INIT(Stroke::HUMID_MEDIUM);
7045717
+PyLongObject _BPy_MediumType_OPAQUE_MEDIUM = _Py_MediumType_DIGIT_INIT(Stroke::OPAQUE_MEDIUM);
7045717
+#endif
7045717
 
7045717
 //-------------------MODULE INITIALIZATION--------------------------------
7045717
 
7045717
--- blender-3.6.1/source/blender/freestyle/intern/python/BPy_Nature.cpp.pyorig	2023-05-18 08:04:44.000000000 +0900
7045717
+++ blender-3.6.1/source/blender/freestyle/intern/python/BPy_Nature.cpp	2023-08-01 16:49:31.446042329 +0900
7045717
@@ -135,6 +135,7 @@ PyTypeObject Nature_Type = {
7045717
 
7045717
 /*-----------------------BPy_Nature instance definitions ----------------------------------*/
7045717
 
7045717
+#if PY_VERSION_HEX < 0x030c0000 /* older than Python 3.12 */
7045717
 static PyLongObject _Nature_POINT = {PyVarObject_HEAD_INIT(&Nature_Type, 0){Nature::POINT}};
7045717
 static PyLongObject _Nature_S_VERTEX = {PyVarObject_HEAD_INIT(&Nature_Type, 1){Nature::S_VERTEX}};
7045717
 static PyLongObject _Nature_VIEW_VERTEX = {
7045717
@@ -157,6 +158,36 @@ static PyLongObject _Nature_MATERIAL_BOU
7045717
     PyVarObject_HEAD_INIT(&Nature_Type, 1){Nature::MATERIAL_BOUNDARY}};
7045717
 static PyLongObject _Nature_EDGE_MARK = {
7045717
     PyVarObject_HEAD_INIT(&Nature_Type, 1){Nature::EDGE_MARK}};
7045717
+#else
7045717
+#define NON_SIZE_BITS 3
7045717
+#define TAG_FROM_SIGN_AND_SIZE(sign, size) ((1 - (sign)) | ((size) << NON_SIZE_BITS))
7045717
+#define _Py_Nature_TypeType_DIGIT_INIT(val) \
7045717
+    { \
7045717
+        .ob_base = PyObject_HEAD_INIT(&Nature_Type) \
7045717
+        .long_value  = { \
7045717
+            .lv_tag = TAG_FROM_SIGN_AND_SIZE( \
7045717
+                (val) == 0 ? 0 : ((val) < 0 ? -1 : 1), \
7045717
+                (val) == 0 ? 0 : 1), \
7045717
+            { ((val) >= 0 ? (val) : -(val)) }, \
7045717
+        } \
7045717
+    }
7045717
+
7045717
+static PyLongObject _Nature_POINT = _Py_Nature_TypeType_DIGIT_INIT(Nature::POINT);
7045717
+static PyLongObject _Nature_S_VERTEX = _Py_Nature_TypeType_DIGIT_INIT(Nature::S_VERTEX);
7045717
+static PyLongObject _Nature_VIEW_VERTEX = _Py_Nature_TypeType_DIGIT_INIT(Nature::VIEW_VERTEX);
7045717
+static PyLongObject _Nature_NON_T_VERTEX = _Py_Nature_TypeType_DIGIT_INIT(Nature::NON_T_VERTEX);
7045717
+static PyLongObject _Nature_T_VERTEX = _Py_Nature_TypeType_DIGIT_INIT(Nature::T_VERTEX);
7045717
+static PyLongObject _Nature_CUSP = _Py_Nature_TypeType_DIGIT_INIT(Nature::CUSP);
7045717
+static PyLongObject _Nature_NO_FEATURE = _Py_Nature_TypeType_DIGIT_INIT(Nature::NO_FEATURE);
7045717
+static PyLongObject _Nature_SILHOUETTE = _Py_Nature_TypeType_DIGIT_INIT(Nature::SILHOUETTE);
7045717
+static PyLongObject _Nature_BORDER = _Py_Nature_TypeType_DIGIT_INIT(Nature::BORDER);
7045717
+static PyLongObject _Nature_CREASE = _Py_Nature_TypeType_DIGIT_INIT(Nature::CREASE);
7045717
+static PyLongObject _Nature_RIDGE = _Py_Nature_TypeType_DIGIT_INIT(Nature::RIDGE);
7045717
+static PyLongObject _Nature_VALLEY = _Py_Nature_TypeType_DIGIT_INIT(Nature::VALLEY);
7045717
+static PyLongObject _Nature_SUGGESTIVE_CONTOUR = _Py_Nature_TypeType_DIGIT_INIT(Nature::SUGGESTIVE_CONTOUR);
7045717
+static PyLongObject _Nature_MATERIAL_BOUNDARY = _Py_Nature_TypeType_DIGIT_INIT(Nature::MATERIAL_BOUNDARY);
7045717
+static PyLongObject _Nature_EDGE_MARK = _Py_Nature_TypeType_DIGIT_INIT(Nature::EDGE_MARK);
7045717
+#endif
7045717
 
7045717
 #define BPy_Nature_POINT ((PyObject *)&_Nature_POINT)
7045717
 #define BPy_Nature_S_VERTEX ((PyObject *)&_Nature_S_VERTEX)
7045717
@@ -247,7 +278,12 @@ static PyObject *BPy_Nature_bitwise(PyOb
7045717
   else {
7045717
     result = PyObject_NewVar(BPy_Nature, &Nature_Type, 1);
7045717
     if (result) {
7045717
+#if PY_VERSION_HEX >= 0x030c0000 /* Python 3.12 and newer */
7045717
+      result->i.long_value.lv_tag = TAG_FROM_SIGN_AND_SIZE((v > 0 ? 1 : -1), 1);
7045717
+      result->i.long_value.ob_digit[0] = v;
7045717
+#else
7045717
       result->i.ob_digit[0] = v;
7045717
+#endif
7045717
     }
7045717
   }
7045717
   return (PyObject *)result;