Use a shorter/simpler license convention, stops the header taking so much space. Follow the SPDX license specification: https://spdx.org/licenses - C/C++/objc/objc++ - Python - Shell Scripts - CMake, GNUmakefile While most of the source tree has been included - `./extern/` was left out. - `./intern/cycles` & `./intern/atomic` are also excluded because they use different header conventions. doc/license/SPDX-license-identifiers.txt has been added to list SPDX all used identifiers. See P2788 for the script that automated these edits. Reviewed By: brecht, mont29, sergey Ref D14069
84 lines
2.1 KiB
C
84 lines
2.1 KiB
C
/* SPDX-License-Identifier: GPL-2.0-or-later */
|
|
|
|
/** \file
|
|
* \ingroup pythonintern
|
|
*
|
|
* This file defines utility functions that use the RNA API, from PyDrivers.
|
|
*/
|
|
|
|
#include <Python.h>
|
|
|
|
#include "MEM_guardedalloc.h"
|
|
|
|
#include "BLI_utildefines.h"
|
|
|
|
#include "BKE_fcurve_driver.h"
|
|
|
|
#include "RNA_access.h"
|
|
|
|
#include "bpy_rna.h"
|
|
|
|
#include "bpy_rna_driver.h" /* own include */
|
|
|
|
PyObject *pyrna_driver_get_variable_value(struct ChannelDriver *driver, struct DriverTarget *dtar)
|
|
{
|
|
PyObject *driver_arg = NULL;
|
|
PointerRNA ptr;
|
|
PropertyRNA *prop = NULL;
|
|
int index;
|
|
|
|
if (driver_get_variable_property(driver, dtar, &ptr, &prop, &index)) {
|
|
if (prop) {
|
|
if (index != -1) {
|
|
if (index < RNA_property_array_length(&ptr, prop) && index >= 0) {
|
|
/* object, property & index */
|
|
driver_arg = pyrna_array_index(&ptr, prop, index);
|
|
}
|
|
else {
|
|
/* out of range, pass */
|
|
}
|
|
}
|
|
else {
|
|
/* object & property */
|
|
const PropertyType type = RNA_property_type(prop);
|
|
if (type == PROP_ENUM) {
|
|
/* Note that enum's are converted to strings by default,
|
|
* we want to avoid that, see: T52213 */
|
|
driver_arg = PyLong_FromLong(RNA_property_enum_get(&ptr, prop));
|
|
}
|
|
else {
|
|
driver_arg = pyrna_prop_to_py(&ptr, prop);
|
|
}
|
|
}
|
|
}
|
|
else {
|
|
/* object only */
|
|
driver_arg = pyrna_struct_CreatePyObject(&ptr);
|
|
}
|
|
}
|
|
else {
|
|
/* can't resolve path, pass */
|
|
}
|
|
|
|
return driver_arg;
|
|
}
|
|
|
|
PyObject *pyrna_driver_self_from_anim_rna(PathResolvedRNA *anim_rna)
|
|
{
|
|
return pyrna_struct_CreatePyObject(&anim_rna->ptr);
|
|
}
|
|
|
|
bool pyrna_driver_is_equal_anim_rna(const PathResolvedRNA *anim_rna, const PyObject *py_anim_rna)
|
|
{
|
|
if (BPy_StructRNA_Check(py_anim_rna)) {
|
|
const PointerRNA *ptr_a = &anim_rna->ptr;
|
|
const PointerRNA *ptr_b = &(((const BPy_StructRNA *)py_anim_rna)->ptr);
|
|
|
|
if ((ptr_a->owner_id == ptr_b->owner_id) && (ptr_a->type == ptr_b->type) &&
|
|
(ptr_a->data == ptr_b->data)) {
|
|
return true;
|
|
}
|
|
}
|
|
return false;
|
|
}
|