Cleanup: move toolsystem into own include
Many files using the window manager don't access the tool-system. This avoids rebuilding many files when the tool-system changes.
This commit is contained in:
@@ -112,6 +112,7 @@
|
|||||||
#include "WM_api.h"
|
#include "WM_api.h"
|
||||||
#include "WM_types.h"
|
#include "WM_types.h"
|
||||||
#include "WM_message.h"
|
#include "WM_message.h"
|
||||||
|
#include "WM_toolsystem.h"
|
||||||
|
|
||||||
#include "object_intern.h" // own include
|
#include "object_intern.h" // own include
|
||||||
|
|
||||||
|
|||||||
@@ -82,6 +82,7 @@
|
|||||||
#include "WM_api.h"
|
#include "WM_api.h"
|
||||||
#include "WM_types.h"
|
#include "WM_types.h"
|
||||||
#include "WM_message.h"
|
#include "WM_message.h"
|
||||||
|
#include "WM_toolsystem.h"
|
||||||
|
|
||||||
#include "RNA_access.h"
|
#include "RNA_access.h"
|
||||||
#include "RNA_define.h"
|
#include "RNA_define.h"
|
||||||
|
|||||||
@@ -52,6 +52,7 @@
|
|||||||
#include "WM_api.h"
|
#include "WM_api.h"
|
||||||
#include "WM_types.h"
|
#include "WM_types.h"
|
||||||
#include "WM_message.h"
|
#include "WM_message.h"
|
||||||
|
#include "WM_toolsystem.h"
|
||||||
|
|
||||||
#include "ED_screen.h"
|
#include "ED_screen.h"
|
||||||
#include "ED_screen_types.h"
|
#include "ED_screen_types.h"
|
||||||
|
|||||||
@@ -65,6 +65,7 @@
|
|||||||
|
|
||||||
#include "WM_api.h"
|
#include "WM_api.h"
|
||||||
#include "WM_types.h"
|
#include "WM_types.h"
|
||||||
|
#include "WM_toolsystem.h"
|
||||||
|
|
||||||
#include "screen_intern.h"
|
#include "screen_intern.h"
|
||||||
|
|
||||||
|
|||||||
@@ -74,6 +74,7 @@
|
|||||||
#include "WM_api.h"
|
#include "WM_api.h"
|
||||||
#include "WM_types.h"
|
#include "WM_types.h"
|
||||||
#include "WM_message.h"
|
#include "WM_message.h"
|
||||||
|
#include "WM_toolsystem.h"
|
||||||
|
|
||||||
#include "RNA_access.h"
|
#include "RNA_access.h"
|
||||||
#include "RNA_define.h"
|
#include "RNA_define.h"
|
||||||
|
|||||||
@@ -69,6 +69,7 @@
|
|||||||
#include "WM_api.h"
|
#include "WM_api.h"
|
||||||
#include "WM_types.h"
|
#include "WM_types.h"
|
||||||
#include "WM_message.h"
|
#include "WM_message.h"
|
||||||
|
#include "WM_toolsystem.h"
|
||||||
|
|
||||||
#include "ED_object.h"
|
#include "ED_object.h"
|
||||||
#include "ED_mesh.h"
|
#include "ED_mesh.h"
|
||||||
|
|||||||
@@ -77,6 +77,7 @@
|
|||||||
#include "WM_api.h"
|
#include "WM_api.h"
|
||||||
#include "WM_types.h"
|
#include "WM_types.h"
|
||||||
#include "WM_message.h"
|
#include "WM_message.h"
|
||||||
|
#include "WM_toolsystem.h"
|
||||||
|
|
||||||
#include "ED_sculpt.h"
|
#include "ED_sculpt.h"
|
||||||
#include "ED_object.h"
|
#include "ED_object.h"
|
||||||
|
|||||||
@@ -69,6 +69,7 @@
|
|||||||
#include "WM_api.h"
|
#include "WM_api.h"
|
||||||
#include "WM_types.h"
|
#include "WM_types.h"
|
||||||
#include "WM_message.h"
|
#include "WM_message.h"
|
||||||
|
#include "WM_toolsystem.h"
|
||||||
|
|
||||||
#include "RE_engine.h"
|
#include "RE_engine.h"
|
||||||
#include "RE_pipeline.h"
|
#include "RE_pipeline.h"
|
||||||
|
|||||||
@@ -54,6 +54,7 @@
|
|||||||
|
|
||||||
#include "WM_api.h"
|
#include "WM_api.h"
|
||||||
#include "WM_types.h"
|
#include "WM_types.h"
|
||||||
|
#include "WM_toolsystem.h"
|
||||||
|
|
||||||
#include "view3d_intern.h" /* own include */
|
#include "view3d_intern.h" /* own include */
|
||||||
|
|
||||||
|
|||||||
@@ -65,6 +65,7 @@
|
|||||||
#include "WM_api.h"
|
#include "WM_api.h"
|
||||||
#include "WM_types.h"
|
#include "WM_types.h"
|
||||||
#include "WM_message.h"
|
#include "WM_message.h"
|
||||||
|
#include "WM_toolsystem.h"
|
||||||
|
|
||||||
#include "ED_armature.h"
|
#include "ED_armature.h"
|
||||||
#include "ED_curve.h"
|
#include "ED_curve.h"
|
||||||
|
|||||||
@@ -53,6 +53,8 @@
|
|||||||
|
|
||||||
#include "RNA_access.h"
|
#include "RNA_access.h"
|
||||||
|
|
||||||
|
#include "WM_toolsystem.h"
|
||||||
|
|
||||||
static void rna_window_update_all(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *UNUSED(ptr))
|
static void rna_window_update_all(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *UNUSED(ptr))
|
||||||
{
|
{
|
||||||
WM_main_add_notifier(NC_WINDOW, NULL);
|
WM_main_add_notifier(NC_WINDOW, NULL);
|
||||||
|
|||||||
@@ -87,6 +87,7 @@ set(SRC
|
|||||||
|
|
||||||
WM_api.h
|
WM_api.h
|
||||||
WM_keymap.h
|
WM_keymap.h
|
||||||
|
WM_toolsystem.h
|
||||||
WM_types.h
|
WM_types.h
|
||||||
wm.h
|
wm.h
|
||||||
wm_cursors.h
|
wm_cursors.h
|
||||||
|
|||||||
@@ -69,7 +69,6 @@ struct ImageFormatData;
|
|||||||
struct ARegion;
|
struct ARegion;
|
||||||
struct ScrArea;
|
struct ScrArea;
|
||||||
struct Main;
|
struct Main;
|
||||||
struct bToolDef;
|
|
||||||
struct ViewLayer;
|
struct ViewLayer;
|
||||||
struct GPUViewport;
|
struct GPUViewport;
|
||||||
|
|
||||||
@@ -602,57 +601,6 @@ bool WM_event_is_tablet(const struct wmEvent *event);
|
|||||||
bool WM_event_is_ime_switch(const struct wmEvent *event);
|
bool WM_event_is_ime_switch(const struct wmEvent *event);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* wm_toolsystem.c */
|
|
||||||
|
|
||||||
/* Values that define a categoey of active tool. */
|
|
||||||
typedef struct bToolKey { int space_type; int mode; } bToolKey;
|
|
||||||
|
|
||||||
struct bToolRef *WM_toolsystem_ref_from_context(struct bContext *C);
|
|
||||||
struct bToolRef *WM_toolsystem_ref_find(struct WorkSpace *workspace, const bToolKey *tkey);
|
|
||||||
bool WM_toolsystem_ref_ensure(
|
|
||||||
struct WorkSpace *workspace, const bToolKey *tkey,
|
|
||||||
struct bToolRef **r_tref);
|
|
||||||
|
|
||||||
struct bToolRef_Runtime *WM_toolsystem_runtime_from_context(struct bContext *C);
|
|
||||||
struct bToolRef_Runtime *WM_toolsystem_runtime_find(struct WorkSpace *workspace, const bToolKey *tkey);
|
|
||||||
|
|
||||||
void WM_toolsystem_unlink(struct bContext *C, struct WorkSpace *workspace, const bToolKey *tkey);
|
|
||||||
void WM_toolsystem_refresh(struct bContext *C, struct WorkSpace *workspace, const bToolKey *tkey);
|
|
||||||
void WM_toolsystem_reinit(struct bContext *C, struct WorkSpace *workspace, const bToolKey *tkey);
|
|
||||||
|
|
||||||
void WM_toolsystem_unlink_all(struct bContext *C, struct WorkSpace *workspace);
|
|
||||||
void WM_toolsystem_refresh_all(struct bContext *C, struct WorkSpace *workspace);
|
|
||||||
void WM_toolsystem_reinit_all(struct bContext *C, struct wmWindow *win);
|
|
||||||
|
|
||||||
void WM_toolsystem_ref_set_from_runtime(
|
|
||||||
struct bContext *C, struct WorkSpace *workspace, struct bToolRef *tref,
|
|
||||||
const struct bToolRef_Runtime *tool, const char *idname);
|
|
||||||
|
|
||||||
void WM_toolsystem_init(struct bContext *C);
|
|
||||||
|
|
||||||
int WM_toolsystem_mode_from_spacetype(
|
|
||||||
struct WorkSpace *workspace, struct Scene *scene, struct ScrArea *sa,
|
|
||||||
int space_type);
|
|
||||||
bool WM_toolsystem_key_from_context(
|
|
||||||
struct WorkSpace *workspace, struct Scene *scene, struct ScrArea *sa,
|
|
||||||
bToolKey *tkey);
|
|
||||||
void WM_toolsystem_update_from_context(
|
|
||||||
struct bContext *C,
|
|
||||||
struct WorkSpace *workspace, struct Scene *scene, struct ScrArea *sa);
|
|
||||||
|
|
||||||
void WM_toolsystem_update_from_context_view3d(struct bContext *C);
|
|
||||||
|
|
||||||
bool WM_toolsystem_active_tool_is_brush(const struct bContext *C);
|
|
||||||
|
|
||||||
void WM_toolsystem_do_msg_notify_tag_refresh(
|
|
||||||
struct bContext *C, struct wmMsgSubscribeKey *msg_key, struct wmMsgSubscribeValue *msg_val);
|
|
||||||
|
|
||||||
struct IDProperty *WM_toolsystem_ref_properties_ensure_idprops(struct bToolRef *tref);
|
|
||||||
void WM_toolsystem_ref_properties_ensure(struct bToolRef *tref, struct wmOperatorType *ot, struct PointerRNA *ptr);
|
|
||||||
|
|
||||||
void WM_toolsystem_ref_properties_init_for_keymap(
|
|
||||||
struct bToolRef *tref, struct PointerRNA *dst_ptr, struct PointerRNA *src_ptr, struct wmOperatorType *ot);
|
|
||||||
|
|
||||||
/* wm_tooltip.c */
|
/* wm_tooltip.c */
|
||||||
typedef struct ARegion *(*wmTooltipInitFn)(struct bContext *, struct ARegion *, bool *);
|
typedef struct ARegion *(*wmTooltipInitFn)(struct bContext *, struct ARegion *, bool *);
|
||||||
|
|
||||||
@@ -664,9 +612,6 @@ void WM_tooltip_clear(struct bContext *C, struct wmWindow *win);
|
|||||||
void WM_tooltip_init(struct bContext *C, struct wmWindow *win);
|
void WM_tooltip_init(struct bContext *C, struct wmWindow *win);
|
||||||
void WM_tooltip_refresh(struct bContext *C, struct wmWindow *win);
|
void WM_tooltip_refresh(struct bContext *C, struct wmWindow *win);
|
||||||
|
|
||||||
void WM_toolsystem_refresh_screen_area(struct WorkSpace *workspace, struct Scene *scene, struct ScrArea *sa);
|
|
||||||
void WM_toolsystem_refresh_screen_all(struct Main *bmain);
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|||||||
102
source/blender/windowmanager/WM_toolsystem.h
Normal file
102
source/blender/windowmanager/WM_toolsystem.h
Normal file
@@ -0,0 +1,102 @@
|
|||||||
|
/*
|
||||||
|
* ***** BEGIN GPL LICENSE BLOCK *****
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU General Public License
|
||||||
|
* as published by the Free Software Foundation; either version 2
|
||||||
|
* of the License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
|
*
|
||||||
|
* ***** END GPL LICENSE BLOCK *****
|
||||||
|
*/
|
||||||
|
#ifndef __WM_TOOLSYSTEM_H__
|
||||||
|
#define __WM_TOOLSYSTEM_H__
|
||||||
|
|
||||||
|
/** \file blender/windowmanager/WM_toolsystem.h
|
||||||
|
* \ingroup wm
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* dna-savable wmStructs here */
|
||||||
|
#include "BLI_compiler_attrs.h"
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
struct bContext;
|
||||||
|
struct bToolRef_Runtime;
|
||||||
|
struct IDProperty;
|
||||||
|
struct wmMsgSubscribeKey;
|
||||||
|
struct wmMsgSubscribeValue;
|
||||||
|
struct wmOperatorType;
|
||||||
|
struct PointerRNA;
|
||||||
|
struct ScrArea;
|
||||||
|
struct Main;
|
||||||
|
|
||||||
|
/* wm_toolsystem.c */
|
||||||
|
|
||||||
|
/* Values that define a categoey of active tool. */
|
||||||
|
typedef struct bToolKey { int space_type; int mode; } bToolKey;
|
||||||
|
|
||||||
|
struct bToolRef *WM_toolsystem_ref_from_context(struct bContext *C);
|
||||||
|
struct bToolRef *WM_toolsystem_ref_find(struct WorkSpace *workspace, const bToolKey *tkey);
|
||||||
|
bool WM_toolsystem_ref_ensure(
|
||||||
|
struct WorkSpace *workspace, const bToolKey *tkey,
|
||||||
|
struct bToolRef **r_tref);
|
||||||
|
|
||||||
|
struct bToolRef_Runtime *WM_toolsystem_runtime_from_context(struct bContext *C);
|
||||||
|
struct bToolRef_Runtime *WM_toolsystem_runtime_find(struct WorkSpace *workspace, const bToolKey *tkey);
|
||||||
|
|
||||||
|
void WM_toolsystem_unlink(struct bContext *C, struct WorkSpace *workspace, const bToolKey *tkey);
|
||||||
|
void WM_toolsystem_refresh(struct bContext *C, struct WorkSpace *workspace, const bToolKey *tkey);
|
||||||
|
void WM_toolsystem_reinit(struct bContext *C, struct WorkSpace *workspace, const bToolKey *tkey);
|
||||||
|
|
||||||
|
void WM_toolsystem_unlink_all(struct bContext *C, struct WorkSpace *workspace);
|
||||||
|
void WM_toolsystem_refresh_all(struct bContext *C, struct WorkSpace *workspace);
|
||||||
|
void WM_toolsystem_reinit_all(struct bContext *C, struct wmWindow *win);
|
||||||
|
|
||||||
|
void WM_toolsystem_ref_set_from_runtime(
|
||||||
|
struct bContext *C, struct WorkSpace *workspace, struct bToolRef *tref,
|
||||||
|
const struct bToolRef_Runtime *tool, const char *idname);
|
||||||
|
|
||||||
|
void WM_toolsystem_init(struct bContext *C);
|
||||||
|
|
||||||
|
int WM_toolsystem_mode_from_spacetype(
|
||||||
|
struct WorkSpace *workspace, struct Scene *scene, struct ScrArea *sa,
|
||||||
|
int space_type);
|
||||||
|
bool WM_toolsystem_key_from_context(
|
||||||
|
struct WorkSpace *workspace, struct Scene *scene, struct ScrArea *sa,
|
||||||
|
bToolKey *tkey);
|
||||||
|
void WM_toolsystem_update_from_context(
|
||||||
|
struct bContext *C,
|
||||||
|
struct WorkSpace *workspace, struct Scene *scene, struct ScrArea *sa);
|
||||||
|
|
||||||
|
void WM_toolsystem_update_from_context_view3d(struct bContext *C);
|
||||||
|
|
||||||
|
bool WM_toolsystem_active_tool_is_brush(const struct bContext *C);
|
||||||
|
|
||||||
|
void WM_toolsystem_do_msg_notify_tag_refresh(
|
||||||
|
struct bContext *C, struct wmMsgSubscribeKey *msg_key, struct wmMsgSubscribeValue *msg_val);
|
||||||
|
|
||||||
|
struct IDProperty *WM_toolsystem_ref_properties_ensure_idprops(struct bToolRef *tref);
|
||||||
|
void WM_toolsystem_ref_properties_ensure(struct bToolRef *tref, struct wmOperatorType *ot, struct PointerRNA *ptr);
|
||||||
|
|
||||||
|
void WM_toolsystem_ref_properties_init_for_keymap(
|
||||||
|
struct bToolRef *tref, struct PointerRNA *dst_ptr, struct PointerRNA *src_ptr, struct wmOperatorType *ot);
|
||||||
|
|
||||||
|
void WM_toolsystem_refresh_screen_area(struct WorkSpace *workspace, struct Scene *scene, struct ScrArea *sa);
|
||||||
|
void WM_toolsystem_refresh_screen_all(struct Main *bmain);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* __WM_TOOLSYSTEM_API_H__ */
|
||||||
@@ -80,6 +80,8 @@
|
|||||||
#include "WM_api.h"
|
#include "WM_api.h"
|
||||||
#include "WM_types.h"
|
#include "WM_types.h"
|
||||||
#include "WM_message.h"
|
#include "WM_message.h"
|
||||||
|
#include "WM_toolsystem.h"
|
||||||
|
|
||||||
#include "wm.h"
|
#include "wm.h"
|
||||||
#include "wm_window.h"
|
#include "wm_window.h"
|
||||||
#include "wm_event_system.h"
|
#include "wm_event_system.h"
|
||||||
|
|||||||
@@ -129,6 +129,8 @@
|
|||||||
#include "WM_api.h"
|
#include "WM_api.h"
|
||||||
#include "WM_types.h"
|
#include "WM_types.h"
|
||||||
#include "WM_message.h"
|
#include "WM_message.h"
|
||||||
|
#include "WM_toolsystem.h"
|
||||||
|
|
||||||
#include "wm.h"
|
#include "wm.h"
|
||||||
#include "wm_files.h"
|
#include "wm_files.h"
|
||||||
#include "wm_window.h"
|
#include "wm_window.h"
|
||||||
|
|||||||
@@ -53,6 +53,7 @@
|
|||||||
#include "WM_api.h"
|
#include "WM_api.h"
|
||||||
#include "WM_types.h"
|
#include "WM_types.h"
|
||||||
#include "WM_message.h"
|
#include "WM_message.h"
|
||||||
|
#include "WM_toolsystem.h" /* own include */
|
||||||
|
|
||||||
static void toolsystem_reinit_with_toolref(
|
static void toolsystem_reinit_with_toolref(
|
||||||
bContext *C, WorkSpace *UNUSED(workspace), bToolRef *tref);
|
bContext *C, WorkSpace *UNUSED(workspace), bToolRef *tref);
|
||||||
|
|||||||
@@ -78,6 +78,7 @@
|
|||||||
#include "ED_datafiles.h"
|
#include "ED_datafiles.h"
|
||||||
|
|
||||||
#include "WM_api.h"
|
#include "WM_api.h"
|
||||||
|
#include "WM_toolsystem.h"
|
||||||
|
|
||||||
#include "RNA_define.h"
|
#include "RNA_define.h"
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user