Logo Search packages:      
Sourcecode: yacas version File versions  Download package

yacas.h

Go to the documentation of this file.
/// \file
/// Definitions of DefaultYacasEnvironment and CYacas.

#ifndef __yacas_h__
#define __yacas_h__

#include "yacasbase.h"
#include "lispstring.h"
#include "stringio.h"
#include "tokenizer.h"
#include "lisphash.h"
#include "lispevalhash.h"
#include "infixparser.h"
#include "stdfileio.h"
#include "lispatom.h"
#include "lispeval.h"
#include "mathenvironment.h"
#include "lispglobals.h"
#include "lisperror.h"
#include "lispuserfunc.h"


/// The default environment for a Yacas session.
/// This class constructs a LispEnvironment (to be found in
/// #iEnvironment), and defines the Yacas core functions. The core
/// functions are listed in corefunctions.h . Examples of core
/// functions are \c Head, \c Set and \c Eval.

00029 class DefaultYacasEnvironment : public YacasBase
{
public:
    DefaultYacasEnvironment();
    DefaultYacasEnvironment(LispOutput* aOutput, LispInt aStackSize);
    virtual ~DefaultYacasEnvironment();
    LispEnvironment& operator() () {return iEnvironment;}
    
private:
    LispOutput* output;
    LispHashTable hash;
    LispPrinter printer;

    YacasCoreCommands coreCommands;
    LispGlobal globals;

    //Define the default operators.
    LispOperators prefixoperators;
    LispOperators infixoperators;
    LispOperators postfixoperators;
    LispOperators bodiedoperators;
    InfixPrinter infixprinter;

    LispUserFunctions userFunctions;

    LispEnvironment iEnvironment;

public:
    CachedStdUserInput input;
};


/// The Yacas engine.
/// This is the only class that applications need to use. It can
/// evaluate Yacas expressions. Every instance has its own Yacas
/// environment, in which the expressions are evaluated.

00066 class CYacas : public YacasBase
{
public:

    /// Pseudo-constructor.
    /// \return A new instance of CYacas, with output connected to a
    /// new instance of StdUserOutput. 
    LISPIMPORT static CYacas* NewL(LispInt aStackSize=50000); 

    /// Pseudo-constructor.
    /// \return A new instance of CYacas, with output connected to \p
    /// aOutput. 
    LISPIMPORT static CYacas* NewL(LispOutput* aOutput,LispInt aStackSize=50000); 

    /// Destructor.
    LISPIMPORT virtual ~CYacas();

    /// Return the underlying Yacas environment.
00084     inline DefaultYacasEnvironment& operator()() {return environment;}

    /// Evaluate a Yacas expression.
    /// First, \p aExpression is parsed by an InfixParser. Then it is
    /// evaluated in the underlying Lisp environment. Finally, the
    /// result is printed to #iResultOutput via the pretty printer or,
    /// if this is not defined, via an InfixPrinter.
    virtual void Evaluate(const LispCharPtr aExpression);

    /// Return the result of the expression.
    /// This is stored in #iResult.
    virtual LispCharPtr Result();

    /// Return the error message produced by the last evaluation.
    /// The error is retrieved from #environment.
    virtual LispCharPtr Error();

    /// Whether an error occured during the last evaluation.
    inline LispBoolean IsError();

private:
    
    /// Constructor.
    /// The output of #environment is directed to \p aOutput.
    CYacas(LispOutput* aOutput,LispInt aStackSize);

private:

    /// The underlying Yacas environment  
00113     DefaultYacasEnvironment environment;

    /// String containing the result of the last evaluation
00116     LispString iResult;

    /// Stream pointing to #iResult.
00119     StringOutput iResultOutput;
};

00122 inline LispBoolean CYacas::IsError()
{
    return (Error()[0] != '\0');
}

#endif



Generated by  Doxygen 1.6.0   Back to index