реклама на сайте
подробности

 
 
> Рекурсивный алгоритм, для перебора файлов на диске
Ivan Kuznetzov
сообщение Feb 25 2011, 20:29
Сообщение #1


Местный
***

Группа: Свой
Сообщений: 307
Регистрация: 6-02-08
Из: Россия, Екатеринбург
Пользователь №: 34 798



Делаю плеер на АВРке, файловая система fatfs. Подскажите пожалуйста, как грамотно реализовать рекурсивный алгоритм поиска файлов с функцией перемещения по текущему воспроизводимому файлу "вперед-назад", с возможностью работы с подпапками.


--------------------
Разработчик
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
KRS
сообщение Feb 27 2011, 23:06
Сообщение #2


Профессионал
*****

Группа: Модераторы
Сообщений: 1 951
Регистрация: 27-08-04
Из: Санкт-Петербург
Пользователь №: 555



Насколько я понял рекурсивный - потому что с обходом дерева каталогов. Т.е. нужно просто перейти к следующему файлу - если это подкаталог - то к первому файлу подкаталога...
Если бы просто надо было получить список всех файлов - то это была бы рекурсивная функция!

А т.к. надо получить следующий файл, надо запоминать данные в виде массива с текущими позициями в каждом каталоге. В самом тупом виде будет примерно следующее
Код
unsigned level;
DIR last;
unsigned dir_pos[MAX_LEVEL];
char* get_next_file(void)
{
    while(1) {
        f_readdir(&last,...);
        если подкаталог {
            ++level;
            f_opendir(&last,...)
            continue;
        }
        если конец {
            dir_pos[level]=0;
            --level;
            открыть каталог верхнего уровня
            пропустить dir_pos[level] файлов
            continue;
        }
        ++dir_pos[level];
        return имя файла
    }
}
Go to the top of the page
 
+Quote Post



Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 29th July 2025 - 10:56
Рейтинг@Mail.ru


Страница сгенерированна за 0.01364 секунд с 7
ELECTRONIX ©2004-2016