/* RetroArch - A frontend for libretro. * Copyright (C) 2010-2012 - Hans-Kristian Arntzen * Copyright (C) 2011-2012 - Daniel De Matteis * * RetroArch 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 Found- * ation, either version 3 of the License, or (at your option) any later version. * * RetroArch 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 RetroArch. * If not, see . */ #include "file_browser.h" static void filebrowser_parse_directory(filebrowser_t * filebrowser, const char * path, const char * extensions) { strlcpy(filebrowser->dir[filebrowser->directory_stack_size], path, sizeof(filebrowser->dir[filebrowser->directory_stack_size])); filebrowser->current_dir.list = dir_list_new(path, extensions, true); filebrowser->current_dir.ptr = 0; dir_list_sort(filebrowser->current_dir.list, true); } static void filebrowser_new(filebrowser_t * filebrowser, const char * start_dir, const char * extensions) { filebrowser->directory_stack_size = 0; strlcpy(filebrowser->extensions, extensions, sizeof(filebrowser->extensions)); filebrowser_parse_directory(filebrowser, start_dir, extensions); } void filebrowser_set_root(filebrowser_t *filebrowser, const char *root_dir) { strlcpy(filebrowser->root_dir, root_dir, sizeof(filebrowser->root_dir)); } void filebrowser_free(filebrowser_t * filebrowser) { dir_list_free(filebrowser->current_dir.list); filebrowser->current_dir.list = NULL; filebrowser->current_dir.ptr = 0; } static void filebrowser_push_directory(filebrowser_t * filebrowser, const char * path, bool with_extension) { filebrowser->directory_stack_size++; if(with_extension) filebrowser_parse_directory(filebrowser, path, filebrowser->extensions); else filebrowser_parse_directory(filebrowser, path, "empty"); } static void filebrowser_pop_directory (filebrowser_t * filebrowser) { if (filebrowser->directory_stack_size > 0) filebrowser->directory_stack_size--; filebrowser_parse_directory(filebrowser, filebrowser->dir[filebrowser->directory_stack_size], filebrowser->extensions); } const char * filebrowser_get_current_dir (filebrowser_t *filebrowser) { return filebrowser->dir[filebrowser->directory_stack_size]; } const char * filebrowser_get_current_path (filebrowser_t *filebrowser) { return filebrowser->current_dir.list->elems[filebrowser->current_dir.ptr].data; } bool filebrowser_get_current_path_isdir (filebrowser_t *filebrowser) { return filebrowser->current_dir.list->elems[filebrowser->current_dir.ptr].attr.b; } size_t filebrowser_get_current_index (filebrowser_t *filebrowser) { return filebrowser->current_dir.ptr; } void filebrowser_set_current_at (filebrowser_t *filebrowser, size_t pos) { filebrowser->current_dir.ptr = pos; } static void filebrowser_set_current_increment (filebrowser_t *filebrowser, bool allow_wraparound) { filebrowser->current_dir.ptr++; if (filebrowser->current_dir.ptr >= filebrowser->current_dir.list->size && allow_wraparound) filebrowser->current_dir.ptr = 0; } static void filebrowser_set_current_decrement (filebrowser_t *filebrowser, bool allow_wraparound) { filebrowser->current_dir.ptr--; if (filebrowser->current_dir.ptr >= filebrowser->current_dir.list->size && allow_wraparound) filebrowser->current_dir.ptr = filebrowser->current_dir.list->size - 1; } void filebrowser_iterate(filebrowser_t *filebrowser, filebrowser_action_t action) { unsigned entries_to_scroll = 19; switch(action) { case FILEBROWSER_ACTION_UP: filebrowser_set_current_decrement(filebrowser, true); break; case FILEBROWSER_ACTION_DOWN: filebrowser_set_current_increment(filebrowser, true); break; case FILEBROWSER_ACTION_LEFT: if (filebrowser->current_dir.ptr <= 5) filebrowser->current_dir.ptr = 0; else filebrowser->current_dir.ptr -= 5; break; case FILEBROWSER_ACTION_RIGHT: filebrowser->current_dir.ptr = (min(filebrowser->current_dir.ptr + 5, filebrowser->current_dir.list->size-1)); break; case FILEBROWSER_ACTION_SCROLL_UP: if (filebrowser->current_dir.ptr <= entries_to_scroll) filebrowser->current_dir.ptr= 0; else filebrowser->current_dir.ptr -= entries_to_scroll; break; case FILEBROWSER_ACTION_SCROLL_UP_SMOOTH: if (filebrowser->current_dir.ptr <= 50) filebrowser->current_dir.ptr= 0; else filebrowser->current_dir.ptr -= 50; break; case FILEBROWSER_ACTION_SCROLL_DOWN: filebrowser->current_dir.ptr = (min(filebrowser->current_dir.ptr + entries_to_scroll, filebrowser->current_dir.list->size-1)); break; case FILEBROWSER_ACTION_SCROLL_DOWN_SMOOTH: filebrowser->current_dir.ptr = (min(filebrowser->current_dir.ptr + 50, filebrowser->current_dir.list->size-1)); if(!filebrowser->current_dir.ptr) filebrowser->current_dir.ptr = 0; break; case FILEBROWSER_ACTION_OK: filebrowser_push_directory(filebrowser, filebrowser_get_current_path(filebrowser), true); break; case FILEBROWSER_ACTION_CANCEL: filebrowser_pop_directory(filebrowser); break; case FILEBROWSER_ACTION_RESET: filebrowser_new(filebrowser, filebrowser->root_dir, filebrowser->extensions); break; case FILEBROWSER_ACTION_NOOP: default: break; } }