2.5
authorAndrea Weikert <elubie@gmx.net>
Sun, 14 Dec 2008 11:25:00 +0000 (11:25 +0000)
committerAndrea Weikert <elubie@gmx.net>
Sun, 14 Dec 2008 11:25:00 +0000 (11:25 +0000)
Skeleton for bringing back SpaceFile.
Code to initialize the SpaceFile struct missing still, I think this is the right time to cleanup there :)

projectfiles_vc9/blender/editors/ED_editors.vcproj
source/blender/editors/include/ED_space_api.h
source/blender/editors/space_api/spacetypes.c
source/blender/editors/space_file/Makefile [new file with mode: 0644]
source/blender/editors/space_file/SConscript [new file with mode: 0644]
source/blender/editors/space_file/file_header.c [new file with mode: 0644]
source/blender/editors/space_file/space_file.c [new file with mode: 0644]

index 4356badaf5f04e21bf77cfb7d9171cfaff87aa04..37e447988bed5968f444f96768d388a9934d9f90 100644 (file)
                                >\r
                        </File>\r
                </Filter>\r
+               <Filter\r
+                       Name="space_file"\r
+                       >\r
+                       <File\r
+                               RelativePath="..\..\..\source\blender\editors\space_file\file_header.c"\r
+                               >\r
+                       </File>\r
+                       <File\r
+                               RelativePath="..\..\..\source\blender\editors\space_file\space_file.c"\r
+                               >\r
+                       </File>\r
+               </Filter>\r
        </Files>\r
        <Globals>\r
        </Globals>\r
index de406af30c94850b0e7c98de4586a347a88b2a4d..ccca2490b7a597b2187558f735a33c39d23af1a6 100644 (file)
@@ -40,6 +40,7 @@ void ED_spacetype_image(void);
 void ED_spacetype_node(void);
 void ED_spacetype_buttons(void);
 void ED_spacetype_info(void);
+void ED_spacetype_file(void);
 
 #endif /* ED_AREA_H */
 
index 063dcb6c1a08e07c97fe1d53757a494774fd83a8..1dd923a613d847eb0f7a388e28c5ebf3884c8d66 100644 (file)
@@ -69,6 +69,7 @@ void ED_spacetypes_init(void)
        ED_spacetype_node();
        ED_spacetype_buttons();
        ED_spacetype_info();
+       ED_spacetype_file();
 //     ...
        
        /* register operator types for screen and all spaces */
