📄 itup.h
字号:
/*------------------------------------------------------------------------- * * itup.h * POSTGRES index tuple definitions. * * * Portions Copyright (c) 1996-2005, PostgreSQL Global Development Group * Portions Copyright (c) 1994, Regents of the University of California * * $PostgreSQL: pgsql/src/include/access/itup.h,v 1.44 2005/10/15 02:49:42 momjian Exp $ * *------------------------------------------------------------------------- */#ifndef ITUP_H#define ITUP_H#include "access/tupdesc.h"#include "access/tupmacs.h"#include "storage/itemptr.h"/* * Index tuple header structure * * All index tuples start with IndexTupleData. If the HasNulls bit is set, * this is followed by an IndexAttributeBitMapData. The index attribute * values follow, beginning at a MAXALIGN boundary. * * Note that the space allocated for the bitmap does not vary with the number * of attributes; that is because we don't have room to store the number of * attributes in the header. Given the MAXALIGN constraint there's no space * savings to be had anyway, for usual values of INDEX_MAX_KEYS. */typedef struct IndexTupleData{ ItemPointerData t_tid; /* reference TID to heap tuple */ /* --------------- * t_info is layed out in the following fashion: * * 15th (high) bit: has nulls * 14th bit: has var-width attributes * 13th bit: unused * 12-0 bit: size of tuple * --------------- */ unsigned short t_info; /* various info about tuple */} IndexTupleData; /* MORE DATA FOLLOWS AT END OF STRUCT */typedef IndexTupleData *IndexTuple;typedef struct IndexAttributeBitMapData{ bits8 bits[(INDEX_MAX_KEYS + 8 - 1) / 8];} IndexAttributeBitMapData;typedef IndexAttributeBitMapData *IndexAttributeBitMap;/* * t_info manipulation macros */#define INDEX_SIZE_MASK 0x1FFF/* bit 0x2000 is not used at present */#define INDEX_VAR_MASK 0x4000#define INDEX_NULL_MASK 0x8000#define IndexTupleSize(itup) ((Size) (((IndexTuple) (itup))->t_info & INDEX_SIZE_MASK))#define IndexTupleDSize(itup) ((Size) ((itup).t_info & INDEX_SIZE_MASK))#define IndexTupleHasNulls(itup) ((((IndexTuple) (itup))->t_info & INDEX_NULL_MASK))#define IndexTupleHasVarwidths(itup) ((((IndexTuple) (itup))->t_info & INDEX_VAR_MASK))/* * Takes an infomask as argument (primarily because this needs to be usable * at index_form_tuple time so enough space is allocated). */#define IndexInfoFindDataOffset(t_info) \( \ (!((t_info) & INDEX_NULL_MASK)) ? \ ( \ (Size)MAXALIGN(sizeof(IndexTupleData)) \ ) \ : \ ( \ (Size)MAXALIGN(sizeof(IndexTupleData) + sizeof(IndexAttributeBitMapData)) \ ) \)/* ---------------- * index_getattr * * This gets called many times, so we macro the cacheable and NULL * lookups, and call nocache_index_getattr() for the rest. * * ---------------- */#define index_getattr(tup, attnum, tupleDesc, isnull) \( \ AssertMacro(PointerIsValid(isnull) && (attnum) > 0), \ *(isnull) = false, \ !IndexTupleHasNulls(tup) ? \ ( \ (tupleDesc)->attrs[(attnum)-1]->attcacheoff >= 0 ? \ ( \ fetchatt((tupleDesc)->attrs[(attnum)-1], \ (char *) (tup) + IndexInfoFindDataOffset((tup)->t_info) \ + (tupleDesc)->attrs[(attnum)-1]->attcacheoff) \ ) \ : \ nocache_index_getattr((tup), (attnum), (tupleDesc), (isnull)) \ ) \ : \ ( \ (att_isnull((attnum)-1, (char *)(tup) + sizeof(IndexTupleData))) ? \ ( \ *(isnull) = true, \ (Datum)NULL \ ) \ : \ ( \ nocache_index_getattr((tup), (attnum), (tupleDesc), (isnull)) \ ) \ ) \)/* routines in indextuple.c */extern IndexTuple index_form_tuple(TupleDesc tupleDescriptor, Datum *values, bool *isnull);extern Datum nocache_index_getattr(IndexTuple tup, int attnum, TupleDesc tupleDesc, bool *isnull);extern IndexTuple CopyIndexTuple(IndexTuple source);#endif /* ITUP_H */
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -