fix for linking on msvc with own recent changes.
[blender.git] / source / blender / editors / space_node / node_header.c
index a0eae40f5796d29815084104838503d370b7a2e1..1ad5954b56eff256e2ad1220541775c92a7349ab 100644 (file)
@@ -15,7 +15,7 @@
  *
  * You should have received a copy of the GNU General Public License
  * along with this program; if not, write to the Free Software Foundation,
- * Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
+ * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
  *
  * The Original Code is Copyright (C) 2008 Blender Foundation.
  * All rights reserved.
 
 #include "DNA_space_types.h"
 #include "DNA_node_types.h"
-#include "DNA_material_types.h"
-#include "DNA_texture_types.h"
 #include "DNA_scene_types.h"
 #include "DNA_screen_types.h"
-#include "DNA_windowmanager_types.h"
 
 #include "MEM_guardedalloc.h"
 
 #include "BKE_screen.h"
 #include "BKE_node.h"
 #include "BKE_main.h"
-#include "BKE_utildefines.h"
 
-#include "ED_screen.h"
-#include "ED_types.h"
-#include "ED_util.h"
 
 #include "WM_api.h"
 #include "WM_types.h"
 
-#include "BIF_gl.h"
-#include "BIF_glutil.h"
 
 #include "UI_interface.h"
-#include "UI_resources.h"
 #include "UI_view2d.h"
 
 #include "node_intern.h"
 
 /* ************************ add menu *********************** */
 
-static void do_node_add(bContext *C, void *arg, int event)
+static void do_node_add(bContext *C, void *UNUSED(arg), int event)
 {
        SpaceNode *snode= CTX_wm_space_node(C);
        bNode *node;
@@ -78,10 +68,19 @@ static void do_node_add(bContext *C, void *arg, int event)
        
        node= node_add_node(snode, CTX_data_scene(C), event, snode->mx, snode->my);
        
-       /* uses test flag */
-       snode_autoconnect(snode, node, NODE_TEST);
+       /* select previous selection before autoconnect */
+       for(node= snode->edittree->nodes.first; node; node= node->next) {
+               if(node->flag & NODE_TEST) node->flag |= NODE_SELECT;
+       }
+       
+       snode_autoconnect(snode, 1, 0);
+       
+       /* deselect after autoconnection */
+       for(node= snode->edittree->nodes.first; node; node= node->next) {
+               if(node->flag & NODE_TEST) node->flag &= ~NODE_SELECT;
+       }
                
-       snode_handle_recalc(C, snode);
+       snode_notify(C, snode);
 }
 
 static void node_auto_add_menu(bContext *C, uiLayout *layout, void *arg_nodeclass)
