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.
 
 
 
 
 
 

34 lines
1.2 KiB

// Copyright (c) 1999 Microsoft Corporation. All rights reserved.
//
// Declaration of Expression.
//
#pragma once
#include "engcontrol.h"
// The expression class takes input of a well-formed expression in infix (the order appearing in the script source)
// notation. The blocks are converted to postfix notation and appeanded to the given script's exprs list and followed
// with an _end block.
// A working stack is used to perform the conversion. The stack to use is passed by reference so that the same stack
// may be used to evaluate multiple expressions. This allows the stack to grow as needed until it reaches the max size
// needed to process the expressions, minimizing reallocation thereafter.
class Expression
{
public:
Expression(Script &script, SmartRef::Stack<ExprBlock> &stack, ExprBlocks *peblocks) : m_script(script), m_stack(stack), m_eblocks(peblocks ? *peblocks : m_script.exprs) {}
// Note: For unary - (negation), use TOKEN_sub instead of TOKEN_op_minus.
HRESULT Add(ExprBlock b) { if (b.k == ExprBlock::_end) {assert(false); return E_INVALIDARG;} return m_e.Add(b); }
HRESULT Generate();
private:
HRESULT InfixToPostfix();
private:
ExprBlocks m_e;
Script &m_script;
SmartRef::Stack<ExprBlock> &m_stack;
ExprBlocks &m_eblocks;
};