2023-08-16 00:20:26 +10:00
|
|
|
/* SPDX-FileCopyrightText: 2023 Blender Authors
|
2023-05-31 16:19:06 +02:00
|
|
|
*
|
|
|
|
|
* SPDX-License-Identifier: GPL-2.0-or-later */
|
2009-11-16 18:56:58 +00:00
|
|
|
|
2019-02-18 08:08:12 +11:00
|
|
|
/** \file
|
|
|
|
|
* \ingroup pygen
|
2011-02-27 20:10:08 +00:00
|
|
|
*/
|
|
|
|
|
|
2012-02-17 18:59:41 +00:00
|
|
|
#pragma once
|
2006-11-17 04:46:48 +00:00
|
|
|
|
2025-01-07 12:39:13 +01:00
|
|
|
#include <Python.h>
|
|
|
|
|
|
2019-01-28 21:08:24 +11:00
|
|
|
struct BPy_IDGroup_Iter;
|
2006-11-17 04:46:48 +00:00
|
|
|
struct ID;
|
|
|
|
|
struct IDProperty;
|
|
|
|
|
|
2012-10-31 19:07:25 +00:00
|
|
|
extern PyTypeObject BPy_IDArray_Type;
|
|
|
|
|
extern PyTypeObject BPy_IDGroup_Type;
|
|
|
|
|
|
2021-05-11 09:40:41 +10:00
|
|
|
extern PyTypeObject BPy_IDGroup_ViewKeys_Type;
|
|
|
|
|
extern PyTypeObject BPy_IDGroup_ViewValues_Type;
|
|
|
|
|
extern PyTypeObject BPy_IDGroup_ViewItems_Type;
|
|
|
|
|
|
|
|
|
|
extern PyTypeObject BPy_IDGroup_IterKeys_Type;
|
|
|
|
|
extern PyTypeObject BPy_IDGroup_IterValues_Type;
|
|
|
|
|
extern PyTypeObject BPy_IDGroup_IterItems_Type;
|
|
|
|
|
|
2012-10-31 19:07:25 +00:00
|
|
|
#define BPy_IDArray_Check(v) (PyObject_TypeCheck(v, &BPy_IDArray_Type))
|
|
|
|
|
#define BPy_IDArray_CheckExact(v) (Py_TYPE(v) == &BPy_IDArray_Type)
|
|
|
|
|
#define BPy_IDGroup_Check(v) (PyObject_TypeCheck(v, &BPy_IDGroup_Type))
|
|
|
|
|
#define BPy_IDGroup_CheckExact(v) (Py_TYPE(v) == &BPy_IDGroup_Type)
|
|
|
|
|
|
2021-05-11 09:40:41 +10:00
|
|
|
#define BPy_IDGroup_ViewKeys_Check(v) (PyObject_TypeCheck(v, &BPy_IDGroup_ViewKeys_Type))
|
|
|
|
|
#define BPy_IDGroup_ViewKeys_CheckExact(v) (Py_TYPE(v) == &BPy_IDGroup_ViewKeys_Type)
|
|
|
|
|
#define BPy_IDGroup_ViewValues_Check(v) (PyObject_TypeCheck(v, &BPy_IDGroup_ViewValues_Type))
|
|
|
|
|
#define BPy_IDGroup_ViewValues_CheckExact(v) (Py_TYPE(v) == &BPy_IDGroup_ViewValues_Type)
|
|
|
|
|
#define BPy_IDGroup_ViewItems_Check(v) (PyObject_TypeCheck(v, &BPy_IDGroup_ViewItems_Type))
|
|
|
|
|
#define BPy_IDGroup_ViewItems_CheckExact(v) (Py_TYPE(v) == &BPy_IDGroup_ViewItems_Type)
|
|
|
|
|
|
|
|
|
|
#define BPy_IDGroup_IterKeys_Check(v) (PyObject_TypeCheck(v, &BPy_IDGroup_IterKeys_Type))
|
|
|
|
|
#define BPy_IDGroup_IterKeys_CheckExact(v) (Py_TYPE(v) == &BPy_IDGroup_IterKeys_Type)
|
|
|
|
|
#define BPy_IDGroup_IterValues_Check(v) (PyObject_TypeCheck(v, &BPy_IDGroup_IterValues_Type))
|
|
|
|
|
#define BPy_IDGroup_IterValues_CheckExact(v) (Py_TYPE(v) == &BPy_IDGroup_IterValues_Type)
|
|
|
|
|
#define BPy_IDGroup_IterItems_Check(v) (PyObject_TypeCheck(v, &BPy_IDGroup_IterItems_Type))
|
|
|
|
|
#define BPy_IDGroup_IterItems_CheckExact(v) (Py_TYPE(v) == &BPy_IDGroup_IterItems_Type)
|
|
|
|
|
|
2024-09-24 15:25:36 +02:00
|
|
|
struct BPy_IDProperty {
|
2021-04-01 11:15:47 +11:00
|
|
|
PyObject_VAR_HEAD
|
2021-06-14 18:13:19 +02:00
|
|
|
struct ID *owner_id; /* can be NULL */
|
2021-04-01 11:15:47 +11:00
|
|
|
struct IDProperty *prop; /* must be second member */
|
2011-06-17 05:45:46 +00:00
|
|
|
struct IDProperty *parent;
|
2024-09-24 15:25:36 +02:00
|
|
|
};
|
2006-11-17 04:46:48 +00:00
|
|
|
|
2024-09-24 15:25:36 +02:00
|
|
|
struct BPy_IDArray {
|
2021-04-01 11:15:47 +11:00
|
|
|
PyObject_VAR_HEAD
|
2021-06-14 18:13:19 +02:00
|
|
|
struct ID *owner_id; /* can be NULL */
|
2021-04-01 11:15:47 +11:00
|
|
|
struct IDProperty *prop; /* must be second member */
|
2024-09-24 15:25:36 +02:00
|
|
|
};
|
2006-11-17 04:46:48 +00:00
|
|
|
|
2024-09-24 15:25:36 +02:00
|
|
|
struct BPy_IDGroup_Iter {
|
2021-04-01 11:15:47 +11:00
|
|
|
PyObject_VAR_HEAD
|
|
|
|
|
BPy_IDProperty *group;
|
2006-11-17 04:46:48 +00:00
|
|
|
struct IDProperty *cur;
|
2021-05-11 09:40:41 +10:00
|
|
|
/** Use for detecting manipulation during iteration (which is not allowed). */
|
|
|
|
|
int len_init;
|
|
|
|
|
/** Iterate in the reverse direction. */
|
|
|
|
|
bool reversed;
|
2024-09-24 15:25:36 +02:00
|
|
|
};
|
2006-11-17 04:46:48 +00:00
|
|
|
|
2021-05-11 09:40:41 +10:00
|
|
|
/** Use to implement `IDPropertyGroup.keys/values/items` */
|
2024-09-24 15:25:36 +02:00
|
|
|
struct BPy_IDGroup_View {
|
2021-05-11 09:40:41 +10:00
|
|
|
PyObject_VAR_HEAD
|
|
|
|
|
/** This will be NULL when accessing keys on data that has no ID properties. */
|
|
|
|
|
BPy_IDProperty *group;
|
|
|
|
|
bool reversed;
|
2024-09-24 15:25:36 +02:00
|
|
|
};
|
2021-05-11 09:40:41 +10:00
|
|
|
|
2024-09-24 15:25:36 +02:00
|
|
|
PyObject *BPy_Wrap_GetKeys(IDProperty *prop);
|
|
|
|
|
PyObject *BPy_Wrap_GetValues(ID *id, IDProperty *prop);
|
|
|
|
|
PyObject *BPy_Wrap_GetItems(ID *id, IDProperty *prop);
|
2021-05-11 09:40:41 +10:00
|
|
|
|
2024-09-24 15:25:36 +02:00
|
|
|
PyObject *BPy_Wrap_GetKeys_View_WithID(ID *id, IDProperty *prop);
|
|
|
|
|
PyObject *BPy_Wrap_GetValues_View_WithID(ID *id, IDProperty *prop);
|
|
|
|
|
PyObject *BPy_Wrap_GetItems_View_WithID(ID *id, IDProperty *prop);
|
2021-05-11 09:40:41 +10:00
|
|
|
|
2024-09-24 15:25:36 +02:00
|
|
|
int BPy_Wrap_SetMapItem(IDProperty *prop, PyObject *key, PyObject *val);
|
2009-11-16 20:16:45 +00:00
|
|
|
|
2021-12-02 17:24:04 +11:00
|
|
|
/**
|
|
|
|
|
* For simple, non nested types this is the same as #BPy_IDGroup_WrapData.
|
|
|
|
|
*/
|
2024-09-24 15:25:36 +02:00
|
|
|
PyObject *BPy_IDGroup_MapDataToPy(IDProperty *prop);
|
|
|
|
|
PyObject *BPy_IDGroup_WrapData(ID *id, IDProperty *prop, IDProperty *parent);
|
2021-12-02 17:24:04 +11:00
|
|
|
/**
|
|
|
|
|
* \note group can be a pointer array or a group.
|
|
|
|
|
* assume we already checked key is a string.
|
|
|
|
|
*
|
|
|
|
|
* \return success.
|
|
|
|
|
*/
|
2024-09-24 15:25:36 +02:00
|
|
|
bool BPy_IDProperty_Map_ValidateAndCreate(PyObject *key, IDProperty *group, PyObject *ob);
|
2006-12-16 23:54:45 +00:00
|
|
|
|
2024-09-24 15:25:36 +02:00
|
|
|
void IDProp_Init_Types();
|
2023-07-21 02:18:59 +02:00
|
|
|
|
2024-09-24 15:25:36 +02:00
|
|
|
PyObject *BPyInit_idprop();
|