[Libreoffice-commits] .: sw/source
Libreoffice Gerrit user
logerrit at kemper.freedesktop.org
Thu Nov 1 10:04:02 PDT 2012
sw/source/core/docnode/node2lay.cxx | 99 ++++++++++++++++++------------------
1 file changed, 51 insertions(+), 48 deletions(-)
New commits:
commit c1cc17bcc96b188d313a89bc31c64d6187aa60ce
Author: Philipp Weissenbacher <p.weissenbacher at gmail.com>
Date: Thu Nov 1 00:05:15 2012 +0100
Translate German comments
Change-Id: I8cf27a705332c6e7ea62474c78d59911406d378e
Reviewed-on: https://gerrit.libreoffice.org/954
Reviewed-by: Michael Stahl <mstahl at redhat.com>
Tested-by: Michael Stahl <mstahl at redhat.com>
diff --git a/sw/source/core/docnode/node2lay.cxx b/sw/source/core/docnode/node2lay.cxx
index 5af266b..0690e72 100644
--- a/sw/source/core/docnode/node2lay.cxx
+++ b/sw/source/core/docnode/node2lay.cxx
@@ -41,25 +41,25 @@
#include "section.hxx"
#include "node2lay.hxx"
-/* --------------------------------------------------
- * Die SwNode2LayImpl-Klasse erledigt die eigentliche Arbeit,
- * die SwNode2Layout-Klasse ist nur die der Oefffentlichkeit bekannte Schnittstelle
- * --------------------------------------------------*/
+/**
+ * The SwNode2LayImpl class does the actual work, the SwNode2Layout class is
+ * just the public interface.
+ */
class SwNode2LayImpl
{
SwIterator<SwFrm,SwModify>* pIter;
SwModify* pMod;
- std::vector<SwFrm*>* pUpperFrms;// Zum Einsammeln der Upper
- sal_uLong nIndex; // Der Index des einzufuegenden Nodes
- sal_Bool bMaster : 1; // sal_True => nur Master , sal_False => nur Frames ohne Follow
- sal_Bool bInit : 1; // Ist am SwClient bereits ein First()-Aufruf erfolgt?
+ std::vector<SwFrm*>* pUpperFrms; // To collect the Upper
+ sal_uLong nIndex; // The Index of the to-be-inserted Nodes
+ sal_Bool bMaster : 1; // sal_True => only Master, sal_False => only Frames without Follow
+ sal_Bool bInit : 1; // Did we already call First() at SwClient?
public:
SwNode2LayImpl( const SwNode& rNode, sal_uLong nIdx, sal_Bool bSearch );
~SwNode2LayImpl() { delete pIter; delete pUpperFrms; }
- SwFrm* NextFrm(); // liefert den naechsten "sinnvollen" Frame
+ SwFrm* NextFrm(); // Returns the next "useful" Frame
SwLayoutFrm* UpperFrm( SwFrm* &rpFrm, const SwNode &rNode );
- void SaveUpperFrms(); // Speichert (und lockt ggf.) die pUpper
- // Fuegt unter jeden pUpper des Arrays einen Frame ein.
+ void SaveUpperFrms(); // Saves (and locks if needed) the pUpper
+ // Inserts a Frame under every pUpper of the array
void RestoreUpperFrms( SwNodes& rNds, sal_uLong nStt, sal_uLong nEnd );
SwFrm* GetFrm( const Point* pDocPos = 0,
@@ -67,15 +67,15 @@ public:
const sal_Bool bCalcFrm = sal_True ) const;
};
-/* --------------------------------------------------
- * Hauptaufgabe des Ctor: Das richtige SwModify zu ermitteln,
- * ueber das iteriert wird.
- * Uebergibt man bSearch == sal_True, so wird der naechste Cntnt- oder TableNode
- * gesucht, der Frames besitzt ( zum Einsammeln der pUpper ), ansonsten wird
- * erwartet, das rNode bereits auf einem solchen Cntnt- oder TableNode sitzt,
- * vor oder hinter den eingefuegt werden soll.
- * --------------------------------------------------*/
-
+/**
+ * The main purpose of this ctor is to find the right SwModify to iterate over.
+ *
+ * @param bSearch sal_True: find the next Content or TableNode which contains
+ * Frames (to collect the pUpper).
+ * Else we assume that rNode points already to such a
+ * Content or TableNode.
+ * We insert before or after it.
+ */
SwNode* GoNextWithFrm(const SwNodes& rNodes, SwNodeIndex *pIdx)
{
if( pIdx->GetIndex() >= rNodes.Count() - 1 )
@@ -147,14 +147,14 @@ SwNode2LayImpl::SwNode2LayImpl( const SwNode& rNode, sal_uLong nIdx, sal_Bool bS
const SwNode* pNd;
if( bSearch || rNode.IsSectionNode() )
{
- // Suche den naechsten Cntnt/TblNode, der einen Frame besitzt,
- // damit wir uns vor/hinter ihn haengen koennen
+ // Find the next Cntnt/TableNode that contains a Frame, so that we can add
+ // ourselves before/after it
if( !bSearch && rNode.GetIndex() < nIndex )
{
SwNodeIndex aTmp( *rNode.EndOfSectionNode(), +1 );
pNd = GoPreviousWithFrm( &aTmp );
if( !bSearch && pNd && rNode.GetIndex() > pNd->GetIndex() )
- pNd = NULL; // Nicht ueber den Bereich hinausschiessen
+ pNd = NULL; // Do not go over the limits
bMaster = sal_False;
}
else
@@ -163,7 +163,7 @@ SwNode2LayImpl::SwNode2LayImpl( const SwNode& rNode, sal_uLong nIdx, sal_Bool bS
pNd = GoNextWithFrm( rNode.GetNodes(), &aTmp );
bMaster = sal_True;
if( !bSearch && pNd && rNode.EndOfSectionIndex() < pNd->GetIndex() )
- pNd = NULL; // Nicht ueber den Bereich hinausschiessen
+ pNd = NULL; // Do not go over the limits
}
}
else
@@ -189,17 +189,20 @@ SwNode2LayImpl::SwNode2LayImpl( const SwNode& rNode, sal_uLong nIdx, sal_Bool bS
}
}
-/* --------------------------------------------------
- * SwNode2LayImpl::NextFrm() liefert den naechsten "sinnvollen" Frame,
- * beim ersten Aufruf wird am eigentlichen Iterator ein First gerufen,
- * danach die Next-Methode. Das Ergebnis wird auf Brauchbarkeit untersucht,
- * so werden keine Follows akzeptiert, ein Master wird beim Einsammeln der
- * pUpper und beim Einfuegen vor ihm akzeptiert. Beim Einfuegen dahinter
- * wird vom Master ausgehend der letzte Follow gesucht und zurueckgegeben.
- * Wenn der Frame innerhalb eines SectionFrms liegt, wird noch festgestellt,
- * ob statt des Frames der SectionFrm der geeignete Rueckgabewert ist, dies
- * ist der Fall, wenn der neu einzufuegende Node ausserhalb des Bereichs liegt.
- * --------------------------------------------------*/
+/**
+ * Returns the next "useful" Frame.
+ *
+ * When calling this method for the first time, a First is triggered at the
+ * actual Iterator. The result is check for suitability: Follows are not
+ * accepted, a Master is accepted when collecting the pUpper and when
+ * inserting before it.
+ * When inserting after it, we find and return the last Follow starting
+ * from the Master.
+ *
+ * If the Frame is located in a SectionFrm, we check to see whether the
+ * SectionFrame is the suitable return value (instead of the Frame itself).
+ * This is the case if the to-be-inserted Node is outside of the Area.
+ */
SwFrm* SwNode2LayImpl::NextFrm()
{
SwFrm* pRet;
@@ -216,9 +219,9 @@ SwFrm* SwNode2LayImpl::NextFrm()
{
SwFlowFrm* pFlow = SwFlowFrm::CastFlowFrm( pRet );
OSL_ENSURE( pFlow, "Cntnt or Table expected?!" );
- // Follows sind fluechtige Gestalten, deshalb werden sie ignoriert.
- // Auch wenn wir hinter dem Frame eingefuegt werden sollen, nehmen wir
- // zunaechst den Master, hangeln uns dann aber zum letzten Follow durch.
+ // Follows are pretty volatile, thus we ignore them.
+ // Even if we insert after the Frame, we start from the Master
+ // and iterate through it until the last Follow
if( !pFlow->IsFollow() )
{
if( !bMaster )
@@ -230,19 +233,19 @@ SwFrm* SwNode2LayImpl::NextFrm()
if( pRet->IsInSct() )
{
SwSectionFrm* pSct = pRet->FindSctFrm();
- // Vorsicht: Wenn wir in einer Fussnote sind, so kann diese
- // Layoutmaessig in einem spaltigen Bereich liegen, obwohl
- // sie nodemaessig ausserhalb liegt. Deshalb muss bei Fussnoten
- // ueberprueft werden, ob auch der SectionFrm in der Fussnote
- // und nicht ausserhalb liegt.
+ // ATTENTION: If we are in a Footnote, from a Layout point of view
+ // it could be located in an Area with columns, although it should be
+ // outside of it when looking at the Nodes.
+ // Thus, when dealing with Footnotes, we need to check whether the
+ // SectionFrm is also located within the Footnote and not outside of it.
if( !pRet->IsInFtn() || pSct->IsInFtn() )
{
OSL_ENSURE( pSct && pSct->GetSection(), "Where's my section?" );
SwSectionNode* pNd = pSct->GetSection()->GetFmt()->GetSectionNode();
OSL_ENSURE( pNd, "Lost SectionNode" );
- // Wenn der erhaltene Frame in einem Bereichsframe steht,
- // dessen Bereich den Ausgangsnode nicht umfasst, so kehren
- // wir mit dem SectionFrm zurueck, sonst mit dem Cntnt/TabFrm
+ // If the received Frame is located within an Area Frame that does
+ // not encompass the ExitNode, we return with the SectionFrm, else
+ // we return with the Cntnt/TabFrm
if( bMaster )
{
if( pNd->GetIndex() >= nIndex )
@@ -382,7 +385,7 @@ void SwNode2LayImpl::RestoreUpperFrms( SwNodes& rNds, sal_uLong nStt, sal_uLong
else
pNxt = pUp->Lower();
pNew = ((SwTableNode*)pNd)->MakeFrm( pUp );
- OSL_ENSURE( pNew->IsTabFrm(), "Table exspected" );
+ OSL_ENSURE( pNew->IsTabFrm(), "Table expected" );
pNew->Paste( pUp, pNxt );
((SwTabFrm*)pNew)->RegistFlys();
(*pUpperFrms)[x-2] = pNew;
@@ -425,7 +428,7 @@ SwFrm* SwNode2LayImpl::GetFrm( const Point* pDocPos,
const SwPosition *pPos,
const sal_Bool bCalcFrm ) const
{
- // mba: test if change of member pIter -> pMod broke anything
+ // test if change of member pIter -> pMod broke anything
return pMod ? ::GetFrmOfModify( 0, *pMod, USHRT_MAX, pDocPos, pPos, bCalcFrm ) : 0;
}
More information about the Libreoffice-commits
mailing list