CS50: Восстановление, изображения говорят о неподдерживаемом формате при открытии - PullRequest
1 голос
/ 06 августа 2020

Когда я запускаю check50, он говорит, что изображения не совпадают. Я застрял на этом 2 часа, теперь не знаю, что делать. Восстановление образа, но когда я пытаюсь его открыть, он говорит, что тип файла не поддерживается. Когда я запускаю check50, он говорит, что изображения не совпадают. Я не знаю что делать Я новичок в программировании, и я все еще начинаю, поэтому прошу прощения, если это глупый вопрос. Вот мой код:

#include <stdio.h>
#include <stdlib.h>
#include <cs50.h>
#include <stdint.h>

typedef uint8_t BYTE;

#define BLOCK_SIZE 512
#define FILE_NAME_SIZE 8
bool is_start_new_jpeg(BYTE buffer[]);
int main(int argc, char *argv[])
{
    if (argc != 2)
    {
    printf("Usage: ./recover image\n");
    return 1;
    }
FILE *infile = fopen(argv[1], "r");
if (infile == NULL)
{
    printf("File not found\n");
    return 1;
}

BYTE buffer[BLOCK_SIZE];
int file_index = 0;
bool have_found_first_jpg = false; 
FILE *outfile;
while (fread(buffer, BLOCK_SIZE, 1, infile))
{
    if (is_start_new_jpeg(buffer))
    {
        if (!have_found_first_jpg)
        {
            have_found_first_jpg = true;
        }    
        else 
        {
            fclose(outfile);
        }
        
        char filename[FILE_NAME_SIZE];
        sprintf(filename, "%03i.jpg", file_index++);
        outfile = fopen(filename, "w");
        if (outfile == NULL)
        {
            return 1;
        }    
        fwrite(buffer, BLOCK_SIZE, 1, outfile);     
               
    }
    else if (have_found_first_jpg)
    {
        //keep writing on the previous file
        fwrite(buffer, BLOCK_SIZE, 1, outfile);
    }
    
}
fclose(outfile);
fclose(infile);

}
bool is_start_new_jpeg(BYTE buffer[])
{
    return buffer[0] = 0xff && buffer[1] == 0xd8 && buffer[2] == 0xff && (buffer[3] & 0xf0) == 0xe0;
}

может кто-нибудь сказать мне, где я ошибся. спасибо

1 Ответ

0 голосов
/ 06 августа 2020

Сообщения приходят, потому что первый байт каждого блока подписи был преобразован в 0xff. В функции is_start_new_jpeg есть (вероятно) опечатка.

...