Source code of Windows XP (NT5)
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
|
|
/*++
// Copyright (c) 1999-2001 Microsoft Corporation, All Rights Reserved
Module Name:
SQL_1.H
Abstract:
Level 1 Syntax SQL Parser
History:
--*/
#ifndef _SQL_1_H_
#define _SQL_1_H_
struct SQL_LEVEL_1_TOKEN { enum { OP_EXPRESSION = 1, TOKEN_AND, TOKEN_OR, TOKEN_NOT }; enum { IFUNC_NONE = 0, IFUNC_UPPER = 1, IFUNC_LOWER = 2 };
int nTokenType; // OP_EXPRESSION,TOKEN_AND, TOKEN_OR, TOKEN_NOT
// If the field is a OP_EXPRESSION, then the following are used.
enum { OP_EQUAL = 1, OP_NOT_EQUAL, OP_EQUALorGREATERTHAN, OP_EQUALorLESSTHAN, OP_LESSTHAN, OP_GREATERTHAN, OP_LIKE }; BSTR pPropertyName; // Name of the property on which the operator is applied
int nOperator; // Operator that is applied on property
BOOL bConstIsStrNumeric; // True if the vConstValue is a BSTR and is a UINT32 or any 64bit number
VARIANT vConstValue; // Value applied by operator
BSTR pPropName2; // Property compared to.
DWORD dwPropertyFunction; // 0=no instrinsic function applied
DWORD dwConstFunction; // "
SQL_LEVEL_1_TOKEN(); SQL_LEVEL_1_TOKEN(SQL_LEVEL_1_TOKEN&); ~SQL_LEVEL_1_TOKEN(); SQL_LEVEL_1_TOKEN& operator=(SQL_LEVEL_1_TOKEN &Src); void Dump(FILE *); };
// Contains RPN version of expression.
// ===================================
struct SQL_LEVEL_1_RPN_EXPRESSION { int nNumTokens; int nCurSize; SQL_LEVEL_1_TOKEN *pArrayOfTokens; BSTR bsClassName;
int nNumberOfProperties; // Zero means all properties selected
int nCurPropSize; BSTR *pbsRequestedPropertyNames; // Array of property names which values are to be returned if
SQL_LEVEL_1_RPN_EXPRESSION(); ~SQL_LEVEL_1_RPN_EXPRESSION(); //Note: this method deletes the token it is passed as an argument
void AddToken(SQL_LEVEL_1_TOKEN *pTok); void AddToken(SQL_LEVEL_1_TOKEN &pTok); void AddProperty(LPWSTR pProp); void Dump(const char *pszTextFile); };
class SQL1_Parser { CGenLexer *m_pLexer; int m_nLine; wchar_t* m_pTokenText; int m_nCurrentToken; SQL_LEVEL_1_RPN_EXPRESSION* m_pExpression;
//Cleanup used by d'tor and SetSource
void Cleanup();
//Init used by c'tor and SetSource
void Init(CGenLexSource *pSrc);
// Semantic transfer variables.
// ============================
VARIANT m_vTypedConst; int m_nRelOp; DWORD m_dwConstFunction; DWORD m_dwPropFunction; LPWSTR m_pIdent; LPWSTR m_pPropComp; BOOL m_bConstIsStrNumeric; // Parsing functions.
// ==================
BOOL Next(); int parse();
int prop_list(); int class_name(); int opt_where(); int expr(); int property_name(); int prop_list_2(); int term(); int expr2(); int simple_expr(); int term2(); int leading_ident_expr(); int finalize(); int rel_operator(); int equiv_operator(); int comp_operator(); int is_operator(); int trailing_prop_expr(); int trailing_prop_expr2(); int trailing_or_null(); int trailing_const_expr(); int unknown_func_expr(); int typed_constant();
public: enum { SUCCESS, SYNTAX_ERROR, LEXICAL_ERROR, FAILED, BUFFER_TOO_SMALL };
SQL1_Parser(CGenLexSource *pSrc); ~SQL1_Parser();
int GetQueryClass(LPWSTR pBuf, int nBufSize); int Parse(SQL_LEVEL_1_RPN_EXPRESSION **pOutput); // use operator delete on pOutput
int CurrentLine() { return m_nLine; } LPWSTR CurrentToken() { return m_pTokenText; } void SetSource(CGenLexSource *pSrc); };
#endif
|