Разработка динамических сайтов
SEO услуги
Управление контекстной рекламой

Вход на хостинг

Имя пользователя:*

Пароль пользователя:*

IT-новости

20.04.2016 iPhone 2017 года поместят в водонепроницаемый корпус из стекла

Линейка iPhone в новом году серьезно поменяется. В этом уверен аналитический исследователь Мин Чи Ку......

подробнее

30.07.2015 Ищем уникальный контент для сайта

Ищем уникальный контент для сайта Без уникального контента Ваш сайт обречен на то, что его страницы......

подробнее

11.05.2015 Распространённые ошибки разработчиков сайтов

Не секрет, что в сети Интернет насчитывается миллионы сайтов, и каждый день появляются тысячси новых......

подробнее

           i++;

           break;

        }

    }

 

    tmp_name_buff[n] = '';

Заполняем структуру struct split_name sn соответствующей информацией. Заполнение выполняет функция split_name, при этом выполняется проверка имени файла на соответствие формату «8.3»:

    if(split_name(tmp_name_buff, &sn) < 0) {

        printf("not valid name ");

        return -1;

    }

Для каждого элемента полного имени файла определяем начальный кластер. Для этого ищем в элементах каталога (начиная с корневого) запись, соответствующую элементу полного имени, и считываем эту запись. Процедуру поиска выполняет функция get_dentry():

    if(get_dentry(&sn) < 0) {

        printf("No such file! ");

        return -1;

    }

Проверяем атрибуты файла. Если это каталог, считываем его содержимое и продолжаем цикл:

    if(dentry.attr & 0x10) {

        if(read_directory(dentry.start) < 0) return -1;

        continue;

    }

Если это файл – считываем первые num кластеров. Для контроля считанную информацию сохраним в отдельном файле:

    if(dentry.attr & 0x20) {

 

        start_cluster = dentry.start;

        tmp_buff = (__u8 *)malloc(byte_per_cluster); // сюда будет считываться содержимое кластера

        n = open("clust", O_CREAT|O_RDWR, 0600);   // в этом файле сохраним считанную информацию

        if(n < 0) {

           perror("open");

           return -1;

        }

 

        printf("file`s first cluster - 0x%X .. ", start_cluster);

Для считывания кластеров файла организуем цикл:

        for(i = 0; i < num; i++) {

 

           memset(tmp_buff, 0, byte_per_cluster);

Считываем содержимое кластера в буфер tmp_buff и сохраняем его в отдельном файле:

           if(read_cluster(start_cluster, tmp_buff) < 0) return -1;

 

           if(write(n, tmp_buff, byte_per_cluster) < 0) {

               perror("write");

               close(n);

               return -1;

           }

Считываем из FAT16 номер следующего кластера, занятого под данный файл. Если это последний кластер – прерываем цикл и возвращаемся в главную функцию:

           next_cluster = fat16[start_cluster];

 

#ifdef DEBUG

           printf("OK. Readed ");

           printf("file`s next cluster - 0x%X .. ", next_cluster);

#endif


Предыдущая страницаОглавлениеСледующая страница
 
[001] [002] [003] [004] [005] [006] [007] [008] [009] [010] [011] [012] [013] [014] [015] [016] [017] [018] [019] [020]
[021] [022] [023] [024] [025] [026] [027] [028] [029] [030] [031] [032] [033] [034] [035] [036] [037] [038] [039] [040]
[041] [042] [043] [044] [045] [046] [047] [048] [049] [050] [051] [052] [053] [054] [055] [056] [057] [058] [059] [060]
[061] [062] [063] [064] [065] [066] [067] [068] [069] [070] [071] [072] [073] [074] [075] [076] [077] [078] [079] [080]
[081] [082] [083] [084] [085] [086] [087] [088] [089] [090] [091] [092] [093] [094] [095] [096] [097] [098] [099] [100]
[101] [102] [103] [104] [105] [106] [107] [108] [109] [110] [111] [112] [113] [114] [115] [116] [117] [118] [119] [120]
[121] [122] [123] [124] [125] [126] [127] [128] [129] [130] [131] [132] [133] [134] [135] [136] [137] [138] [139] [140]
[141] [142] [143] [144] [145] [146] [147] [148] [149] [150] [151] [152] [153] [154] [155] [156] [157]

+7 (831) 413-63-27
ООО Дельта-Технология ©2007 - 2023 год
Нижний Новгород, ул. Дальняя, 17А.
Rambler's Top100