summaryrefslogtreecommitdiff
path: root/starmath
diff options
context:
space:
mode:
authorTakeshi Abe <tabe@fixedpoint.jp>2016-05-31 15:01:49 +0900
committerMichael Stahl <mstahl@redhat.com>2016-05-31 16:15:30 +0000
commit09981cd6383ecb99e4b6c83b98b03af5cf3ff59b (patch)
treed06db24d172ea9f7e5b8c052618e268d3014cfe9 /starmath
parenta61063ca2cce4753a061693a50cccab95865ad6b (diff)
Use std::vector for SmCaretPosGraph
instead of employing ad hoc linked list and its iterator. Change-Id: Ibc4709a2e67aa805cf54117303c47d9a8a5eede9 Reviewed-on: https://gerrit.libreoffice.org/25699 Tested-by: Jenkins <ci@libreoffice.org> Reviewed-by: Michael Stahl <mstahl@redhat.com>
Diffstat (limited to 'starmath')
-rw-r--r--starmath/inc/caret.hxx71
-rw-r--r--starmath/source/caret.cxx45
-rw-r--r--starmath/source/cursor.cxx47
3 files changed, 56 insertions, 107 deletions
diff --git a/starmath/inc/caret.hxx b/starmath/inc/caret.hxx
index 0dff68094a18..de13ac97a32f 100644
--- a/starmath/inc/caret.hxx
+++ b/starmath/inc/caret.hxx
@@ -15,6 +15,9 @@
#include "node.hxx"
+#include <memory>
+#include <vector>
+
/** Representation of caret position with an equation */
struct SmCaretPos{
SmCaretPos(SmNode* selectedNode = nullptr, int iIndex = 0) {
@@ -117,74 +120,34 @@ struct SmCaretPosGraphEntry{
}
};
-class SmCaretPosGraph;
-
-/** Iterator for SmCaretPosGraph */
-class SmCaretPosGraphIterator{
-public:
- SmCaretPosGraphIterator(SmCaretPosGraph* graph){
- pGraph = graph;
- nOffset = 0;
- pEntry = nullptr;
- }
- /** Get the next entry, NULL if none */
- SmCaretPosGraphEntry* Next();
- /** Get the current entry, NULL if none */
- SmCaretPosGraphEntry* Current(){
- return pEntry;
- }
- /** Get the current entry, NULL if none */
- SmCaretPosGraphEntry* operator->(){
- return pEntry;
- }
-private:
- /** Next entry to return */
- int nOffset;
- /** Current graph */
- SmCaretPosGraph* pGraph;
- /** Current entry */
- SmCaretPosGraphEntry* pEntry;
-};
-
-
/** A graph over all caret positions
* @remarks Graphs can only grow, entries cannot be removed!
*/
class SmCaretPosGraph{
public:
- SmCaretPosGraph(){
- pNext = nullptr;
- nOffset = 0;
- }
+ SmCaretPosGraph();
+
~SmCaretPosGraph();
- /** Add a caret position
- * @remarks If Left and/or Right are set NULL, they will point back to the entry.
- */
- SmCaretPosGraphEntry* Add(SmCaretPosGraphEntry entry);
+
/** Add a caret position
* @remarks If left and/or right are set NULL, they will point back to the entry.
*/
SmCaretPosGraphEntry* Add(SmCaretPos pos,
SmCaretPosGraphEntry* left = nullptr,
- SmCaretPosGraphEntry* right = nullptr){
- SAL_WARN_IF( pos.Index < 0, "starmath", "Index shouldn't be -1!" );
- return Add(SmCaretPosGraphEntry(pos, left, right));
+ SmCaretPosGraphEntry* right = nullptr);
+
+ std::vector<std::unique_ptr<SmCaretPosGraphEntry>>::iterator begin()
+ {
+ return mvEntries.begin();
}
- /** Get an iterator for this graph */
- SmCaretPosGraphIterator GetIterator(){
- return SmCaretPosGraphIterator(this);
+
+ std::vector<std::unique_ptr<SmCaretPosGraphEntry>>::iterator end()
+ {
+ return mvEntries.end();
}
- friend class SmCaretPosGraphIterator;
-private:
- /** Define SmCaretPosGraph to be less than one page 4096 */
- static const int SmCaretPosGraphSize = 255;
- /** Next graph, to be used when this graph is full */
- SmCaretPosGraph* pNext;
- /** Next free entry in graph */
- int nOffset;
- /** Entries in this graph segment */
- SmCaretPosGraphEntry Graph[SmCaretPosGraphSize];
+private:
+ std::vector<std::unique_ptr<SmCaretPosGraphEntry>> mvEntries;
};
/** \page visual_formula_editing Visual Formula Editing
diff --git a/starmath/source/caret.cxx b/starmath/source/caret.cxx
index 5801fea30e6a..1a79d50d3c2b 100644
--- a/starmath/source/caret.cxx
+++ b/starmath/source/caret.cxx
@@ -8,39 +8,24 @@
*/
#include "caret.hxx"
-/////////////////////////////// SmCaretPosGraph
+#include <o3tl/make_unique.hxx>
-SmCaretPosGraphEntry* SmCaretPosGraphIterator::Next(){
- if(nOffset >= pGraph->nOffset){
- if(pGraph->pNext){
- pGraph = pGraph->pNext;
- nOffset = 0;
- pEntry = Next();
- }else
- pEntry = nullptr;
- }else
- pEntry = pGraph->Graph + nOffset++;
- return pEntry;
-}
+SmCaretPosGraph::SmCaretPosGraph() = default;
-SmCaretPosGraphEntry* SmCaretPosGraph::Add(SmCaretPosGraphEntry entry){
- if(nOffset >= SmCaretPosGraphSize){
- if(!pNext)
- pNext = new SmCaretPosGraph();
- return pNext->Add(entry);
- }else{
- //Set Left and Right to point to the entry itself if they are NULL
- entry.Left = entry.Left ? entry.Left : Graph + nOffset;
- entry.Right = entry.Right ? entry.Right : Graph + nOffset;
- //Save the entry
- Graph[nOffset] = entry;
- return Graph + nOffset++;
- }
-}
+SmCaretPosGraph::~SmCaretPosGraph() = default;
-SmCaretPosGraph::~SmCaretPosGraph(){
- delete pNext;
- pNext = nullptr;
+SmCaretPosGraphEntry* SmCaretPosGraph::Add(SmCaretPos pos,
+ SmCaretPosGraphEntry* left,
+ SmCaretPosGraphEntry* right)
+{
+ SAL_WARN_IF( pos.Index < 0, "starmath", "Index shouldn't be -1!" );
+ auto entry = o3tl::make_unique<SmCaretPosGraphEntry>(pos, left, right);
+ SmCaretPosGraphEntry* e = entry.get();
+ //Set Left and Right to point to the entry itself if they are NULL
+ entry->Left = entry->Left ? entry->Left : e;
+ entry->Right = entry->Right ? entry->Right : e;
+ mvEntries.push_back(std::move(entry));
+ return e;
}
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
diff --git a/starmath/source/cursor.cxx b/starmath/source/cursor.cxx
index de4439c1e84d..617e100670d6 100644
--- a/starmath/source/cursor.cxx
+++ b/starmath/source/cursor.cxx
@@ -36,12 +36,12 @@ void SmCursor::Move(OutputDevice* pDev, SmMovementDirection direction, bool bMov
best_line, //Best approximated line found so far
curr_line; //Current line
long dbp_sq = 0; //Distance squared to best line
- SmCaretPosGraphIterator it = mpGraph->GetIterator();
- while(it.Next()){
+ for(auto &pEntry : *mpGraph)
+ {
//Reject it if it's the current position
- if(it->CaretPos == mpPosition->CaretPos) continue;
+ if(pEntry->CaretPos == mpPosition->CaretPos) continue;
//Compute caret line
- curr_line = SmCaretPos2LineVisitor(pDev, it->CaretPos).GetResult();
+ curr_line = SmCaretPos2LineVisitor(pDev, pEntry->CaretPos).GetResult();
//Reject anything above if we're moving down
if(curr_line.GetTop() <= from_line.GetTop() && direction == MoveDown) continue;
//Reject anything below if we're moving up
@@ -57,7 +57,7 @@ void SmCursor::Move(OutputDevice* pDev, SmMovementDirection direction, bool bMov
}
//Take current line as the best
best_line = curr_line;
- NewPos = it.Current();
+ NewPos = pEntry.get();
//Update distance to best line
dbp_sq = best_line.SquaredDistanceX(from_line) * HORIZONTICAL_DISTANCE_FACTOR +
best_line.SquaredDistanceY(from_line);
@@ -80,11 +80,11 @@ void SmCursor::MoveTo(OutputDevice* pDev, Point pos, bool bMoveAnchor){
SmCaretPosGraphEntry* NewPos = nullptr;
long dp_sq = 0, //Distance to current line squared
dbp_sq = 1; //Distance to best line squared
- SmCaretPosGraphIterator it = mpGraph->GetIterator();
- while(it.Next()){
- OSL_ENSURE(it->CaretPos.IsValid(), "The caret position graph may not have invalid positions!");
+ for(auto &pEntry : *mpGraph)
+ {
+ OSL_ENSURE(pEntry->CaretPos.IsValid(), "The caret position graph may not have invalid positions!");
//Compute current line
- curr_line = SmCaretPos2LineVisitor(pDev, it->CaretPos).GetResult();
+ curr_line = SmCaretPos2LineVisitor(pDev, pEntry->CaretPos).GetResult();
//If we have a position compare to it
if(NewPos){
//Compute squared distance to current line
@@ -94,7 +94,7 @@ void SmCursor::MoveTo(OutputDevice* pDev, Point pos, bool bMoveAnchor){
}
//Accept current position as the best
best_line = curr_line;
- NewPos = it.Current();
+ NewPos = pEntry.get();
//Update distance to best line
dbp_sq = best_line.SquaredDistanceX(pos) + best_line.SquaredDistanceY(pos);
}
@@ -126,18 +126,18 @@ void SmCursor::BuildGraph(){
//Restore anchor and position pointers
if(_anchor.IsValid() || _position.IsValid()){
- SmCaretPosGraphIterator it = mpGraph->GetIterator();
- while(it.Next()){
- if(_anchor == it->CaretPos)
- mpAnchor = it.Current();
- if(_position == it->CaretPos)
- mpPosition = it.Current();
+ for(auto &pEntry : *mpGraph)
+ {
+ if(_anchor == pEntry->CaretPos)
+ mpAnchor = pEntry.get();
+ if(_position == pEntry->CaretPos)
+ mpPosition = pEntry.get();
}
}
//Set position and anchor to first caret position
- SmCaretPosGraphIterator it = mpGraph->GetIterator();
+ auto it = mpGraph->begin();
if(!mpPosition)
- mpPosition = it.Next();
+ mpPosition = (it == mpGraph->end()) ? nullptr : it->get();
if(!mpAnchor)
mpAnchor = mpPosition;
@@ -146,11 +146,12 @@ void SmCursor::BuildGraph(){
}
bool SmCursor::SetCaretPosition(SmCaretPos pos){
- SmCaretPosGraphIterator it = mpGraph->GetIterator();
- while(it.Next()){
- if(it->CaretPos == pos){
- mpPosition = it.Current();
- mpAnchor = it.Current();
+ for(auto &pEntry : *mpGraph)
+ {
+ if(pEntry->CaretPos == pos)
+ {
+ mpPosition = pEntry.get();
+ mpAnchor = pEntry.get();
return true;
}
}