@@ -127,7 +126,7 @@ static void node_auto_add_menu(bContext *C, uiLayout *layout, void *arg_nodeclas
 
                for(tot=0, a=0; ngroup; ngroup= ngroup->id.next, tot++) {
                        if(ngroup->type==ntree->type) {
-                               uiItemV(layout, ngroup->id.name+2, 0, NODE_GROUP_MENU+tot);
+                               uiItemV(layout, ngroup->id.name+2, ICON_NULL, NODE_GROUP_MENU+tot);
                                a++;
                        }
                }
@@ -139,11 +138,11 @@ static void node_auto_add_menu(bContext *C, uiLayout *layout, void *arg_nodeclas
                for(a=0, type= ntree->alltypes.first; type; type=type->next) {
                        if(type->nclass == nodeclass && type->name) {
                                if(type->type == NODE_DYNAMIC) {
-                                       uiItemV(layout, type->name, 0, NODE_DYNAMIC_MENU+script);
+                                       uiItemV(layout, type->name, ICON_NULL, NODE_DYNAMIC_MENU+script);
                                        script++;
                                }
                                else
-                                       uiItemV(layout, type->name, 0, type->type);
+                                       uiItemV(layout, type->name, ICON_NULL, type->type);
 
                                a++;
                        }
@@ -155,6 +154,18 @@ static void node_menu_add(const bContext *C, Menu *menu)
 {
        uiLayout *layout= menu->layout;
        SpaceNode *snode= CTX_wm_space_node(C);
+       ScrArea *sa= CTX_wm_area(C);
+       ARegion *ar;
+
+       /* get location to add node at mouse */
+       for(ar=sa->regionbase.first; ar; ar=ar->next) {
+               if(ar->regiontype == RGN_TYPE_WINDOW) {
+                       wmWindow *win= CTX_wm_window(C);
+                       UI_view2d_region_to_view(&ar->v2d,
+                               win->eventstate->x - ar->winrct.xmin, win->eventstate->y - ar->winrct.ymin, 
+                               &snode->mx, &snode->my);
+               }
+       }
 
        if(!snode->nodetree)
                uiLayoutSetActive(layout, 0);
@@ -191,7 +202,7 @@ static void node_menu_add(const bContext *C, Menu *menu)
        }
 }
 
-void node_menus_register(ARegionType *art)
+void node_menus_register(void)
 {
        MenuType *mt;
 
@@ -202,131 +213,3 @@ void node_menus_register(ARegionType *art)
        WM_menutype_add(mt);
 }
 
-#if 0
-static void do_node_nodemenu(bContext *C, void *arg, int event)
-{
-       ScrArea *curarea= CTX_wm_area(C);
-       SpaceNode *snode= CTX_wm_space_node(C); 
-       int fromlib=0;
-       
-       /* functions in editnode.c assume there's a tree */
-       if(snode->nodetree==NULL)
-               return;
-       fromlib= (snode->id && snode->id->lib);
-       
-       switch(event) {
-               case 1: /* grab/move */
-                       // XXX node_transform_ext(0,0);
-                       break;
-               case 2: /* duplicate */
-                       if(fromlib) fromlib= -1;
-                       else ; // XXX node_adduplicate(snode);
-                       break;
-               case 3: /* delete */
-                       if(fromlib) fromlib= -1;
-                       else ; // XXX node_delete(snode);
-                       break;
-               case 4: /* make group */
-                       // XXX node_make_group(snode);
-                       break;
-               case 5: /* ungroup */
-                       // XXX node_ungroup(snode);
-                       break;
-               case 6: /* edit group */
-                       if(fromlib) fromlib= -1;
-                       else ; // XXX snode_make_group_editable(snode, NULL);
-                       break;
-               case 7: /* hide/unhide */
-                       // XXX node_hide(snode);
-                       break;
-               case 8: /* read saved render layers */
-                       // XXX node_read_renderlayers(snode);
-                       break;
-               case 9: /* show cyclic */
-                       // XXX ntreeSolveOrder(snode->edittree);
-                       break;
-               case 10: /* execute */
-                       // XXXX addqueue(curarea->win, UI_BUT_EVENT, B_NODE_TREE_EXEC);
-                       break;
-               case 11: /* make link */
-                       // XXX node_make_link(snode);
-                       break;
-               case 12: /* rename */
-                       // XXX node_rename(snode);
-                       break;
-               case 13: /* read saved full sample layers */
-                       // XXX node_read_fullsamplelayers(snode);
-                       break;
-               case 14: /* connect viewer */
-                       // XXX node_active_link_viewer(snode);
-                       break;
-                       
-       }
-       
-       // XXX if(fromlib==-1) error_libdata();
-       
-       ED_area_tag_redraw(curarea);
-}
-
-static uiBlock *node_nodemenu(bContext *C, ARegion *ar, void *arg_unused)
-{
-       ScrArea *curarea= CTX_wm_area(C);
-       SpaceNode *snode= CTX_wm_space_node(C);
-       uiBlock *block;
-       short yco= 0, menuwidth=120;
-       
-       block= uiBeginBlock(C, ar, "node_nodemenu", UI_EMBOSSP);
-       uiBlockSetButmFunc(block, do_node_nodemenu, NULL);
-       
-       uiDefIconTextBut(block, BUTM, 1, ICON_BLANK1, "Grab/Move|G", 0, yco-=20, menuwidth, 19, NULL, 0.0, 0.0, 1, 1, "");
-       
-       uiDefBut(block, SEPR, 0, "",        0, yco-=6, menuwidth, 6, NULL, 0.0, 0.0, 0, 0, "");
-       
-       uiDefIconTextBut(block, BUTM, 1, ICON_BLANK1, "Duplicate|Shift D", 0, yco-=20, menuwidth, 19, NULL, 0.0, 0.0, 1, 2, "");
-       uiDefIconTextBut(block, BUTM, 1, ICON_BLANK1, "Delete|X", 0, yco-=20, menuwidth, 19, NULL, 0.0, 0.0, 1, 3, "");
-       
-       uiDefBut(block, SEPR, 0, "",        0, yco-=6, menuwidth, 6, NULL, 0.0, 0.0, 0, 0, "");
-
-       uiDefIconTextBut(block, BUTM, 1, ICON_BLANK1, "Make Link|F", 0, yco-=20, menuwidth, 19, NULL, 0.0, 0.0, 1, 11, "");
-
-       uiDefBut(block, SEPR, 0, "",        0, yco-=6, menuwidth, 6, NULL, 0.0, 0.0, 0, 0, "");
-       
-       uiDefIconTextBut(block, BUTM, 1, ICON_BLANK1, "Make Group|Ctrl G", 0, yco-=20, menuwidth, 19, NULL, 0.0, 0.0, 1, 4, "");
-       uiDefIconTextBut(block, BUTM, 1, ICON_BLANK1, "Ungroup|Alt G", 0, yco-=20, menuwidth, 19, NULL, 0.0, 0.0, 1, 5, "");
-       uiDefIconTextBut(block, BUTM, 1, ICON_BLANK1, "Edit Group|Tab", 0, yco-=20, menuwidth, 19, NULL, 0.0, 0.0, 1, 6, "");
-       
-       uiDefBut(block, SEPR, 0, "",        0, yco-=6, menuwidth, 6, NULL, 0.0, 0.0, 0, 0, "");
-       
-       uiDefIconTextBut(block, BUTM, 1, ICON_BLANK1, "Hide/Unhide|H", 0, yco-=20, menuwidth, 19, NULL, 0.0, 0.0, 1, 7, "");
-       uiDefIconTextBut(block, BUTM, 1, ICON_BLANK1, "Rename|Ctrl R", 0, yco-=20, menuwidth, 19, NULL, 0.0, 0.0, 1, 12, "");
-       
-       uiDefBut(block, SEPR, 0, "",        0, yco-=6, menuwidth, 6, NULL, 0.0, 0.0, 0, 0, "");
-       
-       if(snode->treetype==NTREE_COMPOSIT) {
-               uiDefIconTextBut(block, BUTM, 1, ICON_BLANK1, "Execute Composite|E", 0, yco-=20, menuwidth, 19, NULL, 0.0, 0.0, 1, 10, "");
-               uiDefIconTextBut(block, BUTM, 1, ICON_BLANK1, "Read Saved Render Results|R", 0, yco-=20, menuwidth, 19, NULL, 0.0, 0.0, 1, 8, "");
-               uiDefIconTextBut(block, BUTM, 1, ICON_BLANK1, "Read Saved Full Sample Results|Shift R", 0, yco-=20, menuwidth, 19, NULL, 0.0, 0.0, 1, 13, "");
-               
-               uiDefBut(block, SEPR, 0, "",        0, yco-=6, menuwidth, 6, NULL, 0.0, 0.0, 0, 0, "");
-               
-               uiDefIconTextBut(block, BUTM, 1, ICON_BLANK1, "Connect Node to Viewer|Ctrl RMB", 0, yco-=20, menuwidth, 19, NULL, 0.0, 0.0, 1, 14, "");
-               
-               uiDefBut(block, SEPR, 0, "",        0, yco-=6, menuwidth, 6, NULL, 0.0, 0.0, 0, 0, "");
-       }
-       uiDefIconTextBut(block, BUTM, 1, ICON_BLANK1, "Show Cyclic Dependencies|C", 0, yco-=20, menuwidth, 19, NULL, 0.0, 0.0, 1, 9, "");
-       
-       if(curarea->headertype==HEADERTOP) {
-               uiBlockSetDirection(block, UI_DOWN);
-       }
-       else {
-               uiBlockSetDirection(block, UI_TOP);
-               uiBlockFlipOrder(block);
-       }
-       
-       uiTextBoundsBlock(block, 50);
-       uiEndBlock(C, block);
-       
-       return block;
-}
-#endif
-