Welcome to mirror list, hosted at ThFree Co, Russian Federation.

git.blender.org/blender.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'source/blender/editors/space_node/node_edit.c')
-rw-r--r--source/blender/editors/space_node/node_edit.c3954
1 files changed, 1991 insertions, 1963 deletions
diff --git a/source/blender/editors/space_node/node_edit.c b/source/blender/editors/space_node/node_edit.c
index 27efb6c9a10..84f512957c7 100644
--- a/source/blender/editors/space_node/node_edit.c
+++ b/source/blender/editors/space_node/node_edit.c
@@ -46,8 +46,7 @@
#include "RE_engine.h"
#include "RE_pipeline.h"
-
-#include "ED_node.h" /* own include */
+#include "ED_node.h" /* own include */
#include "ED_select_utils.h"
#include "ED_screen.h"
#include "ED_render.h"
@@ -65,199 +64,210 @@
#include "IMB_imbuf_types.h"
-#include "node_intern.h" /* own include */
+#include "node_intern.h" /* own include */
#include "NOD_composite.h"
#include "NOD_shader.h"
#include "NOD_texture.h"
-
#define USE_ESC_COMPO
/* ***************** composite job manager ********************** */
enum {
- COM_RECALC_COMPOSITE = 1,
- COM_RECALC_VIEWER = 2,
+ COM_RECALC_COMPOSITE = 1,
+ COM_RECALC_VIEWER = 2,
};
typedef struct CompoJob {
- Main *bmain;
- Scene *scene;
- bNodeTree *ntree;
- bNodeTree *localtree;
- const short *stop;
- short *do_update;
- float *progress;
- int recalc_flags;
+ Main *bmain;
+ Scene *scene;
+ bNodeTree *ntree;
+ bNodeTree *localtree;
+ const short *stop;
+ short *do_update;
+ float *progress;
+ int recalc_flags;
} CompoJob;
static void compo_tag_output_nodes(bNodeTree *nodetree, int recalc_flags)
{
- bNode *node;
-
- for (node = nodetree->nodes.first; node; node = node->next) {
- if (node->type == CMP_NODE_COMPOSITE) {
- if (recalc_flags & COM_RECALC_COMPOSITE) {
- node->flag |= NODE_DO_OUTPUT_RECALC;
- }
- }
- else if (node->type == CMP_NODE_VIEWER || node->type == CMP_NODE_SPLITVIEWER) {
- if (recalc_flags & COM_RECALC_VIEWER) {
- node->flag |= NODE_DO_OUTPUT_RECALC;
- }
- }
- else if (node->type == NODE_GROUP) {
- if (node->id) {
- compo_tag_output_nodes((bNodeTree *)node->id, recalc_flags);
- }
- }
- }
+ bNode *node;
+
+ for (node = nodetree->nodes.first; node; node = node->next) {
+ if (node->type == CMP_NODE_COMPOSITE) {
+ if (recalc_flags & COM_RECALC_COMPOSITE) {
+ node->flag |= NODE_DO_OUTPUT_RECALC;
+ }
+ }
+ else if (node->type == CMP_NODE_VIEWER || node->type == CMP_NODE_SPLITVIEWER) {
+ if (recalc_flags & COM_RECALC_VIEWER) {
+ node->flag |= NODE_DO_OUTPUT_RECALC;
+ }
+ }
+ else if (node->type == NODE_GROUP) {
+ if (node->id) {
+ compo_tag_output_nodes((bNodeTree *)node->id, recalc_flags);
+ }
+ }
+ }
}
static int compo_get_recalc_flags(const bContext *C)
{
- wmWindowManager *wm = CTX_wm_manager(C);
- wmWindow *win;
- int recalc_flags = 0;
-
- for (win = wm->windows.first; win; win = win->next) {
- const bScreen *sc = WM_window_get_active_screen(win);
- ScrArea *sa;
-
- for (sa = sc->areabase.first; sa; sa = sa->next) {
- if (sa->spacetype == SPACE_IMAGE) {
- SpaceImage *sima = sa->spacedata.first;
- if (sima->image) {
- if (sima->image->type == IMA_TYPE_R_RESULT) {
- recalc_flags |= COM_RECALC_COMPOSITE;
- }
- else if (sima->image->type == IMA_TYPE_COMPOSITE) {
- recalc_flags |= COM_RECALC_VIEWER;
- }
- }
- }
- else if (sa->spacetype == SPACE_NODE) {
- SpaceNode *snode = sa->spacedata.first;
- if (snode->flag & SNODE_BACKDRAW) {
- recalc_flags |= COM_RECALC_VIEWER;
- }
- }
- }
- }
-
- return recalc_flags;
+ wmWindowManager *wm = CTX_wm_manager(C);
+ wmWindow *win;
+ int recalc_flags = 0;
+
+ for (win = wm->windows.first; win; win = win->next) {
+ const bScreen *sc = WM_window_get_active_screen(win);
+ ScrArea *sa;
+
+ for (sa = sc->areabase.first; sa; sa = sa->next) {
+ if (sa->spacetype == SPACE_IMAGE) {
+ SpaceImage *sima = sa->spacedata.first;
+ if (sima->image) {
+ if (sima->image->type == IMA_TYPE_R_RESULT) {
+ recalc_flags |= COM_RECALC_COMPOSITE;
+ }
+ else if (sima->image->type == IMA_TYPE_COMPOSITE) {
+ recalc_flags |= COM_RECALC_VIEWER;
+ }
+ }
+ }
+ else if (sa->spacetype == SPACE_NODE) {
+ SpaceNode *snode = sa->spacedata.first;
+ if (snode->flag & SNODE_BACKDRAW) {
+ recalc_flags |= COM_RECALC_VIEWER;
+ }
+ }
+ }
+ }
+
+ return recalc_flags;
}
/* called by compo, only to check job 'stop' value */
static int compo_breakjob(void *cjv)
{
- CompoJob *cj = cjv;
+ CompoJob *cj = cjv;
- /* without G.is_break 'ESC' wont quit - which annoys users */
- return (*(cj->stop)
+ /* without G.is_break 'ESC' wont quit - which annoys users */
+ return (*(cj->stop)
#ifdef USE_ESC_COMPO
- ||
- G.is_break
+ || G.is_break
#endif
- );
+ );
}
/* called by compo, wmJob sends notifier */
static void compo_statsdrawjob(void *cjv, const char *UNUSED(str))
{
- CompoJob *cj = cjv;
+ CompoJob *cj = cjv;
- *(cj->do_update) = true;
+ *(cj->do_update) = true;
}
/* called by compo, wmJob sends notifier */
static void compo_redrawjob(void *cjv)
{
- CompoJob *cj = cjv;
+ CompoJob *cj = cjv;
- *(cj->do_update) = true;
+ *(cj->do_update) = true;
}
static void compo_freejob(void *cjv)
{
- CompoJob *cj = cjv;
+ CompoJob *cj = cjv;
- if (cj->localtree) {
- ntreeLocalMerge(cj->bmain, cj->localtree, cj->ntree);
- }
- MEM_freeN(cj);
+ if (cj->localtree) {
+ ntreeLocalMerge(cj->bmain, cj->localtree, cj->ntree);
+ }
+ MEM_freeN(cj);
}
/* only now we copy the nodetree, so adding many jobs while
* sliding buttons doesn't frustrate */
static void compo_initjob(void *cjv)
{
- CompoJob *cj = cjv;
+ CompoJob *cj = cjv;
- cj->localtree = ntreeLocalize(cj->ntree);
+ cj->localtree = ntreeLocalize(cj->ntree);
- if (cj->recalc_flags) {
- compo_tag_output_nodes(cj->localtree, cj->recalc_flags);
- }
+ if (cj->recalc_flags) {
+ compo_tag_output_nodes(cj->localtree, cj->recalc_flags);
+ }
}
/* called before redraw notifiers, it moves finished previews over */
static void compo_updatejob(void *UNUSED(cjv))
{
- WM_main_add_notifier(NC_SCENE | ND_COMPO_RESULT, NULL);
+ WM_main_add_notifier(NC_SCENE | ND_COMPO_RESULT, NULL);
}
static void compo_progressjob(void *cjv, float progress)
{
- CompoJob *cj = cjv;
+ CompoJob *cj = cjv;
- *(cj->progress) = progress;
+ *(cj->progress) = progress;
}
/* only this runs inside thread */
static void compo_startjob(void *cjv, short *stop, short *do_update, float *progress)
{
- CompoJob *cj = cjv;
- bNodeTree *ntree = cj->localtree;
- Scene *scene = cj->scene;
- SceneRenderView *srv;
-
- if (scene->use_nodes == false) {
- return;
- }
-
- cj->stop = stop;
- cj->do_update = do_update;
- cj->progress = progress;
-
- ntree->test_break = compo_breakjob;
- ntree->tbh = cj;
- ntree->stats_draw = compo_statsdrawjob;
- ntree->sdh = cj;
- ntree->progress = compo_progressjob;
- ntree->prh = cj;
- ntree->update_draw = compo_redrawjob;
- ntree->udh = cj;
-
- // XXX BIF_store_spare();
- /* 1 is do_previews */
-
- if ((cj->scene->r.scemode & R_MULTIVIEW) == 0) {
- ntreeCompositExecTree(cj->scene, ntree, &cj->scene->r, false, true, &scene->view_settings, &scene->display_settings, "");
- }
- else {
- for (srv = scene->r.views.first; srv; srv = srv->next) {
- if (BKE_scene_multiview_is_render_view_active(&scene->r, srv) == false) {
- continue;
- }
- ntreeCompositExecTree(cj->scene, ntree, &cj->scene->r, false, true, &scene->view_settings, &scene->display_settings, srv->name);
- }
- }
-
- ntree->test_break = NULL;
- ntree->stats_draw = NULL;
- ntree->progress = NULL;
-
+ CompoJob *cj = cjv;
+ bNodeTree *ntree = cj->localtree;
+ Scene *scene = cj->scene;
+ SceneRenderView *srv;
+
+ if (scene->use_nodes == false) {
+ return;
+ }
+
+ cj->stop = stop;
+ cj->do_update = do_update;
+ cj->progress = progress;
+
+ ntree->test_break = compo_breakjob;
+ ntree->tbh = cj;
+ ntree->stats_draw = compo_statsdrawjob;
+ ntree->sdh = cj;
+ ntree->progress = compo_progressjob;
+ ntree->prh = cj;
+ ntree->update_draw = compo_redrawjob;
+ ntree->udh = cj;
+
+ // XXX BIF_store_spare();
+ /* 1 is do_previews */
+
+ if ((cj->scene->r.scemode & R_MULTIVIEW) == 0) {
+ ntreeCompositExecTree(cj->scene,
+ ntree,
+ &cj->scene->r,
+ false,
+ true,
+ &scene->view_settings,
+ &scene->display_settings,
+ "");
+ }
+ else {
+ for (srv = scene->r.views.first; srv; srv = srv->next) {
+ if (BKE_scene_multiview_is_render_view_active(&scene->r, srv) == false) {
+ continue;
+ }
+ ntreeCompositExecTree(cj->scene,
+ ntree,
+ &cj->scene->r,
+ false,
+ true,
+ &scene->view_settings,
+ &scene->display_settings,
+ srv->name);
+ }
+ }
+
+ ntree->test_break = NULL;
+ ntree->stats_draw = NULL;
+ ntree->progress = NULL;
}
/**
@@ -269,38 +279,43 @@ static void compo_startjob(void *cjv, short *stop, short *do_update, float *prog
*/
void ED_node_composite_job(const bContext *C, struct bNodeTree *nodetree, Scene *scene_owner)
{
- wmJob *wm_job;
- CompoJob *cj;
- Main *bmain = CTX_data_main(C);
- Scene *scene = CTX_data_scene(C);
+ wmJob *wm_job;
+ CompoJob *cj;
+ Main *bmain = CTX_data_main(C);
+ Scene *scene = CTX_data_scene(C);
- /* to fix bug: [#32272] */
- if (G.is_rendering) {
- return;
- }
+ /* to fix bug: [#32272] */
+ if (G.is_rendering) {
+ return;
+ }
#ifdef USE_ESC_COMPO
- G.is_break = false;
+ G.is_break = false;
#endif
- BKE_image_backup_render(scene, BKE_image_verify_viewer(bmain, IMA_TYPE_R_RESULT, "Render Result"), false);
+ BKE_image_backup_render(
+ scene, BKE_image_verify_viewer(bmain, IMA_TYPE_R_RESULT, "Render Result"), false);
- wm_job = WM_jobs_get(CTX_wm_manager(C), CTX_wm_window(C), scene_owner, "Compositing",
- WM_JOB_EXCL_RENDER | WM_JOB_PROGRESS, WM_JOB_TYPE_COMPOSITE);
- cj = MEM_callocN(sizeof(CompoJob), "compo job");
+ wm_job = WM_jobs_get(CTX_wm_manager(C),
+ CTX_wm_window(C),
+ scene_owner,
+ "Compositing",
+ WM_JOB_EXCL_RENDER | WM_JOB_PROGRESS,
+ WM_JOB_TYPE_COMPOSITE);
+ cj = MEM_callocN(sizeof(CompoJob), "compo job");
- /* customdata for preview thread */
- cj->bmain = bmain;
- cj->scene = scene;
- cj->ntree = nodetree;
- cj->recalc_flags = compo_get_recalc_flags(C);
+ /* customdata for preview thread */
+ cj->bmain = bmain;
+ cj->scene = scene;
+ cj->ntree = nodetree;
+ cj->recalc_flags = compo_get_recalc_flags(C);
- /* setup job */
- WM_jobs_customdata_set(wm_job, cj, compo_freejob);
- WM_jobs_timer(wm_job, 0.1, NC_SCENE | ND_COMPO_RESULT, NC_SCENE | ND_COMPO_RESULT);
- WM_jobs_callbacks(wm_job, compo_startjob, compo_initjob, compo_updatejob, NULL);
+ /* setup job */
+ WM_jobs_customdata_set(wm_job, cj, compo_freejob);
+ WM_jobs_timer(wm_job, 0.1, NC_SCENE | ND_COMPO_RESULT, NC_SCENE | ND_COMPO_RESULT);
+ WM_jobs_callbacks(wm_job, compo_startjob, compo_initjob, compo_updatejob, NULL);
- WM_jobs_start(CTX_wm_manager(C), wm_job);
+ WM_jobs_start(CTX_wm_manager(C), wm_job);
}
/* ***************************************** */
@@ -308,447 +323,449 @@ void ED_node_composite_job(const bContext *C, struct bNodeTree *nodetree, Scene
/* operator poll callback */
bool composite_node_active(bContext *C)
{
- if (ED_operator_node_active(C)) {
- SpaceNode *snode = CTX_wm_space_node(C);
- if (ED_node_is_compositor(snode)) {
- return 1;
- }
- }
- return 0;
+ if (ED_operator_node_active(C)) {
+ SpaceNode *snode = CTX_wm_space_node(C);
+ if (ED_node_is_compositor(snode)) {
+ return 1;
+ }
+ }
+ return 0;
}
/* operator poll callback */
bool composite_node_editable(bContext *C)
{
- if (ED_operator_node_editable(C)) {
- SpaceNode *snode = CTX_wm_space_node(C);
- if (ED_node_is_compositor(snode)) {
- return 1;
- }
- }
- return 0;
+ if (ED_operator_node_editable(C)) {
+ SpaceNode *snode = CTX_wm_space_node(C);
+ if (ED_node_is_compositor(snode)) {
+ return 1;
+ }
+ }
+ return 0;
}
void snode_dag_update(bContext *C, SpaceNode *snode)
{
- Main *bmain = CTX_data_main(C);
+ Main *bmain = CTX_data_main(C);
- /* for groups, update all ID's using this */
- if (snode->edittree != snode->nodetree) {
- FOREACH_NODETREE_BEGIN(bmain, tntree, id) {
- if (ntreeHasTree(tntree, snode->edittree)) {
- DEG_id_tag_update(id, 0);
- }
- } FOREACH_NODETREE_END;
- }
+ /* for groups, update all ID's using this */
+ if (snode->edittree != snode->nodetree) {
+ FOREACH_NODETREE_BEGIN (bmain, tntree, id) {
+ if (ntreeHasTree(tntree, snode->edittree)) {
+ DEG_id_tag_update(id, 0);
+ }
+ }
+ FOREACH_NODETREE_END;
+ }
- DEG_id_tag_update(snode->id, 0);
+ DEG_id_tag_update(snode->id, 0);
}
void snode_notify(bContext *C, SpaceNode *snode)
{
- ID *id = snode->id;
-
- WM_event_add_notifier(C, NC_NODE | NA_EDITED, NULL);
-
- if (ED_node_is_shader(snode)) {
- if (GS(id->name) == ID_MA) {
- WM_main_add_notifier(NC_MATERIAL | ND_SHADING, id);
- }
- else if (GS(id->name) == ID_LA) {
- WM_main_add_notifier(NC_LAMP | ND_LIGHTING, id);
- }
- else if (GS(id->name) == ID_WO) {
- WM_main_add_notifier(NC_WORLD | ND_WORLD, id);
- }
- }
- else if (ED_node_is_compositor(snode)) {
- WM_event_add_notifier(C, NC_SCENE | ND_NODES, id);
- }
- else if (ED_node_is_texture(snode)) {
- WM_event_add_notifier(C, NC_TEXTURE | ND_NODES, id);
- }
+ ID *id = snode->id;
+
+ WM_event_add_notifier(C, NC_NODE | NA_EDITED, NULL);
+
+ if (ED_node_is_shader(snode)) {
+ if (GS(id->name) == ID_MA) {
+ WM_main_add_notifier(NC_MATERIAL | ND_SHADING, id);
+ }
+ else if (GS(id->name) == ID_LA) {
+ WM_main_add_notifier(NC_LAMP | ND_LIGHTING, id);
+ }
+ else if (GS(id->name) == ID_WO) {
+ WM_main_add_notifier(NC_WORLD | ND_WORLD, id);
+ }
+ }
+ else if (ED_node_is_compositor(snode)) {
+ WM_event_add_notifier(C, NC_SCENE | ND_NODES, id);
+ }
+ else if (ED_node_is_texture(snode)) {
+ WM_event_add_notifier(C, NC_TEXTURE | ND_NODES, id);
+ }
}
void ED_node_set_tree_type(SpaceNode *snode, bNodeTreeType *typeinfo)
{
- if (typeinfo) {
- BLI_strncpy(snode->tree_idname, typeinfo->idname, sizeof(snode->tree_idname));
- }
- else {
- snode->tree_idname[0] = '\0';
- }
+ if (typeinfo) {
+ BLI_strncpy(snode->tree_idname, typeinfo->idname, sizeof(snode->tree_idname));
+ }
+ else {
+ snode->tree_idname[0] = '\0';
+ }
}
bool ED_node_is_compositor(struct SpaceNode *snode)
{
- return STREQ(snode->tree_idname, ntreeType_Composite->idname);
+ return STREQ(snode->tree_idname, ntreeType_Composite->idname);
}
bool ED_node_is_shader(struct SpaceNode *snode)
{
- return STREQ(snode->tree_idname, ntreeType_Shader->idname);
+ return STREQ(snode->tree_idname, ntreeType_Shader->idname);
}
bool ED_node_is_texture(struct SpaceNode *snode)
{
- return STREQ(snode->tree_idname, ntreeType_Texture->idname);
+ return STREQ(snode->tree_idname, ntreeType_Texture->idname);
}
/* assumes nothing being done in ntree yet, sets the default in/out node */
/* called from shading buttons or header */
void ED_node_shader_default(const bContext *C, ID *id)
{
- bNode *in, *out;
- bNodeSocket *fromsock, *tosock, *sock;
- bNodeTree *ntree;
- int output_type, shader_type;
- float color[4] = { 0.0f, 0.0f, 0.0f, 1.0f }, strength = 1.0f;
-
- ntree = ntreeAddTree(NULL, "Shader Nodetree", ntreeType_Shader->idname);
-
- switch (GS(id->name)) {
- case ID_MA:
- {
- Material *ma = (Material *)id;
- ma->nodetree = ntree;
-
- output_type = SH_NODE_OUTPUT_MATERIAL;
- shader_type = SH_NODE_BSDF_PRINCIPLED;
-
- copy_v3_v3(color, &ma->r);
- strength = 0.0f;
- break;
- }
- case ID_WO:
- {
- World *wo = (World *)id;
- wo->nodetree = ntree;
-
- output_type = SH_NODE_OUTPUT_WORLD;
- shader_type = SH_NODE_BACKGROUND;
-
- copy_v3_v3(color, &wo->horr);
- strength = 1.0f;
- break;
- }
- case ID_LA:
- {
- Light *la = (Light *)id;
- la->nodetree = ntree;
-
- output_type = SH_NODE_OUTPUT_LIGHT;
- shader_type = SH_NODE_EMISSION;
-
- copy_v3_v3(color, &la->r);
- if (la->type == LA_LOCAL || la->type == LA_SPOT || la->type == LA_AREA) {
- strength = 100.0f;
- }
- else {
- strength = 1.0f;
- }
- break;
- }
- default:
- printf("ED_node_shader_default called on wrong ID type.\n");
- return;
- }
-
- out = nodeAddStaticNode(C, ntree, output_type);
- out->locx = 300.0f; out->locy = 300.0f;
-
- in = nodeAddStaticNode(C, ntree, shader_type);
- in->locx = 10.0f; in->locy = 300.0f;
- nodeSetActive(ntree, in);
-
- /* only a link from color to color */
- fromsock = in->outputs.first;
- tosock = out->inputs.first;
- nodeAddLink(ntree, in, fromsock, out, tosock);
-
- /* default values */
- PointerRNA sockptr;
- sock = in->inputs.first;
- RNA_pointer_create((ID *)ntree, &RNA_NodeSocket, sock, &sockptr);
-
- RNA_float_set_array(&sockptr, "default_value", color);
-
- if (strength != 0.0f) {
- sock = in->inputs.last;
- RNA_pointer_create((ID *)ntree, &RNA_NodeSocket, sock, &sockptr);
- RNA_float_set(&sockptr, "default_value", strength);
- }
-
- ntreeUpdateTree(CTX_data_main(C), ntree);
+ bNode *in, *out;
+ bNodeSocket *fromsock, *tosock, *sock;
+ bNodeTree *ntree;
+ int output_type, shader_type;
+ float color[4] = {0.0f, 0.0f, 0.0f, 1.0f}, strength = 1.0f;
+
+ ntree = ntreeAddTree(NULL, "Shader Nodetree", ntreeType_Shader->idname);
+
+ switch (GS(id->name)) {
+ case ID_MA: {
+ Material *ma = (Material *)id;
+ ma->nodetree = ntree;
+
+ output_type = SH_NODE_OUTPUT_MATERIAL;
+ shader_type = SH_NODE_BSDF_PRINCIPLED;
+
+ copy_v3_v3(color, &ma->r);
+ strength = 0.0f;
+ break;
+ }
+ case ID_WO: {
+ World *wo = (World *)id;
+ wo->nodetree = ntree;
+
+ output_type = SH_NODE_OUTPUT_WORLD;
+ shader_type = SH_NODE_BACKGROUND;
+
+ copy_v3_v3(color, &wo->horr);
+ strength = 1.0f;
+ break;
+ }
+ case ID_LA: {
+ Light *la = (Light *)id;
+ la->nodetree = ntree;
+
+ output_type = SH_NODE_OUTPUT_LIGHT;
+ shader_type = SH_NODE_EMISSION;
+
+ copy_v3_v3(color, &la->r);
+ if (la->type == LA_LOCAL || la->type == LA_SPOT || la->type == LA_AREA) {
+ strength = 100.0f;
+ }
+ else {
+ strength = 1.0f;
+ }
+ break;
+ }
+ default:
+ printf("ED_node_shader_default called on wrong ID type.\n");
+ return;
+ }
+
+ out = nodeAddStaticNode(C, ntree, output_type);
+ out->locx = 300.0f;
+ out->locy = 300.0f;
+
+ in = nodeAddStaticNode(C, ntree, shader_type);
+ in->locx = 10.0f;
+ in->locy = 300.0f;
+ nodeSetActive(ntree, in);
+
+ /* only a link from color to color */
+ fromsock = in->outputs.first;
+ tosock = out->inputs.first;
+ nodeAddLink(ntree, in, fromsock, out, tosock);
+
+ /* default values */
+ PointerRNA sockptr;
+ sock = in->inputs.first;
+ RNA_pointer_create((ID *)ntree, &RNA_NodeSocket, sock, &sockptr);
+
+ RNA_float_set_array(&sockptr, "default_value", color);
+
+ if (strength != 0.0f) {
+ sock = in->inputs.last;
+ RNA_pointer_create((ID *)ntree, &RNA_NodeSocket, sock, &sockptr);
+ RNA_float_set(&sockptr, "default_value", strength);
+ }
+
+ ntreeUpdateTree(CTX_data_main(C), ntree);
}
/* assumes nothing being done in ntree yet, sets the default in/out node */
/* called from shading buttons or header */
void ED_node_composit_default(const bContext *C, struct Scene *sce)
{
- bNode *in, *out;
- bNodeSocket *fromsock, *tosock;
+ bNode *in, *out;
+ bNodeSocket *fromsock, *tosock;
- /* but lets check it anyway */
- if (sce->nodetree) {
- if (G.debug & G_DEBUG) {
- printf("error in composite initialize\n");
- }
- return;
- }
+ /* but lets check it anyway */
+ if (sce->nodetree) {
+ if (G.debug & G_DEBUG) {
+ printf("error in composite initialize\n");
+ }
+ return;
+ }
- sce->nodetree = ntreeAddTree(NULL, "Compositing Nodetree", ntreeType_Composite->idname);
+ sce->nodetree = ntreeAddTree(NULL, "Compositing Nodetree", ntreeType_Composite->idname);
- sce->nodetree->chunksize = 256;
- sce->nodetree->edit_quality = NTREE_QUALITY_HIGH;
- sce->nodetree->render_quality = NTREE_QUALITY_HIGH;
+ sce->nodetree->chunksize = 256;
+ sce->nodetree->edit_quality = NTREE_QUALITY_HIGH;
+ sce->nodetree->render_quality = NTREE_QUALITY_HIGH;
- out = nodeAddStaticNode(C, sce->nodetree, CMP_NODE_COMPOSITE);
- out->locx = 300.0f; out->locy = 400.0f;
+ out = nodeAddStaticNode(C, sce->nodetree, CMP_NODE_COMPOSITE);
+ out->locx = 300.0f;
+ out->locy = 400.0f;
- in = nodeAddStaticNode(C, sce->nodetree, CMP_NODE_R_LAYERS);
- in->locx = 10.0f; in->locy = 400.0f;
- nodeSetActive(sce->nodetree, in);
+ in = nodeAddStaticNode(C, sce->nodetree, CMP_NODE_R_LAYERS);
+ in->locx = 10.0f;
+ in->locy = 400.0f;
+ nodeSetActive(sce->nodetree, in);
- /* links from color to color */
- fromsock = in->outputs.first;
- tosock = out->inputs.first;
- nodeAddLink(sce->nodetree, in, fromsock, out, tosock);
+ /* links from color to color */
+ fromsock = in->outputs.first;
+ tosock = out->inputs.first;
+ nodeAddLink(sce->nodetree, in, fromsock, out, tosock);
- ntreeUpdateTree(CTX_data_main(C), sce->nodetree);
+ ntreeUpdateTree(CTX_data_main(C), sce->nodetree);
}
/* assumes nothing being done in ntree yet, sets the default in/out node */
/* called from shading buttons or header */
void ED_node_texture_default(const bContext *C, Tex *tx)
{
- bNode *in, *out;
- bNodeSocket *fromsock, *tosock;
+ bNode *in, *out;
+ bNodeSocket *fromsock, *tosock;
- /* but lets check it anyway */
- if (tx->nodetree) {
- if (G.debug & G_DEBUG) {
- printf("error in texture initialize\n");
- }
- return;
- }
+ /* but lets check it anyway */
+ if (tx->nodetree) {
+ if (G.debug & G_DEBUG) {
+ printf("error in texture initialize\n");
+ }
+ return;
+ }
- tx->nodetree = ntreeAddTree(NULL, "Texture Nodetree", ntreeType_Texture->idname);
+ tx->nodetree = ntreeAddTree(NULL, "Texture Nodetree", ntreeType_Texture->idname);
- out = nodeAddStaticNode(C, tx->nodetree, TEX_NODE_OUTPUT);
- out->locx = 300.0f; out->locy = 300.0f;
+ out = nodeAddStaticNode(C, tx->nodetree, TEX_NODE_OUTPUT);
+ out->locx = 300.0f;
+ out->locy = 300.0f;
- in = nodeAddStaticNode(C, tx->nodetree, TEX_NODE_CHECKER);
- in->locx = 10.0f; in->locy = 300.0f;
- nodeSetActive(tx->nodetree, in);
+ in = nodeAddStaticNode(C, tx->nodetree, TEX_NODE_CHECKER);
+ in->locx = 10.0f;
+ in->locy = 300.0f;
+ nodeSetActive(tx->nodetree, in);
- fromsock = in->outputs.first;
- tosock = out->inputs.first;
- nodeAddLink(tx->nodetree, in, fromsock, out, tosock);
+ fromsock = in->outputs.first;
+ tosock = out->inputs.first;
+ nodeAddLink(tx->nodetree, in, fromsock, out, tosock);
- ntreeUpdateTree(CTX_data_main(C), tx->nodetree);
+ ntreeUpdateTree(CTX_data_main(C), tx->nodetree);
}
/* Here we set the active tree(s), even called for each redraw now, so keep it fast :) */
void snode_set_context(const bContext *C)
{
- SpaceNode *snode = CTX_wm_space_node(C);
- bNodeTreeType *treetype = ntreeTypeFind(snode->tree_idname);
- bNodeTree *ntree = snode->nodetree;
- ID *id = snode->id, *from = snode->from;
-
- /* check the tree type */
- if (!treetype ||
- (treetype->poll && !treetype->poll(C, treetype)))
- {
- /* invalid tree type, skip
- * NB: not resetting the node path here, invalid bNodeTreeType
- * may still be registered at a later point.
- */
- return;
- }
-
- if (snode->nodetree && !STREQ(snode->nodetree->idname, snode->tree_idname)) {
- /* current tree does not match selected type, clear tree path */
- ntree = NULL;
- id = NULL;
- from = NULL;
- }
-
- if (!(snode->flag & SNODE_PIN) || ntree == NULL) {
- if (treetype->get_from_context) {
- /* reset and update from context */
- ntree = NULL;
- id = NULL;
- from = NULL;
-
- treetype->get_from_context(C, treetype, &ntree, &id, &from);
- }
- }
-
- if (snode->nodetree != ntree || snode->id != id || snode->from != from ||
- (snode->treepath.last == NULL && ntree))
- {
- ED_node_tree_start(snode, ntree, id, from);
- }
+ SpaceNode *snode = CTX_wm_space_node(C);
+ bNodeTreeType *treetype = ntreeTypeFind(snode->tree_idname);
+ bNodeTree *ntree = snode->nodetree;
+ ID *id = snode->id, *from = snode->from;
+
+ /* check the tree type */
+ if (!treetype || (treetype->poll && !treetype->poll(C, treetype))) {
+ /* invalid tree type, skip
+ * NB: not resetting the node path here, invalid bNodeTreeType
+ * may still be registered at a later point.
+ */
+ return;
+ }
+
+ if (snode->nodetree && !STREQ(snode->nodetree->idname, snode->tree_idname)) {
+ /* current tree does not match selected type, clear tree path */
+ ntree = NULL;
+ id = NULL;
+ from = NULL;
+ }
+
+ if (!(snode->flag & SNODE_PIN) || ntree == NULL) {
+ if (treetype->get_from_context) {
+ /* reset and update from context */
+ ntree = NULL;
+ id = NULL;
+ from = NULL;
+
+ treetype->get_from_context(C, treetype, &ntree, &id, &from);
+ }
+ }
+
+ if (snode->nodetree != ntree || snode->id != id || snode->from != from ||
+ (snode->treepath.last == NULL && ntree)) {
+ ED_node_tree_start(snode, ntree, id, from);
+ }
}
void snode_update(SpaceNode *snode, bNode *node)
{
- bNodeTreePath *path;
+ bNodeTreePath *path;
- /* XXX this only updates nodes in the current node space tree path.
- * The function supposedly should update any potential group node linking to changed tree,
- * this really requires a working depsgraph ...
- */
+ /* XXX this only updates nodes in the current node space tree path.
+ * The function supposedly should update any potential group node linking to changed tree,
+ * this really requires a working depsgraph ...
+ */
- /* update all edited group nodes */
- path = snode->treepath.last;
- if (path) {
- bNodeTree *ngroup = path->nodetree;
- for (path = path->prev; path; path = path->prev) {
- nodeUpdateID(path->nodetree, (ID *)ngroup);
- ngroup = path->nodetree;
- }
- }
+ /* update all edited group nodes */
+ path = snode->treepath.last;
+ if (path) {
+ bNodeTree *ngroup = path->nodetree;
+ for (path = path->prev; path; path = path->prev) {
+ nodeUpdateID(path->nodetree, (ID *)ngroup);
+ ngroup = path->nodetree;
+ }
+ }
- if (node) {
- nodeUpdate(snode->edittree, node);
- }
+ if (node) {
+ nodeUpdate(snode->edittree, node);
+ }
}
void ED_node_set_active(Main *bmain, bNodeTree *ntree, bNode *node)
{
- const bool was_active_texture = (node->flag & NODE_ACTIVE_TEXTURE) != 0;
-
- nodeSetActive(ntree, node);
-
- if (node->type != NODE_GROUP) {
- const bool was_output = (node->flag & NODE_DO_OUTPUT) != 0;
- bool do_update = false;
-
- /* generic node group output: set node as active output */
- if (node->type == NODE_GROUP_OUTPUT) {
- bNode *tnode;
- for (tnode = ntree->nodes.first; tnode; tnode = tnode->next) {
- if (tnode->type == NODE_GROUP_OUTPUT) {
- tnode->flag &= ~NODE_DO_OUTPUT;
- }
- }
-
- node->flag |= NODE_DO_OUTPUT;
- if (!was_output) {
- do_update = 1;
- }
- }
-
- /* tree specific activate calls */
- if (ntree->type == NTREE_SHADER) {
- /* when we select a material, active texture is cleared, for buttons */
- if (node->id && ELEM(GS(node->id->name), ID_MA, ID_LA, ID_WO)) {
- nodeClearActiveID(ntree, ID_TE);
- }
-
- if (ELEM(node->type, SH_NODE_OUTPUT_MATERIAL,
- SH_NODE_OUTPUT_WORLD, SH_NODE_OUTPUT_LIGHT, SH_NODE_OUTPUT_LINESTYLE))
- {
- bNode *tnode;
-
- for (tnode = ntree->nodes.first; tnode; tnode = tnode->next) {
- if (tnode->type == node->type) {
- tnode->flag &= ~NODE_DO_OUTPUT;
- }
- }
-
- node->flag |= NODE_DO_OUTPUT;
- if (was_output == 0) {
- ED_node_tag_update_nodetree(bmain, ntree, node);
- }
- }
- else if (do_update) {
- ED_node_tag_update_nodetree(bmain, ntree, node);
- }
-
- /* if active texture changed, free glsl materials */
- if ((node->flag & NODE_ACTIVE_TEXTURE) && !was_active_texture) {
- Material *ma;
- World *wo;
-
- for (ma = bmain->materials.first; ma; ma = ma->id.next) {
- if (ma->nodetree && ma->use_nodes && ntreeHasTree(ma->nodetree, ntree)) {
- GPU_material_free(&ma->gpumaterial);
- }
- }
-
- for (wo = bmain->worlds.first; wo; wo = wo->id.next) {
- if (wo->nodetree && wo->use_nodes && ntreeHasTree(wo->nodetree, ntree)) {
- GPU_material_free(&wo->gpumaterial);
- }
- }
-
- ED_node_tag_update_nodetree(bmain, ntree, node);
- WM_main_add_notifier(NC_IMAGE, NULL);
- }
-
- WM_main_add_notifier(NC_MATERIAL | ND_NODES, node->id);
- }
- else if (ntree->type == NTREE_COMPOSIT) {
- /* make active viewer, currently only 1 supported... */
- if (ELEM(node->type, CMP_NODE_VIEWER, CMP_NODE_SPLITVIEWER)) {
- bNode *tnode;
-
-
- for (tnode = ntree->nodes.first; tnode; tnode = tnode->next) {
- if (ELEM(tnode->type, CMP_NODE_VIEWER, CMP_NODE_SPLITVIEWER)) {
- tnode->flag &= ~NODE_DO_OUTPUT;
- }
- }
-
- node->flag |= NODE_DO_OUTPUT;
- if (was_output == 0) {
- ED_node_tag_update_nodetree(bmain, ntree, node);
- }
-
- /* addnode() doesn't link this yet... */
- node->id = (ID *)BKE_image_verify_viewer(bmain, IMA_TYPE_COMPOSITE, "Viewer Node");
- }
- else if (node->type == CMP_NODE_COMPOSITE) {
- if (was_output == 0) {
- bNode *tnode;
-
- for (tnode = ntree->nodes.first; tnode; tnode = tnode->next) {
- if (tnode->type == CMP_NODE_COMPOSITE) {
- tnode->flag &= ~NODE_DO_OUTPUT;
- }
- }
-
- node->flag |= NODE_DO_OUTPUT;
- ED_node_tag_update_nodetree(bmain, ntree, node);
- }
- }
- else if (do_update) {
- ED_node_tag_update_nodetree(bmain, ntree, node);
- }
- }
- else if (ntree->type == NTREE_TEXTURE) {
- // XXX
+ const bool was_active_texture = (node->flag & NODE_ACTIVE_TEXTURE) != 0;
+
+ nodeSetActive(ntree, node);
+
+ if (node->type != NODE_GROUP) {
+ const bool was_output = (node->flag & NODE_DO_OUTPUT) != 0;
+ bool do_update = false;
+
+ /* generic node group output: set node as active output */
+ if (node->type == NODE_GROUP_OUTPUT) {
+ bNode *tnode;
+ for (tnode = ntree->nodes.first; tnode; tnode = tnode->next) {
+ if (tnode->type == NODE_GROUP_OUTPUT) {
+ tnode->flag &= ~NODE_DO_OUTPUT;
+ }
+ }
+
+ node->flag |= NODE_DO_OUTPUT;
+ if (!was_output) {
+ do_update = 1;
+ }
+ }
+
+ /* tree specific activate calls */
+ if (ntree->type == NTREE_SHADER) {
+ /* when we select a material, active texture is cleared, for buttons */
+ if (node->id && ELEM(GS(node->id->name), ID_MA, ID_LA, ID_WO)) {
+ nodeClearActiveID(ntree, ID_TE);
+ }
+
+ if (ELEM(node->type,
+ SH_NODE_OUTPUT_MATERIAL,
+ SH_NODE_OUTPUT_WORLD,
+ SH_NODE_OUTPUT_LIGHT,
+ SH_NODE_OUTPUT_LINESTYLE)) {
+ bNode *tnode;
+
+ for (tnode = ntree->nodes.first; tnode; tnode = tnode->next) {
+ if (tnode->type == node->type) {
+ tnode->flag &= ~NODE_DO_OUTPUT;
+ }
+ }
+
+ node->flag |= NODE_DO_OUTPUT;
+ if (was_output == 0) {
+ ED_node_tag_update_nodetree(bmain, ntree, node);
+ }
+ }
+ else if (do_update) {
+ ED_node_tag_update_nodetree(bmain, ntree, node);
+ }
+
+ /* if active texture changed, free glsl materials */
+ if ((node->flag & NODE_ACTIVE_TEXTURE) && !was_active_texture) {
+ Material *ma;
+ World *wo;
+
+ for (ma = bmain->materials.first; ma; ma = ma->id.next) {
+ if (ma->nodetree && ma->use_nodes && ntreeHasTree(ma->nodetree, ntree)) {
+ GPU_material_free(&ma->gpumaterial);
+ }
+ }
+
+ for (wo = bmain->worlds.first; wo; wo = wo->id.next) {
+ if (wo->nodetree && wo->use_nodes && ntreeHasTree(wo->nodetree, ntree)) {
+ GPU_material_free(&wo->gpumaterial);
+ }
+ }
+
+ ED_node_tag_update_nodetree(bmain, ntree, node);
+ WM_main_add_notifier(NC_IMAGE, NULL);
+ }
+
+ WM_main_add_notifier(NC_MATERIAL | ND_NODES, node->id);
+ }
+ else if (ntree->type == NTREE_COMPOSIT) {
+ /* make active viewer, currently only 1 supported... */
+ if (ELEM(node->type, CMP_NODE_VIEWER, CMP_NODE_SPLITVIEWER)) {
+ bNode *tnode;
+
+ for (tnode = ntree->nodes.first; tnode; tnode = tnode->next) {
+ if (ELEM(tnode->type, CMP_NODE_VIEWER, CMP_NODE_SPLITVIEWER)) {
+ tnode->flag &= ~NODE_DO_OUTPUT;
+ }
+ }
+
+ node->flag |= NODE_DO_OUTPUT;
+ if (was_output == 0) {
+ ED_node_tag_update_nodetree(bmain, ntree, node);
+ }
+
+ /* addnode() doesn't link this yet... */
+ node->id = (ID *)BKE_image_verify_viewer(bmain, IMA_TYPE_COMPOSITE, "Viewer Node");
+ }
+ else if (node->type == CMP_NODE_COMPOSITE) {
+ if (was_output == 0) {
+ bNode *tnode;
+
+ for (tnode = ntree->nodes.first; tnode; tnode = tnode->next) {
+ if (tnode->type == CMP_NODE_COMPOSITE) {
+ tnode->flag &= ~NODE_DO_OUTPUT;
+ }
+ }
+
+ node->flag |= NODE_DO_OUTPUT;
+ ED_node_tag_update_nodetree(bmain, ntree, node);
+ }
+ }
+ else if (do_update) {
+ ED_node_tag_update_nodetree(bmain, ntree, node);
+ }
+ }
+ else if (ntree->type == NTREE_TEXTURE) {
+ // XXX
#if 0
- if (node->id)
- ; // XXX BIF_preview_changed(-1);
- // allqueue(REDRAWBUTSSHADING, 1);
- // allqueue(REDRAWIPO, 0);
+ if (node->id)
+ ; // XXX BIF_preview_changed(-1);
+ // allqueue(REDRAWBUTSSHADING, 1);
+ // allqueue(REDRAWIPO, 0);
#endif
- }
- }
+ }
+ }
}
void ED_node_post_apply_transform(bContext *UNUSED(C), bNodeTree *UNUSED(ntree))
{
- /* XXX This does not work due to layout functions relying on node->block,
- * which only exists during actual drawing. Can we rely on valid totr rects?
- */
- /* make sure nodes have correct bounding boxes after transform */
- /* node_update_nodetree(C, ntree, 0.0f, 0.0f); */
+ /* XXX This does not work due to layout functions relying on node->block,
+ * which only exists during actual drawing. Can we rely on valid totr rects?
+ */
+ /* make sure nodes have correct bounding boxes after transform */
+ /* node_update_nodetree(C, ntree, 0.0f, 0.0f); */
}
/* ***************** generic operator functions for nodes ***************** */
@@ -757,61 +774,61 @@ void ED_node_post_apply_transform(bContext *UNUSED(C), bNodeTree *UNUSED(ntree))
static bool edit_node_poll(bContext *C)
{
- return ED_operator_node_active(C);
+ return ED_operator_node_active(C);
}
static void edit_node_properties(wmOperatorType *ot)
{
- /* XXX could node be a context pointer? */
- RNA_def_string(ot->srna, "node", NULL, MAX_NAME, "Node", "");
- RNA_def_int(ot->srna, "socket", 0, 0, MAX_SOCKET, "Socket", "", 0, MAX_SOCKET);
- RNA_def_enum(ot->srna, "in_out", rna_enum_node_socket_in_out_items, SOCK_IN, "Socket Side", "");
+ /* XXX could node be a context pointer? */
+ RNA_def_string(ot->srna, "node", NULL, MAX_NAME, "Node", "");
+ RNA_def_int(ot->srna, "socket", 0, 0, MAX_SOCKET, "Socket", "", 0, MAX_SOCKET);
+ RNA_def_enum(ot->srna, "in_out", rna_enum_node_socket_in_out_items, SOCK_IN, "Socket Side", "");
}
static int edit_node_invoke_properties(bContext *C, wmOperator *op)
{
- if (!RNA_struct_property_is_set(op->ptr, "node")) {
- bNode *node = CTX_data_pointer_get_type(C, "node", &RNA_Node).data;
- if (!node)
- return 0;
- else
- RNA_string_set(op->ptr, "node", node->name);
- }
+ if (!RNA_struct_property_is_set(op->ptr, "node")) {
+ bNode *node = CTX_data_pointer_get_type(C, "node", &RNA_Node).data;
+ if (!node)
+ return 0;
+ else
+ RNA_string_set(op->ptr, "node", node->name);
+ }
- if (!RNA_struct_property_is_set(op->ptr, "in_out"))
- RNA_enum_set(op->ptr, "in_out", SOCK_IN);
+ if (!RNA_struct_property_is_set(op->ptr, "in_out"))
+ RNA_enum_set(op->ptr, "in_out", SOCK_IN);
- if (!RNA_struct_property_is_set(op->ptr, "socket"))
- RNA_int_set(op->ptr, "socket", 0);
+ if (!RNA_struct_property_is_set(op->ptr, "socket"))
+ RNA_int_set(op->ptr, "socket", 0);
- return 1;
+ return 1;
}
static void edit_node_properties_get(wmOperator *op, bNodeTree *ntree, bNode **rnode, bNodeSocket **rsock, int *rin_out)
{
- bNode *node;
- bNodeSocket *sock = NULL;
- char nodename[MAX_NAME];
- int sockindex;
- int in_out;
+ bNode *node;
+ bNodeSocket *sock = NULL;
+ char nodename[MAX_NAME];
+ int sockindex;
+ int in_out;
- RNA_string_get(op->ptr, "node", nodename);
- node = nodeFindNodebyName(ntree, nodename);
+ RNA_string_get(op->ptr, "node", nodename);
+ node = nodeFindNodebyName(ntree, nodename);
- in_out = RNA_enum_get(op->ptr, "in_out");
+ in_out = RNA_enum_get(op->ptr, "in_out");
- sockindex = RNA_int_get(op->ptr, "socket");
- switch (in_out) {
- case SOCK_IN: sock = BLI_findlink(&node->inputs, sockindex); break;
- case SOCK_OUT: sock = BLI_findlink(&node->outputs, sockindex); break;
- }
+ sockindex = RNA_int_get(op->ptr, "socket");
+ switch (in_out) {
+ case SOCK_IN: sock = BLI_findlink(&node->inputs, sockindex); break;
+ case SOCK_OUT: sock = BLI_findlink(&node->outputs, sockindex); break;
+ }
- if (rnode)
- *rnode = node;
- if (rsock)
- *rsock = sock;
- if (rin_out)
- *rin_out = in_out;
+ if (rnode)
+ *rnode = node;
+ if (rsock)
+ *rsock = sock;
+ if (rin_out)
+ *rin_out = in_out;
}
#endif
@@ -820,1929 +837,1940 @@ static void edit_node_properties_get(wmOperator *op, bNodeTree *ntree, bNode **r
/* is rct in visible part of node? */
static bNode *visible_node(SpaceNode *snode, const rctf *rct)
{
- bNode *node;
+ bNode *node;
- for (node = snode->edittree->nodes.last; node; node = node->prev) {
- if (BLI_rctf_isect(&node->totr, rct, NULL)) {
- break;
- }
- }
- return node;
+ for (node = snode->edittree->nodes.last; node; node = node->prev) {
+ if (BLI_rctf_isect(&node->totr, rct, NULL)) {
+ break;
+ }
+ }
+ return node;
}
/* ********************** size widget operator ******************** */
typedef struct NodeSizeWidget {
- float mxstart, mystart;
- float oldlocx, oldlocy;
- float oldoffsetx, oldoffsety;
- float oldwidth, oldheight;
- int directions;
+ float mxstart, mystart;
+ float oldlocx, oldlocy;
+ float oldoffsetx, oldoffsety;
+ float oldwidth, oldheight;
+ int directions;
} NodeSizeWidget;
-static void node_resize_init(bContext *C, wmOperator *op, const wmEvent *UNUSED(event), bNode *node, int dir)
+static void node_resize_init(
+ bContext *C, wmOperator *op, const wmEvent *UNUSED(event), bNode *node, int dir)
{
- SpaceNode *snode = CTX_wm_space_node(C);
+ SpaceNode *snode = CTX_wm_space_node(C);
- NodeSizeWidget *nsw = MEM_callocN(sizeof(NodeSizeWidget), "size widget op data");
+ NodeSizeWidget *nsw = MEM_callocN(sizeof(NodeSizeWidget), "size widget op data");
- op->customdata = nsw;
- nsw->mxstart = snode->cursor[0] * UI_DPI_FAC;
- nsw->mystart = snode->cursor[1] * UI_DPI_FAC;
+ op->customdata = nsw;
+ nsw->mxstart = snode->cursor[0] * UI_DPI_FAC;
+ nsw->mystart = snode->cursor[1] * UI_DPI_FAC;
- /* store old */
- nsw->oldlocx = node->locx;
- nsw->oldlocy = node->locy;
- nsw->oldoffsetx = node->offsetx;
- nsw->oldoffsety = node->offsety;
- nsw->oldwidth = node->width;
- nsw->oldheight = node->height;
- nsw->directions = dir;
+ /* store old */
+ nsw->oldlocx = node->locx;
+ nsw->oldlocy = node->locy;
+ nsw->oldoffsetx = node->offsetx;
+ nsw->oldoffsety = node->offsety;
+ nsw->oldwidth = node->width;
+ nsw->oldheight = node->height;
+ nsw->directions = dir;
- WM_cursor_modal_set(CTX_wm_window(C), node_get_resize_cursor(dir));
- /* add modal handler */
- WM_event_add_modal_handler(C, op);
+ WM_cursor_modal_set(CTX_wm_window(C), node_get_resize_cursor(dir));
+ /* add modal handler */
+ WM_event_add_modal_handler(C, op);
}
static void node_resize_exit(bContext *C, wmOperator *op, bool UNUSED(cancel))
{
- WM_cursor_modal_restore(CTX_wm_window(C));
+ WM_cursor_modal_restore(CTX_wm_window(C));
- MEM_freeN(op->customdata);
- op->customdata = NULL;
+ MEM_freeN(op->customdata);
+ op->customdata = NULL;
}
static int node_resize_modal(bContext *C, wmOperator *op, const wmEvent *event)
{
- SpaceNode *snode = CTX_wm_space_node(C);
- ARegion *ar = CTX_wm_region(C);
- bNode *node = nodeGetActive(snode->edittree);
- NodeSizeWidget *nsw = op->customdata;
- float mx, my, dx, dy;
-
- switch (event->type) {
- case MOUSEMOVE:
-
- UI_view2d_region_to_view(&ar->v2d, event->mval[0], event->mval[1], &mx, &my);
- dx = (mx - nsw->mxstart) / UI_DPI_FAC;
- dy = (my - nsw->mystart) / UI_DPI_FAC;
-
- if (node) {
- float *pwidth;
- float oldwidth, widthmin, widthmax;
-
- pwidth = &node->width;
- oldwidth = nsw->oldwidth;
- widthmin = node->typeinfo->minwidth;
- widthmax = node->typeinfo->maxwidth;
-
- {
- if (nsw->directions & NODE_RESIZE_RIGHT) {
- *pwidth = oldwidth + dx;
- CLAMP(*pwidth, widthmin, widthmax);
- }
- if (nsw->directions & NODE_RESIZE_LEFT) {
- float locmax = nsw->oldlocx + oldwidth;
-
- node->locx = nsw->oldlocx + dx;
- CLAMP(node->locx, locmax - widthmax, locmax - widthmin);
- *pwidth = locmax - node->locx;
- }
- }
-
- /* height works the other way round ... */
- {
- float heightmin = UI_DPI_FAC * node->typeinfo->minheight;
- float heightmax = UI_DPI_FAC * node->typeinfo->maxheight;
- if (nsw->directions & NODE_RESIZE_TOP) {
- float locmin = nsw->oldlocy - nsw->oldheight;
-
- node->locy = nsw->oldlocy + dy;
- CLAMP(node->locy, locmin + heightmin, locmin + heightmax);
- node->height = node->locy - locmin;
- }
- if (nsw->directions & NODE_RESIZE_BOTTOM) {
- node->height = nsw->oldheight - dy;
- CLAMP(node->height, heightmin, heightmax);
- }
- }
-
- /* XXX make callback? */
- if (node->type == NODE_FRAME) {
- /* keep the offset symmetric around center point */
- if (nsw->directions & NODE_RESIZE_LEFT) {
- node->locx = nsw->oldlocx + 0.5f * dx;
- node->offsetx = nsw->oldoffsetx + 0.5f * dx;
- }
- if (nsw->directions & NODE_RESIZE_RIGHT) {
- node->locx = nsw->oldlocx + 0.5f * dx;
- node->offsetx = nsw->oldoffsetx - 0.5f * dx;
- }
- if (nsw->directions & NODE_RESIZE_TOP) {
- node->locy = nsw->oldlocy + 0.5f * dy;
- node->offsety = nsw->oldoffsety + 0.5f * dy;
- }
- if (nsw->directions & NODE_RESIZE_BOTTOM) {
- node->locy = nsw->oldlocy + 0.5f * dy;
- node->offsety = nsw->oldoffsety - 0.5f * dy;
- }
- }
- }
-
- ED_region_tag_redraw(ar);
-
- break;
-
- case LEFTMOUSE:
- case MIDDLEMOUSE:
- case RIGHTMOUSE:
- if (event->val == KM_RELEASE) {
- node_resize_exit(C, op, false);
- ED_node_post_apply_transform(C, snode->edittree);
-
- return OPERATOR_FINISHED;
- }
- break;
- }
-
- return OPERATOR_RUNNING_MODAL;
+ SpaceNode *snode = CTX_wm_space_node(C);
+ ARegion *ar = CTX_wm_region(C);
+ bNode *node = nodeGetActive(snode->edittree);
+ NodeSizeWidget *nsw = op->customdata;
+ float mx, my, dx, dy;
+
+ switch (event->type) {
+ case MOUSEMOVE:
+
+ UI_view2d_region_to_view(&ar->v2d, event->mval[0], event->mval[1], &mx, &my);
+ dx = (mx - nsw->mxstart) / UI_DPI_FAC;
+ dy = (my - nsw->mystart) / UI_DPI_FAC;
+
+ if (node) {
+ float *pwidth;
+ float oldwidth, widthmin, widthmax;
+
+ pwidth = &node->width;
+ oldwidth = nsw->oldwidth;
+ widthmin = node->typeinfo->minwidth;
+ widthmax = node->typeinfo->maxwidth;
+
+ {
+ if (nsw->directions & NODE_RESIZE_RIGHT) {
+ *pwidth = oldwidth + dx;
+ CLAMP(*pwidth, widthmin, widthmax);
+ }
+ if (nsw->directions & NODE_RESIZE_LEFT) {
+ float locmax = nsw->oldlocx + oldwidth;
+
+ node->locx = nsw->oldlocx + dx;
+ CLAMP(node->locx, locmax - widthmax, locmax - widthmin);
+ *pwidth = locmax - node->locx;
+ }
+ }
+
+ /* height works the other way round ... */
+ {
+ float heightmin = UI_DPI_FAC * node->typeinfo->minheight;
+ float heightmax = UI_DPI_FAC * node->typeinfo->maxheight;
+ if (nsw->directions & NODE_RESIZE_TOP) {
+ float locmin = nsw->oldlocy - nsw->oldheight;
+
+ node->locy = nsw->oldlocy + dy;
+ CLAMP(node->locy, locmin + heightmin, locmin + heightmax);
+ node->height = node->locy - locmin;
+ }
+ if (nsw->directions & NODE_RESIZE_BOTTOM) {
+ node->height = nsw->oldheight - dy;
+ CLAMP(node->height, heightmin, heightmax);
+ }
+ }
+
+ /* XXX make callback? */
+ if (node->type == NODE_FRAME) {
+ /* keep the offset symmetric around center point */
+ if (nsw->directions & NODE_RESIZE_LEFT) {
+ node->locx = nsw->oldlocx + 0.5f * dx;
+ node->offsetx = nsw->oldoffsetx + 0.5f * dx;
+ }
+ if (nsw->directions & NODE_RESIZE_RIGHT) {
+ node->locx = nsw->oldlocx + 0.5f * dx;
+ node->offsetx = nsw->oldoffsetx - 0.5f * dx;
+ }
+ if (nsw->directions & NODE_RESIZE_TOP) {
+ node->locy = nsw->oldlocy + 0.5f * dy;
+ node->offsety = nsw->oldoffsety + 0.5f * dy;
+ }
+ if (nsw->directions & NODE_RESIZE_BOTTOM) {
+ node->locy = nsw->oldlocy + 0.5f * dy;
+ node->offsety = nsw->oldoffsety - 0.5f * dy;
+ }
+ }
+ }
+
+ ED_region_tag_redraw(ar);
+
+ break;
+
+ case LEFTMOUSE:
+ case MIDDLEMOUSE:
+ case RIGHTMOUSE:
+ if (event->val == KM_RELEASE) {
+ node_resize_exit(C, op, false);
+ ED_node_post_apply_transform(C, snode->edittree);
+
+ return OPERATOR_FINISHED;
+ }
+ break;
+ }
+
+ return OPERATOR_RUNNING_MODAL;
}
static int node_resize_invoke(bContext *C, wmOperator *op, const wmEvent *event)
{
- SpaceNode *snode = CTX_wm_space_node(C);
- ARegion *ar = CTX_wm_region(C);
- bNode *node = nodeGetActive(snode->edittree);
- int dir;
+ SpaceNode *snode = CTX_wm_space_node(C);
+ ARegion *ar = CTX_wm_region(C);
+ bNode *node = nodeGetActive(snode->edittree);
+ int dir;
- if (node) {
- float cursor[2];
+ if (node) {
+ float cursor[2];
- /* convert mouse coordinates to v2d space */
- UI_view2d_region_to_view(&ar->v2d, event->mval[0], event->mval[1],
- &cursor[0], &cursor[1]);
- dir = node->typeinfo->resize_area_func(node, cursor[0], cursor[1]);
- if (dir != 0) {
- node_resize_init(C, op, event, node, dir);
- return OPERATOR_RUNNING_MODAL;
- }
- }
- return OPERATOR_CANCELLED | OPERATOR_PASS_THROUGH;
+ /* convert mouse coordinates to v2d space */
+ UI_view2d_region_to_view(&ar->v2d, event->mval[0], event->mval[1], &cursor[0], &cursor[1]);
+ dir = node->typeinfo->resize_area_func(node, cursor[0], cursor[1]);
+ if (dir != 0) {
+ node_resize_init(C, op, event, node, dir);
+ return OPERATOR_RUNNING_MODAL;
+ }
+ }
+ return OPERATOR_CANCELLED | OPERATOR_PASS_THROUGH;
}
static void node_resize_cancel(bContext *C, wmOperator *op)
{
- node_resize_exit(C, op, true);
+ node_resize_exit(C, op, true);
}
void NODE_OT_resize(wmOperatorType *ot)
{
- /* identifiers */
- ot->name = "Resize Node";
- ot->idname = "NODE_OT_resize";
- ot->description = "Resize a node";
+ /* identifiers */
+ ot->name = "Resize Node";
+ ot->idname = "NODE_OT_resize";
+ ot->description = "Resize a node";
- /* api callbacks */
- ot->invoke = node_resize_invoke;
- ot->modal = node_resize_modal;
- ot->poll = ED_operator_node_active;
- ot->cancel = node_resize_cancel;
+ /* api callbacks */
+ ot->invoke = node_resize_invoke;
+ ot->modal = node_resize_modal;
+ ot->poll = ED_operator_node_active;
+ ot->cancel = node_resize_cancel;
- /* flags */
- ot->flag = OPTYPE_BLOCKING;
+ /* flags */
+ ot->flag = OPTYPE_BLOCKING;
}
-
/* ********************** hidden sockets ******************** */
int node_has_hidden_sockets(bNode *node)
{
- bNodeSocket *sock;
+ bNodeSocket *sock;
- for (sock = node->inputs.first; sock; sock = sock->next) {
- if (sock->flag & SOCK_HIDDEN) {
- return 1;
- }
- }
- for (sock = node->outputs.first; sock; sock = sock->next) {
- if (sock->flag & SOCK_HIDDEN) {
- return 1;
- }
- }
- return 0;
+ for (sock = node->inputs.first; sock; sock = sock->next) {
+ if (sock->flag & SOCK_HIDDEN) {
+ return 1;
+ }
+ }
+ for (sock = node->outputs.first; sock; sock = sock->next) {
+ if (sock->flag & SOCK_HIDDEN) {
+ return 1;
+ }
+ }
+ return 0;
}
void node_set_hidden_sockets(SpaceNode *snode, bNode *node, int set)
{
- bNodeSocket *sock;
-
- if (set == 0) {
- for (sock = node->inputs.first; sock; sock = sock->next) {
- sock->flag &= ~SOCK_HIDDEN;
- }
- for (sock = node->outputs.first; sock; sock = sock->next) {
- sock->flag &= ~SOCK_HIDDEN;
- }
- }
- else {
- /* hide unused sockets */
- for (sock = node->inputs.first; sock; sock = sock->next) {
- if (sock->link == NULL) {
- sock->flag |= SOCK_HIDDEN;
- }
- }
- for (sock = node->outputs.first; sock; sock = sock->next) {
- if (nodeCountSocketLinks(snode->edittree, sock) == 0) {
- sock->flag |= SOCK_HIDDEN;
- }
- }
- }
+ bNodeSocket *sock;
+
+ if (set == 0) {
+ for (sock = node->inputs.first; sock; sock = sock->next) {
+ sock->flag &= ~SOCK_HIDDEN;
+ }
+ for (sock = node->outputs.first; sock; sock = sock->next) {
+ sock->flag &= ~SOCK_HIDDEN;
+ }
+ }
+ else {
+ /* hide unused sockets */
+ for (sock = node->inputs.first; sock; sock = sock->next) {
+ if (sock->link == NULL) {
+ sock->flag |= SOCK_HIDDEN;
+ }
+ }
+ for (sock = node->outputs.first; sock; sock = sock->next) {
+ if (nodeCountSocketLinks(snode->edittree, sock) == 0) {
+ sock->flag |= SOCK_HIDDEN;
+ }
+ }
+ }
}
-
/* checks snode->mouse position, and returns found node/socket */
/* type is SOCK_IN and/or SOCK_OUT */
-int node_find_indicated_socket(SpaceNode *snode, bNode **nodep, bNodeSocket **sockp, float cursor[2], int in_out)
-{
- bNode *node;
- bNodeSocket *sock;
- rctf rect;
-
- *nodep = NULL;
- *sockp = NULL;
-
- /* check if we click in a socket */
- for (node = snode->edittree->nodes.first; node; node = node->next) {
-
- BLI_rctf_init_pt_radius(&rect, cursor, NODE_SOCKSIZE + 4);
-
- if (!(node->flag & NODE_HIDDEN)) {
- /* extra padding inside and out - allow dragging on the text areas too */
- if (in_out == SOCK_IN) {
- rect.xmax += NODE_SOCKSIZE;
- rect.xmin -= NODE_SOCKSIZE * 4;
- }
- else if (in_out == SOCK_OUT) {
- rect.xmax += NODE_SOCKSIZE * 4;
- rect.xmin -= NODE_SOCKSIZE;
- }
- }
-
- if (in_out & SOCK_IN) {
- for (sock = node->inputs.first; sock; sock = sock->next) {
- if (!nodeSocketIsHidden(sock)) {
- if (BLI_rctf_isect_pt(&rect, sock->locx, sock->locy)) {
- if (node == visible_node(snode, &rect)) {
- *nodep = node;
- *sockp = sock;
- return 1;
- }
- }
- }
- }
- }
- if (in_out & SOCK_OUT) {
- for (sock = node->outputs.first; sock; sock = sock->next) {
- if (!nodeSocketIsHidden(sock)) {
- if (BLI_rctf_isect_pt(&rect, sock->locx, sock->locy)) {
- if (node == visible_node(snode, &rect)) {
- *nodep = node;
- *sockp = sock;
- return 1;
- }
- }
- }
- }
- }
- }
-
- return 0;
+int node_find_indicated_socket(
+ SpaceNode *snode, bNode **nodep, bNodeSocket **sockp, float cursor[2], int in_out)
+{
+ bNode *node;
+ bNodeSocket *sock;
+ rctf rect;
+
+ *nodep = NULL;
+ *sockp = NULL;
+
+ /* check if we click in a socket */
+ for (node = snode->edittree->nodes.first; node; node = node->next) {
+
+ BLI_rctf_init_pt_radius(&rect, cursor, NODE_SOCKSIZE + 4);
+
+ if (!(node->flag & NODE_HIDDEN)) {
+ /* extra padding inside and out - allow dragging on the text areas too */
+ if (in_out == SOCK_IN) {
+ rect.xmax += NODE_SOCKSIZE;
+ rect.xmin -= NODE_SOCKSIZE * 4;
+ }
+ else if (in_out == SOCK_OUT) {
+ rect.xmax += NODE_SOCKSIZE * 4;
+ rect.xmin -= NODE_SOCKSIZE;
+ }
+ }
+
+ if (in_out & SOCK_IN) {
+ for (sock = node->inputs.first; sock; sock = sock->next) {
+ if (!nodeSocketIsHidden(sock)) {
+ if (BLI_rctf_isect_pt(&rect, sock->locx, sock->locy)) {
+ if (node == visible_node(snode, &rect)) {
+ *nodep = node;
+ *sockp = sock;
+ return 1;
+ }
+ }
+ }
+ }
+ }
+ if (in_out & SOCK_OUT) {
+ for (sock = node->outputs.first; sock; sock = sock->next) {
+ if (!nodeSocketIsHidden(sock)) {
+ if (BLI_rctf_isect_pt(&rect, sock->locx, sock->locy)) {
+ if (node == visible_node(snode, &rect)) {
+ *nodep = node;
+ *sockp = sock;
+ return 1;
+ }
+ }
+ }
+ }
+ }
+ }
+
+ return 0;
}
/* ****************** Duplicate *********************** */
static void node_duplicate_reparent_recursive(bNode *node)
{
- bNode *parent;
+ bNode *parent;
- node->flag |= NODE_TEST;
+ node->flag |= NODE_TEST;
- /* find first selected parent */
- for (parent = node->parent; parent; parent = parent->parent) {
- if (parent->flag & SELECT) {
- if (!(parent->flag & NODE_TEST)) {
- node_duplicate_reparent_recursive(parent);
- }
- break;
- }
- }
- /* reparent node copy to parent copy */
- if (parent) {
- nodeDetachNode(node->new_node);
- nodeAttachNode(node->new_node, parent->new_node);
- }
+ /* find first selected parent */
+ for (parent = node->parent; parent; parent = parent->parent) {
+ if (parent->flag & SELECT) {
+ if (!(parent->flag & NODE_TEST)) {
+ node_duplicate_reparent_recursive(parent);
+ }
+ break;
+ }
+ }
+ /* reparent node copy to parent copy */
+ if (parent) {
+ nodeDetachNode(node->new_node);
+ nodeAttachNode(node->new_node, parent->new_node);
+ }
}
static int node_duplicate_exec(bContext *C, wmOperator *op)
{
- Main *bmain = CTX_data_main(C);
- SpaceNode *snode = CTX_wm_space_node(C);
- bNodeTree *ntree = snode->edittree;
- bNode *node, *newnode, *lastnode;
- bNodeLink *link, *newlink, *lastlink;
- const bool keep_inputs = RNA_boolean_get(op->ptr, "keep_inputs");
- bool do_tag_update = false;
-
- ED_preview_kill_jobs(CTX_wm_manager(C), bmain);
-
- lastnode = ntree->nodes.last;
- for (node = ntree->nodes.first; node; node = node->next) {
- if (node->flag & SELECT) {
- newnode = BKE_node_copy_ex(ntree, node, LIB_ID_COPY_DEFAULT);
-
- /* to ensure redraws or rerenders happen */
- ED_node_tag_update_id(snode->id);
- }
-
- /* make sure we don't copy new nodes again! */
- if (node == lastnode) {
- break;
- }
- }
-
- /* copy links between selected nodes
- * NB: this depends on correct node->new_node and sock->new_sock pointers from above copy!
- */
- lastlink = ntree->links.last;
- for (link = ntree->links.first; link; link = link->next) {
- /* This creates new links between copied nodes.
- * If keep_inputs is set, also copies input links from unselected (when fromnode==NULL)!
- */
- if (link->tonode && (link->tonode->flag & NODE_SELECT) &&
- (keep_inputs || (link->fromnode && (link->fromnode->flag & NODE_SELECT))))
- {
- newlink = MEM_callocN(sizeof(bNodeLink), "bNodeLink");
- newlink->flag = link->flag;
- newlink->tonode = link->tonode->new_node;
- newlink->tosock = link->tosock->new_sock;
- if (link->fromnode && (link->fromnode->flag & NODE_SELECT)) {
- newlink->fromnode = link->fromnode->new_node;
- newlink->fromsock = link->fromsock->new_sock;
- }
- else {
- /* input node not copied, this keeps the original input linked */
- newlink->fromnode = link->fromnode;
- newlink->fromsock = link->fromsock;
- }
-
- BLI_addtail(&ntree->links, newlink);
- }
-
- /* make sure we don't copy new links again! */
- if (link == lastlink) {
- break;
- }
- }
-
- /* clear flags for recursive depth-first iteration */
- for (node = ntree->nodes.first; node; node = node->next) {
- node->flag &= ~NODE_TEST;
- }
- /* reparent copied nodes */
- for (node = ntree->nodes.first; node; node = node->next) {
- if ((node->flag & SELECT) && !(node->flag & NODE_TEST)) {
- node_duplicate_reparent_recursive(node);
- }
-
- /* only has to check old nodes */
- if (node == lastnode) {
- break;
- }
- }
-
- /* deselect old nodes, select the copies instead */
- for (node = ntree->nodes.first; node; node = node->next) {
- if (node->flag & SELECT) {
- /* has been set during copy above */
- newnode = node->new_node;
-
- nodeSetSelected(node, false);
- node->flag &= ~NODE_ACTIVE;
- nodeSetSelected(newnode, true);
-
- do_tag_update |= (do_tag_update || node_connected_to_output(bmain, ntree, newnode));
- }
-
- /* make sure we don't copy new nodes again! */
- if (node == lastnode) {
- break;
- }
- }
-
- ntreeUpdateTree(CTX_data_main(C), snode->edittree);
-
- snode_notify(C, snode);
- if (do_tag_update) {
- snode_dag_update(C, snode);
- }
-
- return OPERATOR_FINISHED;
+ Main *bmain = CTX_data_main(C);
+ SpaceNode *snode = CTX_wm_space_node(C);
+ bNodeTree *ntree = snode->edittree;
+ bNode *node, *newnode, *lastnode;
+ bNodeLink *link, *newlink, *lastlink;
+ const bool keep_inputs = RNA_boolean_get(op->ptr, "keep_inputs");
+ bool do_tag_update = false;
+
+ ED_preview_kill_jobs(CTX_wm_manager(C), bmain);
+
+ lastnode = ntree->nodes.last;
+ for (node = ntree->nodes.first; node; node = node->next) {
+ if (node->flag & SELECT) {
+ newnode = BKE_node_copy_ex(ntree, node, LIB_ID_COPY_DEFAULT);
+
+ /* to ensure redraws or rerenders happen */
+ ED_node_tag_update_id(snode->id);
+ }
+
+ /* make sure we don't copy new nodes again! */
+ if (node == lastnode) {
+ break;
+ }
+ }
+
+ /* copy links between selected nodes
+ * NB: this depends on correct node->new_node and sock->new_sock pointers from above copy!
+ */
+ lastlink = ntree->links.last;
+ for (link = ntree->links.first; link; link = link->next) {
+ /* This creates new links between copied nodes.
+ * If keep_inputs is set, also copies input links from unselected (when fromnode==NULL)!
+ */
+ if (link->tonode && (link->tonode->flag & NODE_SELECT) &&
+ (keep_inputs || (link->fromnode && (link->fromnode->flag & NODE_SELECT)))) {
+ newlink = MEM_callocN(sizeof(bNodeLink), "bNodeLink");
+ newlink->flag = link->flag;
+ newlink->tonode = link->tonode->new_node;
+ newlink->tosock = link->tosock->new_sock;
+ if (link->fromnode && (link->fromnode->flag & NODE_SELECT)) {
+ newlink->fromnode = link->fromnode->new_node;
+ newlink->fromsock = link->fromsock->new_sock;
+ }
+ else {
+ /* input node not copied, this keeps the original input linked */
+ newlink->fromnode = link->fromnode;
+ newlink->fromsock = link->fromsock;
+ }
+
+ BLI_addtail(&ntree->links, newlink);
+ }
+
+ /* make sure we don't copy new links again! */
+ if (link == lastlink) {
+ break;
+ }
+ }
+
+ /* clear flags for recursive depth-first iteration */
+ for (node = ntree->nodes.first; node; node = node->next) {
+ node->flag &= ~NODE_TEST;
+ }
+ /* reparent copied nodes */
+ for (node = ntree->nodes.first; node; node = node->next) {
+ if ((node->flag & SELECT) && !(node->flag & NODE_TEST)) {
+ node_duplicate_reparent_recursive(node);
+ }
+
+ /* only has to check old nodes */
+ if (node == lastnode) {
+ break;
+ }
+ }
+
+ /* deselect old nodes, select the copies instead */
+ for (node = ntree->nodes.first; node; node = node->next) {
+ if (node->flag & SELECT) {
+ /* has been set during copy above */
+ newnode = node->new_node;
+
+ nodeSetSelected(node, false);
+ node->flag &= ~NODE_ACTIVE;
+ nodeSetSelected(newnode, true);
+
+ do_tag_update |= (do_tag_update || node_connected_to_output(bmain, ntree, newnode));
+ }
+
+ /* make sure we don't copy new nodes again! */
+ if (node == lastnode) {
+ break;
+ }
+ }
+
+ ntreeUpdateTree(CTX_data_main(C), snode->edittree);
+
+ snode_notify(C, snode);
+ if (do_tag_update) {
+ snode_dag_update(C, snode);
+ }
+
+ return OPERATOR_FINISHED;
}
void NODE_OT_duplicate(wmOperatorType *ot)
{
- /* identifiers */
- ot->name = "Duplicate Nodes";
- ot->description = "Duplicate selected nodes";
- ot->idname = "NODE_OT_duplicate";
+ /* identifiers */
+ ot->name = "Duplicate Nodes";
+ ot->description = "Duplicate selected nodes";
+ ot->idname = "NODE_OT_duplicate";
- /* api callbacks */
- ot->exec = node_duplicate_exec;
- ot->poll = ED_operator_node_editable;
+ /* api callbacks */
+ ot->exec = node_duplicate_exec;
+ ot->poll = ED_operator_node_editable;
- /* flags */
- ot->flag = OPTYPE_REGISTER | OPTYPE_UNDO;
+ /* flags */
+ ot->flag = OPTYPE_REGISTER | OPTYPE_UNDO;
- RNA_def_boolean(ot->srna, "keep_inputs", 0, "Keep Inputs", "Keep the input links to duplicated nodes");
+ RNA_def_boolean(
+ ot->srna, "keep_inputs", 0, "Keep Inputs", "Keep the input links to duplicated nodes");
}
bool ED_node_select_check(ListBase *lb)
{
- for (bNode *node = lb->first; node; node = node->next) {
- if (node->flag & NODE_SELECT) {
- return true;
- }
- }
+ for (bNode *node = lb->first; node; node = node->next) {
+ if (node->flag & NODE_SELECT) {
+ return true;
+ }
+ }
- return false;
+ return false;
}
void ED_node_select_all(ListBase *lb, int action)
{
- if (action == SEL_TOGGLE) {
- if (ED_node_select_check(lb)) {
- action = SEL_DESELECT;
- }
- else {
- action = SEL_SELECT;
- }
- }
-
- for (bNode *node = lb->first; node; node = node->next) {
- switch (action) {
- case SEL_SELECT:
- nodeSetSelected(node, true);
- break;
- case SEL_DESELECT:
- nodeSetSelected(node, false);
- break;
- case SEL_INVERT:
- nodeSetSelected(node, !(node->flag & SELECT));
- break;
- }
- }
+ if (action == SEL_TOGGLE) {
+ if (ED_node_select_check(lb)) {
+ action = SEL_DESELECT;
+ }
+ else {
+ action = SEL_SELECT;
+ }
+ }
+
+ for (bNode *node = lb->first; node; node = node->next) {
+ switch (action) {
+ case SEL_SELECT:
+ nodeSetSelected(node, true);
+ break;
+ case SEL_DESELECT:
+ nodeSetSelected(node, false);
+ break;
+ case SEL_INVERT:
+ nodeSetSelected(node, !(node->flag & SELECT));
+ break;
+ }
+ }
}
/* ******************************** */
// XXX some code needing updating to operators...
-
/* goes over all scenes, reads render layers */
static int node_read_viewlayers_exec(bContext *C, wmOperator *UNUSED(op))
{
- Main *bmain = CTX_data_main(C);
- SpaceNode *snode = CTX_wm_space_node(C);
- Scene *curscene = CTX_data_scene(C), *scene;
- bNode *node;
+ Main *bmain = CTX_data_main(C);
+ SpaceNode *snode = CTX_wm_space_node(C);
+ Scene *curscene = CTX_data_scene(C), *scene;
+ bNode *node;
- ED_preview_kill_jobs(CTX_wm_manager(C), bmain);
+ ED_preview_kill_jobs(CTX_wm_manager(C), bmain);
- /* first tag scenes unread */
- for (scene = bmain->scenes.first; scene; scene = scene->id.next) {
- scene->id.tag |= LIB_TAG_DOIT;
- }
+ /* first tag scenes unread */
+ for (scene = bmain->scenes.first; scene; scene = scene->id.next) {
+ scene->id.tag |= LIB_TAG_DOIT;
+ }
- for (node = snode->edittree->nodes.first; node; node = node->next) {
- if (node->type == CMP_NODE_R_LAYERS) {
- ID *id = node->id;
- if (id->tag & LIB_TAG_DOIT) {
- RE_ReadRenderResult(curscene, (Scene *)id);
- ntreeCompositTagRender((Scene *)id);
- id->tag &= ~LIB_TAG_DOIT;
- }
- }
- }
+ for (node = snode->edittree->nodes.first; node; node = node->next) {
+ if (node->type == CMP_NODE_R_LAYERS) {
+ ID *id = node->id;
+ if (id->tag & LIB_TAG_DOIT) {
+ RE_ReadRenderResult(curscene, (Scene *)id);
+ ntreeCompositTagRender((Scene *)id);
+ id->tag &= ~LIB_TAG_DOIT;
+ }
+ }
+ }
- snode_notify(C, snode);
- snode_dag_update(C, snode);
+ snode_notify(C, snode);
+ snode_dag_update(C, snode);
- return OPERATOR_FINISHED;
+ return OPERATOR_FINISHED;
}
void NODE_OT_read_viewlayers(wmOperatorType *ot)
{
- ot->name = "Read View Layers";
- ot->idname = "NODE_OT_read_viewlayers";
- ot->description = "Read all render layers of all used scenes";
+ ot->name = "Read View Layers";
+ ot->idname = "NODE_OT_read_viewlayers";
+ ot->description = "Read all render layers of all used scenes";
- ot->exec = node_read_viewlayers_exec;
+ ot->exec = node_read_viewlayers_exec;
- ot->poll = composite_node_active;
+ ot->poll = composite_node_active;
- /* flags */
- ot->flag = 0;
+ /* flags */
+ ot->flag = 0;
}
int node_render_changed_exec(bContext *C, wmOperator *UNUSED(op))
{
- Scene *sce = CTX_data_scene(C);
- bNode *node;
+ Scene *sce = CTX_data_scene(C);
+ bNode *node;
- for (node = sce->nodetree->nodes.first; node; node = node->next) {
- if (node->id == (ID *)sce && node->need_exec) {
- break;
- }
- }
- if (node) {
- ViewLayer *view_layer = BLI_findlink(&sce->view_layers, node->custom1);
+ for (node = sce->nodetree->nodes.first; node; node = node->next) {
+ if (node->id == (ID *)sce && node->need_exec) {
+ break;
+ }
+ }
+ if (node) {
+ ViewLayer *view_layer = BLI_findlink(&sce->view_layers, node->custom1);
- if (view_layer) {
- PointerRNA op_ptr;
+ if (view_layer) {
+ PointerRNA op_ptr;
- WM_operator_properties_create(&op_ptr, "RENDER_OT_render");
- RNA_string_set(&op_ptr, "layer", view_layer->name);
- RNA_string_set(&op_ptr, "scene", sce->id.name + 2);
+ WM_operator_properties_create(&op_ptr, "RENDER_OT_render");
+ RNA_string_set(&op_ptr, "layer", view_layer->name);
+ RNA_string_set(&op_ptr, "scene", sce->id.name + 2);
- /* to keep keypositions */
- sce->r.scemode |= R_NO_FRAME_UPDATE;
+ /* to keep keypositions */
+ sce->r.scemode |= R_NO_FRAME_UPDATE;
- WM_operator_name_call(C, "RENDER_OT_render", WM_OP_INVOKE_DEFAULT, &op_ptr);
+ WM_operator_name_call(C, "RENDER_OT_render", WM_OP_INVOKE_DEFAULT, &op_ptr);
- WM_operator_properties_free(&op_ptr);
+ WM_operator_properties_free(&op_ptr);
- return OPERATOR_FINISHED;
- }
- }
- return OPERATOR_CANCELLED;
+ return OPERATOR_FINISHED;
+ }
+ }
+ return OPERATOR_CANCELLED;
}
void NODE_OT_render_changed(wmOperatorType *ot)
{
- ot->name = "Render Changed Layer";
- ot->idname = "NODE_OT_render_changed";
- ot->description = "Render current scene, when input node's layer has been changed";
+ ot->name = "Render Changed Layer";
+ ot->idname = "NODE_OT_render_changed";
+ ot->description = "Render current scene, when input node's layer has been changed";
- ot->exec = node_render_changed_exec;
+ ot->exec = node_render_changed_exec;
- ot->poll = composite_node_active;
+ ot->poll = composite_node_active;
- /* flags */
- ot->flag = 0;
+ /* flags */
+ ot->flag = 0;
}
-
/* ****************** Hide operator *********************** */
static void node_flag_toggle_exec(SpaceNode *snode, int toggle_flag)
{
- bNode *node;
- int tot_eq = 0, tot_neq = 0;
-
- /* Toggles the flag on all selected nodes.
- * If the flag is set on all nodes it is unset.
- * If the flag is not set on all nodes, it is set.
- */
- for (node = snode->edittree->nodes.first; node; node = node->next) {
- if (node->flag & SELECT) {
-
- if (toggle_flag == NODE_PREVIEW && (node->typeinfo->flag & NODE_PREVIEW) == 0) {
- continue;
- }
- if (toggle_flag == NODE_OPTIONS && !(node->typeinfo->draw_buttons || node->typeinfo->draw_buttons_ex)) {
- continue;
- }
-
- if (node->flag & toggle_flag) {
- tot_eq++;
- }
- else {
- tot_neq++;
- }
- }
- }
- for (node = snode->edittree->nodes.first; node; node = node->next) {
- if (node->flag & SELECT) {
-
- if (toggle_flag == NODE_PREVIEW && (node->typeinfo->flag & NODE_PREVIEW) == 0) {
- continue;
- }
- if (toggle_flag == NODE_OPTIONS && !(node->typeinfo->draw_buttons || node->typeinfo->draw_buttons_ex)) {
- continue;
- }
-
- if ((tot_eq && tot_neq) || tot_eq == 0) {
- node->flag |= toggle_flag;
- }
- else {
- node->flag &= ~toggle_flag;
- }
- }
- }
+ bNode *node;
+ int tot_eq = 0, tot_neq = 0;
+
+ /* Toggles the flag on all selected nodes.
+ * If the flag is set on all nodes it is unset.
+ * If the flag is not set on all nodes, it is set.
+ */
+ for (node = snode->edittree->nodes.first; node; node = node->next) {
+ if (node->flag & SELECT) {
+
+ if (toggle_flag == NODE_PREVIEW && (node->typeinfo->flag & NODE_PREVIEW) == 0) {
+ continue;
+ }
+ if (toggle_flag == NODE_OPTIONS &&
+ !(node->typeinfo->draw_buttons || node->typeinfo->draw_buttons_ex)) {
+ continue;
+ }
+
+ if (node->flag & toggle_flag) {
+ tot_eq++;
+ }
+ else {
+ tot_neq++;
+ }
+ }
+ }
+ for (node = snode->edittree->nodes.first; node; node = node->next) {
+ if (node->flag & SELECT) {
+
+ if (toggle_flag == NODE_PREVIEW && (node->typeinfo->flag & NODE_PREVIEW) == 0) {
+ continue;
+ }
+ if (toggle_flag == NODE_OPTIONS &&
+ !(node->typeinfo->draw_buttons || node->typeinfo->draw_buttons_ex)) {
+ continue;
+ }
+
+ if ((tot_eq && tot_neq) || tot_eq == 0) {
+ node->flag |= toggle_flag;
+ }
+ else {
+ node->flag &= ~toggle_flag;
+ }
+ }
+ }
}
static int node_hide_toggle_exec(bContext *C, wmOperator *UNUSED(op))
{
- SpaceNode *snode = CTX_wm_space_node(C);
+ SpaceNode *snode = CTX_wm_space_node(C);
- /* sanity checking (poll callback checks this already) */
- if ((snode == NULL) || (snode->edittree == NULL)) {
- return OPERATOR_CANCELLED;
- }
+ /* sanity checking (poll callback checks this already) */
+ if ((snode == NULL) || (snode->edittree == NULL)) {
+ return OPERATOR_CANCELLED;
+ }
- node_flag_toggle_exec(snode, NODE_HIDDEN);
+ node_flag_toggle_exec(snode, NODE_HIDDEN);
- WM_event_add_notifier(C, NC_NODE | ND_DISPLAY, NULL);
+ WM_event_add_notifier(C, NC_NODE | ND_DISPLAY, NULL);
- return OPERATOR_FINISHED;
+ return OPERATOR_FINISHED;
}
void NODE_OT_hide_toggle(wmOperatorType *ot)
{
- /* identifiers */
- ot->name = "Hide";
- ot->description = "Toggle hiding of selected nodes";
- ot->idname = "NODE_OT_hide_toggle";
+ /* identifiers */
+ ot->name = "Hide";
+ ot->description = "Toggle hiding of selected nodes";
+ ot->idname = "NODE_OT_hide_toggle";
- /* callbacks */
- ot->exec = node_hide_toggle_exec;
- ot->poll = ED_operator_node_active;
+ /* callbacks */
+ ot->exec = node_hide_toggle_exec;
+ ot->poll = ED_operator_node_active;
- /* flags */
- ot->flag = OPTYPE_REGISTER | OPTYPE_UNDO;
+ /* flags */
+ ot->flag = OPTYPE_REGISTER | OPTYPE_UNDO;
}
static int node_preview_toggle_exec(bContext *C, wmOperator *UNUSED(op))
{
- SpaceNode *snode = CTX_wm_space_node(C);
+ SpaceNode *snode = CTX_wm_space_node(C);
- /* sanity checking (poll callback checks this already) */
- if ((snode == NULL) || (snode->edittree == NULL)) {
- return OPERATOR_CANCELLED;
- }
+ /* sanity checking (poll callback checks this already) */
+ if ((snode == NULL) || (snode->edittree == NULL)) {
+ return OPERATOR_CANCELLED;
+ }
- ED_preview_kill_jobs(CTX_wm_manager(C), CTX_data_main(C));
+ ED_preview_kill_jobs(CTX_wm_manager(C), CTX_data_main(C));
- node_flag_toggle_exec(snode, NODE_PREVIEW);
+ node_flag_toggle_exec(snode, NODE_PREVIEW);
- snode_notify(C, snode);
+ snode_notify(C, snode);
- return OPERATOR_FINISHED;
+ return OPERATOR_FINISHED;
}
void NODE_OT_preview_toggle(wmOperatorType *ot)
{
- /* identifiers */
- ot->name = "Toggle Node Preview";
- ot->description = "Toggle preview display for selected nodes";
- ot->idname = "NODE_OT_preview_toggle";
+ /* identifiers */
+ ot->name = "Toggle Node Preview";
+ ot->description = "Toggle preview display for selected nodes";
+ ot->idname = "NODE_OT_preview_toggle";
- /* callbacks */
- ot->exec = node_preview_toggle_exec;
- ot->poll = ED_operator_node_active;
+ /* callbacks */
+ ot->exec = node_preview_toggle_exec;
+ ot->poll = ED_operator_node_active;
- /* flags */
- ot->flag = OPTYPE_REGISTER | OPTYPE_UNDO;
+ /* flags */
+ ot->flag = OPTYPE_REGISTER | OPTYPE_UNDO;
}
static int node_options_toggle_exec(bContext *C, wmOperator *UNUSED(op))
{
- SpaceNode *snode = CTX_wm_space_node(C);
+ SpaceNode *snode = CTX_wm_space_node(C);
- /* sanity checking (poll callback checks this already) */
- if ((snode == NULL) || (snode->edittree == NULL)) {
- return OPERATOR_CANCELLED;
- }
+ /* sanity checking (poll callback checks this already) */
+ if ((snode == NULL) || (snode->edittree == NULL)) {
+ return OPERATOR_CANCELLED;
+ }
- node_flag_toggle_exec(snode, NODE_OPTIONS);
+ node_flag_toggle_exec(snode, NODE_OPTIONS);
- WM_event_add_notifier(C, NC_NODE | ND_DISPLAY, NULL);
+ WM_event_add_notifier(C, NC_NODE | ND_DISPLAY, NULL);
- return OPERATOR_FINISHED;
+ return OPERATOR_FINISHED;
}
void NODE_OT_options_toggle(wmOperatorType *ot)
{
- /* identifiers */
- ot->name = "Toggle Node Options";
- ot->description = "Toggle option buttons display for selected nodes";
- ot->idname = "NODE_OT_options_toggle";
+ /* identifiers */
+ ot->name = "Toggle Node Options";
+ ot->description = "Toggle option buttons display for selected nodes";
+ ot->idname = "NODE_OT_options_toggle";
- /* callbacks */
- ot->exec = node_options_toggle_exec;
- ot->poll = ED_operator_node_active;
+ /* callbacks */
+ ot->exec = node_options_toggle_exec;
+ ot->poll = ED_operator_node_active;
- /* flags */
- ot->flag = OPTYPE_REGISTER | OPTYPE_UNDO;
+ /* flags */
+ ot->flag = OPTYPE_REGISTER | OPTYPE_UNDO;
}
static int node_socket_toggle_exec(bContext *C, wmOperator *UNUSED(op))
{
- SpaceNode *snode = CTX_wm_space_node(C);
- bNode *node;
- int hidden;
+ SpaceNode *snode = CTX_wm_space_node(C);
+ bNode *node;
+ int hidden;
- /* sanity checking (poll callback checks this already) */
- if ((snode == NULL) || (snode->edittree == NULL)) {
- return OPERATOR_CANCELLED;
- }
+ /* sanity checking (poll callback checks this already) */
+ if ((snode == NULL) || (snode->edittree == NULL)) {
+ return OPERATOR_CANCELLED;
+ }
- ED_preview_kill_jobs(CTX_wm_manager(C), CTX_data_main(C));
+ ED_preview_kill_jobs(CTX_wm_manager(C), CTX_data_main(C));
- /* Toggle for all selected nodes */
- hidden = 0;
- for (node = snode->edittree->nodes.first; node; node = node->next) {
- if (node->flag & SELECT) {
- if (node_has_hidden_sockets(node)) {
- hidden = 1;
- break;
- }
- }
- }
+ /* Toggle for all selected nodes */
+ hidden = 0;
+ for (node = snode->edittree->nodes.first; node; node = node->next) {
+ if (node->flag & SELECT) {
+ if (node_has_hidden_sockets(node)) {
+ hidden = 1;
+ break;
+ }
+ }
+ }
- for (node = snode->edittree->nodes.first; node; node = node->next) {
- if (node->flag & SELECT) {
- node_set_hidden_sockets(snode, node, !hidden);
- }
- }
+ for (node = snode->edittree->nodes.first; node; node = node->next) {
+ if (node->flag & SELECT) {
+ node_set_hidden_sockets(snode, node, !hidden);
+ }
+ }
- ntreeUpdateTree(CTX_data_main(C), snode->edittree);
+ ntreeUpdateTree(CTX_data_main(C), snode->edittree);
- WM_event_add_notifier(C, NC_NODE | ND_DISPLAY, NULL);
+ WM_event_add_notifier(C, NC_NODE | ND_DISPLAY, NULL);
- return OPERATOR_FINISHED;
+ return OPERATOR_FINISHED;
}
void NODE_OT_hide_socket_toggle(wmOperatorType *ot)
{
- /* identifiers */
- ot->name = "Toggle Hidden Node Sockets";
- ot->description = "Toggle unused node socket display";
- ot->idname = "NODE_OT_hide_socket_toggle";
+ /* identifiers */
+ ot->name = "Toggle Hidden Node Sockets";
+ ot->description = "Toggle unused node socket display";
+ ot->idname = "NODE_OT_hide_socket_toggle";
- /* callbacks */
- ot->exec = node_socket_toggle_exec;
- ot->poll = ED_operator_node_active;
+ /* callbacks */
+ ot->exec = node_socket_toggle_exec;
+ ot->poll = ED_operator_node_active;
- /* flags */
- ot->flag = OPTYPE_REGISTER | OPTYPE_UNDO;
+ /* flags */
+ ot->flag = OPTYPE_REGISTER | OPTYPE_UNDO;
}
/* ****************** Mute operator *********************** */
static int node_mute_exec(bContext *C, wmOperator *UNUSED(op))
{
- Main *bmain = CTX_data_main(C);
- SpaceNode *snode = CTX_wm_space_node(C);
- bNode *node;
- bool do_tag_update = false;
+ Main *bmain = CTX_data_main(C);
+ SpaceNode *snode = CTX_wm_space_node(C);
+ bNode *node;
+ bool do_tag_update = false;
- ED_preview_kill_jobs(CTX_wm_manager(C), bmain);
+ ED_preview_kill_jobs(CTX_wm_manager(C), bmain);
- for (node = snode->edittree->nodes.first; node; node = node->next) {
- /* Only allow muting of nodes having a mute func! */
- if ((node->flag & SELECT) && node->typeinfo->update_internal_links) {
- node->flag ^= NODE_MUTED;
- snode_update(snode, node);
- do_tag_update |= (do_tag_update || node_connected_to_output(bmain, snode->edittree, node));
- }
- }
+ for (node = snode->edittree->nodes.first; node; node = node->next) {
+ /* Only allow muting of nodes having a mute func! */
+ if ((node->flag & SELECT) && node->typeinfo->update_internal_links) {
+ node->flag ^= NODE_MUTED;
+ snode_update(snode, node);
+ do_tag_update |= (do_tag_update || node_connected_to_output(bmain, snode->edittree, node));
+ }
+ }
- snode_notify(C, snode);
- if (do_tag_update) {
- snode_dag_update(C, snode);
- }
+ snode_notify(C, snode);
+ if (do_tag_update) {
+ snode_dag_update(C, snode);
+ }
- return OPERATOR_FINISHED;
+ return OPERATOR_FINISHED;
}
void NODE_OT_mute_toggle(wmOperatorType *ot)
{
- /* identifiers */
- ot->name = "Toggle Node Mute";
- ot->description = "Toggle muting of the nodes";
- ot->idname = "NODE_OT_mute_toggle";
+ /* identifiers */
+ ot->name = "Toggle Node Mute";
+ ot->description = "Toggle muting of the nodes";
+ ot->idname = "NODE_OT_mute_toggle";
- /* callbacks */
- ot->exec = node_mute_exec;
- ot->poll = ED_operator_node_editable;
+ /* callbacks */
+ ot->exec = node_mute_exec;
+ ot->poll = ED_operator_node_editable;
- /* flags */
- ot->flag = OPTYPE_REGISTER | OPTYPE_UNDO;
+ /* flags */
+ ot->flag = OPTYPE_REGISTER | OPTYPE_UNDO;
}
/* ****************** Delete operator ******************* */
static int node_delete_exec(bContext *C, wmOperator *UNUSED(op))
{
- Main *bmain = CTX_data_main(C);
- SpaceNode *snode = CTX_wm_space_node(C);
- bNode *node, *next;
- bool do_tag_update = false;
+ Main *bmain = CTX_data_main(C);
+ SpaceNode *snode = CTX_wm_space_node(C);
+ bNode *node, *next;
+ bool do_tag_update = false;
- ED_preview_kill_jobs(CTX_wm_manager(C), bmain);
+ ED_preview_kill_jobs(CTX_wm_manager(C), bmain);
- for (node = snode->edittree->nodes.first; node; node = next) {
- next = node->next;
- if (node->flag & SELECT) {
- do_tag_update |= (do_tag_update || node_connected_to_output(bmain, snode->edittree, node));
- nodeRemoveNode(bmain, snode->edittree, node, true);
- }
- }
+ for (node = snode->edittree->nodes.first; node; node = next) {
+ next = node->next;
+ if (node->flag & SELECT) {
+ do_tag_update |= (do_tag_update || node_connected_to_output(bmain, snode->edittree, node));
+ nodeRemoveNode(bmain, snode->edittree, node, true);
+ }
+ }
- ntreeUpdateTree(CTX_data_main(C), snode->edittree);
+ ntreeUpdateTree(CTX_data_main(C), snode->edittree);
- snode_notify(C, snode);
- if (do_tag_update) {
- snode_dag_update(C, snode);
- }
+ snode_notify(C, snode);
+ if (do_tag_update) {
+ snode_dag_update(C, snode);
+ }
- return OPERATOR_FINISHED;
+ return OPERATOR_FINISHED;
}
void NODE_OT_delete(wmOperatorType *ot)
{
- /* identifiers */
- ot->name = "Delete";
- ot->description = "Delete selected nodes";
- ot->idname = "NODE_OT_delete";
+ /* identifiers */
+ ot->name = "Delete";
+ ot->description = "Delete selected nodes";
+ ot->idname = "NODE_OT_delete";
- /* api callbacks */
- ot->exec = node_delete_exec;
- ot->poll = ED_operator_node_editable;
+ /* api callbacks */
+ ot->exec = node_delete_exec;
+ ot->poll = ED_operator_node_editable;
- /* flags */
- ot->flag = OPTYPE_REGISTER | OPTYPE_UNDO;
+ /* flags */
+ ot->flag = OPTYPE_REGISTER | OPTYPE_UNDO;
}
/* ****************** Switch View ******************* */
static bool node_switch_view_poll(bContext *C)
{
- SpaceNode *snode = CTX_wm_space_node(C);
+ SpaceNode *snode = CTX_wm_space_node(C);
- if (snode && snode->edittree) {
- return true;
- }
+ if (snode && snode->edittree) {
+ return true;
+ }
- return false;
+ return false;
}
static int node_switch_view_exec(bContext *C, wmOperator *UNUSED(op))
{
- SpaceNode *snode = CTX_wm_space_node(C);
- bNode *node, *next;
+ SpaceNode *snode = CTX_wm_space_node(C);
+ bNode *node, *next;
- for (node = snode->edittree->nodes.first; node; node = next) {
- next = node->next;
- if (node->flag & SELECT) {
- /* call the update function from the Switch View node */
- node->update = NODE_UPDATE_OPERATOR;
- }
- }
+ for (node = snode->edittree->nodes.first; node; node = next) {
+ next = node->next;
+ if (node->flag & SELECT) {
+ /* call the update function from the Switch View node */
+ node->update = NODE_UPDATE_OPERATOR;
+ }
+ }
- ntreeUpdateTree(CTX_data_main(C), snode->edittree);
+ ntreeUpdateTree(CTX_data_main(C), snode->edittree);
- snode_notify(C, snode);
- snode_dag_update(C, snode);
+ snode_notify(C, snode);
+ snode_dag_update(C, snode);
- return OPERATOR_FINISHED;
+ return OPERATOR_FINISHED;
}
void NODE_OT_switch_view_update(wmOperatorType *ot)
{
- /* identifiers */
- ot->name = "Update Views";
- ot->description = "Update views of selected node";
- ot->idname = "NODE_OT_switch_view_update";
+ /* identifiers */
+ ot->name = "Update Views";
+ ot->description = "Update views of selected node";
+ ot->idname = "NODE_OT_switch_view_update";
- /* api callbacks */
- ot->exec = node_switch_view_exec;
- ot->poll = node_switch_view_poll;
+ /* api callbacks */
+ ot->exec = node_switch_view_exec;
+ ot->poll = node_switch_view_poll;
- /* flags */
- ot->flag = OPTYPE_REGISTER | OPTYPE_UNDO;
+ /* flags */
+ ot->flag = OPTYPE_REGISTER | OPTYPE_UNDO;
}
/* ****************** Delete with reconnect ******************* */
static int node_delete_reconnect_exec(bContext *C, wmOperator *UNUSED(op))
{
- Main *bmain = CTX_data_main(C);
- SpaceNode *snode = CTX_wm_space_node(C);
- bNode *node, *next;
+ Main *bmain = CTX_data_main(C);
+ SpaceNode *snode = CTX_wm_space_node(C);
+ bNode *node, *next;
- ED_preview_kill_jobs(CTX_wm_manager(C), CTX_data_main(C));
+ ED_preview_kill_jobs(CTX_wm_manager(C), CTX_data_main(C));
- for (node = snode->edittree->nodes.first; node; node = next) {
- next = node->next;
- if (node->flag & SELECT) {
- nodeInternalRelink(snode->edittree, node);
- nodeRemoveNode(bmain, snode->edittree, node, true);
- }
- }
+ for (node = snode->edittree->nodes.first; node; node = next) {
+ next = node->next;
+ if (node->flag & SELECT) {
+ nodeInternalRelink(snode->edittree, node);
+ nodeRemoveNode(bmain, snode->edittree, node, true);
+ }
+ }
- ntreeUpdateTree(CTX_data_main(C), snode->edittree);
+ ntreeUpdateTree(CTX_data_main(C), snode->edittree);
- snode_notify(C, snode);
- snode_dag_update(C, snode);
+ snode_notify(C, snode);
+ snode_dag_update(C, snode);
- return OPERATOR_FINISHED;
+ return OPERATOR_FINISHED;
}
void NODE_OT_delete_reconnect(wmOperatorType *ot)
{
- /* identifiers */
- ot->name = "Delete with Reconnect";
- ot->description = "Delete nodes; will reconnect nodes as if deletion was muted";
- ot->idname = "NODE_OT_delete_reconnect";
+ /* identifiers */
+ ot->name = "Delete with Reconnect";
+ ot->description = "Delete nodes; will reconnect nodes as if deletion was muted";
+ ot->idname = "NODE_OT_delete_reconnect";
- /* api callbacks */
- ot->exec = node_delete_reconnect_exec;
- ot->poll = ED_operator_node_editable;
+ /* api callbacks */
+ ot->exec = node_delete_reconnect_exec;
+ ot->poll = ED_operator_node_editable;
- /* flags */
- ot->flag = OPTYPE_REGISTER | OPTYPE_UNDO;
+ /* flags */
+ ot->flag = OPTYPE_REGISTER | OPTYPE_UNDO;
}
-
/* ****************** File Output Add Socket ******************* */
static int node_output_file_add_socket_exec(bContext *C, wmOperator *op)
{
- Scene *scene = CTX_data_scene(C);
- SpaceNode *snode = CTX_wm_space_node(C);
- PointerRNA ptr = CTX_data_pointer_get(C, "node");
- bNodeTree *ntree = NULL;
- bNode *node = NULL;
- char file_path[MAX_NAME];
+ Scene *scene = CTX_data_scene(C);
+ SpaceNode *snode = CTX_wm_space_node(C);
+ PointerRNA ptr = CTX_data_pointer_get(C, "node");
+ bNodeTree *ntree = NULL;
+ bNode *node = NULL;
+ char file_path[MAX_NAME];
- if (ptr.data) {
- node = ptr.data;
- ntree = ptr.id.data;
- }
- else if (snode && snode->edittree) {
- ntree = snode->edittree;
- node = nodeGetActive(snode->edittree);
- }
+ if (ptr.data) {
+ node = ptr.data;
+ ntree = ptr.id.data;
+ }
+ else if (snode && snode->edittree) {
+ ntree = snode->edittree;
+ node = nodeGetActive(snode->edittree);
+ }
- if (!node || node->type != CMP_NODE_OUTPUT_FILE) {
- return OPERATOR_CANCELLED;
- }
+ if (!node || node->type != CMP_NODE_OUTPUT_FILE) {
+ return OPERATOR_CANCELLED;
+ }
- RNA_string_get(op->ptr, "file_path", file_path);
- ntreeCompositOutputFileAddSocket(ntree, node, file_path, &scene->r.im_format);
+ RNA_string_get(op->ptr, "file_path", file_path);
+ ntreeCompositOutputFileAddSocket(ntree, node, file_path, &scene->r.im_format);
- snode_notify(C, snode);
+ snode_notify(C, snode);
- return OPERATOR_FINISHED;
+ return OPERATOR_FINISHED;
}
void NODE_OT_output_file_add_socket(wmOperatorType *ot)
{
- /* identifiers */
- ot->name = "Add File Node Socket";
- ot->description = "Add a new input to a file output node";
- ot->idname = "NODE_OT_output_file_add_socket";
+ /* identifiers */
+ ot->name = "Add File Node Socket";
+ ot->description = "Add a new input to a file output node";
+ ot->idname = "NODE_OT_output_file_add_socket";
- /* callbacks */
- ot->exec = node_output_file_add_socket_exec;
- ot->poll = composite_node_editable;
+ /* callbacks */
+ ot->exec = node_output_file_add_socket_exec;
+ ot->poll = composite_node_editable;
- /* flags */
- ot->flag = OPTYPE_REGISTER | OPTYPE_UNDO;
+ /* flags */
+ ot->flag = OPTYPE_REGISTER | OPTYPE_UNDO;
- RNA_def_string(ot->srna, "file_path", "Image", MAX_NAME, "File Path", "Sub-path of the output file");
+ RNA_def_string(
+ ot->srna, "file_path", "Image", MAX_NAME, "File Path", "Sub-path of the output file");
}
/* ****************** Multi File Output Remove Socket ******************* */
static int node_output_file_remove_active_socket_exec(bContext *C, wmOperator *UNUSED(op))
{
- SpaceNode *snode = CTX_wm_space_node(C);
- PointerRNA ptr = CTX_data_pointer_get(C, "node");
- bNodeTree *ntree = NULL;
- bNode *node = NULL;
+ SpaceNode *snode = CTX_wm_space_node(C);
+ PointerRNA ptr = CTX_data_pointer_get(C, "node");
+ bNodeTree *ntree = NULL;
+ bNode *node = NULL;
- if (ptr.data) {
- node = ptr.data;
- ntree = ptr.id.data;
- }
- else if (snode && snode->edittree) {
- ntree = snode->edittree;
- node = nodeGetActive(snode->edittree);
- }
+ if (ptr.data) {
+ node = ptr.data;
+ ntree = ptr.id.data;
+ }
+ else if (snode && snode->edittree) {
+ ntree = snode->edittree;
+ node = nodeGetActive(snode->edittree);
+ }
- if (!node || node->type != CMP_NODE_OUTPUT_FILE) {
- return OPERATOR_CANCELLED;
- }
+ if (!node || node->type != CMP_NODE_OUTPUT_FILE) {
+ return OPERATOR_CANCELLED;
+ }
- if (!ntreeCompositOutputFileRemoveActiveSocket(ntree, node)) {
- return OPERATOR_CANCELLED;
- }
+ if (!ntreeCompositOutputFileRemoveActiveSocket(ntree, node)) {
+ return OPERATOR_CANCELLED;
+ }
- snode_notify(C, snode);
+ snode_notify(C, snode);
- return OPERATOR_FINISHED;
+ return OPERATOR_FINISHED;
}
void NODE_OT_output_file_remove_active_socket(wmOperatorType *ot)
{
- /* identifiers */
- ot->name = "Remove File Node Socket";
- ot->description = "Remove active input from a file output node";
- ot->idname = "NODE_OT_output_file_remove_active_socket";
+ /* identifiers */
+ ot->name = "Remove File Node Socket";
+ ot->description = "Remove active input from a file output node";
+ ot->idname = "NODE_OT_output_file_remove_active_socket";
- /* callbacks */
- ot->exec = node_output_file_remove_active_socket_exec;
- ot->poll = composite_node_editable;
+ /* callbacks */
+ ot->exec = node_output_file_remove_active_socket_exec;
+ ot->poll = composite_node_editable;
- /* flags */
- ot->flag = OPTYPE_REGISTER | OPTYPE_UNDO;
+ /* flags */
+ ot->flag = OPTYPE_REGISTER | OPTYPE_UNDO;
}
/* ****************** Multi File Output Move Socket ******************* */
static int node_output_file_move_active_socket_exec(bContext *C, wmOperator *op)
{
- SpaceNode *snode = CTX_wm_space_node(C);
- PointerRNA ptr = CTX_data_pointer_get(C, "node");
- bNode *node = NULL;
- NodeImageMultiFile *nimf;
- bNodeSocket *sock;
- int direction;
-
- if (ptr.data) {
- node = ptr.data;
- }
- else if (snode && snode->edittree) {
- node = nodeGetActive(snode->edittree);
- }
-
- if (!node || node->type != CMP_NODE_OUTPUT_FILE) {
- return OPERATOR_CANCELLED;
- }
-
- nimf = node->storage;
-
- sock = BLI_findlink(&node->inputs, nimf->active_input);
- if (!sock) {
- return OPERATOR_CANCELLED;
- }
-
- direction = RNA_enum_get(op->ptr, "direction");
-
- if (direction == 1) {
- bNodeSocket *before = sock->prev;
- if (!before) {
- return OPERATOR_CANCELLED;
- }
- BLI_remlink(&node->inputs, sock);
- BLI_insertlinkbefore(&node->inputs, before, sock);
- nimf->active_input--;
- }
- else {
- bNodeSocket *after = sock->next;
- if (!after) {
- return OPERATOR_CANCELLED;
- }
- BLI_remlink(&node->inputs, sock);
- BLI_insertlinkafter(&node->inputs, after, sock);
- nimf->active_input++;
- }
-
- snode_notify(C, snode);
-
- return OPERATOR_FINISHED;
+ SpaceNode *snode = CTX_wm_space_node(C);
+ PointerRNA ptr = CTX_data_pointer_get(C, "node");
+ bNode *node = NULL;
+ NodeImageMultiFile *nimf;
+ bNodeSocket *sock;
+ int direction;
+
+ if (ptr.data) {
+ node = ptr.data;
+ }
+ else if (snode && snode->edittree) {
+ node = nodeGetActive(snode->edittree);
+ }
+
+ if (!node || node->type != CMP_NODE_OUTPUT_FILE) {
+ return OPERATOR_CANCELLED;
+ }
+
+ nimf = node->storage;
+
+ sock = BLI_findlink(&node->inputs, nimf->active_input);
+ if (!sock) {
+ return OPERATOR_CANCELLED;
+ }
+
+ direction = RNA_enum_get(op->ptr, "direction");
+
+ if (direction == 1) {
+ bNodeSocket *before = sock->prev;
+ if (!before) {
+ return OPERATOR_CANCELLED;
+ }
+ BLI_remlink(&node->inputs, sock);
+ BLI_insertlinkbefore(&node->inputs, before, sock);
+ nimf->active_input--;
+ }
+ else {
+ bNodeSocket *after = sock->next;
+ if (!after) {
+ return OPERATOR_CANCELLED;
+ }
+ BLI_remlink(&node->inputs, sock);
+ BLI_insertlinkafter(&node->inputs, after, sock);
+ nimf->active_input++;
+ }
+
+ snode_notify(C, snode);
+
+ return OPERATOR_FINISHED;
}
void NODE_OT_output_file_move_active_socket(wmOperatorType *ot)
{
- static const EnumPropertyItem direction_items[] = {
- {1, "UP", 0, "Up", ""},
- {2, "DOWN", 0, "Down", ""},
- { 0, NULL, 0, NULL, NULL }
- };
+ static const EnumPropertyItem direction_items[] = {
+ {1, "UP", 0, "Up", ""}, {2, "DOWN", 0, "Down", ""}, {0, NULL, 0, NULL, NULL}};
- /* identifiers */
- ot->name = "Move File Node Socket";
- ot->description = "Move the active input of a file output node up or down the list";
- ot->idname = "NODE_OT_output_file_move_active_socket";
+ /* identifiers */
+ ot->name = "Move File Node Socket";
+ ot->description = "Move the active input of a file output node up or down the list";
+ ot->idname = "NODE_OT_output_file_move_active_socket";
- /* callbacks */
- ot->exec = node_output_file_move_active_socket_exec;
- ot->poll = composite_node_editable;
+ /* callbacks */
+ ot->exec = node_output_file_move_active_socket_exec;
+ ot->poll = composite_node_editable;
- /* flags */
- ot->flag = OPTYPE_REGISTER | OPTYPE_UNDO;
+ /* flags */
+ ot->flag = OPTYPE_REGISTER | OPTYPE_UNDO;
- RNA_def_enum(ot->srna, "direction", direction_items, 2, "Direction", "");
+ RNA_def_enum(ot->srna, "direction", direction_items, 2, "Direction", "");
}
/* ****************** Copy Node Color ******************* */
static int node_copy_color_exec(bContext *C, wmOperator *UNUSED(op))
{
- SpaceNode *snode = CTX_wm_space_node(C);
- bNodeTree *ntree = snode->edittree;
- bNode *node, *tnode;
+ SpaceNode *snode = CTX_wm_space_node(C);
+ bNodeTree *ntree = snode->edittree;
+ bNode *node, *tnode;
- if (!ntree) {
- return OPERATOR_CANCELLED;
- }
- node = nodeGetActive(ntree);
- if (!node) {
- return OPERATOR_CANCELLED;
- }
+ if (!ntree) {
+ return OPERATOR_CANCELLED;
+ }
+ node = nodeGetActive(ntree);
+ if (!node) {
+ return OPERATOR_CANCELLED;
+ }
- for (tnode = ntree->nodes.first; tnode; tnode = tnode->next) {
- if (tnode->flag & NODE_SELECT && tnode != node) {
- if (node->flag & NODE_CUSTOM_COLOR) {
- tnode->flag |= NODE_CUSTOM_COLOR;
- copy_v3_v3(tnode->color, node->color);
- }
- else {
- tnode->flag &= ~NODE_CUSTOM_COLOR;
- }
- }
- }
+ for (tnode = ntree->nodes.first; tnode; tnode = tnode->next) {
+ if (tnode->flag & NODE_SELECT && tnode != node) {
+ if (node->flag & NODE_CUSTOM_COLOR) {
+ tnode->flag |= NODE_CUSTOM_COLOR;
+ copy_v3_v3(tnode->color, node->color);
+ }
+ else {
+ tnode->flag &= ~NODE_CUSTOM_COLOR;
+ }
+ }
+ }
- ED_node_sort(ntree);
- WM_event_add_notifier(C, NC_NODE | ND_DISPLAY, NULL);
+ ED_node_sort(ntree);
+ WM_event_add_notifier(C, NC_NODE | ND_DISPLAY, NULL);
- return OPERATOR_FINISHED;
+ return OPERATOR_FINISHED;
}
void NODE_OT_node_copy_color(wmOperatorType *ot)
{
- /* identifiers */
- ot->name = "Copy Color";
- ot->description = "Copy color to all selected nodes";
- ot->idname = "NODE_OT_node_copy_color";
+ /* identifiers */
+ ot->name = "Copy Color";
+ ot->description = "Copy color to all selected nodes";
+ ot->idname = "NODE_OT_node_copy_color";
- /* api callbacks */
- ot->exec = node_copy_color_exec;
- ot->poll = ED_operator_node_editable;
+ /* api callbacks */
+ ot->exec = node_copy_color_exec;
+ ot->poll = ED_operator_node_editable;
- /* flags */
- ot->flag = OPTYPE_REGISTER | OPTYPE_UNDO;
+ /* flags */
+ ot->flag = OPTYPE_REGISTER | OPTYPE_UNDO;
}
/* ****************** Copy to clipboard ******************* */
static int node_clipboard_copy_exec(bContext *C, wmOperator *UNUSED(op))
{
- SpaceNode *snode = CTX_wm_space_node(C);
- bNodeTree *ntree = snode->edittree;
- bNode *node;
- bNodeLink *link, *newlink;
-
- ED_preview_kill_jobs(CTX_wm_manager(C), CTX_data_main(C));
-
- /* clear current clipboard */
- BKE_node_clipboard_clear();
- BKE_node_clipboard_init(ntree);
-
- for (node = ntree->nodes.first; node; node = node->next) {
- if (node->flag & SELECT) {
- /* No ID refcounting, this node is virtual, detached from any actual Blender data currently. */
- bNode *new_node = BKE_node_copy_ex(NULL, node, LIB_ID_CREATE_NO_USER_REFCOUNT);
- BKE_node_clipboard_add_node(new_node);
- }
- }
-
- for (node = ntree->nodes.first; node; node = node->next) {
- if (node->flag & SELECT) {
- bNode *new_node = node->new_node;
-
- /* ensure valid pointers */
- if (new_node->parent) {
- /* parent pointer must be redirected to new node or detached if parent is
- * not copied */
- if (new_node->parent->flag & NODE_SELECT) {
- new_node->parent = new_node->parent->new_node;
- }
- else {
- nodeDetachNode(new_node);
- }
- }
- }
- }
-
- /* copy links between selected nodes
- * NB: this depends on correct node->new_node and sock->new_sock pointers from above copy!
- */
- for (link = ntree->links.first; link; link = link->next) {
- /* This creates new links between copied nodes. */
- if (link->tonode && (link->tonode->flag & NODE_SELECT) &&
- link->fromnode && (link->fromnode->flag & NODE_SELECT))
- {
- newlink = MEM_callocN(sizeof(bNodeLink), "bNodeLink");
- newlink->flag = link->flag;
- newlink->tonode = link->tonode->new_node;
- newlink->tosock = link->tosock->new_sock;
- newlink->fromnode = link->fromnode->new_node;
- newlink->fromsock = link->fromsock->new_sock;
-
- BKE_node_clipboard_add_link(newlink);
- }
- }
-
- return OPERATOR_FINISHED;
+ SpaceNode *snode = CTX_wm_space_node(C);
+ bNodeTree *ntree = snode->edittree;
+ bNode *node;
+ bNodeLink *link, *newlink;
+
+ ED_preview_kill_jobs(CTX_wm_manager(C), CTX_data_main(C));
+
+ /* clear current clipboard */
+ BKE_node_clipboard_clear();
+ BKE_node_clipboard_init(ntree);
+
+ for (node = ntree->nodes.first; node; node = node->next) {
+ if (node->flag & SELECT) {
+ /* No ID refcounting, this node is virtual, detached from any actual Blender data currently. */
+ bNode *new_node = BKE_node_copy_ex(NULL, node, LIB_ID_CREATE_NO_USER_REFCOUNT);
+ BKE_node_clipboard_add_node(new_node);
+ }
+ }
+
+ for (node = ntree->nodes.first; node; node = node->next) {
+ if (node->flag & SELECT) {
+ bNode *new_node = node->new_node;
+
+ /* ensure valid pointers */
+ if (new_node->parent) {
+ /* parent pointer must be redirected to new node or detached if parent is
+ * not copied */
+ if (new_node->parent->flag & NODE_SELECT) {
+ new_node->parent = new_node->parent->new_node;
+ }
+ else {
+ nodeDetachNode(new_node);
+ }
+ }
+ }
+ }
+
+ /* copy links between selected nodes
+ * NB: this depends on correct node->new_node and sock->new_sock pointers from above copy!
+ */
+ for (link = ntree->links.first; link; link = link->next) {
+ /* This creates new links between copied nodes. */
+ if (link->tonode && (link->tonode->flag & NODE_SELECT) && link->fromnode &&
+ (link->fromnode->flag & NODE_SELECT)) {
+ newlink = MEM_callocN(sizeof(bNodeLink), "bNodeLink");
+ newlink->flag = link->flag;
+ newlink->tonode = link->tonode->new_node;
+ newlink->tosock = link->tosock->new_sock;
+ newlink->fromnode = link->fromnode->new_node;
+ newlink->fromsock = link->fromsock->new_sock;
+
+ BKE_node_clipboard_add_link(newlink);
+ }
+ }
+
+ return OPERATOR_FINISHED;
}
void NODE_OT_clipboard_copy(wmOperatorType *ot)
{
- /* identifiers */
- ot->name = "Copy to Clipboard";
- ot->description = "Copies selected nodes to the clipboard";
- ot->idname = "NODE_OT_clipboard_copy";
+ /* identifiers */
+ ot->name = "Copy to Clipboard";
+ ot->description = "Copies selected nodes to the clipboard";
+ ot->idname = "NODE_OT_clipboard_copy";
- /* api callbacks */
- ot->exec = node_clipboard_copy_exec;
- ot->poll = ED_operator_node_active;
+ /* api callbacks */
+ ot->exec = node_clipboard_copy_exec;
+ ot->poll = ED_operator_node_active;
- /* flags */
- ot->flag = OPTYPE_REGISTER | OPTYPE_UNDO;
+ /* flags */
+ ot->flag = OPTYPE_REGISTER | OPTYPE_UNDO;
}
/* ****************** Paste from clipboard ******************* */
static int node_clipboard_paste_exec(bContext *C, wmOperator *op)
{
- SpaceNode *snode = CTX_wm_space_node(C);
- bNodeTree *ntree = snode->edittree;
- const ListBase *clipboard_nodes_lb;
- const ListBase *clipboard_links_lb;
- bNode *node;
- bNodeLink *link;
- int num_nodes;
- float center[2];
- bool is_clipboard_valid, all_nodes_valid;
-
- /* validate pointers in the clipboard */
- is_clipboard_valid = BKE_node_clipboard_validate();
- clipboard_nodes_lb = BKE_node_clipboard_get_nodes();
- clipboard_links_lb = BKE_node_clipboard_get_links();
-
- if (BLI_listbase_is_empty(clipboard_nodes_lb)) {
- BKE_report(op->reports, RPT_ERROR, "Clipboard is empty");
- return OPERATOR_CANCELLED;
- }
-
- if (BKE_node_clipboard_get_type() != ntree->type) {
- BKE_report(op->reports, RPT_ERROR, "Clipboard nodes are an incompatible type");
- return OPERATOR_CANCELLED;
- }
-
- /* only warn */
- if (is_clipboard_valid == false) {
- BKE_report(op->reports, RPT_WARNING, "Some nodes references could not be restored, will be left empty");
- }
-
- /* make sure all clipboard nodes would be valid in the target tree */
- all_nodes_valid = true;
- for (node = clipboard_nodes_lb->first; node; node = node->next) {
- if (!node->typeinfo->poll_instance || !node->typeinfo->poll_instance(node, ntree)) {
- all_nodes_valid = false;
- BKE_reportf(op->reports, RPT_ERROR, "Cannot add node %s into node tree %s", node->name, ntree->id.name + 2);
- }
- }
- if (!all_nodes_valid) {
- return OPERATOR_CANCELLED;
- }
-
- ED_preview_kill_jobs(CTX_wm_manager(C), CTX_data_main(C));
-
- /* deselect old nodes */
- node_deselect_all(snode);
-
- /* calculate "barycenter" for placing on mouse cursor */
- zero_v2(center);
- for (node = clipboard_nodes_lb->first, num_nodes = 0; node; node = node->next, num_nodes++) {
- center[0] += BLI_rctf_cent_x(&node->totr);
- center[1] += BLI_rctf_cent_y(&node->totr);
- }
- mul_v2_fl(center, 1.0 / num_nodes);
-
- /* copy nodes from clipboard */
- for (node = clipboard_nodes_lb->first; node; node = node->next) {
- bNode *new_node = BKE_node_copy_ex(ntree, node, LIB_ID_COPY_DEFAULT);
-
- /* pasted nodes are selected */
- nodeSetSelected(new_node, true);
- }
-
- /* reparent copied nodes */
- for (node = clipboard_nodes_lb->first; node; node = node->next) {
- bNode *new_node = node->new_node;
- if (new_node->parent) {
- new_node->parent = new_node->parent->new_node;
- }
- }
-
- for (link = clipboard_links_lb->first; link; link = link->next) {
- nodeAddLink(ntree, link->fromnode->new_node, link->fromsock->new_sock,
- link->tonode->new_node, link->tosock->new_sock);
- }
-
- ntreeUpdateTree(CTX_data_main(C), snode->edittree);
-
- snode_notify(C, snode);
- snode_dag_update(C, snode);
-
- return OPERATOR_FINISHED;
+ SpaceNode *snode = CTX_wm_space_node(C);
+ bNodeTree *ntree = snode->edittree;
+ const ListBase *clipboard_nodes_lb;
+ const ListBase *clipboard_links_lb;
+ bNode *node;
+ bNodeLink *link;
+ int num_nodes;
+ float center[2];
+ bool is_clipboard_valid, all_nodes_valid;
+
+ /* validate pointers in the clipboard */
+ is_clipboard_valid = BKE_node_clipboard_validate();
+ clipboard_nodes_lb = BKE_node_clipboard_get_nodes();
+ clipboard_links_lb = BKE_node_clipboard_get_links();
+
+ if (BLI_listbase_is_empty(clipboard_nodes_lb)) {
+ BKE_report(op->reports, RPT_ERROR, "Clipboard is empty");
+ return OPERATOR_CANCELLED;
+ }
+
+ if (BKE_node_clipboard_get_type() != ntree->type) {
+ BKE_report(op->reports, RPT_ERROR, "Clipboard nodes are an incompatible type");
+ return OPERATOR_CANCELLED;
+ }
+
+ /* only warn */
+ if (is_clipboard_valid == false) {
+ BKE_report(op->reports,
+ RPT_WARNING,
+ "Some nodes references could not be restored, will be left empty");
+ }
+
+ /* make sure all clipboard nodes would be valid in the target tree */
+ all_nodes_valid = true;
+ for (node = clipboard_nodes_lb->first; node; node = node->next) {
+ if (!node->typeinfo->poll_instance || !node->typeinfo->poll_instance(node, ntree)) {
+ all_nodes_valid = false;
+ BKE_reportf(op->reports,
+ RPT_ERROR,
+ "Cannot add node %s into node tree %s",
+ node->name,
+ ntree->id.name + 2);
+ }
+ }
+ if (!all_nodes_valid) {
+ return OPERATOR_CANCELLED;
+ }
+
+ ED_preview_kill_jobs(CTX_wm_manager(C), CTX_data_main(C));
+
+ /* deselect old nodes */
+ node_deselect_all(snode);
+
+ /* calculate "barycenter" for placing on mouse cursor */
+ zero_v2(center);
+ for (node = clipboard_nodes_lb->first, num_nodes = 0; node; node = node->next, num_nodes++) {
+ center[0] += BLI_rctf_cent_x(&node->totr);
+ center[1] += BLI_rctf_cent_y(&node->totr);
+ }
+ mul_v2_fl(center, 1.0 / num_nodes);
+
+ /* copy nodes from clipboard */
+ for (node = clipboard_nodes_lb->first; node; node = node->next) {
+ bNode *new_node = BKE_node_copy_ex(ntree, node, LIB_ID_COPY_DEFAULT);
+
+ /* pasted nodes are selected */
+ nodeSetSelected(new_node, true);
+ }
+
+ /* reparent copied nodes */
+ for (node = clipboard_nodes_lb->first; node; node = node->next) {
+ bNode *new_node = node->new_node;
+ if (new_node->parent) {
+ new_node->parent = new_node->parent->new_node;
+ }
+ }
+
+ for (link = clipboard_links_lb->first; link; link = link->next) {
+ nodeAddLink(ntree,
+ link->fromnode->new_node,
+ link->fromsock->new_sock,
+ link->tonode->new_node,
+ link->tosock->new_sock);
+ }
+
+ ntreeUpdateTree(CTX_data_main(C), snode->edittree);
+
+ snode_notify(C, snode);
+ snode_dag_update(C, snode);
+
+ return OPERATOR_FINISHED;
}
void NODE_OT_clipboard_paste(wmOperatorType *ot)
{
- /* identifiers */
- ot->name = "Paste from Clipboard";
- ot->description = "Pastes nodes from the clipboard to the active node tree";
- ot->idname = "NODE_OT_clipboard_paste";
+ /* identifiers */
+ ot->name = "Paste from Clipboard";
+ ot->description = "Pastes nodes from the clipboard to the active node tree";
+ ot->idname = "NODE_OT_clipboard_paste";
- /* api callbacks */
- ot->exec = node_clipboard_paste_exec;
- ot->poll = ED_operator_node_editable;
+ /* api callbacks */
+ ot->exec = node_clipboard_paste_exec;
+ ot->poll = ED_operator_node_editable;
- /* flags */
- ot->flag = OPTYPE_REGISTER | OPTYPE_UNDO;
+ /* flags */
+ ot->flag = OPTYPE_REGISTER | OPTYPE_UNDO;
}
/********************** Add interface socket operator *********************/
static bNodeSocket *ntree_get_active_interface_socket(ListBase *lb)
{
- bNodeSocket *sock;
- for (sock = lb->first; sock; sock = sock->next) {
- if (sock->flag & SELECT) {
- return sock;
- }
- }
- return NULL;
+ bNodeSocket *sock;
+ for (sock = lb->first; sock; sock = sock->next) {
+ if (sock->flag & SELECT) {
+ return sock;
+ }
+ }
+ return NULL;
}
static int ntree_socket_add_exec(bContext *C, wmOperator *op)
{
- SpaceNode *snode = CTX_wm_space_node(C);
- bNodeTree *ntree = snode->edittree;
- int in_out = RNA_enum_get(op->ptr, "in_out");
- PointerRNA ntree_ptr;
- bNodeSocket *sock, *tsock, *active_sock;
- const char *default_name;
-
- RNA_id_pointer_create((ID *)ntree, &ntree_ptr);
-
- if (in_out == SOCK_IN) {
- active_sock = ntree_get_active_interface_socket(&ntree->inputs);
- default_name = "Input";
- }
- else {
- active_sock = ntree_get_active_interface_socket(&ntree->outputs);
- default_name = "Output";
- }
-
- if (active_sock) {
- /* insert a copy of the active socket right after it */
- sock = ntreeInsertSocketInterface(ntree, in_out, active_sock->idname, active_sock->next, active_sock->name);
- /* XXX this only works for actual sockets, not interface templates! */
- /*nodeSocketCopyValue(sock, &ntree_ptr, active_sock, &ntree_ptr);*/
- }
- else {
- /* XXX TODO define default socket type for a tree! */
- sock = ntreeAddSocketInterface(ntree, in_out, "NodeSocketFloat", default_name);
- }
-
- /* deactivate sockets (has to check both lists) */
- for (tsock = ntree->inputs.first; tsock; tsock = tsock->next) {
- tsock->flag &= ~SELECT;
- }
- for (tsock = ntree->outputs.first; tsock; tsock = tsock->next) {
- tsock->flag &= ~SELECT;
- }
- /* make the new socket active */
- sock->flag |= SELECT;
-
- ntreeUpdateTree(CTX_data_main(C), ntree);
-
- snode_notify(C, snode);
- snode_dag_update(C, snode);
-
- WM_event_add_notifier(C, NC_NODE | ND_DISPLAY, NULL);
-
- return OPERATOR_FINISHED;
+ SpaceNode *snode = CTX_wm_space_node(C);
+ bNodeTree *ntree = snode->edittree;
+ int in_out = RNA_enum_get(op->ptr, "in_out");
+ PointerRNA ntree_ptr;
+ bNodeSocket *sock, *tsock, *active_sock;
+ const char *default_name;
+
+ RNA_id_pointer_create((ID *)ntree, &ntree_ptr);
+
+ if (in_out == SOCK_IN) {
+ active_sock = ntree_get_active_interface_socket(&ntree->inputs);
+ default_name = "Input";
+ }
+ else {
+ active_sock = ntree_get_active_interface_socket(&ntree->outputs);
+ default_name = "Output";
+ }
+
+ if (active_sock) {
+ /* insert a copy of the active socket right after it */
+ sock = ntreeInsertSocketInterface(
+ ntree, in_out, active_sock->idname, active_sock->next, active_sock->name);
+ /* XXX this only works for actual sockets, not interface templates! */
+ /*nodeSocketCopyValue(sock, &ntree_ptr, active_sock, &ntree_ptr);*/
+ }
+ else {
+ /* XXX TODO define default socket type for a tree! */
+ sock = ntreeAddSocketInterface(ntree, in_out, "NodeSocketFloat", default_name);
+ }
+
+ /* deactivate sockets (has to check both lists) */
+ for (tsock = ntree->inputs.first; tsock; tsock = tsock->next) {
+ tsock->flag &= ~SELECT;
+ }
+ for (tsock = ntree->outputs.first; tsock; tsock = tsock->next) {
+ tsock->flag &= ~SELECT;
+ }
+ /* make the new socket active */
+ sock->flag |= SELECT;
+
+ ntreeUpdateTree(CTX_data_main(C), ntree);
+
+ snode_notify(C, snode);
+ snode_dag_update(C, snode);
+
+ WM_event_add_notifier(C, NC_NODE | ND_DISPLAY, NULL);
+
+ return OPERATOR_FINISHED;
}
void NODE_OT_tree_socket_add(wmOperatorType *ot)
{
- /* identifiers */
- ot->name = "Add Node Tree Interface Socket";
- ot->description = "Add an input or output socket to the current node tree";
- ot->idname = "NODE_OT_tree_socket_add";
+ /* identifiers */
+ ot->name = "Add Node Tree Interface Socket";
+ ot->description = "Add an input or output socket to the current node tree";
+ ot->idname = "NODE_OT_tree_socket_add";
- /* api callbacks */
- ot->exec = ntree_socket_add_exec;
- ot->poll = ED_operator_node_editable;
+ /* api callbacks */
+ ot->exec = ntree_socket_add_exec;
+ ot->poll = ED_operator_node_editable;
- /* flags */
- ot->flag = OPTYPE_REGISTER | OPTYPE_UNDO;
+ /* flags */
+ ot->flag = OPTYPE_REGISTER | OPTYPE_UNDO;
- RNA_def_enum(ot->srna, "in_out", rna_enum_node_socket_in_out_items, SOCK_IN, "Socket Type", "");
+ RNA_def_enum(ot->srna, "in_out", rna_enum_node_socket_in_out_items, SOCK_IN, "Socket Type", "");
}
/********************** Remove interface socket operator *********************/
static int ntree_socket_remove_exec(bContext *C, wmOperator *UNUSED(op))
{
- SpaceNode *snode = CTX_wm_space_node(C);
- bNodeTree *ntree = snode->edittree;
- bNodeSocket *iosock, *active_sock;
+ SpaceNode *snode = CTX_wm_space_node(C);
+ bNodeTree *ntree = snode->edittree;
+ bNodeSocket *iosock, *active_sock;
- iosock = ntree_get_active_interface_socket(&ntree->inputs);
- if (!iosock) {
- iosock = ntree_get_active_interface_socket(&ntree->outputs);
- }
- if (!iosock) {
- return OPERATOR_CANCELLED;
- }
+ iosock = ntree_get_active_interface_socket(&ntree->inputs);
+ if (!iosock) {
+ iosock = ntree_get_active_interface_socket(&ntree->outputs);
+ }
+ if (!iosock) {
+ return OPERATOR_CANCELLED;
+ }
- /* preferably next socket becomes active, otherwise try previous socket */
- active_sock = (iosock->next ? iosock->next : iosock->prev);
- ntreeRemoveSocketInterface(ntree, iosock);
+ /* preferably next socket becomes active, otherwise try previous socket */
+ active_sock = (iosock->next ? iosock->next : iosock->prev);
+ ntreeRemoveSocketInterface(ntree, iosock);
- /* set active socket */
- if (active_sock) {
- active_sock->flag |= SELECT;
- }
+ /* set active socket */
+ if (active_sock) {
+ active_sock->flag |= SELECT;
+ }
- ntreeUpdateTree(CTX_data_main(C), ntree);
+ ntreeUpdateTree(CTX_data_main(C), ntree);
- snode_notify(C, snode);
- snode_dag_update(C, snode);
+ snode_notify(C, snode);
+ snode_dag_update(C, snode);
- WM_event_add_notifier(C, NC_NODE | ND_DISPLAY, NULL);
+ WM_event_add_notifier(C, NC_NODE | ND_DISPLAY, NULL);
- return OPERATOR_FINISHED;
+ return OPERATOR_FINISHED;
}
void NODE_OT_tree_socket_remove(wmOperatorType *ot)
{
- /* identifiers */
- ot->name = "Remove Node Tree Interface Socket";
- ot->description = "Remove an input or output socket to the current node tree";
- ot->idname = "NODE_OT_tree_socket_remove";
+ /* identifiers */
+ ot->name = "Remove Node Tree Interface Socket";
+ ot->description = "Remove an input or output socket to the current node tree";
+ ot->idname = "NODE_OT_tree_socket_remove";
- /* api callbacks */
- ot->exec = ntree_socket_remove_exec;
- ot->poll = ED_operator_node_editable;
+ /* api callbacks */
+ ot->exec = ntree_socket_remove_exec;
+ ot->poll = ED_operator_node_editable;
- /* flags */
- ot->flag = OPTYPE_REGISTER | OPTYPE_UNDO;
+ /* flags */
+ ot->flag = OPTYPE_REGISTER | OPTYPE_UNDO;
}
/********************** Move interface socket operator *********************/
static const EnumPropertyItem move_direction_items[] = {
- { 1, "UP", 0, "Up", "" },
- { 2, "DOWN", 0, "Down", "" },
- { 0, NULL, 0, NULL, NULL },
+ {1, "UP", 0, "Up", ""},
+ {2, "DOWN", 0, "Down", ""},
+ {0, NULL, 0, NULL, NULL},
};
static int ntree_socket_move_exec(bContext *C, wmOperator *op)
{
- SpaceNode *snode = CTX_wm_space_node(C);
- bNodeTree *ntree = snode->edittree;
- int direction = RNA_enum_get(op->ptr, "direction");
- bNodeSocket *iosock;
- ListBase *lb;
-
- lb = &ntree->inputs;
- iosock = ntree_get_active_interface_socket(lb);
- if (!iosock) {
- lb = &ntree->outputs;
- iosock = ntree_get_active_interface_socket(lb);
- }
- if (!iosock) {
- return OPERATOR_CANCELLED;
- }
-
- switch (direction) {
- case 1:
- { /* up */
- bNodeSocket *before = iosock->prev;
- BLI_remlink(lb, iosock);
- if (before) {
- BLI_insertlinkbefore(lb, before, iosock);
- }
- else {
- BLI_addhead(lb, iosock);
- }
- break;
- }
- case 2:
- { /* down */
- bNodeSocket *after = iosock->next;
- BLI_remlink(lb, iosock);
- if (after) {
- BLI_insertlinkafter(lb, after, iosock);
- }
- else {
- BLI_addtail(lb, iosock);
- }
- break;
- }
- }
-
- ntreeUpdateTree(CTX_data_main(C), ntree);
-
- snode_notify(C, snode);
- snode_dag_update(C, snode);
-
- WM_event_add_notifier(C, NC_NODE | ND_DISPLAY, NULL);
-
- return OPERATOR_FINISHED;
+ SpaceNode *snode = CTX_wm_space_node(C);
+ bNodeTree *ntree = snode->edittree;
+ int direction = RNA_enum_get(op->ptr, "direction");
+ bNodeSocket *iosock;
+ ListBase *lb;
+
+ lb = &ntree->inputs;
+ iosock = ntree_get_active_interface_socket(lb);
+ if (!iosock) {
+ lb = &ntree->outputs;
+ iosock = ntree_get_active_interface_socket(lb);
+ }
+ if (!iosock) {
+ return OPERATOR_CANCELLED;
+ }
+
+ switch (direction) {
+ case 1: { /* up */
+ bNodeSocket *before = iosock->prev;
+ BLI_remlink(lb, iosock);
+ if (before) {
+ BLI_insertlinkbefore(lb, before, iosock);
+ }
+ else {
+ BLI_addhead(lb, iosock);
+ }
+ break;
+ }
+ case 2: { /* down */
+ bNodeSocket *after = iosock->next;
+ BLI_remlink(lb, iosock);
+ if (after) {
+ BLI_insertlinkafter(lb, after, iosock);
+ }
+ else {
+ BLI_addtail(lb, iosock);
+ }
+ break;
+ }
+ }
+
+ ntreeUpdateTree(CTX_data_main(C), ntree);
+
+ snode_notify(C, snode);
+ snode_dag_update(C, snode);
+
+ WM_event_add_notifier(C, NC_NODE | ND_DISPLAY, NULL);
+
+ return OPERATOR_FINISHED;
}
void NODE_OT_tree_socket_move(wmOperatorType *ot)
{
- /* identifiers */
- ot->name = "Move Node Tree Socket";
- ot->description = "Move a socket up or down in the current node tree's sockets stack";
- ot->idname = "NODE_OT_tree_socket_move";
+ /* identifiers */
+ ot->name = "Move Node Tree Socket";
+ ot->description = "Move a socket up or down in the current node tree's sockets stack";
+ ot->idname = "NODE_OT_tree_socket_move";
- /* api callbacks */
- ot->exec = ntree_socket_move_exec;
- ot->poll = ED_operator_node_editable;
+ /* api callbacks */
+ ot->exec = ntree_socket_move_exec;
+ ot->poll = ED_operator_node_editable;
- /* flags */
- ot->flag = OPTYPE_REGISTER | OPTYPE_UNDO;
+ /* flags */
+ ot->flag = OPTYPE_REGISTER | OPTYPE_UNDO;
- RNA_def_enum(ot->srna, "direction", move_direction_items, 1, "Direction", "");
+ RNA_def_enum(ot->srna, "direction", move_direction_items, 1, "Direction", "");
}
/* ********************** Shader Script Update ******************/
static bool node_shader_script_update_poll(bContext *C)
{
- Scene *scene = CTX_data_scene(C);
- RenderEngineType *type = RE_engines_find(scene->r.engine);
- SpaceNode *snode = CTX_wm_space_node(C);
- bNode *node;
- Text *text;
+ Scene *scene = CTX_data_scene(C);
+ RenderEngineType *type = RE_engines_find(scene->r.engine);
+ SpaceNode *snode = CTX_wm_space_node(C);
+ bNode *node;
+ Text *text;
- /* test if we have a render engine that supports shaders scripts */
- if (!(type && type->update_script_node)) {
- return 0;
- }
+ /* test if we have a render engine that supports shaders scripts */
+ if (!(type && type->update_script_node)) {
+ return 0;
+ }
- /* see if we have a shader script node in context */
- node = CTX_data_pointer_get_type(C, "node", &RNA_ShaderNodeScript).data;
+ /* see if we have a shader script node in context */
+ node = CTX_data_pointer_get_type(C, "node", &RNA_ShaderNodeScript).data;
- if (!node && snode && snode->edittree) {
- node = nodeGetActive(snode->edittree);
- }
+ if (!node && snode && snode->edittree) {
+ node = nodeGetActive(snode->edittree);
+ }
- if (node && node->type == SH_NODE_SCRIPT) {
- NodeShaderScript *nss = node->storage;
+ if (node && node->type == SH_NODE_SCRIPT) {
+ NodeShaderScript *nss = node->storage;
- if (node->id || nss->filepath[0]) {
- return ED_operator_node_editable(C);
- }
- }
+ if (node->id || nss->filepath[0]) {
+ return ED_operator_node_editable(C);
+ }
+ }
- /* see if we have a text datablock in context */
- text = CTX_data_pointer_get_type(C, "edit_text", &RNA_Text).data;
- if (text) {
- return 1;
- }
+ /* see if we have a text datablock in context */
+ text = CTX_data_pointer_get_type(C, "edit_text", &RNA_Text).data;
+ if (text) {
+ return 1;
+ }
- /* we don't check if text datablock is actually in use, too slow for poll */
+ /* we don't check if text datablock is actually in use, too slow for poll */
- return 0;
+ return 0;
}
/* recursively check for script nodes in groups using this text and update */
-static bool node_shader_script_update_text_recursive(RenderEngine *engine, RenderEngineType *type, bNodeTree *ntree, Text *text)
+static bool node_shader_script_update_text_recursive(RenderEngine *engine,
+ RenderEngineType *type,
+ bNodeTree *ntree,
+ Text *text)
{
- bool found = false;
- bNode *node;
+ bool found = false;
+ bNode *node;
- ntree->done = true;
+ ntree->done = true;
- /* update each script that is using this text datablock */
- for (node = ntree->nodes.first; node; node = node->next) {
- if (node->type == NODE_GROUP) {
- bNodeTree *ngroup = (bNodeTree *)node->id;
- if (ngroup && !ngroup->done) {
- found |= node_shader_script_update_text_recursive(engine, type, ngroup, text);
- }
- }
- else if (node->type == SH_NODE_SCRIPT && node->id == &text->id) {
- type->update_script_node(engine, ntree, node);
- found = true;
- }
- }
+ /* update each script that is using this text datablock */
+ for (node = ntree->nodes.first; node; node = node->next) {
+ if (node->type == NODE_GROUP) {
+ bNodeTree *ngroup = (bNodeTree *)node->id;
+ if (ngroup && !ngroup->done) {
+ found |= node_shader_script_update_text_recursive(engine, type, ngroup, text);
+ }
+ }
+ else if (node->type == SH_NODE_SCRIPT && node->id == &text->id) {
+ type->update_script_node(engine, ntree, node);
+ found = true;
+ }
+ }
- return found;
+ return found;
}
static int node_shader_script_update_exec(bContext *C, wmOperator *op)
{
- Main *bmain = CTX_data_main(C);
- Scene *scene = CTX_data_scene(C);
- SpaceNode *snode = CTX_wm_space_node(C);
- PointerRNA nodeptr = CTX_data_pointer_get_type(C, "node", &RNA_ShaderNodeScript);
- bNodeTree *ntree_base = NULL;
- bNode *node = NULL;
- RenderEngine *engine;
- RenderEngineType *type;
- bool found = false;
-
- /* setup render engine */
- type = RE_engines_find(scene->r.engine);
- engine = RE_engine_create(type);
- engine->reports = op->reports;
-
- /* get node */
- if (nodeptr.data) {
- ntree_base = nodeptr.id.data;
- node = nodeptr.data;
- }
- else if (snode && snode->edittree) {
- ntree_base = snode->edittree;
- node = nodeGetActive(snode->edittree);
- }
-
- if (node) {
- /* update single node */
- type->update_script_node(engine, ntree_base, node);
-
- found = true;
- }
- else {
- /* update all nodes using text datablock */
- Text *text = CTX_data_pointer_get_type(C, "edit_text", &RNA_Text).data;
-
- if (text) {
- /* clear flags for recursion check */
- FOREACH_NODETREE_BEGIN(bmain, ntree, id) {
- if (ntree->type == NTREE_SHADER) {
- ntree->done = false;
- }
- } FOREACH_NODETREE_END;
-
- FOREACH_NODETREE_BEGIN(bmain, ntree, id) {
- if (ntree->type == NTREE_SHADER) {
- if (!ntree->done) {
- found |= node_shader_script_update_text_recursive(engine, type, ntree, text);
- }
- }
- } FOREACH_NODETREE_END;
-
- if (!found) {
- BKE_report(op->reports, RPT_INFO, "Text not used by any node, no update done");
- }
- }
- }
-
- RE_engine_free(engine);
-
- return (found) ? OPERATOR_FINISHED : OPERATOR_CANCELLED;
+ Main *bmain = CTX_data_main(C);
+ Scene *scene = CTX_data_scene(C);
+ SpaceNode *snode = CTX_wm_space_node(C);
+ PointerRNA nodeptr = CTX_data_pointer_get_type(C, "node", &RNA_ShaderNodeScript);
+ bNodeTree *ntree_base = NULL;
+ bNode *node = NULL;
+ RenderEngine *engine;
+ RenderEngineType *type;
+ bool found = false;
+
+ /* setup render engine */
+ type = RE_engines_find(scene->r.engine);
+ engine = RE_engine_create(type);
+ engine->reports = op->reports;
+
+ /* get node */
+ if (nodeptr.data) {
+ ntree_base = nodeptr.id.data;
+ node = nodeptr.data;
+ }
+ else if (snode && snode->edittree) {
+ ntree_base = snode->edittree;
+ node = nodeGetActive(snode->edittree);
+ }
+
+ if (node) {
+ /* update single node */
+ type->update_script_node(engine, ntree_base, node);
+
+ found = true;
+ }
+ else {
+ /* update all nodes using text datablock */
+ Text *text = CTX_data_pointer_get_type(C, "edit_text", &RNA_Text).data;
+
+ if (text) {
+ /* clear flags for recursion check */
+ FOREACH_NODETREE_BEGIN (bmain, ntree, id) {
+ if (ntree->type == NTREE_SHADER) {
+ ntree->done = false;
+ }
+ }
+ FOREACH_NODETREE_END;
+
+ FOREACH_NODETREE_BEGIN (bmain, ntree, id) {
+ if (ntree->type == NTREE_SHADER) {
+ if (!ntree->done) {
+ found |= node_shader_script_update_text_recursive(engine, type, ntree, text);
+ }
+ }
+ }
+ FOREACH_NODETREE_END;
+
+ if (!found) {
+ BKE_report(op->reports, RPT_INFO, "Text not used by any node, no update done");
+ }
+ }
+ }
+
+ RE_engine_free(engine);
+
+ return (found) ? OPERATOR_FINISHED : OPERATOR_CANCELLED;
}
void NODE_OT_shader_script_update(wmOperatorType *ot)
{
- /* identifiers */
- ot->name = "Script Node Update";
- ot->description = "Update shader script node with new sockets and options from the script";
- ot->idname = "NODE_OT_shader_script_update";
+ /* identifiers */
+ ot->name = "Script Node Update";
+ ot->description = "Update shader script node with new sockets and options from the script";
+ ot->idname = "NODE_OT_shader_script_update";
- /* api callbacks */
- ot->exec = node_shader_script_update_exec;
- ot->poll = node_shader_script_update_poll;
+ /* api callbacks */
+ ot->exec = node_shader_script_update_exec;
+ ot->poll = node_shader_script_update_poll;
- /* flags */
- ot->flag = OPTYPE_REGISTER | OPTYPE_UNDO;
+ /* flags */
+ ot->flag = OPTYPE_REGISTER | OPTYPE_UNDO;
}
/* ********************** Viewer border ******************/
-static void viewer_border_corner_to_backdrop(SpaceNode *snode, ARegion *ar, int x, int y,
- int backdrop_width, int backdrop_height,
- float *fx, float *fy)
+static void viewer_border_corner_to_backdrop(SpaceNode *snode,
+ ARegion *ar,
+ int x,
+ int y,
+ int backdrop_width,
+ int backdrop_height,
+ float *fx,
+ float *fy)
{
- float bufx, bufy;
+ float bufx, bufy;
- bufx = backdrop_width * snode->zoom;
- bufy = backdrop_height * snode->zoom;
+ bufx = backdrop_width * snode->zoom;
+ bufy = backdrop_height * snode->zoom;
- *fx = (bufx > 0.0f ? ((float) x - 0.5f * ar->winx - snode->xof) / bufx + 0.5f : 0.0f);
- *fy = (bufy > 0.0f ? ((float) y - 0.5f * ar->winy - snode->yof) / bufy + 0.5f : 0.0f);
+ *fx = (bufx > 0.0f ? ((float)x - 0.5f * ar->winx - snode->xof) / bufx + 0.5f : 0.0f);
+ *fy = (bufy > 0.0f ? ((float)y - 0.5f * ar->winy - snode->yof) / bufy + 0.5f : 0.0f);
}
static int viewer_border_exec(bContext *C, wmOperator *op)
{
- Main *bmain = CTX_data_main(C);
- Image *ima;
- void *lock;
- ImBuf *ibuf;
+ Main *bmain = CTX_data_main(C);
+ Image *ima;
+ void *lock;
+ ImBuf *ibuf;
- ED_preview_kill_jobs(CTX_wm_manager(C), bmain);
+ ED_preview_kill_jobs(CTX_wm_manager(C), bmain);
- ima = BKE_image_verify_viewer(bmain, IMA_TYPE_COMPOSITE, "Viewer Node");
- ibuf = BKE_image_acquire_ibuf(ima, NULL, &lock);
+ ima = BKE_image_verify_viewer(bmain, IMA_TYPE_COMPOSITE, "Viewer Node");
+ ibuf = BKE_image_acquire_ibuf(ima, NULL, &lock);
- if (ibuf) {
- ARegion *ar = CTX_wm_region(C);
- SpaceNode *snode = CTX_wm_space_node(C);
- bNodeTree *btree = snode->nodetree;
- rcti rect;
- rctf rectf;
+ if (ibuf) {
+ ARegion *ar = CTX_wm_region(C);
+ SpaceNode *snode = CTX_wm_space_node(C);
+ bNodeTree *btree = snode->nodetree;
+ rcti rect;
+ rctf rectf;
- /* get border from operator */
- WM_operator_properties_border_to_rcti(op, &rect);
+ /* get border from operator */
+ WM_operator_properties_border_to_rcti(op, &rect);
- /* convert border to unified space within backdrop image */
- viewer_border_corner_to_backdrop(snode, ar, rect.xmin, rect.ymin, ibuf->x, ibuf->y,
- &rectf.xmin, &rectf.ymin);
+ /* convert border to unified space within backdrop image */
+ viewer_border_corner_to_backdrop(
+ snode, ar, rect.xmin, rect.ymin, ibuf->x, ibuf->y, &rectf.xmin, &rectf.ymin);
- viewer_border_corner_to_backdrop(snode, ar, rect.xmax, rect.ymax, ibuf->x, ibuf->y,
- &rectf.xmax, &rectf.ymax);
+ viewer_border_corner_to_backdrop(
+ snode, ar, rect.xmax, rect.ymax, ibuf->x, ibuf->y, &rectf.xmax, &rectf.ymax);
- /* clamp coordinates */
- rectf.xmin = max_ff(rectf.xmin, 0.0f);
- rectf.ymin = max_ff(rectf.ymin, 0.0f);
- rectf.xmax = min_ff(rectf.xmax, 1.0f);
- rectf.ymax = min_ff(rectf.ymax, 1.0f);
+ /* clamp coordinates */
+ rectf.xmin = max_ff(rectf.xmin, 0.0f);
+ rectf.ymin = max_ff(rectf.ymin, 0.0f);
+ rectf.xmax = min_ff(rectf.xmax, 1.0f);
+ rectf.ymax = min_ff(rectf.ymax, 1.0f);
- if (rectf.xmin < rectf.xmax && rectf.ymin < rectf.ymax) {
- btree->viewer_border = rectf;
+ if (rectf.xmin < rectf.xmax && rectf.ymin < rectf.ymax) {
+ btree->viewer_border = rectf;
- if (rectf.xmin == 0.0f && rectf.ymin == 0.0f &&
- rectf.xmax == 1.0f && rectf.ymax == 1.0f)
- {
- btree->flag &= ~NTREE_VIEWER_BORDER;
- }
- else {
- btree->flag |= NTREE_VIEWER_BORDER;
- }
+ if (rectf.xmin == 0.0f && rectf.ymin == 0.0f && rectf.xmax == 1.0f && rectf.ymax == 1.0f) {
+ btree->flag &= ~NTREE_VIEWER_BORDER;
+ }
+ else {
+ btree->flag |= NTREE_VIEWER_BORDER;
+ }
- snode_notify(C, snode);
- WM_event_add_notifier(C, NC_NODE | ND_DISPLAY, NULL);
- }
- else {
- btree->flag &= ~NTREE_VIEWER_BORDER;
- }
- }
+ snode_notify(C, snode);
+ WM_event_add_notifier(C, NC_NODE | ND_DISPLAY, NULL);
+ }
+ else {
+ btree->flag &= ~NTREE_VIEWER_BORDER;
+ }
+ }
- BKE_image_release_ibuf(ima, ibuf, lock);
+ BKE_image_release_ibuf(ima, ibuf, lock);
- return OPERATOR_FINISHED;
+ return OPERATOR_FINISHED;
}
void NODE_OT_viewer_border(wmOperatorType *ot)
{
- /* identifiers */
- ot->name = "Viewer Border";
- ot->description = "Set the boundaries for viewer operations";
- ot->idname = "NODE_OT_viewer_border";
+ /* identifiers */
+ ot->name = "Viewer Border";
+ ot->description = "Set the boundaries for viewer operations";
+ ot->idname = "NODE_OT_viewer_border";
- /* api callbacks */
- ot->invoke = WM_gesture_box_invoke;
- ot->exec = viewer_border_exec;
- ot->modal = WM_gesture_box_modal;
- ot->cancel = WM_gesture_box_cancel;
- ot->poll = composite_node_active;
+ /* api callbacks */
+ ot->invoke = WM_gesture_box_invoke;
+ ot->exec = viewer_border_exec;
+ ot->modal = WM_gesture_box_modal;
+ ot->cancel = WM_gesture_box_cancel;
+ ot->poll = composite_node_active;
- /* flags */
- ot->flag = OPTYPE_REGISTER | OPTYPE_UNDO;
+ /* flags */
+ ot->flag = OPTYPE_REGISTER | OPTYPE_UNDO;
- /* properties */
- WM_operator_properties_gesture_box_select(ot);
+ /* properties */
+ WM_operator_properties_gesture_box_select(ot);
}
static int clear_viewer_border_exec(bContext *C, wmOperator *UNUSED(op))
{
- SpaceNode *snode = CTX_wm_space_node(C);
- bNodeTree *btree = snode->nodetree;
+ SpaceNode *snode = CTX_wm_space_node(C);
+ bNodeTree *btree = snode->nodetree;
- btree->flag &= ~NTREE_VIEWER_BORDER;
- snode_notify(C, snode);
- WM_event_add_notifier(C, NC_NODE | ND_DISPLAY, NULL);
+ btree->flag &= ~NTREE_VIEWER_BORDER;
+ snode_notify(C, snode);
+ WM_event_add_notifier(C, NC_NODE | ND_DISPLAY, NULL);
- return OPERATOR_FINISHED;
+ return OPERATOR_FINISHED;
}
void NODE_OT_clear_viewer_border(wmOperatorType *ot)
{
- /* identifiers */
- ot->name = "Clear Viewer Border";
- ot->description = "Clear the boundaries for viewer operations";
- ot->idname = "NODE_OT_clear_viewer_border";
+ /* identifiers */
+ ot->name = "Clear Viewer Border";
+ ot->description = "Clear the boundaries for viewer operations";
+ ot->idname = "NODE_OT_clear_viewer_border";
- /* api callbacks */
- ot->exec = clear_viewer_border_exec;
- ot->poll = composite_node_active;
+ /* api callbacks */
+ ot->exec = clear_viewer_border_exec;
+ ot->poll = composite_node_active;
- /* flags */
- ot->flag = OPTYPE_REGISTER | OPTYPE_UNDO;
+ /* flags */
+ ot->flag = OPTYPE_REGISTER | OPTYPE_UNDO;
}
/* ****************** Cryptomatte Add Socket ******************* */
static int node_cryptomatte_add_socket_exec(bContext *C, wmOperator *UNUSED(op))
{
- SpaceNode *snode = CTX_wm_space_node(C);
- PointerRNA ptr = CTX_data_pointer_get(C, "node");
- bNodeTree *ntree = NULL;
- bNode *node = NULL;
+ SpaceNode *snode = CTX_wm_space_node(C);
+ PointerRNA ptr = CTX_data_pointer_get(C, "node");
+ bNodeTree *ntree = NULL;
+ bNode *node = NULL;
- if (ptr.data) {
- node = ptr.data;
- ntree = ptr.id.data;
- }
- else if (snode && snode->edittree) {
- ntree = snode->edittree;
- node = nodeGetActive(snode->edittree);
- }
+ if (ptr.data) {
+ node = ptr.data;
+ ntree = ptr.id.data;
+ }
+ else if (snode && snode->edittree) {
+ ntree = snode->edittree;
+ node = nodeGetActive(snode->edittree);
+ }
- if (!node || node->type != CMP_NODE_CRYPTOMATTE) {
- return OPERATOR_CANCELLED;
- }
+ if (!node || node->type != CMP_NODE_CRYPTOMATTE) {
+ return OPERATOR_CANCELLED;
+ }
- ntreeCompositCryptomatteAddSocket(ntree, node);
+ ntreeCompositCryptomatteAddSocket(ntree, node);
- snode_notify(C, snode);
+ snode_notify(C, snode);
- return OPERATOR_FINISHED;
+ return OPERATOR_FINISHED;
}
void NODE_OT_cryptomatte_layer_add(wmOperatorType *ot)
{
- /* identifiers */
- ot->name = "Add Cryptomatte Socket";
- ot->description = "Add a new input layer to a Cryptomatte node";
- ot->idname = "NODE_OT_cryptomatte_layer_add";
+ /* identifiers */
+ ot->name = "Add Cryptomatte Socket";
+ ot->description = "Add a new input layer to a Cryptomatte node";
+ ot->idname = "NODE_OT_cryptomatte_layer_add";
- /* callbacks */
- ot->exec = node_cryptomatte_add_socket_exec;
- ot->poll = composite_node_editable;
+ /* callbacks */
+ ot->exec = node_cryptomatte_add_socket_exec;
+ ot->poll = composite_node_editable;
- /* flags */
- ot->flag = OPTYPE_REGISTER | OPTYPE_UNDO;
+ /* flags */
+ ot->flag = OPTYPE_REGISTER | OPTYPE_UNDO;
}
/* ****************** Cryptomatte Remove Socket ******************* */
static int node_cryptomatte_remove_socket_exec(bContext *C, wmOperator *UNUSED(op))
{
- SpaceNode *snode = CTX_wm_space_node(C);
- PointerRNA ptr = CTX_data_pointer_get(C, "node");
- bNodeTree *ntree = NULL;
- bNode *node = NULL;
+ SpaceNode *snode = CTX_wm_space_node(C);
+ PointerRNA ptr = CTX_data_pointer_get(C, "node");
+ bNodeTree *ntree = NULL;
+ bNode *node = NULL;
- if (ptr.data) {
- node = ptr.data;
- ntree = ptr.id.data;
- }
- else if (snode && snode->edittree) {
- ntree = snode->edittree;
- node = nodeGetActive(snode->edittree);
- }
+ if (ptr.data) {
+ node = ptr.data;
+ ntree = ptr.id.data;
+ }
+ else if (snode && snode->edittree) {
+ ntree = snode->edittree;
+ node = nodeGetActive(snode->edittree);
+ }
- if (!node || node->type != CMP_NODE_CRYPTOMATTE) {
- return OPERATOR_CANCELLED;
- }
+ if (!node || node->type != CMP_NODE_CRYPTOMATTE) {
+ return OPERATOR_CANCELLED;
+ }
- if (!ntreeCompositCryptomatteRemoveSocket(ntree, node)) {
- return OPERATOR_CANCELLED;
- }
+ if (!ntreeCompositCryptomatteRemoveSocket(ntree, node)) {
+ return OPERATOR_CANCELLED;
+ }
- snode_notify(C, snode);
+ snode_notify(C, snode);
- return OPERATOR_FINISHED;
+ return OPERATOR_FINISHED;
}
void NODE_OT_cryptomatte_layer_remove(wmOperatorType *ot)
{
- /* identifiers */
- ot->name = "Remove Cryptomatte Socket";
- ot->description = "Remove layer from a Cryptomatte node";
- ot->idname = "NODE_OT_cryptomatte_layer_remove";
+ /* identifiers */
+ ot->name = "Remove Cryptomatte Socket";
+ ot->description = "Remove layer from a Cryptomatte node";
+ ot->idname = "NODE_OT_cryptomatte_layer_remove";
- /* callbacks */
- ot->exec = node_cryptomatte_remove_socket_exec;
- ot->poll = composite_node_editable;
+ /* callbacks */
+ ot->exec = node_cryptomatte_remove_socket_exec;
+ ot->poll = composite_node_editable;
- /* flags */
- ot->flag = OPTYPE_REGISTER | OPTYPE_UNDO;
+ /* flags */
+ ot->flag = OPTYPE_REGISTER | OPTYPE_UNDO;
}