UI: Make default Info Editor theme more consistent with Outliner (round 2)
[blender.git] / source / blender / blenkernel / BKE_context.h
index cf573232bac2ca8cf491392ad2243bb7ce9b2ee7..88a27b6796335d6ee33f4a3f3b24960236db80d3 100644 (file)
@@ -33,7 +33,6 @@ extern "C" {
 
 struct ARegion;
 struct Base;
-struct Brush;
 struct CacheFile;
 struct Collection;
 struct Depsgraph;
@@ -59,7 +58,6 @@ struct Text;
 struct ToolSettings;
 struct View3D;
 struct ViewLayer;
-struct ViewRender;
 struct bGPDframe;
 struct bGPDlayer;
 struct bGPdata;
@@ -79,44 +77,45 @@ struct bContextDataResult;
 typedef struct bContextDataResult bContextDataResult;
 
 typedef int (*bContextDataCallback)(const bContext *C,
-                                    const char *member, bContextDataResult *result);
+                                    const char *member,
+                                    bContextDataResult *result);
 
 typedef struct bContextStoreEntry {
-       struct bContextStoreEntry *next, *prev;
+  struct bContextStoreEntry *next, *prev;
 
-       char name[128];
-       PointerRNA ptr;
+  char name[128];
+  PointerRNA ptr;
 } bContextStoreEntry;
 
 typedef struct bContextStore {
-       struct bContextStore *next, *prev;
+  struct bContextStore *next, *prev;
 
-       ListBase entries;
-       bool used;
+  ListBase entries;
+  bool used;
 } bContextStore;
 
 /* for the context's rna mode enum
  * keep aligned with data_mode_strings in context.c */
-enum eContextObjectMode {
-       CTX_MODE_EDIT_MESH = 0,
-       CTX_MODE_EDIT_CURVE,
-       CTX_MODE_EDIT_SURFACE,
-       CTX_MODE_EDIT_TEXT,
-       CTX_MODE_EDIT_ARMATURE,
-       CTX_MODE_EDIT_METABALL,
-       CTX_MODE_EDIT_LATTICE,
-       CTX_MODE_POSE,
-       CTX_MODE_SCULPT,
-       CTX_MODE_PAINT_WEIGHT,
-       CTX_MODE_PAINT_VERTEX,
-       CTX_MODE_PAINT_TEXTURE,
-       CTX_MODE_PARTICLE,
-       CTX_MODE_OBJECT,
-       CTX_MODE_PAINT_GPENCIL,
-       CTX_MODE_EDIT_GPENCIL,
-       CTX_MODE_SCULPT_GPENCIL,
-       CTX_MODE_WEIGHT_GPENCIL,
-};
+typedef enum eContextObjectMode {
+  CTX_MODE_EDIT_MESH = 0,
+  CTX_MODE_EDIT_CURVE,
+  CTX_MODE_EDIT_SURFACE,
+  CTX_MODE_EDIT_TEXT,
+  CTX_MODE_EDIT_ARMATURE,
+  CTX_MODE_EDIT_METABALL,
+  CTX_MODE_EDIT_LATTICE,
+  CTX_MODE_POSE,
+  CTX_MODE_SCULPT,
+  CTX_MODE_PAINT_WEIGHT,
+  CTX_MODE_PAINT_VERTEX,
+  CTX_MODE_PAINT_TEXTURE,
+  CTX_MODE_PARTICLE,
+  CTX_MODE_OBJECT,
+  CTX_MODE_PAINT_GPENCIL,
+  CTX_MODE_EDIT_GPENCIL,
+  CTX_MODE_SCULPT_GPENCIL,
+  CTX_MODE_WEIGHT_GPENCIL,
+} eContextObjectMode;
 #define CTX_MODE_NUM (CTX_MODE_WEIGHT_GPENCIL + 1)
 
 /* Context */
@@ -136,8 +135,8 @@ void CTX_store_free(bContextStore *store);
 void CTX_store_free_list(ListBase *contexts);
 
 /* need to store if python is initialized or not */
-int CTX_py_init_get(bContext *C);
-void CTX_py_init_set(bContext *C, int value);
+bool CTX_py_init_get(bContext *C);
+void CTX_py_init_set(bContext *C, bool value);
 
 void *CTX_py_dict_get(const bContext *C);
 void CTX_py_dict_set(bContext *C, void *value);
@@ -193,16 +192,23 @@ void CTX_wm_operator_poll_msg_set(struct bContext *C, const char *msg);
 
 /* data type, needed so we can tell between a NULL pointer and an empty list */
 enum {
-       CTX_DATA_TYPE_POINTER = 0,
-       CTX_DATA_TYPE_COLLECTION,
+  CTX_DATA_TYPE_POINTER = 0,
+  CTX_DATA_TYPE_COLLECTION,
 };
 
 PointerRNA CTX_data_pointer_get(const bContext *C, const char *member);
 PointerRNA CTX_data_pointer_get_type(const bContext *C, const char *member, StructRNA *type);
+PointerRNA CTX_data_pointer_get_type_silent(const bContext *C,
+                                            const char *member,
+                                            StructRNA *type);
 ListBase CTX_data_collection_get(const bContext *C, const char *member);
-ListBase CTX_data_dir_get_ex(const bContext *C, const bool use_store, const bool use_rna, const bool use_all);
+ListBase CTX_data_dir_get_ex(const bContext *C,
+                             const bool use_store,
+                             const bool use_rna,
+                             const bool use_all);
 ListBase CTX_data_dir_get(const bContext *C);
