Jeff Davis wrote:
> --- 1000,1015 ----
> strcat (flagString, "HASEXTERNAL|");
> if (infoMask & HEAP_HASOID)
> strcat (flagString, "HASOID|");
> + if (infoMask & HEAP_XMAX_KEYSHR_LOCK)
> + strcat (flagString, "XMAX_KEYSHR_LOCK|");
> if (infoMask & HEAP_COMBOCID)
> strcat (flagString, "COMBOCID|");
> if (infoMask & HEAP_XMAX_EXCL_LOCK)
> strcat (flagString, "XMAX_EXCL_LOCK|");
> ! if (infoMask & HEAP_XMAX_SHR_LOCK)
> ! strcat (flagString, "XMAX_SHR_LOCK|");
> ! if (infoMask & HEAP_XMAX_LOCK_ONLY)
> ! strcat (flagString, "XMAX_LOCK_ONLY|");
> if (infoMask & HEAP_XMIN_COMMITTED)
> strcat (flagString, "XMIN_COMMITTED|");
> if (infoMask & HEAP_XMIN_INVALID)
Hm, note that XMAX_SHR_LOCK is two bits, so when that flag is present
you will get the three lock modes displayed with the above code, which is
probably going to be misleading. htup_details.h does this:
/** Use these to test whether a particular lock is applied to a tuple*/
#define HEAP_XMAX_IS_SHR_LOCKED(infomask) \(((infomask) & HEAP_LOCK_MASK) == HEAP_XMAX_SHR_LOCK)
#define HEAP_XMAX_IS_EXCL_LOCKED(infomask) \(((infomask) & HEAP_LOCK_MASK) == HEAP_XMAX_EXCL_LOCK)
#define HEAP_XMAX_IS_KEYSHR_LOCKED(infomask) \(((infomask) & HEAP_LOCK_MASK) == HEAP_XMAX_KEYSHR_LOCK)
Presumably it'd be better to do something similar.
--
Álvaro Herrera http://www.2ndQuadrant.com/
PostgreSQL Development, 24x7 Support, Training & Services