diff options
author | Campbell Barton <ideasman42@gmail.com> | 2021-01-22 04:42:20 +0300 |
---|---|---|
committer | Campbell Barton <ideasman42@gmail.com> | 2021-01-22 04:42:20 +0300 |
commit | 4f3fba2aa78ee1bd97963630e7c17b0d22cc7c35 (patch) | |
tree | 9b5403b6a6b1472afbd60b44c15f8d1da9171474 /source/blender/editors/object | |
parent | 665eca85baaee380c067b375d22647d3c6c95a0e (diff) | |
parent | 7b528b2a3ad33b3ad7328213669d8179528e254b (diff) |
Merge branch 'blender-v2.92-release'
Diffstat (limited to 'source/blender/editors/object')
-rw-r--r-- | source/blender/editors/object/object_select.c | 15 |
1 files changed, 15 insertions, 0 deletions
diff --git a/source/blender/editors/object/object_select.c b/source/blender/editors/object/object_select.c index ab404f0a72d..ede0a92cede 100644 --- a/source/blender/editors/object/object_select.c +++ b/source/blender/editors/object/object_select.c @@ -143,6 +143,21 @@ void ED_object_base_activate(bContext *C, Base *base) ED_object_base_active_refresh(CTX_data_main(C), scene, view_layer); } +void ED_object_base_activate_with_mode_exit_if_needed(bContext *C, Base *base) +{ + ViewLayer *view_layer = CTX_data_view_layer(C); + + /* Currently we only need to be concerned with edit-mode. */ + Object *obedit = OBEDIT_FROM_VIEW_LAYER(view_layer); + if (obedit) { + Object *ob = base->object; + if (((ob->mode & OB_MODE_EDIT) == 0) || (obedit->type != ob->type)) { + ED_object_editmode_exit(C, EM_FREEDATA); + } + } + ED_object_base_activate(C, base); +} + bool ED_object_base_deselect_all_ex(ViewLayer *view_layer, View3D *v3d, int action, |