summaryrefslogtreecommitdiff
path: root/sw/inc
diff options
context:
space:
mode:
authorTobias Lippert <drtl@fastmail.fm>2014-06-01 14:18:39 +0200
committerCaolán McNamara <caolanm@redhat.com>2014-06-05 16:26:39 +0000
commit94b296d5416dd71d721ad16216b50bce79e3dc04 (patch)
treea53b0a660ce6646c5767865fe85af03bfaba3b3e /sw/inc
parente5345f62bf525b6258736f1ce11a61b5e638e0ff (diff)
Unittest link generation for table of contents.
The logic was moved to a separate class and unittested. Conflicts: sw/inc/ToxTextGenerator.hxx Change-Id: I0e4475f5e2950cdfdfb07b89128c4ce1d6af3f22 Reviewed-on: https://gerrit.libreoffice.org/9609 Reviewed-by: Caolán McNamara <caolanm@redhat.com> Tested-by: Caolán McNamara <caolanm@redhat.com>
Diffstat (limited to 'sw/inc')
-rw-r--r--sw/inc/ToxLinkProcessor.hxx86
-rw-r--r--sw/inc/ToxTextGenerator.hxx12
2 files changed, 94 insertions, 4 deletions
diff --git a/sw/inc/ToxLinkProcessor.hxx b/sw/inc/ToxLinkProcessor.hxx
new file mode 100644
index 000000000000..5a4546562ec6
--- /dev/null
+++ b/sw/inc/ToxLinkProcessor.hxx
@@ -0,0 +1,86 @@
+/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
+/*
+ * This file is part of the LibreOffice project.
+ *
+ * This Source Code Form is subject to the terms of the Mozilla Public
+ * License, v. 2.0. If a copy of the MPL was not distributed with this
+ * file, You can obtain one at http://mozilla.org/MPL/2.0/.
+ */
+
+#ifndef SW_TOXLINKPROCESSOR_HXX_
+#define SW_TOXLINKPROCESSOR_HXX_
+
+#include "fmtinfmt.hxx"
+#include "rtl/ustring.hxx"
+
+#include <vector>
+
+class SwTxtNode;
+
+class ToxLinkProcessorTest;
+
+namespace sw {
+
+/** A helper class for ToxTextGenerator.
+ * It collects information about encountered link tokens and allows access in a processed form.
+ */
+class SW_DLLPUBLIC ToxLinkProcessor {
+public:
+ ToxLinkProcessor() {;}
+ virtual ~ToxLinkProcessor() {;}
+
+ void
+ StartNewLink(sal_Int32 startPosition, const OUString& characterStyle);
+
+ /** Close a link which has been found during processing.
+ *
+ * @throw std::runtime_error If there are no open links.
+ */
+ void
+ CloseLink(sal_Int32 endPosition, const OUString& url);
+
+ /** Insert the found links as attributes to a text node */
+ void
+ InsertLinkAttributes(SwTxtNode& node);
+
+private:
+ /** Obtain the pool id which belongs to a character style.
+ *
+ * @internal
+ * This method is overridden in the unittests. You should not override it yourself.
+ */
+ virtual sal_uInt16
+ ObtainPoolId(const OUString& characterStyle) const;
+
+ /** Information about a started link */
+ struct StartedLink {
+ StartedLink(sal_Int32 startPosition, OUString characterStyle) :
+ mStartPosition(startPosition), mCharacterStyle(characterStyle) {
+ ;
+ }
+ sal_Int32 mStartPosition;
+ OUString mCharacterStyle;
+ };
+
+ /** A link that has been encountered while parsing a tox.
+ * A link is closed if it has both a start and an end token.
+ */
+ struct ClosedLink {
+ ClosedLink(const OUString& url, sal_Int32 startPosition, sal_Int32 endPosition) :
+ mINetFmt(url, OUString()), mStartTextPos(endPosition), mEndTextPos(startPosition) {
+ }
+ SwFmtINetFmt mINetFmt;
+ sal_Int32 mStartTextPos;
+ sal_Int32 mEndTextPos;
+ };
+
+ std::vector<ClosedLink> mClosedLinks;
+
+ std::vector<StartedLink> mStartedLinks;
+
+ friend class ::ToxLinkProcessorTest;
+};
+
+}
+
+#endif /* SW_TOXLINKPROCESSOR_HXX_ */
diff --git a/sw/inc/ToxTextGenerator.hxx b/sw/inc/ToxTextGenerator.hxx
index e64c8b678d90..d83736b3eb31 100644
--- a/sw/inc/ToxTextGenerator.hxx
+++ b/sw/inc/ToxTextGenerator.hxx
@@ -22,6 +22,7 @@
#include "sal/types.h"
#include "swdllapi.h"
+#include <boost/shared_ptr.hpp>
#include <vector>
class SwDoc;
@@ -31,12 +32,15 @@ struct SwTOXSortTabBase;
namespace sw {
+class ToxLinkProcessor;
+
class SW_DLLPUBLIC ToxTextGenerator
{
public:
- ToxTextGenerator(const SwForm& toxForm)
- : mToxForm(toxForm)
- {}
+ ToxTextGenerator(const SwForm& toxForm);
+
+ ~ToxTextGenerator();
+
/** Generate the text for an entry of a table of X (X is, e.g., content).
*
* This method will process the entries in @p entries, starting at @p indexOfEntryToProcess and
@@ -47,9 +51,9 @@ public:
sal_uInt16 indexOfEntryToProcess, sal_uInt16 numberOfEntriesToProcess,
sal_uInt32 _nTOXSectNdIdx, const SwPageDesc* _pDefaultPageDesc);
-
private:
const SwForm& mToxForm;
+ boost::shared_ptr<ToxLinkProcessor> mLinkProcessor;
};
}