mirror of
https://github.com/postgres/postgres.git
synced 2026-03-19 00:52:42 -04:00
Since C99, there can be a trailing comma after the last value in an enum definition. A lot of new code has been introducing this style on the fly. Some new patches are now taking an inconsistent approach to this. Some add the last comma on the fly if they add a new last value, some are trying to preserve the existing style in each place, some are even dropping the last comma if there was one. We could nudge this all in a consistent direction if we just add the trailing commas everywhere once. I omitted a few places where there was a fixed "last" value that will always stay last. I also skipped the header files of libpq and ecpg, in case people want to use those with older compilers. There were also a small number of cases where the enum type wasn't used anywhere (but the enum values were), which ended up confusing pgindent a bit, so I left those alone. Discussion: https://www.postgresql.org/message-id/flat/386f8c45-c8ac-4681-8add-e3b0852c1620%40eisentraut.org
66 lines
2 KiB
C
66 lines
2 KiB
C
/*-------------------------------------------------------------------------
|
|
*
|
|
* sync.h
|
|
* File synchronization management code.
|
|
*
|
|
* Portions Copyright (c) 1996-2023, PostgreSQL Global Development Group
|
|
* Portions Copyright (c) 1994, Regents of the University of California
|
|
*
|
|
* src/include/storage/sync.h
|
|
*
|
|
*-------------------------------------------------------------------------
|
|
*/
|
|
#ifndef SYNC_H
|
|
#define SYNC_H
|
|
|
|
#include "storage/relfilelocator.h"
|
|
|
|
/*
|
|
* Type of sync request. These are used to manage the set of pending
|
|
* requests to call a sync handler's sync or unlink functions at the next
|
|
* checkpoint.
|
|
*/
|
|
typedef enum SyncRequestType
|
|
{
|
|
SYNC_REQUEST, /* schedule a call of sync function */
|
|
SYNC_UNLINK_REQUEST, /* schedule a call of unlink function */
|
|
SYNC_FORGET_REQUEST, /* forget all calls for a tag */
|
|
SYNC_FILTER_REQUEST, /* forget all calls satisfying match fn */
|
|
} SyncRequestType;
|
|
|
|
/*
|
|
* Which set of functions to use to handle a given request. The values of
|
|
* the enumerators must match the indexes of the function table in sync.c.
|
|
*/
|
|
typedef enum SyncRequestHandler
|
|
{
|
|
SYNC_HANDLER_MD = 0,
|
|
SYNC_HANDLER_CLOG,
|
|
SYNC_HANDLER_COMMIT_TS,
|
|
SYNC_HANDLER_MULTIXACT_OFFSET,
|
|
SYNC_HANDLER_MULTIXACT_MEMBER,
|
|
SYNC_HANDLER_NONE,
|
|
} SyncRequestHandler;
|
|
|
|
/*
|
|
* A tag identifying a file. Currently it has the members required for md.c's
|
|
* usage, but sync.c has no knowledge of the internal structure, and it is
|
|
* liable to change as required by future handlers.
|
|
*/
|
|
typedef struct FileTag
|
|
{
|
|
int16 handler; /* SyncRequestHandler value, saving space */
|
|
int16 forknum; /* ForkNumber, saving space */
|
|
RelFileLocator rlocator;
|
|
uint32 segno;
|
|
} FileTag;
|
|
|
|
extern void InitSync(void);
|
|
extern void SyncPreCheckpoint(void);
|
|
extern void SyncPostCheckpoint(void);
|
|
extern void ProcessSyncRequests(void);
|
|
extern void RememberSyncRequest(const FileTag *ftag, SyncRequestType type);
|
|
extern bool RegisterSyncRequest(const FileTag *ftag, SyncRequestType type,
|
|
bool retryOnError);
|
|
|
|
#endif /* SYNC_H */
|