Fix T56707: Assert changing grease pencil modes
This commit is contained in:
parent
ee6b95f7e0
commit
066afa2198
Notes:
blender-bot
2023-02-14 05:21:02 +01:00
Referenced by issue #56707, Gizmo crash when change mode when rotate tool activate
|
@ -73,6 +73,8 @@
|
|||
|
||||
#include "WM_api.h"
|
||||
#include "WM_types.h"
|
||||
#include "WM_message.h"
|
||||
#include "WM_toolsystem.h"
|
||||
|
||||
#include "RNA_access.h"
|
||||
#include "RNA_define.h"
|
||||
|
@ -113,8 +115,10 @@ static bool gpencil_editmode_toggle_poll(bContext *C)
|
|||
static int gpencil_editmode_toggle_exec(bContext *C, wmOperator *op)
|
||||
{
|
||||
const int back = RNA_boolean_get(op->ptr, "back");
|
||||
Depsgraph *depsgraph = CTX_data_depsgraph(C); \
|
||||
bGPdata *gpd = ED_gpencil_data_get_active(C);
|
||||
|
||||
struct wmMsgBus *mbus = CTX_wm_message_bus(C);
|
||||
Depsgraph *depsgraph = CTX_data_depsgraph(C);
|
||||
bGPdata *gpd = ED_gpencil_data_get_active(C);
|
||||
bool is_object = false;
|
||||
short mode;
|
||||
/* if using a gpencil object, use this datablock */
|
||||
|
@ -161,6 +165,13 @@ static int gpencil_editmode_toggle_exec(bContext *C, wmOperator *op)
|
|||
WM_event_add_notifier(C, NC_GPENCIL | ND_GPENCIL_EDITMODE, NULL);
|
||||
WM_event_add_notifier(C, NC_SCENE | ND_MODE, NULL);
|
||||
|
||||
if (is_object) {
|
||||
WM_msg_publish_rna_prop(mbus, &ob->id, ob, Object, mode);
|
||||
}
|
||||
if (G.background == false) {
|
||||
WM_toolsystem_update_from_context_view3d(C);
|
||||
}
|
||||
|
||||
return OPERATOR_FINISHED;
|
||||
}
|
||||
|
||||
|
@ -201,6 +212,7 @@ static int gpencil_paintmode_toggle_exec(bContext *C, wmOperator *op)
|
|||
{
|
||||
const bool back = RNA_boolean_get(op->ptr, "back");
|
||||
|
||||
struct wmMsgBus *mbus = CTX_wm_message_bus(C);
|
||||
bGPdata *gpd = ED_gpencil_data_get_active(C);
|
||||
ToolSettings *ts = CTX_data_tool_settings(C);
|
||||
|
||||
|
@ -250,6 +262,13 @@ static int gpencil_paintmode_toggle_exec(bContext *C, wmOperator *op)
|
|||
WM_event_add_notifier(C, NC_GPENCIL | ND_DATA | ND_GPENCIL_EDITMODE, NULL);
|
||||
WM_event_add_notifier(C, NC_SCENE | ND_MODE, NULL);
|
||||
|
||||
if (is_object) {
|
||||
WM_msg_publish_rna_prop(mbus, &ob->id, ob, Object, mode);
|
||||
}
|
||||
if (G.background == false) {
|
||||
WM_toolsystem_update_from_context_view3d(C);
|
||||
}
|
||||
|
||||
return OPERATOR_FINISHED;
|
||||
}
|
||||
|
||||
|
@ -290,6 +309,7 @@ static int gpencil_sculptmode_toggle_exec(bContext *C, wmOperator *op)
|
|||
{
|
||||
const bool back = RNA_boolean_get(op->ptr, "back");
|
||||
|
||||
struct wmMsgBus *mbus = CTX_wm_message_bus(C);
|
||||
bGPdata *gpd = ED_gpencil_data_get_active(C);
|
||||
bool is_object = false;
|
||||
short mode;
|
||||
|
@ -330,6 +350,13 @@ static int gpencil_sculptmode_toggle_exec(bContext *C, wmOperator *op)
|
|||
WM_event_add_notifier(C, NC_GPENCIL | ND_DATA | ND_GPENCIL_EDITMODE, NULL);
|
||||
WM_event_add_notifier(C, NC_SCENE | ND_MODE, NULL);
|
||||
|
||||
if (is_object) {
|
||||
WM_msg_publish_rna_prop(mbus, &ob->id, ob, Object, mode);
|
||||
}
|
||||
if (G.background == false) {
|
||||
WM_toolsystem_update_from_context_view3d(C);
|
||||
}
|
||||
|
||||
return OPERATOR_FINISHED;
|
||||
}
|
||||
|
||||
|
@ -370,6 +397,7 @@ static int gpencil_weightmode_toggle_exec(bContext *C, wmOperator *op)
|
|||
{
|
||||
const bool back = RNA_boolean_get(op->ptr, "back");
|
||||
|
||||
struct wmMsgBus *mbus = CTX_wm_message_bus(C);
|
||||
bGPdata *gpd = ED_gpencil_data_get_active(C);
|
||||
bool is_object = false;
|
||||
short mode;
|
||||
|
@ -410,6 +438,13 @@ static int gpencil_weightmode_toggle_exec(bContext *C, wmOperator *op)
|
|||
WM_event_add_notifier(C, NC_GPENCIL | ND_DATA | ND_GPENCIL_EDITMODE, NULL);
|
||||
WM_event_add_notifier(C, NC_SCENE | ND_MODE, NULL);
|
||||
|
||||
if (is_object) {
|
||||
WM_msg_publish_rna_prop(mbus, &ob->id, ob, Object, mode);
|
||||
}
|
||||
if (G.background == false) {
|
||||
WM_toolsystem_update_from_context_view3d(C);
|
||||
}
|
||||
|
||||
return OPERATOR_FINISHED;
|
||||
}
|
||||
|
||||
|
|
|
@ -2713,6 +2713,7 @@ static int gpencil_draw_invoke(bContext *C, wmOperator *op, const wmEvent *event
|
|||
if (p->sa->spacetype == SPACE_VIEW3D) {
|
||||
Object *ob = CTX_data_active_object(C);
|
||||
if (ob && (ob->type == OB_GPENCIL) && ((p->gpd->flag & GP_DATA_STROKE_PAINTMODE) == 0)) {
|
||||
/* FIXME: use the mode switching operator, this misses notifiers, messages. */
|
||||
/* Just set paintmode flag... */
|
||||
p->gpd->flag |= GP_DATA_STROKE_PAINTMODE;
|
||||
/* disable other GP modes */
|
||||
|
|
Loading…
Reference in New Issue