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_file/space_file.c')
-rw-r--r--source/blender/editors/space_file/space_file.c1024
1 files changed, 517 insertions, 507 deletions
diff --git a/source/blender/editors/space_file/space_file.c b/source/blender/editors/space_file/space_file.c
index 5a4b0e36ae1..53bcf7068f4 100644
--- a/source/blender/editors/space_file/space_file.c
+++ b/source/blender/editors/space_file/space_file.c
@@ -26,11 +26,9 @@
#include "MEM_guardedalloc.h"
-
#include "BLI_blenlib.h"
#include "BLI_utildefines.h"
-
#include "BKE_appdir.h"
#include "BKE_context.h"
#include "BKE_screen.h"
@@ -52,8 +50,7 @@
#include "UI_resources.h"
#include "UI_view2d.h"
-
-#include "file_intern.h" // own include
+#include "file_intern.h" // own include
#include "fsmenu.h"
#include "filelist.h"
#include "GPU_framebuffer.h"
@@ -62,653 +59,666 @@
static SpaceLink *file_new(const ScrArea *UNUSED(area), const Scene *UNUSED(scene))
{
- ARegion *ar;
- SpaceFile *sfile;
-
- sfile = MEM_callocN(sizeof(SpaceFile), "initfile");
- sfile->spacetype = SPACE_FILE;
-
- /* header */
- ar = MEM_callocN(sizeof(ARegion), "header for file");
- BLI_addtail(&sfile->regionbase, ar);
- ar->regiontype = RGN_TYPE_HEADER;
- /* Ignore user preference "USER_HEADER_BOTTOM" here (always show top for new types). */
- ar->alignment = RGN_ALIGN_TOP;
-
- /* Tools region */
- ar = MEM_callocN(sizeof(ARegion), "tools region for file");
- BLI_addtail(&sfile->regionbase, ar);
- ar->regiontype = RGN_TYPE_TOOLS;
- ar->alignment = RGN_ALIGN_LEFT;
-
- /* Tool props (aka operator) region */
- ar = MEM_callocN(sizeof(ARegion), "tool props region for file");
- BLI_addtail(&sfile->regionbase, ar);
- ar->regiontype = RGN_TYPE_TOOL_PROPS;
- ar->alignment = RGN_ALIGN_BOTTOM | RGN_SPLIT_PREV;
-
- /* ui list region */
- ar = MEM_callocN(sizeof(ARegion), "ui region for file");
- BLI_addtail(&sfile->regionbase, ar);
- ar->regiontype = RGN_TYPE_UI;
- ar->alignment = RGN_ALIGN_TOP;
-
- /* main region */
- ar = MEM_callocN(sizeof(ARegion), "main region for file");
- BLI_addtail(&sfile->regionbase, ar);
- ar->regiontype = RGN_TYPE_WINDOW;
- ar->v2d.scroll = (V2D_SCROLL_RIGHT | V2D_SCROLL_BOTTOM);
- ar->v2d.align = (V2D_ALIGN_NO_NEG_X | V2D_ALIGN_NO_POS_Y);
- ar->v2d.keepzoom = (V2D_LOCKZOOM_X | V2D_LOCKZOOM_Y | V2D_LIMITZOOM | V2D_KEEPASPECT);
- ar->v2d.keeptot = V2D_KEEPTOT_STRICT;
- ar->v2d.minzoom = ar->v2d.maxzoom = 1.0f;
-
- return (SpaceLink *)sfile;
+ ARegion *ar;
+ SpaceFile *sfile;
+
+ sfile = MEM_callocN(sizeof(SpaceFile), "initfile");
+ sfile->spacetype = SPACE_FILE;
+
+ /* header */
+ ar = MEM_callocN(sizeof(ARegion), "header for file");
+ BLI_addtail(&sfile->regionbase, ar);
+ ar->regiontype = RGN_TYPE_HEADER;
+ /* Ignore user preference "USER_HEADER_BOTTOM" here (always show top for new types). */
+ ar->alignment = RGN_ALIGN_TOP;
+
+ /* Tools region */
+ ar = MEM_callocN(sizeof(ARegion), "tools region for file");
+ BLI_addtail(&sfile->regionbase, ar);
+ ar->regiontype = RGN_TYPE_TOOLS;
+ ar->alignment = RGN_ALIGN_LEFT;
+
+ /* Tool props (aka operator) region */
+ ar = MEM_callocN(sizeof(ARegion), "tool props region for file");
+ BLI_addtail(&sfile->regionbase, ar);
+ ar->regiontype = RGN_TYPE_TOOL_PROPS;
+ ar->alignment = RGN_ALIGN_BOTTOM | RGN_SPLIT_PREV;
+
+ /* ui list region */
+ ar = MEM_callocN(sizeof(ARegion), "ui region for file");
+ BLI_addtail(&sfile->regionbase, ar);
+ ar->regiontype = RGN_TYPE_UI;
+ ar->alignment = RGN_ALIGN_TOP;
+
+ /* main region */
+ ar = MEM_callocN(sizeof(ARegion), "main region for file");
+ BLI_addtail(&sfile->regionbase, ar);
+ ar->regiontype = RGN_TYPE_WINDOW;
+ ar->v2d.scroll = (V2D_SCROLL_RIGHT | V2D_SCROLL_BOTTOM);
+ ar->v2d.align = (V2D_ALIGN_NO_NEG_X | V2D_ALIGN_NO_POS_Y);
+ ar->v2d.keepzoom = (V2D_LOCKZOOM_X | V2D_LOCKZOOM_Y | V2D_LIMITZOOM | V2D_KEEPASPECT);
+ ar->v2d.keeptot = V2D_KEEPTOT_STRICT;
+ ar->v2d.minzoom = ar->v2d.maxzoom = 1.0f;
+
+ return (SpaceLink *)sfile;
}
/* not spacelink itself */
static void file_free(SpaceLink *sl)
{
- SpaceFile *sfile = (SpaceFile *) sl;
-
- BLI_assert(sfile->previews_timer == NULL);
-
- if (sfile->files) {
- // XXXXX would need to do thumbnails_stop here, but no context available
- filelist_freelib(sfile->files);
- filelist_free(sfile->files);
- MEM_freeN(sfile->files);
- sfile->files = NULL;
- }
-
- if (sfile->folders_prev) {
- folderlist_free(sfile->folders_prev);
- MEM_freeN(sfile->folders_prev);
- sfile->folders_prev = NULL;
- }
-
- if (sfile->folders_next) {
- folderlist_free(sfile->folders_next);
- MEM_freeN(sfile->folders_next);
- sfile->folders_next = NULL;
- }
-
- if (sfile->params) {
- MEM_freeN(sfile->params);
- sfile->params = NULL;
- }
-
- if (sfile->layout) {
- MEM_freeN(sfile->layout);
- sfile->layout = NULL;
- }
+ SpaceFile *sfile = (SpaceFile *)sl;
+
+ BLI_assert(sfile->previews_timer == NULL);
+
+ if (sfile->files) {
+ // XXXXX would need to do thumbnails_stop here, but no context available
+ filelist_freelib(sfile->files);
+ filelist_free(sfile->files);
+ MEM_freeN(sfile->files);
+ sfile->files = NULL;
+ }
+
+ if (sfile->folders_prev) {
+ folderlist_free(sfile->folders_prev);
+ MEM_freeN(sfile->folders_prev);
+ sfile->folders_prev = NULL;
+ }
+
+ if (sfile->folders_next) {
+ folderlist_free(sfile->folders_next);
+ MEM_freeN(sfile->folders_next);
+ sfile->folders_next = NULL;
+ }
+
+ if (sfile->params) {
+ MEM_freeN(sfile->params);
+ sfile->params = NULL;
+ }
+
+ if (sfile->layout) {
+ MEM_freeN(sfile->layout);
+ sfile->layout = NULL;
+ }
}
-
/* spacetype; init callback, area size changes, screen set, etc */
static void file_init(wmWindowManager *UNUSED(wm), ScrArea *sa)
{
- SpaceFile *sfile = (SpaceFile *)sa->spacedata.first;
+ SpaceFile *sfile = (SpaceFile *)sa->spacedata.first;
- /* refresh system directory list */
- fsmenu_refresh_system_category(ED_fsmenu_get());
+ /* refresh system directory list */
+ fsmenu_refresh_system_category(ED_fsmenu_get());
- /* Update bookmarks 'valid' state.
- * Done here, because it seems BLI_is_dir() can have huge impact on performances
- * in some cases, on win systems... See T43684.
- */
- fsmenu_refresh_bookmarks_status(ED_fsmenu_get());
+ /* Update bookmarks 'valid' state.
+ * Done here, because it seems BLI_is_dir() can have huge impact on performances
+ * in some cases, on win systems... See T43684.
+ */
+ fsmenu_refresh_bookmarks_status(ED_fsmenu_get());
- if (sfile->layout) sfile->layout->dirty = true;
+ if (sfile->layout)
+ sfile->layout->dirty = true;
}
static void file_exit(wmWindowManager *wm, ScrArea *sa)
{
- SpaceFile *sfile = (SpaceFile *)sa->spacedata.first;
+ SpaceFile *sfile = (SpaceFile *)sa->spacedata.first;
- if (sfile->previews_timer) {
- WM_event_remove_timer_notifier(wm, NULL, sfile->previews_timer);
- sfile->previews_timer = NULL;
- }
+ if (sfile->previews_timer) {
+ WM_event_remove_timer_notifier(wm, NULL, sfile->previews_timer);
+ sfile->previews_timer = NULL;
+ }
- ED_fileselect_exit(wm, sa, sfile);
+ ED_fileselect_exit(wm, sa, sfile);
}
static SpaceLink *file_duplicate(SpaceLink *sl)
{
- SpaceFile *sfileo = (SpaceFile *)sl;
- SpaceFile *sfilen = MEM_dupallocN(sl);
+ SpaceFile *sfileo = (SpaceFile *)sl;
+ SpaceFile *sfilen = MEM_dupallocN(sl);
- /* clear or remove stuff from old */
- sfilen->op = NULL; /* file window doesn't own operators */
+ /* clear or remove stuff from old */
+ sfilen->op = NULL; /* file window doesn't own operators */
- sfilen->previews_timer = NULL;
- sfilen->smoothscroll_timer = NULL;
+ sfilen->previews_timer = NULL;
+ sfilen->smoothscroll_timer = NULL;
- if (sfileo->params) {
- sfilen->files = filelist_new(sfileo->params->type);
- sfilen->params = MEM_dupallocN(sfileo->params);
- filelist_setdir(sfilen->files, sfilen->params->dir);
- }
+ if (sfileo->params) {
+ sfilen->files = filelist_new(sfileo->params->type);
+ sfilen->params = MEM_dupallocN(sfileo->params);
+ filelist_setdir(sfilen->files, sfilen->params->dir);
+ }
- if (sfileo->folders_prev)
- sfilen->folders_prev = folderlist_duplicate(sfileo->folders_prev);
+ if (sfileo->folders_prev)
+ sfilen->folders_prev = folderlist_duplicate(sfileo->folders_prev);
- if (sfileo->folders_next)
- sfilen->folders_next = folderlist_duplicate(sfileo->folders_next);
+ if (sfileo->folders_next)
+ sfilen->folders_next = folderlist_duplicate(sfileo->folders_next);
- if (sfileo->layout) {
- sfilen->layout = MEM_dupallocN(sfileo->layout);
- }
- return (SpaceLink *)sfilen;
+ if (sfileo->layout) {
+ sfilen->layout = MEM_dupallocN(sfileo->layout);
+ }
+ return (SpaceLink *)sfilen;
}
static void file_refresh(const bContext *C, ScrArea *sa)
{
- wmWindowManager *wm = CTX_wm_manager(C);
- SpaceFile *sfile = CTX_wm_space_file(C);
- FileSelectParams *params = ED_fileselect_get_params(sfile);
- struct FSMenu *fsmenu = ED_fsmenu_get();
-
- if (!sfile->folders_prev) {
- sfile->folders_prev = folderlist_new();
- }
- if (!sfile->files) {
- sfile->files = filelist_new(params->type);
- params->highlight_file = -1; /* added this so it opens nicer (ton) */
- }
- filelist_setdir(sfile->files, params->dir);
- filelist_setrecursion(sfile->files, params->recursion_level);
- filelist_setsorting(sfile->files, params->sort);
- filelist_setfilter_options(sfile->files, (params->flag & FILE_FILTER) != 0,
- (params->flag & FILE_HIDE_DOT) != 0,
- false, /* TODO hide_parent, should be controllable? */
- params->filter,
- params->filter_id,
- params->filter_glob,
- params->filter_search);
-
- /* Update the active indices of bookmarks & co. */
- sfile->systemnr = fsmenu_get_active_indices(fsmenu, FS_CATEGORY_SYSTEM, params->dir);
- sfile->system_bookmarknr = fsmenu_get_active_indices(fsmenu, FS_CATEGORY_SYSTEM_BOOKMARKS, params->dir);
- sfile->bookmarknr = fsmenu_get_active_indices(fsmenu, FS_CATEGORY_BOOKMARKS, params->dir);
- sfile->recentnr = fsmenu_get_active_indices(fsmenu, FS_CATEGORY_RECENT, params->dir);
-
- if (filelist_force_reset(sfile->files)) {
- filelist_readjob_stop(wm, sa);
- filelist_clear(sfile->files);
- }
-
- if (filelist_empty(sfile->files)) {
- if (!filelist_pending(sfile->files)) {
- filelist_readjob_start(sfile->files, C);
- }
- }
-
- filelist_sort(sfile->files);
- filelist_filter(sfile->files);
-
- if (params->display == FILE_IMGDISPLAY) {
- filelist_cache_previews_set(sfile->files, true);
- }
- else {
- filelist_cache_previews_set(sfile->files, false);
- if (sfile->previews_timer) {
- WM_event_remove_timer_notifier(wm, CTX_wm_window(C), sfile->previews_timer);
- sfile->previews_timer = NULL;
- }
- }
-
- if (params->rename_flag != 0) {
- file_params_renamefile_activate(sfile, params);
- }
-
- if (sfile->layout) {
- sfile->layout->dirty = true;
- }
-
- /* Might be called with NULL sa, see file_main_region_draw() below. */
- if (sa && BKE_area_find_region_type(sa, RGN_TYPE_TOOLS) == NULL) {
- /* Create TOOLS/TOOL_PROPS regions. */
- file_tools_region(sa);
-
- ED_area_initialize(wm, CTX_wm_window(C), sa);
- }
-
- ED_area_tag_redraw(sa);
+ wmWindowManager *wm = CTX_wm_manager(C);
+ SpaceFile *sfile = CTX_wm_space_file(C);
+ FileSelectParams *params = ED_fileselect_get_params(sfile);
+ struct FSMenu *fsmenu = ED_fsmenu_get();
+
+ if (!sfile->folders_prev) {
+ sfile->folders_prev = folderlist_new();
+ }
+ if (!sfile->files) {
+ sfile->files = filelist_new(params->type);
+ params->highlight_file = -1; /* added this so it opens nicer (ton) */
+ }
+ filelist_setdir(sfile->files, params->dir);
+ filelist_setrecursion(sfile->files, params->recursion_level);
+ filelist_setsorting(sfile->files, params->sort);
+ filelist_setfilter_options(sfile->files,
+ (params->flag & FILE_FILTER) != 0,
+ (params->flag & FILE_HIDE_DOT) != 0,
+ false, /* TODO hide_parent, should be controllable? */
+ params->filter,
+ params->filter_id,
+ params->filter_glob,
+ params->filter_search);
+
+ /* Update the active indices of bookmarks & co. */
+ sfile->systemnr = fsmenu_get_active_indices(fsmenu, FS_CATEGORY_SYSTEM, params->dir);
+ sfile->system_bookmarknr = fsmenu_get_active_indices(
+ fsmenu, FS_CATEGORY_SYSTEM_BOOKMARKS, params->dir);
+ sfile->bookmarknr = fsmenu_get_active_indices(fsmenu, FS_CATEGORY_BOOKMARKS, params->dir);
+ sfile->recentnr = fsmenu_get_active_indices(fsmenu, FS_CATEGORY_RECENT, params->dir);
+
+ if (filelist_force_reset(sfile->files)) {
+ filelist_readjob_stop(wm, sa);
+ filelist_clear(sfile->files);
+ }
+
+ if (filelist_empty(sfile->files)) {
+ if (!filelist_pending(sfile->files)) {
+ filelist_readjob_start(sfile->files, C);
+ }
+ }
+
+ filelist_sort(sfile->files);
+ filelist_filter(sfile->files);
+
+ if (params->display == FILE_IMGDISPLAY) {
+ filelist_cache_previews_set(sfile->files, true);
+ }
+ else {
+ filelist_cache_previews_set(sfile->files, false);
+ if (sfile->previews_timer) {
+ WM_event_remove_timer_notifier(wm, CTX_wm_window(C), sfile->previews_timer);
+ sfile->previews_timer = NULL;
+ }
+ }
+
+ if (params->rename_flag != 0) {
+ file_params_renamefile_activate(sfile, params);
+ }
+
+ if (sfile->layout) {
+ sfile->layout->dirty = true;
+ }
+
+ /* Might be called with NULL sa, see file_main_region_draw() below. */
+ if (sa && BKE_area_find_region_type(sa, RGN_TYPE_TOOLS) == NULL) {
+ /* Create TOOLS/TOOL_PROPS regions. */
+ file_tools_region(sa);
+
+ ED_area_initialize(wm, CTX_wm_window(C), sa);
+ }
+
+ ED_area_tag_redraw(sa);
}
-static void file_listener(wmWindow *UNUSED(win), ScrArea *sa, wmNotifier *wmn, Scene *UNUSED(scene))
+static void file_listener(wmWindow *UNUSED(win),
+ ScrArea *sa,
+ wmNotifier *wmn,
+ Scene *UNUSED(scene))
{
- SpaceFile *sfile = (SpaceFile *)sa->spacedata.first;
-
- /* context changes */
- switch (wmn->category) {
- case NC_SPACE:
- switch (wmn->data) {
- case ND_SPACE_FILE_LIST:
- ED_area_tag_refresh(sa);
- break;
- case ND_SPACE_FILE_PARAMS:
- ED_area_tag_refresh(sa);
- break;
- case ND_SPACE_FILE_PREVIEW:
- if (sfile->files && filelist_cache_previews_update(sfile->files)) {
- ED_area_tag_refresh(sa);
- }
- break;
- }
- break;
- }
+ SpaceFile *sfile = (SpaceFile *)sa->spacedata.first;
+
+ /* context changes */
+ switch (wmn->category) {
+ case NC_SPACE:
+ switch (wmn->data) {
+ case ND_SPACE_FILE_LIST:
+ ED_area_tag_refresh(sa);
+ break;
+ case ND_SPACE_FILE_PARAMS:
+ ED_area_tag_refresh(sa);
+ break;
+ case ND_SPACE_FILE_PREVIEW:
+ if (sfile->files && filelist_cache_previews_update(sfile->files)) {
+ ED_area_tag_refresh(sa);
+ }
+ break;
+ }
+ break;
+ }
}
/* add handlers, stuff you only do once or on area/region changes */
static void file_main_region_init(wmWindowManager *wm, ARegion *ar)
{
- wmKeyMap *keymap;
+ wmKeyMap *keymap;
- UI_view2d_region_reinit(&ar->v2d, V2D_COMMONVIEW_LIST, ar->winx, ar->winy);
+ UI_view2d_region_reinit(&ar->v2d, V2D_COMMONVIEW_LIST, ar->winx, ar->winy);
- /* own keymaps */
- keymap = WM_keymap_ensure(wm->defaultconf, "File Browser", SPACE_FILE, 0);
- WM_event_add_keymap_handler_bb(&ar->handlers, keymap, &ar->v2d.mask, &ar->winrct);
+ /* own keymaps */
+ keymap = WM_keymap_ensure(wm->defaultconf, "File Browser", SPACE_FILE, 0);
+ WM_event_add_keymap_handler_bb(&ar->handlers, keymap, &ar->v2d.mask, &ar->winrct);
- keymap = WM_keymap_ensure(wm->defaultconf, "File Browser Main", SPACE_FILE, 0);
- WM_event_add_keymap_handler_bb(&ar->handlers, keymap, &ar->v2d.mask, &ar->winrct);
+ keymap = WM_keymap_ensure(wm->defaultconf, "File Browser Main", SPACE_FILE, 0);
+ WM_event_add_keymap_handler_bb(&ar->handlers, keymap, &ar->v2d.mask, &ar->winrct);
}
-static void file_main_region_listener(
- wmWindow *UNUSED(win), ScrArea *UNUSED(sa), ARegion *ar,
- wmNotifier *wmn, const Scene *UNUSED(scene))
+static void file_main_region_listener(wmWindow *UNUSED(win),
+ ScrArea *UNUSED(sa),
+ ARegion *ar,
+ wmNotifier *wmn,
+ const Scene *UNUSED(scene))
{
- /* context changes */
- switch (wmn->category) {
- case NC_SPACE:
- switch (wmn->data) {
- case ND_SPACE_FILE_LIST:
- ED_region_tag_redraw(ar);
- break;
- case ND_SPACE_FILE_PARAMS:
- ED_region_tag_redraw(ar);
- break;
- }
- break;
- }
+ /* context changes */
+ switch (wmn->category) {
+ case NC_SPACE:
+ switch (wmn->data) {
+ case ND_SPACE_FILE_LIST:
+ ED_region_tag_redraw(ar);
+ break;
+ case ND_SPACE_FILE_PARAMS:
+ ED_region_tag_redraw(ar);
+ break;
+ }
+ break;
+ }
}
-static void file_main_region_message_subscribe(
- const struct bContext *UNUSED(C),
- struct WorkSpace *UNUSED(workspace), struct Scene *UNUSED(scene),
- struct bScreen *screen, struct ScrArea *sa, struct ARegion *ar,
- struct wmMsgBus *mbus)
+static void file_main_region_message_subscribe(const struct bContext *UNUSED(C),
+ struct WorkSpace *UNUSED(workspace),
+ struct Scene *UNUSED(scene),
+ struct bScreen *screen,
+ struct ScrArea *sa,
+ struct ARegion *ar,
+ struct wmMsgBus *mbus)
{
- SpaceFile *sfile = sa->spacedata.first;
- FileSelectParams *params = ED_fileselect_get_params(sfile);
- /* This is a bit odd that a region owns the subscriber for an area,
- * keep for now since all subscribers for WM are regions.
- * May be worth re-visiting later. */
- wmMsgSubscribeValue msg_sub_value_area_tag_refresh = {
- .owner = ar,
- .user_data = sa,
- .notify = ED_area_do_msg_notify_tag_refresh,
- };
-
- /* SpaceFile itself. */
- {
- PointerRNA ptr;
- RNA_pointer_create(&screen->id, &RNA_SpaceFileBrowser, sfile, &ptr);
-
- /* All properties for this space type. */
- WM_msg_subscribe_rna(mbus, &ptr, NULL, &msg_sub_value_area_tag_refresh, __func__);
- }
-
- /* FileSelectParams */
- {
- PointerRNA ptr;
- RNA_pointer_create(&screen->id, &RNA_FileSelectParams, params, &ptr);
-
- /* All properties for this space type. */
- WM_msg_subscribe_rna(mbus, &ptr, NULL, &msg_sub_value_area_tag_refresh, __func__);
- }
+ SpaceFile *sfile = sa->spacedata.first;
+ FileSelectParams *params = ED_fileselect_get_params(sfile);
+ /* This is a bit odd that a region owns the subscriber for an area,
+ * keep for now since all subscribers for WM are regions.
+ * May be worth re-visiting later. */
+ wmMsgSubscribeValue msg_sub_value_area_tag_refresh = {
+ .owner = ar,
+ .user_data = sa,
+ .notify = ED_area_do_msg_notify_tag_refresh,
+ };
+
+ /* SpaceFile itself. */
+ {
+ PointerRNA ptr;
+ RNA_pointer_create(&screen->id, &RNA_SpaceFileBrowser, sfile, &ptr);
+
+ /* All properties for this space type. */
+ WM_msg_subscribe_rna(mbus, &ptr, NULL, &msg_sub_value_area_tag_refresh, __func__);
+ }
+
+ /* FileSelectParams */
+ {
+ PointerRNA ptr;
+ RNA_pointer_create(&screen->id, &RNA_FileSelectParams, params, &ptr);
+
+ /* All properties for this space type. */
+ WM_msg_subscribe_rna(mbus, &ptr, NULL, &msg_sub_value_area_tag_refresh, __func__);
+ }
}
static void file_main_region_draw(const bContext *C, ARegion *ar)
{
- /* draw entirely, view changes should be handled here */
- SpaceFile *sfile = CTX_wm_space_file(C);
- FileSelectParams *params = ED_fileselect_get_params(sfile);
-
- View2D *v2d = &ar->v2d;
- View2DScrollers *scrollers;
- float col[3];
-
- /* Needed, because filelist is not initialized on loading */
- if (!sfile->files || filelist_empty(sfile->files))
- file_refresh(C, NULL);
-
- /* clear and setup matrix */
- UI_GetThemeColor3fv(TH_BACK, col);
- GPU_clear_color(col[0], col[1], col[2], 0.0);
- GPU_clear(GPU_COLOR_BIT);
-
- /* Allow dynamically sliders to be set, saves notifiers etc. */
-
- if (params->display == FILE_IMGDISPLAY) {
- v2d->scroll = V2D_SCROLL_RIGHT;
- v2d->keepofs &= ~V2D_LOCKOFS_Y;
- v2d->keepofs |= V2D_LOCKOFS_X;
- }
- else {
- v2d->scroll = V2D_SCROLL_BOTTOM;
- v2d->keepofs &= ~V2D_LOCKOFS_X;
- v2d->keepofs |= V2D_LOCKOFS_Y;
-
- /* XXX this happens on scaling down Screen (like from startup.blend) */
- /* view2d has no type specific for filewindow case, which doesn't scroll vertically */
- if (v2d->cur.ymax < 0) {
- v2d->cur.ymin -= v2d->cur.ymax;
- v2d->cur.ymax = 0;
- }
- }
- /* v2d has initialized flag, so this call will only set the mask correct */
- UI_view2d_region_reinit(v2d, V2D_COMMONVIEW_LIST, ar->winx, ar->winy);
-
- /* sets tile/border settings in sfile */
- file_calc_previews(C, ar);
-
- /* set view */
- UI_view2d_view_ortho(v2d);
-
- /* on first read, find active file */
- if (params->highlight_file == -1) {
- wmEvent *event = CTX_wm_window(C)->eventstate;
- file_highlight_set(sfile, ar, event->x, event->y);
- }
-
- file_draw_list(C, ar);
-
- /* reset view matrix */
- UI_view2d_view_restore(C);
-
- /* scrollers */
- scrollers = UI_view2d_scrollers_calc(C, v2d, NULL, V2D_ARG_DUMMY, V2D_ARG_DUMMY, V2D_ARG_DUMMY, V2D_ARG_DUMMY);
- UI_view2d_scrollers_draw(C, v2d, scrollers);
- UI_view2d_scrollers_free(scrollers);
-
+ /* draw entirely, view changes should be handled here */
+ SpaceFile *sfile = CTX_wm_space_file(C);
+ FileSelectParams *params = ED_fileselect_get_params(sfile);
+
+ View2D *v2d = &ar->v2d;
+ View2DScrollers *scrollers;
+ float col[3];
+
+ /* Needed, because filelist is not initialized on loading */
+ if (!sfile->files || filelist_empty(sfile->files))
+ file_refresh(C, NULL);
+
+ /* clear and setup matrix */
+ UI_GetThemeColor3fv(TH_BACK, col);
+ GPU_clear_color(col[0], col[1], col[2], 0.0);
+ GPU_clear(GPU_COLOR_BIT);
+
+ /* Allow dynamically sliders to be set, saves notifiers etc. */
+
+ if (params->display == FILE_IMGDISPLAY) {
+ v2d->scroll = V2D_SCROLL_RIGHT;
+ v2d->keepofs &= ~V2D_LOCKOFS_Y;
+ v2d->keepofs |= V2D_LOCKOFS_X;
+ }
+ else {
+ v2d->scroll = V2D_SCROLL_BOTTOM;
+ v2d->keepofs &= ~V2D_LOCKOFS_X;
+ v2d->keepofs |= V2D_LOCKOFS_Y;
+
+ /* XXX this happens on scaling down Screen (like from startup.blend) */
+ /* view2d has no type specific for filewindow case, which doesn't scroll vertically */
+ if (v2d->cur.ymax < 0) {
+ v2d->cur.ymin -= v2d->cur.ymax;
+ v2d->cur.ymax = 0;
+ }
+ }
+ /* v2d has initialized flag, so this call will only set the mask correct */
+ UI_view2d_region_reinit(v2d, V2D_COMMONVIEW_LIST, ar->winx, ar->winy);
+
+ /* sets tile/border settings in sfile */
+ file_calc_previews(C, ar);
+
+ /* set view */
+ UI_view2d_view_ortho(v2d);
+
+ /* on first read, find active file */
+ if (params->highlight_file == -1) {
+ wmEvent *event = CTX_wm_window(C)->eventstate;
+ file_highlight_set(sfile, ar, event->x, event->y);
+ }
+
+ file_draw_list(C, ar);
+
+ /* reset view matrix */
+ UI_view2d_view_restore(C);
+
+ /* scrollers */
+ scrollers = UI_view2d_scrollers_calc(
+ C, v2d, NULL, V2D_ARG_DUMMY, V2D_ARG_DUMMY, V2D_ARG_DUMMY, V2D_ARG_DUMMY);
+ UI_view2d_scrollers_draw(C, v2d, scrollers);
+ UI_view2d_scrollers_free(scrollers);
}
static void file_operatortypes(void)
{
- WM_operatortype_append(FILE_OT_select);
- WM_operatortype_append(FILE_OT_select_walk);
- WM_operatortype_append(FILE_OT_select_all);
- WM_operatortype_append(FILE_OT_select_box);
- WM_operatortype_append(FILE_OT_select_bookmark);
- WM_operatortype_append(FILE_OT_highlight);
- WM_operatortype_append(FILE_OT_execute);
- WM_operatortype_append(FILE_OT_cancel);
- WM_operatortype_append(FILE_OT_parent);
- WM_operatortype_append(FILE_OT_previous);
- WM_operatortype_append(FILE_OT_next);
- WM_operatortype_append(FILE_OT_refresh);
- WM_operatortype_append(FILE_OT_bookmark_toggle);
- WM_operatortype_append(FILE_OT_bookmark_add);
- WM_operatortype_append(FILE_OT_bookmark_delete);
- WM_operatortype_append(FILE_OT_bookmark_cleanup);
- WM_operatortype_append(FILE_OT_bookmark_move);
- WM_operatortype_append(FILE_OT_reset_recent);
- WM_operatortype_append(FILE_OT_hidedot);
- WM_operatortype_append(FILE_OT_filenum);
- WM_operatortype_append(FILE_OT_directory_new);
- WM_operatortype_append(FILE_OT_delete);
- WM_operatortype_append(FILE_OT_rename);
- WM_operatortype_append(FILE_OT_smoothscroll);
- WM_operatortype_append(FILE_OT_filepath_drop);
+ WM_operatortype_append(FILE_OT_select);
+ WM_operatortype_append(FILE_OT_select_walk);
+ WM_operatortype_append(FILE_OT_select_all);
+ WM_operatortype_append(FILE_OT_select_box);
+ WM_operatortype_append(FILE_OT_select_bookmark);
+ WM_operatortype_append(FILE_OT_highlight);
+ WM_operatortype_append(FILE_OT_execute);
+ WM_operatortype_append(FILE_OT_cancel);
+ WM_operatortype_append(FILE_OT_parent);
+ WM_operatortype_append(FILE_OT_previous);
+ WM_operatortype_append(FILE_OT_next);
+ WM_operatortype_append(FILE_OT_refresh);
+ WM_operatortype_append(FILE_OT_bookmark_toggle);
+ WM_operatortype_append(FILE_OT_bookmark_add);
+ WM_operatortype_append(FILE_OT_bookmark_delete);
+ WM_operatortype_append(FILE_OT_bookmark_cleanup);
+ WM_operatortype_append(FILE_OT_bookmark_move);
+ WM_operatortype_append(FILE_OT_reset_recent);
+ WM_operatortype_append(FILE_OT_hidedot);
+ WM_operatortype_append(FILE_OT_filenum);
+ WM_operatortype_append(FILE_OT_directory_new);
+ WM_operatortype_append(FILE_OT_delete);
+ WM_operatortype_append(FILE_OT_rename);
+ WM_operatortype_append(FILE_OT_smoothscroll);
+ WM_operatortype_append(FILE_OT_filepath_drop);
}
/* NOTE: do not add .blend file reading on this level */
static void file_keymap(struct wmKeyConfig *keyconf)
{
- /* keys for all regions */
- WM_keymap_ensure(keyconf, "File Browser", SPACE_FILE, 0);
+ /* keys for all regions */
+ WM_keymap_ensure(keyconf, "File Browser", SPACE_FILE, 0);
- /* keys for main region */
- WM_keymap_ensure(keyconf, "File Browser Main", SPACE_FILE, 0);
+ /* keys for main region */
+ WM_keymap_ensure(keyconf, "File Browser Main", SPACE_FILE, 0);
- /* keys for button region (top) */
- WM_keymap_ensure(keyconf, "File Browser Buttons", SPACE_FILE, 0);
+ /* keys for button region (top) */
+ WM_keymap_ensure(keyconf, "File Browser Buttons", SPACE_FILE, 0);
}
-
static void file_tools_region_init(wmWindowManager *wm, ARegion *ar)
{
- wmKeyMap *keymap;
+ wmKeyMap *keymap;
- ar->v2d.scroll = V2D_SCROLL_RIGHT | V2D_SCROLL_VERTICAL_HIDE;
- ED_region_panels_init(wm, ar);
+ ar->v2d.scroll = V2D_SCROLL_RIGHT | V2D_SCROLL_VERTICAL_HIDE;
+ ED_region_panels_init(wm, ar);
- /* own keymaps */
- keymap = WM_keymap_ensure(wm->defaultconf, "File Browser", SPACE_FILE, 0);
- WM_event_add_keymap_handler_bb(&ar->handlers, keymap, &ar->v2d.mask, &ar->winrct);
+ /* own keymaps */
+ keymap = WM_keymap_ensure(wm->defaultconf, "File Browser", SPACE_FILE, 0);
+ WM_event_add_keymap_handler_bb(&ar->handlers, keymap, &ar->v2d.mask, &ar->winrct);
}
static void file_tools_region_draw(const bContext *C, ARegion *ar)
{
- ED_region_panels(C, ar);
+ ED_region_panels(C, ar);
}
-static void file_tools_region_listener(
- wmWindow *UNUSED(win), ScrArea *UNUSED(sa), ARegion *UNUSED(ar),
- wmNotifier *UNUSED(wmn), const Scene *UNUSED(scene))
+static void file_tools_region_listener(wmWindow *UNUSED(win),
+ ScrArea *UNUSED(sa),
+ ARegion *UNUSED(ar),
+ wmNotifier *UNUSED(wmn),
+ const Scene *UNUSED(scene))
{
#if 0
- /* context changes */
- switch (wmn->category) {
- /* pass */
- }
+ /* context changes */
+ switch (wmn->category) {
+ /* pass */
+ }
#endif
}
/* add handlers, stuff you only do once or on area/region changes */
static void file_header_region_init(wmWindowManager *wm, ARegion *ar)
{
- wmKeyMap *keymap;
+ wmKeyMap *keymap;
- ED_region_header_init(ar);
+ ED_region_header_init(ar);
- keymap = WM_keymap_ensure(wm->defaultconf, "File Browser", SPACE_FILE, 0);
- WM_event_add_keymap_handler_bb(&ar->handlers, keymap, &ar->v2d.mask, &ar->winrct);
+ keymap = WM_keymap_ensure(wm->defaultconf, "File Browser", SPACE_FILE, 0);
+ WM_event_add_keymap_handler_bb(&ar->handlers, keymap, &ar->v2d.mask, &ar->winrct);
}
static void file_header_region_draw(const bContext *C, ARegion *ar)
{
- ED_region_header(C, ar);
+ ED_region_header(C, ar);
}
/* add handlers, stuff you only do once or on area/region changes */
static void file_ui_region_init(wmWindowManager *wm, ARegion *ar)
{
- wmKeyMap *keymap;
+ wmKeyMap *keymap;
- UI_view2d_region_reinit(&ar->v2d, V2D_COMMONVIEW_HEADER, ar->winx, ar->winy);
+ UI_view2d_region_reinit(&ar->v2d, V2D_COMMONVIEW_HEADER, ar->winx, ar->winy);
- /* own keymap */
- keymap = WM_keymap_ensure(wm->defaultconf, "File Browser", SPACE_FILE, 0);
- WM_event_add_keymap_handler_bb(&ar->handlers, keymap, &ar->v2d.mask, &ar->winrct);
+ /* own keymap */
+ keymap = WM_keymap_ensure(wm->defaultconf, "File Browser", SPACE_FILE, 0);
+ WM_event_add_keymap_handler_bb(&ar->handlers, keymap, &ar->v2d.mask, &ar->winrct);
- keymap = WM_keymap_ensure(wm->defaultconf, "File Browser Buttons", SPACE_FILE, 0);
- WM_event_add_keymap_handler_bb(&ar->handlers, keymap, &ar->v2d.mask, &ar->winrct);
+ keymap = WM_keymap_ensure(wm->defaultconf, "File Browser Buttons", SPACE_FILE, 0);
+ WM_event_add_keymap_handler_bb(&ar->handlers, keymap, &ar->v2d.mask, &ar->winrct);
}
static void file_ui_region_draw(const bContext *C, ARegion *ar)
{
- float col[3];
- /* clear */
- UI_GetThemeColor3fv(TH_BACK, col);
- GPU_clear_color(col[0], col[1], col[2], 0.0);
- GPU_clear(GPU_COLOR_BIT);
+ float col[3];
+ /* clear */
+ UI_GetThemeColor3fv(TH_BACK, col);
+ GPU_clear_color(col[0], col[1], col[2], 0.0);
+ GPU_clear(GPU_COLOR_BIT);
- /* scrolling here is just annoying, disable it */
- ar->v2d.cur.ymax = BLI_rctf_size_y(&ar->v2d.cur);
- ar->v2d.cur.ymin = 0;
+ /* scrolling here is just annoying, disable it */
+ ar->v2d.cur.ymax = BLI_rctf_size_y(&ar->v2d.cur);
+ ar->v2d.cur.ymin = 0;
- /* set view2d view matrix for scrolling (without scrollers) */
- UI_view2d_view_ortho(&ar->v2d);
+ /* set view2d view matrix for scrolling (without scrollers) */
+ UI_view2d_view_ortho(&ar->v2d);
+ file_draw_buttons(C, ar);
- file_draw_buttons(C, ar);
-
- UI_view2d_view_restore(C);
+ UI_view2d_view_restore(C);
}
-static void file_ui_region_listener(
- wmWindow *UNUSED(win), ScrArea *UNUSED(sa), ARegion *ar,
- wmNotifier *wmn, const Scene *UNUSED(scene))
+static void file_ui_region_listener(wmWindow *UNUSED(win),
+ ScrArea *UNUSED(sa),
+ ARegion *ar,
+ wmNotifier *wmn,
+ const Scene *UNUSED(scene))
{
- /* context changes */
- switch (wmn->category) {
- case NC_SPACE:
- switch (wmn->data) {
- case ND_SPACE_FILE_LIST:
- ED_region_tag_redraw(ar);
- break;
- }
- break;
- }
+ /* context changes */
+ switch (wmn->category) {
+ case NC_SPACE:
+ switch (wmn->data) {
+ case ND_SPACE_FILE_LIST:
+ ED_region_tag_redraw(ar);
+ break;
+ }
+ break;
+ }
}
-static bool filepath_drop_poll(bContext *C, wmDrag *drag, const wmEvent *UNUSED(event), const char **UNUSED(tooltip))
+static bool filepath_drop_poll(bContext *C,
+ wmDrag *drag,
+ const wmEvent *UNUSED(event),
+ const char **UNUSED(tooltip))
{
- if (drag->type == WM_DRAG_PATH) {
- SpaceFile *sfile = CTX_wm_space_file(C);
- if (sfile) {
- return 1;
- }
- }
- return 0;
+ if (drag->type == WM_DRAG_PATH) {
+ SpaceFile *sfile = CTX_wm_space_file(C);
+ if (sfile) {
+ return 1;
+ }
+ }
+ return 0;
}
static void filepath_drop_copy(wmDrag *drag, wmDropBox *drop)
{
- RNA_string_set(drop->ptr, "filepath", drag->path);
+ RNA_string_set(drop->ptr, "filepath", drag->path);
}
/* region dropbox definition */
static void file_dropboxes(void)
{
- ListBase *lb = WM_dropboxmap_find("Window", SPACE_EMPTY, RGN_TYPE_WINDOW);
+ ListBase *lb = WM_dropboxmap_find("Window", SPACE_EMPTY, RGN_TYPE_WINDOW);
- WM_dropbox_add(lb, "FILE_OT_filepath_drop", filepath_drop_poll, filepath_drop_copy);
+ WM_dropbox_add(lb, "FILE_OT_filepath_drop", filepath_drop_poll, filepath_drop_copy);
}
/* 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;
- strncpy(st->name, "File", BKE_ST_MAXNAME);
-
- st->new = file_new;
- st->free = file_free;
- st->init = file_init;
- st->exit = file_exit;
- st->duplicate = file_duplicate;
- st->refresh = file_refresh;
- st->listener = file_listener;
- st->operatortypes = file_operatortypes;
- st->keymap = file_keymap;
- st->dropboxes = file_dropboxes;
-
- /* regions: main window */
- art = MEM_callocN(sizeof(ARegionType), "spacetype file region");
- art->regionid = RGN_TYPE_WINDOW;
- art->init = file_main_region_init;
- art->draw = file_main_region_draw;
- art->listener = file_main_region_listener;
- art->message_subscribe = file_main_region_message_subscribe;
- art->keymapflag = ED_KEYMAP_UI | ED_KEYMAP_VIEW2D;
- BLI_addhead(&st->regiontypes, art);
-
- /* regions: header */
- art = MEM_callocN(sizeof(ARegionType), "spacetype file region");
- art->regionid = RGN_TYPE_HEADER;
- art->prefsizey = HEADERY;
- art->keymapflag = ED_KEYMAP_UI | ED_KEYMAP_VIEW2D | ED_KEYMAP_HEADER;
- art->init = file_header_region_init;
- art->draw = file_header_region_draw;
- // art->listener = file_header_region_listener;
- BLI_addhead(&st->regiontypes, art);
-
- /* regions: ui */
- art = MEM_callocN(sizeof(ARegionType), "spacetype file region");
- art->regionid = RGN_TYPE_UI;
- art->prefsizey = 60;
- art->keymapflag = ED_KEYMAP_UI;
- art->listener = file_ui_region_listener;
- art->init = file_ui_region_init;
- art->draw = file_ui_region_draw;
- BLI_addhead(&st->regiontypes, art);
-
- /* regions: channels (directories) */
- art = MEM_callocN(sizeof(ARegionType), "spacetype file region");
- art->regionid = RGN_TYPE_TOOLS;
- art->prefsizex = 240;
- art->prefsizey = 60;
- art->keymapflag = ED_KEYMAP_UI;
- art->listener = file_tools_region_listener;
- art->init = file_tools_region_init;
- art->draw = file_tools_region_draw;
- BLI_addhead(&st->regiontypes, art);
-
- /* regions: tool properties */
- art = MEM_callocN(sizeof(ARegionType), "spacetype file operator region");
- art->regionid = RGN_TYPE_TOOL_PROPS;
- art->prefsizex = 0;
- art->prefsizey = 360;
- art->keymapflag = ED_KEYMAP_UI;
- art->listener = file_tools_region_listener;
- art->init = file_tools_region_init;
- art->draw = file_tools_region_draw;
- BLI_addhead(&st->regiontypes, art);
- file_panels_register(art);
-
- BKE_spacetype_register(st);
-
+ SpaceType *st = MEM_callocN(sizeof(SpaceType), "spacetype file");
+ ARegionType *art;
+
+ st->spaceid = SPACE_FILE;
+ strncpy(st->name, "File", BKE_ST_MAXNAME);
+
+ st->new = file_new;
+ st->free = file_free;
+ st->init = file_init;
+ st->exit = file_exit;
+ st->duplicate = file_duplicate;
+ st->refresh = file_refresh;
+ st->listener = file_listener;
+ st->operatortypes = file_operatortypes;
+ st->keymap = file_keymap;
+ st->dropboxes = file_dropboxes;
+
+ /* regions: main window */
+ art = MEM_callocN(sizeof(ARegionType), "spacetype file region");
+ art->regionid = RGN_TYPE_WINDOW;
+ art->init = file_main_region_init;
+ art->draw = file_main_region_draw;
+ art->listener = file_main_region_listener;
+ art->message_subscribe = file_main_region_message_subscribe;
+ art->keymapflag = ED_KEYMAP_UI | ED_KEYMAP_VIEW2D;
+ BLI_addhead(&st->regiontypes, art);
+
+ /* regions: header */
+ art = MEM_callocN(sizeof(ARegionType), "spacetype file region");
+ art->regionid = RGN_TYPE_HEADER;
+ art->prefsizey = HEADERY;
+ art->keymapflag = ED_KEYMAP_UI | ED_KEYMAP_VIEW2D | ED_KEYMAP_HEADER;
+ art->init = file_header_region_init;
+ art->draw = file_header_region_draw;
+ // art->listener = file_header_region_listener;
+ BLI_addhead(&st->regiontypes, art);
+
+ /* regions: ui */
+ art = MEM_callocN(sizeof(ARegionType), "spacetype file region");
+ art->regionid = RGN_TYPE_UI;
+ art->prefsizey = 60;
+ art->keymapflag = ED_KEYMAP_UI;
+ art->listener = file_ui_region_listener;
+ art->init = file_ui_region_init;
+ art->draw = file_ui_region_draw;
+ BLI_addhead(&st->regiontypes, art);
+
+ /* regions: channels (directories) */
+ art = MEM_callocN(sizeof(ARegionType), "spacetype file region");
+ art->regionid = RGN_TYPE_TOOLS;
+ art->prefsizex = 240;
+ art->prefsizey = 60;
+ art->keymapflag = ED_KEYMAP_UI;
+ art->listener = file_tools_region_listener;
+ art->init = file_tools_region_init;
+ art->draw = file_tools_region_draw;
+ BLI_addhead(&st->regiontypes, art);
+
+ /* regions: tool properties */
+ art = MEM_callocN(sizeof(ARegionType), "spacetype file operator region");
+ art->regionid = RGN_TYPE_TOOL_PROPS;
+ art->prefsizex = 0;
+ art->prefsizey = 360;
+ art->keymapflag = ED_KEYMAP_UI;
+ art->listener = file_tools_region_listener;
+ art->init = file_tools_region_init;
+ art->draw = file_tools_region_draw;
+ BLI_addhead(&st->regiontypes, art);
+ file_panels_register(art);
+
+ BKE_spacetype_register(st);
}
void ED_file_init(void)
{
- ED_file_read_bookmarks();
+ ED_file_read_bookmarks();
- if (G.background == false) {
- filelist_init_icons();
- }
+ if (G.background == false) {
+ filelist_init_icons();
+ }
- IMB_thumb_makedirs();
+ IMB_thumb_makedirs();
}
void ED_file_exit(void)
{
- fsmenu_free();
+ fsmenu_free();
- if (G.background == false) {
- filelist_free_icons();
- }
+ if (G.background == false) {
+ filelist_free_icons();
+ }
}
void ED_file_read_bookmarks(void)
{
- const char * const cfgdir = BKE_appdir_folder_id(BLENDER_USER_CONFIG, NULL);
+ const char *const cfgdir = BKE_appdir_folder_id(BLENDER_USER_CONFIG, NULL);
- fsmenu_free();
+ fsmenu_free();
- fsmenu_read_system(ED_fsmenu_get(), true);
+ fsmenu_read_system(ED_fsmenu_get(), true);
- if (cfgdir) {
- char name[FILE_MAX];
- BLI_make_file_string("/", name, cfgdir, BLENDER_BOOKMARK_FILE);
- fsmenu_read_bookmarks(ED_fsmenu_get(), name);
- }
+ if (cfgdir) {
+ char name[FILE_MAX];
+ BLI_make_file_string("/", name, cfgdir, BLENDER_BOOKMARK_FILE);
+ fsmenu_read_bookmarks(ED_fsmenu_get(), name);
+ }
}