/*
 * isop.h --
 *	POSTGRES index strategy manipulation operator definitions.
 *
 * Identification:
 *	/usr/local/devel/postgres-v4r2/src/backend/access/RCS/isop.h,v 1.8 1991/11/08 15:43:10 kemnitz Exp
 */

#ifndef	ISOpIncluded	/* Include this file only once */
#define ISOpIncluded	1

#include "tmp/c.h"
#include "access/istrat.h"

typedef struct StrategyTransformMapData {
	StrategyNumber	strategy[1];	/* VARIABLE LENGTH ARRAY */
} StrategyTransformMapData;	/* VARIABLE LENGTH STRUCTURE */

typedef StrategyTransformMapData	*StrategyTransformMap;

typedef struct StrategyOperatorData {
	StrategyNumber	strategy;
	bits16		flags;		/* scan qualification flags h/skey.h */
} StrategyOperatorData;

typedef StrategyOperatorData	*StrategyOperator;

typedef struct StrategyTermData {	/* conjunctive term */
	uint16			degree;
	StrategyOperatorData	operatorData[1];	/* VARIABLE LENGTH */
} StrategyTermData;	/* VARIABLE LENGTH STRUCTURE */

typedef StrategyTermData	*StrategyTerm;

typedef struct StrategyExpressionData {	/* disjunctive normal form */
	StrategyTerm	term[1];	/* VARIABLE LENGTH ARRAY */
} StrategyExpressionData;	/* VARIABLE LENGTH STRUCTURE */

typedef StrategyExpressionData	*StrategyExpression;

typedef struct StrategyEvaluationData {
	StrategyNumber		maxStrategy;
	StrategyTransformMap	negateTransform;
	StrategyTransformMap	commuteTransform;
	StrategyTransformMap	negateCommuteTransform;
	StrategyExpression	expression[12];	/* XXX VARIABLE LENGTH */
} StrategyEvaluationData;	/* VARIABLE LENGTH STRUCTURE */

typedef StrategyEvaluationData	*StrategyEvaluation;

/*
 * StrategyTransformMapIsValid --
 *	Returns true iff strategy transformation map is valid.
 */
#define	StrategyTransformMapIsValid(transform) PointerIsValid(transform)

/*
 * StrategyOperatorIsValid --
 *	Returns true iff strategy operator is valid.
 */
extern
bool
StrategyOperatorMapIsValid ARGS((
	StrategyOperator	operator,
	StrategyNumber		maxStrategy
));

/*
 * StrategyTermIsValid --
 *	Returns true iff strategy term is valid.
 */
extern
bool
StrategyTermIsValid ARGS((
	StrategyTerm	term,
	StrategyNumber	maxStrategy
));

/*
 * StrategyExpressionIsValid --
 *	Returns true iff strategy expression is valid.
 */
extern
bool
StrategyExpressionIsValid ARGS((
	StrategyExpression	expression,
	StrategyNumber		maxStrategy
));

/*
 * StrategyEvaluationIsValid --
 *	Returns true iff strategy evaluation information is valid.
 */
extern
bool
StrategyEvaluationIsValid ARGS((
	StrategyEvaluation	evaluation
));

/*
 * RelationGetStrategy --
 *	Returns the strategy for an index relation and registered procedure.
 *	Returns InvalidStrategyNumber if registered procedure is unknown.
 *
 * Note:
 *	Assumes relation is valid index relation.
 *	Assumes attribute number is in valid range.
 *	Assumes maximum strategy is valid.
 *	Assumes strategy transformation maps are valid.
 *	Assumes registered procedure is valid.
 */
extern
StrategyNumber
RelationGetStrategy ARGS((
	Relation		relation,
	AttributeNumber		attributeNumber,
	StrategyEvaluation	evaluation,
	RegProcedure		procedure
));

/*
 * RelationInvokeStrategy --
 *	Returns the result of evaluating a strategy for an index relation.
 *
 * Note:
 *	Assumes relation is a valid index relation.
 *	Assumes strategy evalution information is valid.
 *	Assumes attribute number is in valid range.
 *	Assumes strategy is valid.
 */
extern
bool		/* XXX someday, this may return Datum */
RelationInvokeStrategy ARGS((
	Relation		relation,
	StrategyEvaluation	evaluation,
	AttributeNumber		attributeNumber,
	StrategyNumber		strategy,
	Datum			left,
	Datum			right
));

#endif	/* !defined(ISOpIncluded) */
