greenplumn CParseHandlerMDGPDBScalarOp 源码
greenplumn CParseHandlerMDGPDBScalarOp 代码
文件路径:/src/backend/gporca/libnaucrates/include/naucrates/dxl/parser/CParseHandlerMDGPDBScalarOp.h
//---------------------------------------------------------------------------
//	Greenplum Database
//	Copyright (C) 2011 EMC Corp.
//
//	@filename:
//		CParseHandlerMDGPDBScalarOp.h
//
//	@doc:
//		SAX parse handler class for GPDB scalar operator metadata
//---------------------------------------------------------------------------
#ifndef GPDXL_CParseHandlerMDGPDBScalarOp_H
#define GPDXL_CParseHandlerMDGPDBScalarOp_H
#include "gpos/base.h"
#include "naucrates/dxl/parser/CParseHandlerMetadataObject.h"
namespace gpdxl
{
using namespace gpos;
XERCES_CPP_NAMESPACE_USE
//---------------------------------------------------------------------------
//	@class:
//		CParseHandlerMDGPDBScalarOp
//
//	@doc:
//		Parse handler for GPDB scalar operator metadata
//
//---------------------------------------------------------------------------
class CParseHandlerMDGPDBScalarOp : public CParseHandlerMetadataObject
{
private:
	// id and version
	IMDId *m_mdid;
	// name
	CMDName *m_mdname;
	// type of left operand
	IMDId *m_mdid_type_left;
	// type of right operand
	IMDId *m_mdid_type_right;
	// type of result operand
	IMDId *m_mdid_type_result;
	// id of function which implements the operator
	IMDId *m_func_mdid;
	// id of commute operator
	IMDId *m_mdid_commute_opr;
	// id of inverse operator
	IMDId *m_mdid_inverse_opr;
	// comparison type
	IMDType::ECmpType m_comparision_type;
	// does operator return NULL on NULL input?
	BOOL m_returns_null_on_null_input;
	IMDId *m_mdid_hash_opfamily;
	IMDId *m_mdid_legacy_hash_opfamily;
	// preserves NDVs of inputs
	BOOL m_is_ndv_preserving;
	// process the start of an element
	void StartElement(
		const XMLCh *const element_uri,			// URI of element's namespace
		const XMLCh *const element_local_name,	// local part of element's name
		const XMLCh *const element_qname,		// element's qname
		const Attributes &attr					// element's attributes
		) override;
	// process the end of an element
	void EndElement(
		const XMLCh *const element_uri,			// URI of element's namespace
		const XMLCh *const element_local_name,	// local part of element's name
		const XMLCh *const element_qname		// element's qname
		) override;
	// is this a supported child elem of the scalar op
	static BOOL IsSupportedChildElem(const XMLCh *const xml_str);
public:
	CParseHandlerMDGPDBScalarOp(const CParseHandlerMDGPDBScalarOp &) = delete;
	// ctor
	CParseHandlerMDGPDBScalarOp(CMemoryPool *mp,
								CParseHandlerManager *parse_handler_mgr,
								CParseHandlerBase *parse_handler_root);
};
}  // namespace gpdxl
#endif	// !GPDXL_CParseHandlerMDGPDBScalarOp_H
// EOF
相关信息
相关文章
greenplumn CParseHandlerAgg 源码
greenplumn CParseHandlerAppend 源码
greenplumn CParseHandlerArray 源码
greenplumn CParseHandlerAssert 源码
greenplumn CParseHandlerBase 源码
greenplumn CParseHandlerBroadcastMotion 源码
greenplumn CParseHandlerCTEConfig 源码
greenplumn CParseHandlerCTEList 源码
                        
                            0
                        
                        
                             赞
                        
                    
                    
                热门推荐
- 
                        2、 - 优质文章
 - 
                        3、 gate.io
 - 
                        7、 openharmony
 - 
                        9、 golang