-int CTX_data_get(const bContext *C, const char *member, PointerRNA *r_ptr, ListBase *r_lb, short *r_type);
+int CTX_data_get(
+    const bContext *C, const char *member, PointerRNA *r_ptr, ListBase *r_lb, short *r_type);
 
 void CTX_data_id_pointer_set(bContextDataResult *result, struct ID *id);
 void CTX_data_pointer_set(bContextDataResult *result, struct ID *id, StructRNA *type, void *data);
@@ -218,30 +224,27 @@ short CTX_data_type_get(struct bContextDataResult *result);
 bool CTX_data_equals(const char *member, const char *str);
 bool CTX_data_dir(const char *member);
 
-#define CTX_DATA_BEGIN(C, Type, instance, member)                             \
-       {                                                                         \
-               ListBase ctx_data_list;                                               \
-               CollectionPointerLink *ctx_link;                                      \
-               CTX_data_##member(C, &ctx_data_list);                                 \
-               for (ctx_link = ctx_data_list.first;                                  \
-                    ctx_link;                                                        \
-                    ctx_link = ctx_link->next)                                       \
-               {                                                                     \
-                       Type instance = ctx_link->ptr.data;
-
-#define CTX_DATA_END                                                          \
-               }                                                                     \
-               BLI_freelistN(&ctx_data_list);                                        \
-} (void)0
-
-#define CTX_DATA_BEGIN_WITH_ID(C, Type, instance, member, Type_id, instance_id)      \
-       CTX_DATA_BEGIN(C, Type, instance, member) \
-       Type_id instance_id = ctx_link->ptr.id.data; \
+#define CTX_DATA_BEGIN(C, Type, instance, member) \
+  { \
+    ListBase ctx_data_list; \
+    CollectionPointerLink *ctx_link; \
+    CTX_data_##member(C, &ctx_data_list); \
+    for (ctx_link = ctx_data_list.first; ctx_link; ctx_link = ctx_link->next) { \
+      Type instance = ctx_link->ptr.data;
+
+#define CTX_DATA_END \
+  } \
+  BLI_freelistN(&ctx_data_list); \
+  } \
+  (void)0
+
+#define CTX_DATA_BEGIN_WITH_ID(C, Type, instance, member, Type_id, instance_id) \
+  CTX_DATA_BEGIN (C, Type, instance, member) \
+    Type_id instance_id = (Type_id)ctx_link->ptr.owner_id;
 
 int ctx_data_list_count(const bContext *C, int (*func)(const bContext *, ListBase *));
 
-#define CTX_DATA_COUNT(C, member) \
-       ctx_data_list_count(C, CTX_data_##member)
+#define CTX_DATA_COUNT(C, member) ctx_data_list_count(C, CTX_data_##member)
 
 /* Data Context Members */
 
@@ -254,10 +257,10 @@ struct RenderEngineType *CTX_data_engine_type(const bContext *C);
 struct ToolSettings *CTX_data_tool_settings(const bContext *C);
 
 const char *CTX_data_mode_string(const bContext *C);
-int CTX_data_mode_enum_ex(
-        const struct Object *obedit, const struct Object *ob,
-        const eObjectMode object_mode);
-int CTX_data_mode_enum(const bContext *C);
+enum eContextObjectMode CTX_data_mode_enum_ex(const struct Object *obedit,
+                                              const struct Object *ob,
+                                              const eObjectMode object_mode);
+enum eContextObjectMode CTX_data_mode_enum(const bContext *C);
 
 void CTX_data_main_set(bContext *C, struct Main *bmain);
 void CTX_data_scene_set(bContext *C, struct Scene *bmain);
@@ -309,7 +312,29 @@ int CTX_data_visible_gpencil_layers(const bContext *C, ListBase *list);
 int CTX_data_editable_gpencil_layers(const bContext *C, ListBase *list);
 int CTX_data_editable_gpencil_strokes(const bContext *C, ListBase *list);
 
-struct Depsgraph *CTX_data_depsgraph(const bContext *C);
+/* Gets pointer to the dependency graph.
+ * If it doesn't exist yet, it will be allocated.
+ *
+ * The result dependency graph is NOT guaranteed to be up-to-date neither from relation nor from
+ * evaluated data points of view.
+ *
+ * NOTE: Can not be used if access to a fully evaluated datablock is needed. */
+struct Depsgraph *CTX_data_depsgraph_pointer(const bContext *C);
+
+/* Get dependency graph which is expected to be fully evaluated.
+ *
+ * In the release builds it is the same as CTX_data_depsgraph_pointer(). In the debug builds extra
+ * sanity checks are done. Additionally, this provides more semantic meaning to what is exactly
+ * expected to happen. */
+struct Depsgraph *CTX_data_expect_evaluated_depsgraph(const bContext *C);
+
+/* Gets fully updated and evaluated dependency graph.
+ *
+ * All the relations and evaluated objects are guaranteed to be up to date.
+ *
+ * NOTE: Will be expensive if there are relations or objects tagged for update.
+ * NOTE: If there are pending updates depsgraph hooks will be invoked. */
+struct Depsgraph *CTX_data_ensure_evaluated_depsgraph(const bContext *C);
 
 /* Will Return NULL if depsgraph is not allocated yet.
  * Only used by handful of operators which are run on file load.