summaryrefslogtreecommitdiff
path: root/sw/source/writerfilter/dmapper/LoggedResources.hxx
blob: c0927c9130c483f21cee8050715c64833eedb2d2 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
/* -*- 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/.
 *
 * This file incorporates work covered by the following license notice:
 *
 *   Licensed to the Apache Software Foundation (ASF) under one or more
 *   contributor license agreements. See the NOTICE file distributed
 *   with this work for additional information regarding copyright
 *   ownership. The ASF licenses this file to you under the Apache
 *   License, Version 2.0 (the "License"); you may not use this file
 *   except in compliance with the License. You may obtain a copy of
 *   the License at http://www.apache.org/licenses/LICENSE-2.0 .
 */

#pragma once

#include <sal/config.h>

#include <string_view>

#include <dmapper/resourcemodel.hxx>

namespace writerfilter
{
#ifdef DBG_UTIL
class LoggedResourcesHelper final
{
public:
    explicit LoggedResourcesHelper(std::string sPrefix);
    ~LoggedResourcesHelper();

    void startElement(const std::string& sElement);
    static void endElement();
    static void chars(std::u16string_view rChars);
    static void chars(const std::string& rChars);
    static void attribute(const std::string& rName, const std::string& rValue);
    static void attribute(const std::string& rName, sal_uInt32 nValue);

private:
    std::string msPrefix;
};
#endif

class LoggedStream : public Stream
{
public:
    explicit LoggedStream(const std::string& sPrefix);
    virtual ~LoggedStream() override;

    void startSectionGroup() override;
    void endSectionGroup() override;
    void startParagraphGroup() override;
    void endParagraphGroup() override;
    void startCharacterGroup() override;
    void endCharacterGroup() override;
    void startShape(css::uno::Reference<css::drawing::XShape> const& xShape) override;
    void endShape() override;
    void startTextBoxContent() override;
    void endTextBoxContent() override;
    void text(const sal_uInt8* data, size_t len) override;
    void utext(const sal_Unicode* data, size_t len) override;
    void positionOffset(const OUString& rText, bool bVertical) override;
    void align(const OUString& rText, bool bVertical) override;
    void positivePercentage(const OUString& rText) override;
    void props(const writerfilter::Reference<Properties>::Pointer_t& ref) override;
    void table(Id name, const writerfilter::Reference<Table>::Pointer_t& ref) override;
    void substream(Id name, const writerfilter::Reference<Stream>::Pointer_t& ref) override;
    void info(const std::string& info) override;
    void startGlossaryEntry() override;
    void endGlossaryEntry() override;
    void checkId(const sal_Int32 nId) override;

    virtual void setDocumentReference(writerfilter::ooxml::OOXMLDocument* /*pDocument*/) override{};

protected:
    virtual void lcl_startSectionGroup() = 0;
    virtual void lcl_endSectionGroup() = 0;
    virtual void lcl_startParagraphGroup() = 0;
    virtual void lcl_endParagraphGroup() = 0;
    virtual void lcl_startCharacterGroup() = 0;
    virtual void lcl_endCharacterGroup() = 0;
    virtual void lcl_startShape(css::uno::Reference<css::drawing::XShape> const& xShape) = 0;
    virtual void lcl_endShape() = 0;
    virtual void lcl_startTextBoxContent() = 0;
    virtual void lcl_endTextBoxContent() = 0;
    virtual void lcl_text(const sal_uInt8* data, size_t len) = 0;
    virtual void lcl_utext(const sal_Unicode* data, size_t len) = 0;
    virtual void lcl_positionOffset(const OUString& /*rText*/, bool /*bVertical*/) {}
    virtual css::awt::Point getPositionOffset() override { return css::awt::Point(); }
    virtual void lcl_align(const OUString& /*rText*/, bool /*bVertical*/) {}
    virtual void lcl_positivePercentage(const OUString& /*rText*/) {}
    virtual void lcl_props(const writerfilter::Reference<Properties>::Pointer_t& ref) = 0;
    virtual void lcl_table(Id name, const writerfilter::Reference<Table>::Pointer_t& ref) = 0;
    virtual void lcl_substream(Id name, const writerfilter::Reference<Stream>::Pointer_t& ref) = 0;
    virtual void lcl_startGlossaryEntry() {}
    virtual void lcl_endGlossaryEntry() {}
    virtual void lcl_checkId(const sal_Int32) {}

private:
#ifdef DBG_UTIL
    LoggedResourcesHelper mHelper;
#endif
};

class LoggedProperties : public Properties
{
public:
    explicit LoggedProperties(const std::string& sPrefix);
    virtual ~LoggedProperties() override;

    void attribute(Id name, Value& val) override;
    void sprm(Sprm& sprm) override;

protected:
    virtual void lcl_attribute(Id name, Value& val) = 0;
    virtual void lcl_sprm(Sprm& sprm) = 0;

private:
#ifdef DBG_UTIL
    LoggedResourcesHelper mHelper;
#endif
};

class LoggedTable : public Table
{
public:
    explicit LoggedTable(const std::string& sPrefix);
    virtual ~LoggedTable() override;

    void entry(int pos, writerfilter::Reference<Properties>::Pointer_t ref) override;

protected:
    virtual void lcl_entry(const writerfilter::Reference<Properties>::Pointer_t& ref) = 0;

private:
#ifdef DBG_UTIL
    LoggedResourcesHelper mHelper;
#endif
};
}

/* vim:set shiftwidth=4 softtabstop=4 expandtab: */