mirror of
https://github.com/postgrespro/pg_probackup.git
synced 2024-11-24 08:52:38 +02:00
Fix recalc checksums during restore for segno > 0.
This commit is contained in:
parent
8957aadae6
commit
fb4ae4a235
2
data.c
2
data.c
@ -519,7 +519,7 @@ restore_data_file(const char *from_root,
|
||||
if (i == BLCKSZ)
|
||||
goto skip_checksum;
|
||||
}
|
||||
((PageHeader) page.data)->pd_checksum = pg_checksum_page(page.data, header.block);
|
||||
((PageHeader) page.data)->pd_checksum = pg_checksum_page(page.data, file->segno * RELSEG_SIZE + header.block);
|
||||
}
|
||||
|
||||
skip_checksum:
|
||||
|
24
dir.c
24
dir.c
@ -590,6 +590,30 @@ dir_read_file_list(const char *root, const char *file_txt)
|
||||
strcpy(file->path, path);
|
||||
|
||||
parray_append(files, file);
|
||||
|
||||
if(file->is_datafile)
|
||||
{
|
||||
int find_dot;
|
||||
int check_digit;
|
||||
char *text_segno;
|
||||
size_t path_len = strlen(file->path);
|
||||
for(find_dot = path_len-1; file->path[find_dot] != '.' && find_dot >= 0; find_dot--);
|
||||
if (find_dot <= 0)
|
||||
continue;
|
||||
|
||||
text_segno = file->path + find_dot + 1;
|
||||
for(check_digit=0; text_segno[check_digit] != '\0'; check_digit++)
|
||||
if (!isdigit(text_segno[check_digit]))
|
||||
{
|
||||
check_digit = -1;
|
||||
break;
|
||||
}
|
||||
|
||||
if (check_digit == -1)
|
||||
continue;
|
||||
|
||||
file->segno = (int) strtol(text_segno, NULL, 10);
|
||||
}
|
||||
}
|
||||
|
||||
fclose(fp);
|
||||
|
Loading…
Reference in New Issue
Block a user