Commit 4bb50236 authored by Andres Freund's avatar Andres Freund

tableam: Formatting and other minor cleanups.

The superflous heapam_xlog.h includes were reported by Peter
Geoghegan.
parent 76a39f22
...@@ -14,7 +14,6 @@ ...@@ -14,7 +14,6 @@
*/ */
#include "postgres.h" #include "postgres.h"
#include "access/heapam_xlog.h"
#include "access/bufmask.h" #include "access/bufmask.h"
#include "access/hash.h" #include "access/hash.h"
#include "access/hash_xlog.h" #include "access/hash_xlog.h"
......
This diff is collapsed.
...@@ -15,7 +15,6 @@ ...@@ -15,7 +15,6 @@
#include "postgres.h" #include "postgres.h"
#include "access/bufmask.h" #include "access/bufmask.h"
#include "access/heapam_xlog.h"
#include "access/nbtree.h" #include "access/nbtree.h"
#include "access/nbtxlog.h" #include "access/nbtxlog.h"
#include "access/transam.h" #include "access/transam.h"
......
...@@ -96,8 +96,9 @@ table_beginscan_catalog(Relation relation, int nkeys, struct ScanKeyData *key) ...@@ -96,8 +96,9 @@ table_beginscan_catalog(Relation relation, int nkeys, struct ScanKeyData *key)
Oid relid = RelationGetRelid(relation); Oid relid = RelationGetRelid(relation);
Snapshot snapshot = RegisterSnapshot(GetCatalogSnapshot(relid)); Snapshot snapshot = RegisterSnapshot(GetCatalogSnapshot(relid));
return relation->rd_tableam->scan_begin(relation, snapshot, nkeys, key, NULL, return relation->rd_tableam->scan_begin(relation, snapshot, nkeys, key,
true, true, true, false, false, true); NULL, true, true, true, false,
false, true);
} }
void void
...@@ -171,8 +172,10 @@ table_beginscan_parallel(Relation relation, ParallelTableScanDesc parallel_scan) ...@@ -171,8 +172,10 @@ table_beginscan_parallel(Relation relation, ParallelTableScanDesc parallel_scan)
snapshot = SnapshotAny; snapshot = SnapshotAny;
} }
return relation->rd_tableam->scan_begin(relation, snapshot, 0, NULL, parallel_scan, return relation->rd_tableam->scan_begin(relation, snapshot, 0, NULL,
true, true, true, false, false, !parallel_scan->phs_snapshot_any); parallel_scan, true, true, true,
false, false,
!parallel_scan->phs_snapshot_any);
} }
......
...@@ -78,6 +78,17 @@ GetTableAmRoutine(Oid amhandler) ...@@ -78,6 +78,17 @@ GetTableAmRoutine(Oid amhandler)
Assert(routine->tuple_update != NULL); Assert(routine->tuple_update != NULL);
Assert(routine->tuple_lock != NULL); Assert(routine->tuple_lock != NULL);
Assert(routine->relation_set_new_filenode != NULL);
Assert(routine->relation_nontransactional_truncate != NULL);
Assert(routine->relation_copy_data != NULL);
Assert(routine->relation_copy_for_cluster != NULL);
Assert(routine->relation_vacuum != NULL);
Assert(routine->scan_analyze_next_block != NULL);
Assert(routine->scan_analyze_next_tuple != NULL);
Assert(routine->index_build_range_scan != NULL);
Assert(routine->index_validate_scan != NULL);
Assert(routine->relation_estimate_size != NULL);
return routine; return routine;
} }
......
...@@ -2068,9 +2068,9 @@ bool ...@@ -2068,9 +2068,9 @@ bool
has_stored_generated_columns(PlannerInfo *root, Index rti) has_stored_generated_columns(PlannerInfo *root, Index rti)
{ {
RangeTblEntry *rte = planner_rt_fetch(rti, root); RangeTblEntry *rte = planner_rt_fetch(rti, root);
Relation relation; Relation relation;
TupleDesc tupdesc; TupleDesc tupdesc;
bool result = false; bool result = false;
/* Assume we already have adequate lock */ /* Assume we already have adequate lock */
relation = heap_open(rte->relid, NoLock); relation = heap_open(rte->relid, NoLock);
......
...@@ -192,14 +192,16 @@ typedef struct TableAmRoutine ...@@ -192,14 +192,16 @@ typedef struct TableAmRoutine
* Restart relation scan. If set_params is set to true, allow{strat, * Restart relation scan. If set_params is set to true, allow{strat,
* sync, pagemode} (see scan_begin) changes should be taken into account. * sync, pagemode} (see scan_begin) changes should be taken into account.
*/ */
void (*scan_rescan) (TableScanDesc scan, struct ScanKeyData *key, bool set_params, void (*scan_rescan) (TableScanDesc scan, struct ScanKeyData *key,
bool allow_strat, bool allow_sync, bool allow_pagemode); bool set_params, bool allow_strat,
bool allow_sync, bool allow_pagemode);
/* /*
* Return next tuple from `scan`, store in slot. * Return next tuple from `scan`, store in slot.
*/ */
bool (*scan_getnextslot) (TableScanDesc scan, bool (*scan_getnextslot) (TableScanDesc scan,
ScanDirection direction, TupleTableSlot *slot); ScanDirection direction,
TupleTableSlot *slot);
/* ------------------------------------------------------------------------ /* ------------------------------------------------------------------------
...@@ -218,13 +220,15 @@ typedef struct TableAmRoutine ...@@ -218,13 +220,15 @@ typedef struct TableAmRoutine
* pscan will be sized according to parallelscan_estimate() for the same * pscan will be sized according to parallelscan_estimate() for the same
* relation. * relation.
*/ */
Size (*parallelscan_initialize) (Relation rel, ParallelTableScanDesc pscan); Size (*parallelscan_initialize) (Relation rel,
ParallelTableScanDesc pscan);
/* /*
* Reinitialize `pscan` for a new scan. `rel` will be the same relation as * Reinitialize `pscan` for a new scan. `rel` will be the same relation as
* when `pscan` was initialized by parallelscan_initialize. * when `pscan` was initialized by parallelscan_initialize.
*/ */
void (*parallelscan_reinitialize) (Relation rel, ParallelTableScanDesc pscan); void (*parallelscan_reinitialize) (Relation rel,
ParallelTableScanDesc pscan);
/* ------------------------------------------------------------------------ /* ------------------------------------------------------------------------
...@@ -323,8 +327,9 @@ typedef struct TableAmRoutine ...@@ -323,8 +327,9 @@ typedef struct TableAmRoutine
*/ */
/* see table_insert() for reference about parameters */ /* see table_insert() for reference about parameters */
void (*tuple_insert) (Relation rel, TupleTableSlot *slot, CommandId cid, void (*tuple_insert) (Relation rel, TupleTableSlot *slot,
int options, struct BulkInsertStateData *bistate); CommandId cid, int options,
struct BulkInsertStateData *bistate);
/* see table_insert_speculative() for reference about parameters */ /* see table_insert_speculative() for reference about parameters */
void (*tuple_insert_speculative) (Relation rel, void (*tuple_insert_speculative) (Relation rel,
...@@ -414,10 +419,16 @@ typedef struct TableAmRoutine ...@@ -414,10 +419,16 @@ typedef struct TableAmRoutine
void (*relation_copy_data) (Relation rel, RelFileNode newrnode); void (*relation_copy_data) (Relation rel, RelFileNode newrnode);
/* See table_relation_copy_for_cluster() */ /* See table_relation_copy_for_cluster() */
void (*relation_copy_for_cluster) (Relation NewHeap, Relation OldHeap, Relation OldIndex, void (*relation_copy_for_cluster) (Relation NewHeap,
Relation OldHeap,
Relation OldIndex,
bool use_sort, bool use_sort,
TransactionId OldestXmin, TransactionId FreezeXid, MultiXactId MultiXactCutoff, TransactionId OldestXmin,
double *num_tuples, double *tups_vacuumed, double *tups_recently_dead); TransactionId FreezeXid,
MultiXactId MultiXactCutoff,
double *num_tuples,
double *tups_vacuumed,
double *tups_recently_dead);
/* /*
* React to VACUUM command on the relation. The VACUUM might be user * React to VACUUM command on the relation. The VACUUM might be user
...@@ -434,7 +445,8 @@ typedef struct TableAmRoutine ...@@ -434,7 +445,8 @@ typedef struct TableAmRoutine
* There probably, in the future, needs to be a separate callback to * There probably, in the future, needs to be a separate callback to
* integrate with autovacuum's scheduling. * integrate with autovacuum's scheduling.
*/ */
void (*relation_vacuum) (Relation onerel, struct VacuumParams *params, void (*relation_vacuum) (Relation onerel,
struct VacuumParams *params,
BufferAccessStrategy bstrategy); BufferAccessStrategy bstrategy);
/* /*
...@@ -595,7 +607,8 @@ table_beginscan_bm(Relation rel, Snapshot snapshot, ...@@ -595,7 +607,8 @@ table_beginscan_bm(Relation rel, Snapshot snapshot,
static inline TableScanDesc static inline TableScanDesc
table_beginscan_sampling(Relation rel, Snapshot snapshot, table_beginscan_sampling(Relation rel, Snapshot snapshot,
int nkeys, struct ScanKeyData *key, int nkeys, struct ScanKeyData *key,
bool allow_strat, bool allow_sync, bool allow_pagemode) bool allow_strat, bool allow_sync,
bool allow_pagemode)
{ {
return rel->rd_tableam->scan_begin(rel, snapshot, nkeys, key, NULL, return rel->rd_tableam->scan_begin(rel, snapshot, nkeys, key, NULL,
allow_strat, allow_sync, allow_pagemode, allow_strat, allow_sync, allow_pagemode,
...@@ -686,7 +699,9 @@ extern Size table_parallelscan_estimate(Relation rel, Snapshot snapshot); ...@@ -686,7 +699,9 @@ extern Size table_parallelscan_estimate(Relation rel, Snapshot snapshot);
* for the same relation. Call this just once in the leader process; then, * for the same relation. Call this just once in the leader process; then,
* individual workers attach via table_beginscan_parallel. * individual workers attach via table_beginscan_parallel.
*/ */
extern void table_parallelscan_initialize(Relation rel, ParallelTableScanDesc pscan, Snapshot snapshot); extern void table_parallelscan_initialize(Relation rel,
ParallelTableScanDesc pscan,
Snapshot snapshot);
/* /*
* Begin a parallel scan. `pscan` needs to have been initialized with * Begin a parallel scan. `pscan` needs to have been initialized with
...@@ -695,7 +710,8 @@ extern void table_parallelscan_initialize(Relation rel, ParallelTableScanDesc ps ...@@ -695,7 +710,8 @@ extern void table_parallelscan_initialize(Relation rel, ParallelTableScanDesc ps
* *
* Caller must hold a suitable lock on the correct relation. * Caller must hold a suitable lock on the correct relation.
*/ */
extern TableScanDesc table_beginscan_parallel(Relation rel, ParallelTableScanDesc pscan); extern TableScanDesc table_beginscan_parallel(Relation rel,
ParallelTableScanDesc pscan);
/* /*
* Restart a parallel scan. Call this in the leader process. Caller is * Restart a parallel scan. Call this in the leader process. Caller is
...@@ -836,7 +852,8 @@ table_get_latest_tid(Relation rel, Snapshot snapshot, ItemPointer tid) ...@@ -836,7 +852,8 @@ table_get_latest_tid(Relation rel, Snapshot snapshot, ItemPointer tid)
* they ought to mark the relevant buffer dirty. * they ought to mark the relevant buffer dirty.
*/ */
static inline bool static inline bool
table_tuple_satisfies_snapshot(Relation rel, TupleTableSlot *slot, Snapshot snapshot) table_tuple_satisfies_snapshot(Relation rel, TupleTableSlot *slot,
Snapshot snapshot)
{ {
return rel->rd_tableam->tuple_satisfies_snapshot(rel, slot, snapshot); return rel->rd_tableam->tuple_satisfies_snapshot(rel, slot, snapshot);
} }
...@@ -919,7 +936,8 @@ table_insert(Relation rel, TupleTableSlot *slot, CommandId cid, ...@@ -919,7 +936,8 @@ table_insert(Relation rel, TupleTableSlot *slot, CommandId cid,
*/ */
static inline void static inline void
table_insert_speculative(Relation rel, TupleTableSlot *slot, CommandId cid, table_insert_speculative(Relation rel, TupleTableSlot *slot, CommandId cid,
int options, struct BulkInsertStateData *bistate, uint32 specToken) int options, struct BulkInsertStateData *bistate,
uint32 specToken)
{ {
rel->rd_tableam->tuple_insert_speculative(rel, slot, cid, options, rel->rd_tableam->tuple_insert_speculative(rel, slot, cid, options,
bistate, specToken); bistate, specToken);
...@@ -930,8 +948,8 @@ table_insert_speculative(Relation rel, TupleTableSlot *slot, CommandId cid, ...@@ -930,8 +948,8 @@ table_insert_speculative(Relation rel, TupleTableSlot *slot, CommandId cid,
* succeeded is true, the tuple is fully inserted, if false, it's removed. * succeeded is true, the tuple is fully inserted, if false, it's removed.
*/ */
static inline void static inline void
table_complete_speculative(Relation rel, TupleTableSlot *slot, uint32 specToken, table_complete_speculative(Relation rel, TupleTableSlot *slot,
bool succeeded) uint32 specToken, bool succeeded)
{ {
rel->rd_tableam->tuple_complete_speculative(rel, slot, specToken, rel->rd_tableam->tuple_complete_speculative(rel, slot, specToken,
succeeded); succeeded);
...@@ -1342,9 +1360,12 @@ extern void simple_table_update(Relation rel, ItemPointer otid, ...@@ -1342,9 +1360,12 @@ extern void simple_table_update(Relation rel, ItemPointer otid,
extern Size table_block_parallelscan_estimate(Relation rel); extern Size table_block_parallelscan_estimate(Relation rel);
extern Size table_block_parallelscan_initialize(Relation rel, extern Size table_block_parallelscan_initialize(Relation rel,
ParallelTableScanDesc pscan); ParallelTableScanDesc pscan);
extern void table_block_parallelscan_reinitialize(Relation rel, ParallelTableScanDesc pscan); extern void table_block_parallelscan_reinitialize(Relation rel,
extern BlockNumber table_block_parallelscan_nextpage(Relation rel, ParallelBlockTableScanDesc pbscan); ParallelTableScanDesc pscan);
extern void table_block_parallelscan_startblock_init(Relation rel, ParallelBlockTableScanDesc pbscan); extern BlockNumber table_block_parallelscan_nextpage(Relation rel,
ParallelBlockTableScanDesc pbscan);
extern void table_block_parallelscan_startblock_init(Relation rel,
ParallelBlockTableScanDesc pbscan);
/* ---------------------------------------------------------------------------- /* ----------------------------------------------------------------------------
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment