mirror of
https://github.com/postgres/postgres.git
synced 2026-03-12 21:54:00 -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
61 lines
1.8 KiB
C
61 lines
1.8 KiB
C
/*-------------------------------------------------------------------------
|
|
*
|
|
* lockoptions.h
|
|
* Common header for some locking-related declarations.
|
|
*
|
|
*
|
|
* Copyright (c) 2014-2023, PostgreSQL Global Development Group
|
|
*
|
|
* src/include/nodes/lockoptions.h
|
|
*
|
|
*-------------------------------------------------------------------------
|
|
*/
|
|
#ifndef LOCKOPTIONS_H
|
|
#define LOCKOPTIONS_H
|
|
|
|
/*
|
|
* This enum represents the different strengths of FOR UPDATE/SHARE clauses.
|
|
* The ordering here is important, because the highest numerical value takes
|
|
* precedence when a RTE is specified multiple ways. See applyLockingClause.
|
|
*/
|
|
typedef enum LockClauseStrength
|
|
{
|
|
LCS_NONE, /* no such clause - only used in PlanRowMark */
|
|
LCS_FORKEYSHARE, /* FOR KEY SHARE */
|
|
LCS_FORSHARE, /* FOR SHARE */
|
|
LCS_FORNOKEYUPDATE, /* FOR NO KEY UPDATE */
|
|
LCS_FORUPDATE, /* FOR UPDATE */
|
|
} LockClauseStrength;
|
|
|
|
/*
|
|
* This enum controls how to deal with rows being locked by FOR UPDATE/SHARE
|
|
* clauses (i.e., it represents the NOWAIT and SKIP LOCKED options).
|
|
* The ordering here is important, because the highest numerical value takes
|
|
* precedence when a RTE is specified multiple ways. See applyLockingClause.
|
|
*/
|
|
typedef enum LockWaitPolicy
|
|
{
|
|
/* Wait for the lock to become available (default behavior) */
|
|
LockWaitBlock,
|
|
/* Skip rows that can't be locked (SKIP LOCKED) */
|
|
LockWaitSkip,
|
|
/* Raise an error if a row cannot be locked (NOWAIT) */
|
|
LockWaitError,
|
|
} LockWaitPolicy;
|
|
|
|
/*
|
|
* Possible lock modes for a tuple.
|
|
*/
|
|
typedef enum LockTupleMode
|
|
{
|
|
/* SELECT FOR KEY SHARE */
|
|
LockTupleKeyShare,
|
|
/* SELECT FOR SHARE */
|
|
LockTupleShare,
|
|
/* SELECT FOR NO KEY UPDATE, and UPDATEs that don't modify key columns */
|
|
LockTupleNoKeyExclusive,
|
|
/* SELECT FOR UPDATE, UPDATEs that modify key columns, and DELETE */
|
|
LockTupleExclusive,
|
|
} LockTupleMode;
|
|
|
|
#endif /* LOCKOPTIONS_H */
|