summaryrefslogtreecommitdiff
path: root/starmath
diff options
context:
space:
mode:
authorTakeshi Abe <tabe@fixedpoint.jp>2016-06-07 17:28:40 +0900
committerTakeshi Abe <tabe@fixedpoint.jp>2016-06-08 06:26:48 +0000
commit261f734b3c0e62ada51485ba81a535d32049c946 (patch)
treebb601110bd295659393ca00427888a27ec564ac4 /starmath
parentd106ffc5f1c611657e7ccd96ac9dab70cc7ebe53 (diff)
starmath: The formula tree must be of type SmTableNode
This also omits the last push & pop on m_aNodeStack at the end of parsing. Change-Id: Iefff8fa801ea7cb9015d6cba0d5a972dee675cb7 Reviewed-on: https://gerrit.libreoffice.org/26003 Tested-by: Jenkins <ci@libreoffice.org> Reviewed-by: Takeshi Abe <tabe@fixedpoint.jp>
Diffstat (limited to 'starmath')
-rw-r--r--starmath/inc/document.hxx6
-rw-r--r--starmath/inc/node.hxx4
-rw-r--r--starmath/inc/parse.hxx4
-rw-r--r--starmath/source/mathmlimport.cxx6
-rw-r--r--starmath/source/node.cxx6
-rw-r--r--starmath/source/parse.cxx13
6 files changed, 14 insertions, 25 deletions
diff --git a/starmath/inc/document.hxx b/starmath/inc/document.hxx
index 1b519265a653..667102d5be44 100644
--- a/starmath/inc/document.hxx
+++ b/starmath/inc/document.hxx
@@ -91,7 +91,7 @@ class SM_DLLPUBLIC SmDocShell : public SfxObjectShell, public SfxListener
SmFormat maFormat;
SmParser maParser;
OUString maAccText;
- SmNode *mpTree;
+ SmTableNode *mpTree;
SfxItemPool *mpEditEngineItemPool;
EditEngine *mpEditEngine;
VclPtr<SfxPrinter> mpPrinter; //q.v. comment to SmPrinter Access!
@@ -177,8 +177,8 @@ public:
void Parse();
SmParser & GetParser() { return maParser; }
- const SmNode * GetFormulaTree() const { return mpTree; }
- void SetFormulaTree(SmNode *&rTree) { mpTree = rTree; }
+ const SmTableNode *GetFormulaTree() const { return mpTree; }
+ void SetFormulaTree(SmTableNode *pTree) { mpTree = pTree; }
const std::set< OUString > & GetUsedSymbols() const { return maUsedSymbols; }
diff --git a/starmath/inc/node.hxx b/starmath/inc/node.hxx
index 9e092693a9bf..af03a7be183f 100644
--- a/starmath/inc/node.hxx
+++ b/starmath/inc/node.hxx
@@ -189,8 +189,6 @@ public:
const SmNode * FindTokenAt(sal_uInt16 nRow, sal_uInt16 nCol) const;
const SmNode * FindRectClosestTo(const Point &rPoint) const;
- virtual long GetFormulaBaseline() const;
-
/** Accept a visitor
* Calls the method for this class on the visitor
*/
@@ -678,7 +676,7 @@ public:
virtual const SmNode * GetLeftMost() const override;
virtual void Arrange(OutputDevice &rDev, const SmFormat &rFormat) override;
- virtual long GetFormulaBaseline() const override;
+ long GetFormulaBaseline() const;
void Accept(SmVisitor* pVisitor) override;
};
diff --git a/starmath/inc/parse.hxx b/starmath/inc/parse.hxx
index 3ebeb2c1e2ee..2c8e9b2ea0d9 100644
--- a/starmath/inc/parse.hxx
+++ b/starmath/inc/parse.hxx
@@ -59,7 +59,7 @@ class SmParser
inline bool TokenInGroup( TG nGroup );
// grammar
- void DoTable();
+ SmTableNode *DoTable();
void DoLine();
void DoExpression();
void DoRelation();
@@ -99,7 +99,7 @@ public:
SmParser();
/** Parse rBuffer to formula tree */
- SmNode *Parse(const OUString &rBuffer);
+ SmTableNode *Parse(const OUString &rBuffer);
/** Parse rBuffer to formula subtree that constitutes an expression */
SmNode *ParseExpression(const OUString &rBuffer);
diff --git a/starmath/source/mathmlimport.cxx b/starmath/source/mathmlimport.cxx
index 5be05264945a..03accbf79cff 100644
--- a/starmath/source/mathmlimport.cxx
+++ b/starmath/source/mathmlimport.cxx
@@ -484,8 +484,8 @@ void SmXMLImport::endDocument()
throw(xml::sax::SAXException, uno::RuntimeException, std::exception)
{
//Set the resulted tree into the SmDocShell where it belongs
- SmNode *pTree;
- if (nullptr != (pTree = GetTree()))
+ SmNode *pTree = GetTree();
+ if (pTree && pTree->GetType() == NTABLE)
{
uno::Reference <frame::XModel> xModel = GetModel();
uno::Reference <lang::XUnoTunnel> xTunnel(xModel,uno::UNO_QUERY);
@@ -496,7 +496,7 @@ void SmXMLImport::endDocument()
{
SmDocShell *pDocShell =
static_cast<SmDocShell*>(pModel->GetObjectShell());
- pDocShell->SetFormulaTree(pTree);
+ pDocShell->SetFormulaTree(static_cast<SmTableNode *>(pTree));
if (aText.isEmpty()) //If we picked up no annotation text
{
// Get text from imported formula
diff --git a/starmath/source/node.cxx b/starmath/source/node.cxx
index 71c48ba3bfe4..8f7f52cdeb71 100644
--- a/starmath/source/node.cxx
+++ b/starmath/source/node.cxx
@@ -393,12 +393,6 @@ const SmNode * SmNode::FindNodeWithAccessibleIndex(sal_Int32 nAccIdx) const
return pResult;
}
-long SmNode::GetFormulaBaseline() const
-{
- SAL_WARN("starmath", "This dummy implementation should not have been called.");
- return 0;
-}
-
SmStructureNode::~SmStructureNode()
{
diff --git a/starmath/source/parse.cxx b/starmath/source/parse.cxx
index 591404af14a1..5674e3dd4f38 100644
--- a/starmath/source/parse.cxx
+++ b/starmath/source/parse.cxx
@@ -944,7 +944,7 @@ void SmParser::NextToken()
// grammar
-void SmParser::DoTable()
+SmTableNode *SmParser::DoTable()
{
DoLine();
while (m_aCurToken.eType == TNEWLINE)
@@ -962,9 +962,9 @@ void SmParser::DoTable()
*rIt = popOrZero(m_aNodeStack);
}
- std::unique_ptr<SmStructureNode> pSNode(new SmTableNode(m_aCurToken));
+ std::unique_ptr<SmTableNode> pSNode(new SmTableNode(m_aCurToken));
pSNode->SetSubNodes(LineArray);
- m_aNodeStack.push_front(std::move(pSNode));
+ return pSNode.release();
}
void SmParser::DoAlign()
@@ -2326,7 +2326,7 @@ SmParser::SmParser()
{
}
-SmNode *SmParser::Parse(const OUString &rBuffer)
+SmTableNode *SmParser::Parse(const OUString &rBuffer)
{
ClearUsedSymbols();
@@ -2342,10 +2342,7 @@ SmNode *SmParser::Parse(const OUString &rBuffer)
m_aNodeStack.clear();
NextToken();
- DoTable();
-
- SmNode* result = popOrZero(m_aNodeStack);
- return result;
+ return DoTable();
}
SmNode *SmParser::ParseExpression(const OUString &rBuffer)