From 9be5b2d23fb46a7da22d16decd044324ed8d4e78 Mon Sep 17 00:00:00 2001 From: Dalai Felinto Date: Fri, 23 Nov 2018 14:41:38 -0200 Subject: Pass viewport to BASE_ related tests, for viewport view/select restrictions Note: functions like select all are still not respecting that. I will fix this as part of the local view commit though. --- source/blender/makesdna/DNA_scene_types.h | 23 +++++++++++++++-------- 1 file changed, 15 insertions(+), 8 deletions(-) (limited to 'source/blender/makesdna/DNA_scene_types.h') diff --git a/source/blender/makesdna/DNA_scene_types.h b/source/blender/makesdna/DNA_scene_types.h index 029e8765c8d..cb72d83e10b 100644 --- a/source/blender/makesdna/DNA_scene_types.h +++ b/source/blender/makesdna/DNA_scene_types.h @@ -1805,24 +1805,31 @@ extern const char *RE_engine_id_CYCLES; #define MINAFRAMEF -1048574.0f /* deprecate this! */ -#define TESTBASE(base) ( \ +#define TESTBASE(v3d, base) ( \ + (((1 << (base)->object->type) & (v3d)->object_type_exclude_viewport) == 0) && \ (((base)->flag & BASE_SELECTED) != 0) && \ (((base)->flag & BASE_VISIBLE) != 0)) -#define TESTBASELIB(base) ( \ +#define TESTBASELIB(v3d, base) ( \ + (((1 << (base)->object->type) & (v3d)->object_type_exclude_viewport) == 0) && \ (((base)->flag & BASE_SELECTED) != 0) && \ ((base)->object->id.lib == NULL) && \ (((base)->flag & BASE_VISIBLE) != 0)) -#define TESTBASELIB_BGMODE(base) ( \ +#define TESTBASELIB_BGMODE(v3d, base) ( \ + ((v3d == NULL) || (((1 << (base)->object->type) & (v3d)->object_type_exclude_viewport) == 0)) && \ (((base)->flag & BASE_SELECTED) != 0) && \ ((base)->object->id.lib == NULL) && \ (((base)->flag & BASE_VISIBLE) != 0)) -#define BASE_EDITABLE_BGMODE(base) ( \ +#define BASE_EDITABLE_BGMODE(v3d, base) ( \ + ((v3d == NULL) || (((1 << (base)->object->type) & (v3d)->object_type_exclude_viewport) == 0)) && \ ((base)->object->id.lib == NULL) && \ (((base)->flag & BASE_VISIBLE) != 0)) -#define BASE_SELECTABLE(base) \ - (((base)->flag & BASE_SELECTABLE) != 0) -#define BASE_VISIBLE(base) ( \ - ((base)->flag & BASE_VISIBLE) != 0) +#define BASE_SELECTABLE(v3d, base) ( \ + (((1 << (base)->object->type) & (v3d)->object_type_exclude_viewport) == 0) && \ + (((1 << (base)->object->type) & (v3d)->object_type_exclude_select) == 0) && \ + (((base)->flag & BASE_SELECTABLE) != 0)) +#define BASE_VISIBLE(v3d, base) ( \ + (((1 << (base)->object->type) & (v3d)->object_type_exclude_viewport) == 0) && \ + (((base)->flag & BASE_VISIBLE) != 0)) #define FIRSTBASE(_view_layer) ((_view_layer)->object_bases.first) #define LASTBASE(_view_layer) ((_view_layer)->object_bases.last) -- cgit v1.2.3