/** \file infixparser.h * parsing and printing in the infix style. * */ #ifndef __infixparser_h__ #define __infixparser_h__ #include "yacasbase.h" #include "lispparser.h" #define KMaxPrecedence 60000 class LispInFixOperator : public YacasBase { public: inline LispInFixOperator(LispInt aPrecedence) : iPrecedence(aPrecedence), iLeftPrecedence(aPrecedence), iRightPrecedence(aPrecedence), iRightAssociative(0) {}; inline void SetRightAssociative(void) { iRightAssociative = 1; } inline void SetLeftPrecedence(LispInt aPrecedence) { iLeftPrecedence = aPrecedence; } inline void SetRightPrecedence(LispInt aPrecedence) { iRightPrecedence = aPrecedence; } public: LispInt iPrecedence; LispInt iLeftPrecedence; LispInt iRightPrecedence; LispInt iRightAssociative; }; class LispOperators : public LispAssociatedHash<LispInFixOperator> { public: void SetOperator(LispInt aPrecedence,LispString * aString); void SetRightAssociative(LispString * aString); void SetLeftPrecedence(LispString * aString,LispInt aPrecedence); void SetRightPrecedence(LispString * aString,LispInt aPrecedence); }; class InfixParser : public LispParser { public: InfixParser(LispTokenizer& aTokenizer, LispInput& aInput, LispEnvironment& aEnvironment, LispOperators& aPrefixOperators, LispOperators& aInfixOperators, LispOperators& aPostfixOperators, LispOperators& aBodiedOperators); ~InfixParser(); virtual void Parse(LispPtr& aResult); //private: void ParseCont(LispPtr& aResult); public: LispOperators& iPrefixOperators; LispOperators& iInfixOperators; LispOperators& iPostfixOperators; LispOperators& iBodiedOperators; // LispEnvironment* iEnvironment; }; class ParsedObject : public YacasBase { public: ParsedObject(InfixParser& aParser) : iParser(aParser), iError(LispFalse), iEndOfFile(LispFalse), iLookAhead(NULL),iResult() {}; void Parse(); private: void ReadToken(); void MatchToken(LispString * aToken); void ReadExpression(LispInt depth); void ReadAtom(); private: void GetOtherSide(LispInt aNrArgsToCombine, LispInt depth); void Combine(LispInt aNrArgsToCombine); void InsertAtom(LispString * aString); private: void Fail(); // called when parsing fails, raising an exception private: InfixParser& iParser; private: LispBoolean iError; LispBoolean iEndOfFile; LispString * iLookAhead; public: LispPtr iResult; }; class InfixPrinter : public LispPrinter { public: InfixPrinter(LispOperators& aPrefixOperators, LispOperators& aInfixOperators, LispOperators& aPostfixOperators, LispOperators& aBodiedOperators) : iPrefixOperators(aPrefixOperators), iInfixOperators(aInfixOperators), iPostfixOperators(aPostfixOperators), iBodiedOperators(aBodiedOperators), iPrevLastChar(0),iCurrentEnvironment(NULL){} virtual void Print(LispPtr& aExpression, LispOutput& aOutput, LispEnvironment& aEnvironment); virtual void RememberLastChar(LispChar aChar); private: void Print(LispPtr& aExpression, LispOutput& aOutput, LispInt iPrecedence); void WriteToken(LispOutput& aOutput,LispChar * aString); private: LispOperators& iPrefixOperators; LispOperators& iInfixOperators; LispOperators& iPostfixOperators; LispOperators& iBodiedOperators; LispChar iPrevLastChar; LispEnvironment* iCurrentEnvironment; }; #endif