itemptr.h 2.9 KB
Newer Older
1 2 3
/*-------------------------------------------------------------------------
 *
 * itemptr.h--
4
 *	  POSTGRES disk item pointer definitions.
5 6 7 8
 *
 *
 * Copyright (c) 1994, Regents of the University of California
 *
9
 * $Id: itemptr.h,v 1.9 1998/09/01 04:38:20 momjian Exp $
10 11 12
 *
 *-------------------------------------------------------------------------
 */
13
#ifndef ITEMPTR_H
14 15
#define ITEMPTR_H

16 17
#include <storage/off.h>
#include <storage/block.h>
18 19 20 21 22 23 24 25

/*
 * ItemPointer:
 *
 * this is a pointer to an item on another disk page in the same file.
 * blkid tells us which block, posid tells us which entry in the linp
 * (ItemIdData) array we want.
 */
26 27
typedef struct ItemPointerData
{
28 29
	BlockIdData ip_blkid;
	OffsetNumber ip_posid;
30
} ItemPointerData;
31

32
typedef ItemPointerData *ItemPointer;
33 34

/* ----------------
35
 *		support macros
36 37 38 39 40
 * ----------------
 */

/*
 * ItemPointerIsValid --
41
 *		True iff the disk item pointer is not NULL.
42 43
 */
#define ItemPointerIsValid(pointer) \
44
	((bool) (PointerIsValid(pointer) && ((pointer)->ip_posid != 0)))
45 46 47

/*
 * ItemPointerGetBlockNumber --
48
 *		Returns the block number of a disk item pointer.
49 50
 */
#define ItemPointerGetBlockNumber(pointer) \
51 52 53 54
( \
	AssertMacro(ItemPointerIsValid(pointer)), \
	BlockIdGetBlockNumber(&(pointer)->ip_blkid) \
)
55 56 57

/*
 * ItemPointerGetOffsetNumber --
58
 *		Returns the offset number of a disk item pointer.
59 60
 */
#define ItemPointerGetOffsetNumber(pointer) \
61 62 63 64
( \
	AssertMacro(ItemPointerIsValid(pointer)), \
	(pointer)->ip_posid \
)
65 66 67

/*
 * ItemPointerSet --
68
 *		Sets a disk item pointer to the specified block and offset.
69 70
 */
#define ItemPointerSet(pointer, blockNumber, offNum) \
71 72 73 74 75
( \
	AssertMacro(PointerIsValid(pointer)), \
	BlockIdSet(&((pointer)->ip_blkid), blockNumber), \
	(pointer)->ip_posid = offNum \
)
76 77 78

/*
 * ItemPointerSetBlockNumber --
79
 *		Sets a disk item pointer to the specified block.
80 81
 */
#define ItemPointerSetBlockNumber(pointer, blockNumber) \
82 83 84 85
( \
	AssertMacro(PointerIsValid(pointer)), \
	BlockIdSet(&((pointer)->ip_blkid), blockNumber) \
)
86 87 88

/*
 * ItemPointerSetOffsetNumber --
89
 *		Sets a disk item pointer to the specified offset.
90 91
 */
#define ItemPointerSetOffsetNumber(pointer, offsetNumber) \
92 93 94 95
( \
	AssertMacro(PointerIsValid(pointer)), \
	(pointer)->ip_posid = (offsetNumber) \
)
96 97 98

/*
 * ItemPointerCopy --
99
 *		Copies the contents of one disk item pointer to another.
100 101
 */
#define ItemPointerCopy(fromPointer, toPointer) \
102 103 104 105 106
( \
	AssertMacro(PointerIsValid(toPointer)), \
	AssertMacro(PointerIsValid(fromPointer)), \
	*(toPointer) = *(fromPointer) \
)
107 108 109

/*
 * ItemPointerSetInvalid --
110
 *		Sets a disk item pointer to be invalid.
111 112
 */
#define ItemPointerSetInvalid(pointer) \
113 114 115 116 117
( \
	AssertMacro(PointerIsValid(pointer)), \
	BlockIdSet(&((pointer)->ip_blkid), InvalidBlockNumber), \
	(pointer)->ip_posid = InvalidOffsetNumber \
)
118 119

/* ----------------
120
 *		externs
121 122 123
 * ----------------
 */

124
extern bool ItemPointerEquals(ItemPointer pointer1, ItemPointer pointer2);
125

126
#endif	 /* ITEMPTR_H */