• Skip to content
  • Skip to link menu
KDE API Reference
  • KDE API Reference
  • kdeedu API Reference
  • KDE Home
  • Contact Us
 

kalgebra

  • sources
  • kde-4.14
  • kdeedu
  • kalgebra
  • mobile
  • declarative
analitzawrapper.cpp
Go to the documentation of this file.
1 /*************************************************************************************
2  * Copyright (C) 2010 by Aleix Pol <aleixpol@kde.org> *
3  * *
4  * This program is free software; you can redistribute it and/or *
5  * modify it under the terms of the GNU General Public License *
6  * as published by the Free Software Foundation; either version 2 *
7  * of the License, or (at your option) any later version. *
8  * *
9  * This program is distributed in the hope that it will be useful, *
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of *
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
12  * GNU General Public License for more details. *
13  * *
14  * You should have received a copy of the GNU General Public License *
15  * along with this program; if not, write to the Free Software *
16  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA *
17  *************************************************************************************/
18 
19 #include "analitzawrapper.h"
20 #include <analitza/analyzer.h>
21 #include <analitza/value.h>
22 #include <analitza/variables.h>
23 #include <analitza/analitzautils.h>
24 #include <analitzagui/variablesmodel.h>
25 
26 #include <QVariant>
27 
28 Q_DECLARE_METATYPE(ExpressionWrapper*);
29 
30 ExpressionWrapper::ExpressionWrapper(QObject* parent)
31  : QObject(parent)
32 {}
33 
34 
35 ExpressionWrapper::ExpressionWrapper(const Analitza::Expression& e, QObject* parent)
36  : QObject(parent)
37  , m_exp(e)
38 {}
39 
40 void ExpressionWrapper::setText(const QString& exp) { m_exp.setText(exp); }
41 
42 bool ExpressionWrapper::isCorrect() const { return m_exp.isCorrect(); }
43 QString ExpressionWrapper::toString() const { return m_exp.toString(); }
44 QVariant ExpressionWrapper::value() const { return AnalitzaUtils::expressionToVariant(m_exp); }
45 QStringList ExpressionWrapper::errors() const { return m_exp.error(); }
46 
48 
49 AnalitzaWrapper::AnalitzaWrapper(QObject* parent)
50  : QObject(parent)
51  , m_wrapped(0), m_calc(false)
52 {
53  initWrapped();
54 }
55 
56 void AnalitzaWrapper::initWrapped()
57 {
58  if(!m_wrapped) {
59  if(m_vars)
60  m_wrapped = new Analitza::Analyzer(m_vars);
61  else {
62  m_wrapped = new Analitza::Analyzer;
63  m_vars = m_wrapped->variables();
64  }
65  }
66 }
67 
68 void AnalitzaWrapper::setVariables(Analitza::Variables* v)
69 {
70  delete m_wrapped;
71  m_wrapped = 0;
72  m_vars = v;
73  initWrapped();
74 }
75 
76 QVariant AnalitzaWrapper::execute(const QString& expression)
77 {
78  initWrapped();
79  Analitza::Expression e(expression, false);
80  if(!e.isCorrect()) {
81  return e.error();
82  }
83  m_wrapped->setExpression(e);
84 
85  Analitza::Expression res;
86  if(m_calc)
87  res = m_wrapped->calculate();
88  else
89  res = m_wrapped->evaluate();
90 
91  if(!m_wrapped->isCorrect())
92  return QVariant();
93 
94  return qVariantFromValue(new ExpressionWrapper(res));
95 }
96 
97 QVariant AnalitzaWrapper::executeFunc(const QString& name, const QVariantList& args)
98 {
99  if(m_vars && !m_vars->contains(name))
100  return QVariant();
101 
102  QStack<Analitza::Object*> stack;
103  QList<Analitza::Expression> exps;
104  foreach(const QVariant& v, args) {
105  exps += AnalitzaUtils::variantToExpression(v);
106  stack << exps.last().tree();
107  }
108 
109  m_wrapped->setExpression(Analitza::Expression(name, false));
110  m_wrapped->setExpression(m_wrapped->calculate());
111  m_wrapped->setStack(stack);
112  Analitza::Expression expr = m_wrapped->calculateLambda();
113 
114  if(!m_wrapped->isCorrect())
115  return QVariant();
116  else
117  return qVariantFromValue(new ExpressionWrapper(expr));
118 }
119 
120 QString AnalitzaWrapper::dependenciesToLambda(const QString& expression) const
121 {
122  m_wrapped->setExpression(Analitza::Expression(expression, false));
123  return m_wrapped->dependenciesToLambda().toString();
124 }
125 
126 void AnalitzaWrapper::insertVariable(const QString& name, const QString& expression) const
127 {
128  m_wrapped->insertVariable(name, Analitza::Expression(expression, false));
129 }
130 
131 QString AnalitzaWrapper::unusedVariableName() const
132 {
133  QString candidate;
134  char curr='a';
135 
136  for(candidate=curr; m_vars->contains(candidate); ) {
137  curr+=1;
138  if(curr>'z')
139  curr='a';
140  else
141  candidate.chop(1);
142 
143  candidate += curr;
144  }
145 
146  return candidate;
147 }
148 
149 void AnalitzaWrapper::removeVariable(const QString& name)
150 {
151  m_vars->remove(name);
152 }
153 
154 bool AnalitzaWrapper::isCorrect() const { return m_wrapped->isCorrect(); }
155 
156 QStringList AnalitzaWrapper::errors() const { return m_wrapped->errors(); }
AnalitzaWrapper::AnalitzaWrapper
AnalitzaWrapper(QObject *parent=0)
Definition: analitzawrapper.cpp:49
AnalitzaWrapper::unusedVariableName
Q_SCRIPTABLE QString unusedVariableName() const
Definition: analitzawrapper.cpp:131
ExpressionWrapper::value
QVariant value() const
Definition: analitzawrapper.cpp:44
QString::chop
void chop(int n)
ExpressionWrapper::setText
void setText(const QString &exp)
Definition: analitzawrapper.cpp:40
AnalitzaWrapper::isCorrect
bool isCorrect() const
ExpressionWrapper::ExpressionWrapper
ExpressionWrapper(QObject *parent=0)
Definition: analitzawrapper.cpp:30
QObject
Q_DECLARE_METATYPE
Q_DECLARE_METATYPE(ExpressionWrapper *)
QString
QList< Analitza::Expression >
AnalitzaWrapper::errors
QStringList errors() const
AnalitzaWrapper::dependenciesToLambda
Q_SCRIPTABLE QString dependenciesToLambda(const QString &expression) const
Definition: analitzawrapper.cpp:120
QStringList
AnalitzaWrapper::execute
Q_SCRIPTABLE QVariant execute(const QString &expression)
Definition: analitzawrapper.cpp:76
AnalitzaWrapper::removeVariable
Q_SCRIPTABLE void removeVariable(const QString &name)
Definition: analitzawrapper.cpp:149
analitzawrapper.h
AnalitzaWrapper::insertVariable
Q_SCRIPTABLE void insertVariable(const QString &name, const QString &expression) const
Definition: analitzawrapper.cpp:126
ExpressionWrapper::toString
QString toString() const
Definition: analitzawrapper.cpp:43
ExpressionWrapper::errors
QStringList errors() const
Definition: analitzawrapper.cpp:45
QList::last
T & last()
AnalitzaWrapper::setVariables
void setVariables(Analitza::Variables *v)
Definition: analitzawrapper.cpp:68
AnalitzaWrapper::executeFunc
Q_SCRIPTABLE QVariant executeFunc(const QString &name, const QVariantList &args)
Definition: analitzawrapper.cpp:97
ExpressionWrapper
Definition: analitzawrapper.h:31
ExpressionWrapper::isCorrect
bool isCorrect() const
Definition: analitzawrapper.cpp:42
QStack
QVariant
This file is part of the KDE documentation.
Documentation copyright © 1996-2020 The KDE developers.
Generated on Mon Jun 22 2020 13:11:49 by doxygen 1.8.7 written by Dimitri van Heesch, © 1997-2006

KDE's Doxygen guidelines are available online.

kalgebra

Skip menu "kalgebra"
  • Main Page
  • Namespace List
  • Alphabetical List
  • Class List
  • Class Hierarchy
  • Class Members
  • File List
  • File Members

kdeedu API Reference

Skip menu "kdeedu API Reference"
  • Analitza
  •     lib
  • kalgebra
  • kalzium
  •   libscience
  • kanagram
  • kig
  •   lib
  • klettres
  • marble
  • parley
  • rocs
  •   App
  •   RocsCore
  •   VisualEditor
  •   stepcore

Search



Report problems with this website to our bug tracking system.
Contact the specific authors with questions and comments about the page contents.

KDE® and the K Desktop Environment® logo are registered trademarks of KDE e.V. | Legal