mirror of
https://github.com/UpsilonNumworks/Upsilon.git
synced 2026-01-19 00:37:25 +01:00
46 lines
844 B
C++
46 lines
844 B
C++
#include "equation.h"
|
|
|
|
using namespace Poincare;
|
|
|
|
namespace Solver {
|
|
|
|
Equation::Equation() :
|
|
Shared::ExpressionModel(),
|
|
m_standardForm(nullptr)
|
|
{
|
|
}
|
|
|
|
Equation& Equation::operator=(const Equation& other) {
|
|
Shared::ExpressionModel::operator=(other);
|
|
return *this;
|
|
}
|
|
|
|
Equation::~Equation() {
|
|
if (m_standardForm) {
|
|
delete m_standardForm;
|
|
m_standardForm = nullptr;
|
|
}
|
|
}
|
|
|
|
void Equation::setContent(const char * c) {
|
|
tidy();
|
|
ExpressionModel::setContent(c);
|
|
}
|
|
|
|
void Equation::tidy() {
|
|
ExpressionModel::tidy();
|
|
if (m_standardForm) {
|
|
delete m_standardForm;
|
|
m_standardForm = nullptr;
|
|
}
|
|
}
|
|
|
|
Expression * Equation::standardForm(Context * context) const {
|
|
if (m_standardForm == nullptr) {
|
|
m_standardForm = static_cast<const Equal *>(expression(context))->standardEquation(*context);
|
|
}
|
|
return m_standardForm;
|
|
}
|
|
|
|
}
|