diff --git a/source/blender/editors/space_file/Makefile b/source/blender/editors/space_file/Makefile
new file mode 100644 (file)
index 0000000..07811dc
--- /dev/null
@@ -0,0 +1,53 @@
+#
+# $Id:  $
+#
+# ***** BEGIN GPL LICENSE BLOCK *****
+#
+# This program is free software; you can redistribute it and/or
+# modify it under the terms of the GNU General Public License
+# as published by the Free Software Foundation; either version 2
+# of the License, or (at your option) any later version. 
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the Free Software Foundation,
+# Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
+#
+# The Original Code is Copyright (C) 2007 Blender Foundation
+# All rights reserved.
+#
+# The Original Code is: all of this file.
+#
+# Contributor(s): none yet.
+#
+# ***** END GPL LICENSE BLOCK *****
+#
+# Makes module object directory and bounces make to subdirectories.
+
+LIBNAME = ed_file
+DIR = $(OCGDIR)/blender/$(LIBNAME)
+
+include nan_compile.mk
+
+CFLAGS += $(LEVEL_1_C_WARNINGS)
+
+CPPFLAGS += -I$(NAN_GLEW)/include
+CPPFLAGS += -I$(OPENGL_HEADERS)
+
+# not very neat....
+CPPFLAGS += -I../../windowmanager
+CPPFLAGS += -I../../blenloader
+CPPFLAGS += -I../../blenkernel
+CPPFLAGS += -I../../blenlib
+CPPFLAGS += -I../../makesdna
+CPPFLAGS += -I../../imbuf
+CPPFLAGS += -I../../python
+CPPFLAGS += -I$(NAN_GUARDEDALLOC)/include
+
+# own include 
+
+CPPFLAGS += -I../include 
diff --git a/source/blender/editors/space_file/SConscript b/source/blender/editors/space_file/SConscript
new file mode 100644 (file)
index 0000000..b08d616
--- /dev/null
@@ -0,0 +1,9 @@
+#!/usr/bin/python
+Import ('env')
+
+sources = env.Glob('*.c')
+
+incs = '../include ../../blenlib ../../blenkernel ../../makesdna ../../imbuf'
+incs += ' ../../windowmanager #/intern/guardedalloc #/extern/glew/include'
+
+env.BlenderLib ( 'bf_editors_space_file', sources, Split(incs), [], libtype=['core','intern'], priority=[35, 40] )
diff --git a/source/blender/editors/space_file/file_header.c b/source/blender/editors/space_file/file_header.c
new file mode 100644 (file)
index 0000000..d52a35f
--- /dev/null
@@ -0,0 +1,165 @@
+/**
+ * $Id$
+ *
+ * ***** BEGIN GPL LICENSE BLOCK *****
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License
+ * as published by the Free Software Foundation; either version 2
+ * of the License, or (at your option) any later version. 
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software Foundation,
+ * Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
+ *
+ * The Original Code is Copyright (C) 2008 Blender Foundation.
+ * All rights reserved.
+ *
+ * 
+ * Contributor(s): Blender Foundation
+ *
+ * ***** END GPL LICENSE BLOCK *****
+ */
+
+#include <string.h>
+#include <stdio.h>
+
+#include "DNA_space_types.h"
+#include "DNA_scene_types.h"
+#include "DNA_screen_types.h"
+#include "DNA_windowmanager_types.h"
+
+#include "MEM_guardedalloc.h"
+
+#include "BLI_blenlib.h"
+
+#include "BKE_global.h"
+#include "BKE_screen.h"
+
+#include "ED_screen.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"
+
+
+/* ************************ header area region *********************** */
+
+static void do_viewmenu(bContext *C, void *arg, int event)
+{
+       
+}
+
+static uiBlock *dummy_viewmenu(bContext *C, uiMenuBlockHandle *handle, void *arg_unused)
+{
+       ScrArea *curarea= C->area;
+       uiBlock *block;
+       short yco= 0, menuwidth=120;
+       
+       block= uiBeginBlock(C, handle->region, "dummy_viewmenu", UI_EMBOSSP, UI_HELV);
+       uiBlockSetButmFunc(block, do_viewmenu, NULL);
+       
+       uiDefIconTextBut(block, BUTM, 1, ICON_BLANK1, "Nothing yet", 0, yco-=20, 
+                                        menuwidth, 19, NULL, 0.0, 0.0, 1, 3, "");
+       
+       if(curarea->headertype==HEADERTOP) {
+               uiBlockSetDirection(block, UI_DOWN);
+       }
+       else {
+               uiBlockSetDirection(block, UI_TOP);
+               uiBlockFlipOrder(block);
+       }
+       
+       uiTextBoundsBlock(block, 50);
+       uiEndBlock(C, block);
+       
+       return block;
+}
+
+#define B_NEWSPACE             100
+
+static void do_file_buttons(bContext *C, void *arg, int event)
+{
+       switch(event) {
+               case B_NEWSPACE:
+                       ED_newspace(C->area, C->area->butspacetype);
+                       WM_event_add_notifier(C, WM_NOTE_SCREEN_CHANGED, 0, NULL);
+                       break;
+               }
+}
+
+
+void file_header_buttons(const bContext *C, ARegion *ar)
+{
+       ScrArea *sa= C->area;
+       uiBlock *block;
+       short xco, yco= 3;
+       
+       block= uiBeginBlock(C, ar, "header buttons", UI_EMBOSS, UI_HELV);
+       uiBlockSetHandleFunc(block, do_file_buttons, NULL);
+       
+       if(ED_screen_area_active(C)) uiBlockSetCol(block, TH_HEADER);
+       else uiBlockSetCol(block, TH_HEADERDESEL);
+
+       xco = 8;
+       
+       uiDefIconTextButC(block, ICONTEXTROW,B_NEWSPACE, ICON_VIEW3D, 
+                                         windowtype_pup(), xco, yco, XIC+10, YIC, 
+                                         &(C->area->butspacetype), 1.0, SPACEICONMAX, 0, 0, 
+                                         "Displays Current Window Type. "
+                                         "Click for menu of available types.");
+       
+       xco += XIC + 14;
+       
+       uiBlockSetEmboss(block, UI_EMBOSSN);
+       if (sa->flag & HEADER_NO_PULLDOWN) {
+               uiDefIconButBitS(block, TOG, HEADER_NO_PULLDOWN, 0, 
+                                                ICON_DISCLOSURE_TRI_RIGHT,
+                                                xco,yco,XIC,YIC-2,
+                                                &(sa->flag), 0, 0, 0, 0, 
+                                                "Show pulldown menus");
+       }
+       else {
+               uiDefIconButBitS(block, TOG, HEADER_NO_PULLDOWN, 0, 
+                                                ICON_DISCLOSURE_TRI_DOWN,
+                                                xco,yco,XIC,YIC-2,
+                                                &(sa->flag), 0, 0, 0, 0, 
+                                                "Hide pulldown menus");
+       }
+       uiBlockSetEmboss(block, UI_EMBOSS);
+       xco+=XIC;
+       
+       if((sa->flag & HEADER_NO_PULLDOWN)==0) {
+               int xmax;
+               
+               /* pull down menus */
+               uiBlockSetEmboss(block, UI_EMBOSSP);
+               
+               xmax= GetButStringLength("View");
+               uiDefPulldownBut(block, dummy_viewmenu, C->area, 
+                                                "View", xco, yco-2, xmax-3, 24, "");
+               xco+=XIC+xmax;
+       }
+       
+       uiBlockSetEmboss(block, UI_EMBOSS);
+
+       /* always as last  */
+       sa->headbutlen= xco+XIC+80; // +80 because the last button is not an icon
+       
+       uiEndBlock(C, block);
+       uiDrawBlock(block);
+}
+
+
diff --git a/source/blender/editors/space_file/space_file.c b/source/blender/editors/space_file/space_file.c
new file mode 100644 (file)
index 0000000..9a7ffe7
--- /dev/null
@@ -0,0 +1,236 @@
+/**
+ * $Id:
+ *
+ * ***** BEGIN GPL LICENSE BLOCK *****
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License
+ * as published by the Free Software Foundation; either version 2
+ * of the License, or (at your option) any later version. 
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software Foundation,
+ * Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
+ *
+ * The Original Code is Copyright (C) 2008 Blender Foundation.
+ * All rights reserved.
+ *
+ * 
+ * Contributor(s): Blender Foundation
+ *
+ * ***** END GPL LICENSE BLOCK *****
+ */
+
+#include <string.h>
+#include <stdio.h>
+
+#include "DNA_image_types.h"
+#include "DNA_object_types.h"
+#include "DNA_space_types.h"
+#include "DNA_scene_types.h"
+#include "DNA_screen_types.h"
+
+#include "MEM_guardedalloc.h"
+
+#include "BLI_blenlib.h"
+#include "BLI_arithb.h"
+#include "BLI_rand.h"
+
+#include "BKE_colortools.h"
+#include "BKE_global.h"
+#include "BKE_screen.h"
+
+#include "ED_space_api.h"
+#include "ED_screen.h"
+
+#include "BIF_gl.h"
+
+#include "WM_api.h"
+#include "WM_types.h"
+
+#include "UI_interface.h"
+#include "UI_resources.h"
+#include "UI_view2d.h"
+
+
+/* ******************** default callbacks for image space ***************** */
+
+static SpaceLink *file_new(void)
+{
+       ARegion *ar;
+       SpaceFile *sfile;
+       
+       sfile= MEM_callocN(sizeof(SpaceImage), "initimage");
+       sfile->spacetype= SPACE_FILE;
+       
+       /* XXX init cleaned up file space */
+       
+       /* header */
+       ar= MEM_callocN(sizeof(ARegion), "header for file");
+       
+       BLI_addtail(&sfile->regionbase, ar);
+       ar->regiontype= RGN_TYPE_HEADER;
+       ar->alignment= RGN_ALIGN_BOTTOM;
+       UI_view2d_header_default(&ar->v2d);
+       
+       /* main area */
+       ar= MEM_callocN(sizeof(ARegion), "main area for file");
+       
+       BLI_addtail(&sfile->regionbase, ar);
+       ar->regiontype= RGN_TYPE_WINDOW;
+       
+       /* bookmark region XXX */
+
+       /* button region XXX */
+       
+       return (SpaceLink *)sfile;
+}
+
+/* not spacelink itself */
+static void file_free(SpaceLink *sl)
+{      
+       SpaceFile *sfile= (SpaceFile*) sl;
+       
+       /* XXX free necessary items */
+       
+}
+
+
+/* spacetype; init callback */
+static void file_init(struct wmWindowManager *wm, ScrArea *sa)
+{
+
+}
+
+static SpaceLink *file_duplicate(SpaceLink *sl)
+{
+       SpaceImage *file_dup= MEM_dupallocN(sl);
+       
+       /* clear or remove stuff from old */
+       
+       return (SpaceLink *)file_dup;
+}
+
+
+
+/* add handlers, stuff you only do once or on area/region changes */
+static void file_main_area_init(wmWindowManager *wm, ARegion *ar)
+{
+       ListBase *keymap;
+       
+       UI_view2d_size_update(&ar->v2d, ar->winx, ar->winy);
+       
+       /* own keymap */
+       keymap= WM_keymap_listbase(wm, "Image", SPACE_IMAGE, 0);        /* XXX weak? */
+       WM_event_add_keymap_handler_bb(&ar->handlers, keymap, &ar->v2d.mask, &ar->winrct);
+}
+
+static void file_main_area_draw(const bContext *C, ARegion *ar)
+{
+       /* draw entirely, view changes should be handled here */
+       // SpaceImage *simage= C->area->spacedata.first;
+       View2D *v2d= &ar->v2d;
+       float col[3];
+       
+       /* clear and setup matrix */
+       UI_GetThemeColor3fv(TH_BACK, col);
+       glClearColor(col[0], col[1], col[2], 0.0);
+       glClear(GL_COLOR_BUFFER_BIT);
+       
+       UI_view2d_view_ortho(C, v2d);
+               
+       /* data... */
+       
+       
+       /* reset view matrix */
+       UI_view2d_view_restore(C);
+       
+       /* scrollers? */
+}
+
+void file_operatortypes(void)
+{
+       
+}
+
+void file_keymap(struct wmWindowManager *wm)
+{
+       
+}
+
+/* add handlers, stuff you only do once or on area/region changes */
+static void file_header_area_init(wmWindowManager *wm, ARegion *ar)
+{
+       UI_view2d_size_update(&ar->v2d, ar->winx, ar->winy);
+}
+
+static void file_header_area_draw(const bContext *C, ARegion *ar)
+{
+       float col[3];
+       
+       /* clear */
+       if(ED_screen_area_active(C))
+               UI_GetThemeColor3fv(TH_HEADER, col);
+       else
+               UI_GetThemeColor3fv(TH_HEADERDESEL, col);
+       
+       glClearColor(col[0], col[1], col[2], 0.0);
+       glClear(GL_COLOR_BUFFER_BIT);
+       
+       /* set view2d view matrix for scrolling (without scrollers) */
+       UI_view2d_view_ortho(C, &ar->v2d);
+       
+       file_header_buttons(C, ar);
+       
+       /* restore view matrix? */
+       UI_view2d_view_restore(C);
+}
+
+static void file_main_area_listener(ARegion *ar, wmNotifier *wmn)
+{
+       /* context changes */
+}
+
+/* only called once, from space/spacetypes.c */
+void ED_spacetype_file(void)
+{
+       SpaceType *st= MEM_callocN(sizeof(SpaceType), "spacetype file");
+       ARegionType *art;
+       
+       st->spaceid= SPACE_FILE;
+       
+       st->new= file_new;
+       st->free= file_free;
+       st->init= file_init;
+       st->duplicate= file_duplicate;
+       st->operatortypes= file_operatortypes;
+       st->keymap= file_keymap;
+       
+       /* regions: main window */
+       art= MEM_callocN(sizeof(ARegionType), "spacetype file region");
+       art->regionid = RGN_TYPE_WINDOW;
+       art->init= file_main_area_init;
+       art->draw= file_main_area_draw;
+       art->listener= file_main_area_listener;
+       art->keymapflag= ED_KEYMAP_VIEW2D;
+
+       BLI_addhead(&st->regiontypes, art);
+       
+       /* regions: header */
+       art= MEM_callocN(sizeof(ARegionType), "spacetype file region");
+       art->regionid = RGN_TYPE_HEADER;
+       art->init= file_header_area_init;
+       art->draw= file_header_area_draw;
+       art->minsizey= HEADERY;
+       art->keymapflag= ED_KEYMAP_UI|ED_KEYMAP_VIEW2D; 
+       
+       BLI_addhead(&st->regiontypes, art);
+
+       BKE_spacetype_register(st);
+}
+