mirror of
https://github.com/postgres/postgres.git
synced 2026-04-29 18:32:53 -04:00
heapam.h previously was included in a number of widely used headers (e.g. execnodes.h, indirectly in executor.h, ...). That's problematic on its own, as heapam.h contains a lot of low-level details that don't need to be exposed that widely, but becomes more problematic with the upcoming introduction of pluggable table storage - it seems inappropriate for heapam.h to be included that widely afterwards. heapam.h was largely only included in other headers to get the HeapScanDesc typedef (which was defined in heapam.h, even though HeapScanDescData is defined in relscan.h). The better solution here seems to be to just use the underlying struct (forward declared where necessary). Similar for BulkInsertState. Another problem was that LockTupleMode was used in executor.h - parts of the file tried to cope without heapam.h, but due to the fact that it indirectly included it, several subsequent violations of that goal were not not noticed. We could just reuse the approach of declaring parameters as int, but it seems nicer to move LockTupleMode to lockoptions.h - that's not a perfect location, but also doesn't seem bad. As a number of files relied on implicitly included heapam.h, a significant number of files grew an explicit include. It's quite probably that a few external projects will need to do the same. Author: Andres Freund Reviewed-By: Alvaro Herrera Discussion: https://postgr.es/m/20190114000701.y4ttcb74jpskkcfb@alap3.anarazel.de
61 lines
1.8 KiB
C
61 lines
1.8 KiB
C
/*-------------------------------------------------------------------------
|
|
*
|
|
* lockoptions.h
|
|
* Common header for some locking-related declarations.
|
|
*
|
|
*
|
|
* Copyright (c) 2014-2019, 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 */
|