mirror of
https://github.com/postgres/postgres.git
synced 2025-06-29 10:41:53 +03:00
Rework XLogReader callback system
Code review for0dc8ead463
, prompted by a bug closed by91c40548d5
. XLogReader's system for opening and closing segments had gotten too complicated, with callbacks being passed at both the XLogReaderAllocate level (read_page) as well as at the WALRead level (segment_open). This was confusing and hard to follow, so restructure things so that these callbacks are passed together at XLogReaderAllocate time, and add another callback to the set (segment_close) to make it a coherent whole. Also, ensure XLogReaderState is an argument to all the callbacks, so that they can grab at the ->private data if necessary. Document the whole arrangement more clearly. Author: Álvaro Herrera <alvherre@alvh.no-ip.org> Reviewed-by: Kyotaro Horiguchi <horikyota.ntt@gmail.com> Discussion: https://postgr.es/m/20200422175754.GA19858@alvherre.pgsql
This commit is contained in:
@ -1223,7 +1223,7 @@ XLogInsertRecord(XLogRecData *rdata,
|
||||
|
||||
if (!debug_reader)
|
||||
debug_reader = XLogReaderAllocate(wal_segment_size, NULL,
|
||||
NULL, NULL);
|
||||
XL_ROUTINE(), NULL);
|
||||
|
||||
if (!debug_reader)
|
||||
{
|
||||
@ -6478,8 +6478,12 @@ StartupXLOG(void)
|
||||
|
||||
/* Set up XLOG reader facility */
|
||||
MemSet(&private, 0, sizeof(XLogPageReadPrivate));
|
||||
xlogreader = XLogReaderAllocate(wal_segment_size, NULL,
|
||||
&XLogPageRead, &private);
|
||||
xlogreader =
|
||||
XLogReaderAllocate(wal_segment_size, NULL,
|
||||
XL_ROUTINE(.page_read = &XLogPageRead,
|
||||
.segment_open = NULL,
|
||||
.segment_close = wal_segment_close),
|
||||
&private);
|
||||
if (!xlogreader)
|
||||
ereport(ERROR,
|
||||
(errcode(ERRCODE_OUT_OF_MEMORY),
|
||||
|
Reference in New Issue
Block a user