LibreOffice Module sw (master)  1
dbgoutsw.hxx
Go to the documentation of this file.
1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 /*
3  * This file is part of the LibreOffice project.
4  *
5  * This Source Code Form is subject to the terms of the Mozilla Public
6  * License, v. 2.0. If a copy of the MPL was not distributed with this
7  * file, You can obtain one at http://mozilla.org/MPL/2.0/.
8  *
9  * This file incorporates work covered by the following license notice:
10  *
11  * Licensed to the Apache Software Foundation (ASF) under one or more
12  * contributor license agreements. See the NOTICE file distributed
13  * with this work for additional information regarding copyright
14  * ownership. The ASF licenses this file to you under the Apache
15  * License, Version 2.0 (the "License"); you may not use this file
16  * except in compliance with the License. You may obtain a copy of
17  * the License at http://www.apache.org/licenses/LICENSE-2.0 .
18  */
19 #ifndef INCLUDED_SW_INC_DBGOUTSW_HXX
20 #define INCLUDED_SW_INC_DBGOUTSW_HXX
21 
22 #ifdef DBG_UTIL
23 
24 #include <rtl/ustring.hxx>
25 #include <rtl/ustrbuf.hxx>
26 #include "tox.hxx"
27 #include <cstdio>
28 #include <unordered_map>
29 
30 class SwContentNode;
31 class SwNode;
32 class SwTextAttr;
33 class SwTextNode;
34 class SwpHints;
35 class SfxPoolItem;
36 class SfxItemSet;
37 struct SwPosition;
38 class SwPaM;
39 class SwNodeNum;
40 class SwUndo;
41 class SwRect;
42 class SwFrameFormat;
43 class SwFrameFormats;
44 class SwNumRuleTable;
45 class SwNumRule;
46 class SwOutlineNodes;
47 class SwTextFormatColl;
48 class SwNodeRange;
49 
50 extern bool bDbgOutStdErr;
51 extern bool bDbgOutPrintAttrSet;
52 
53 const char* dbg_out(const void* pVoid);
54 const char* dbg_out(const OUString& aStr);
55 const char* dbg_out(const SwRect& rRect);
56 const char* dbg_out(const SwFrameFormat& rFrameFormat);
57 SW_DLLPUBLIC const char* dbg_out(const SwNode& rNode);
58 SW_DLLPUBLIC const char* dbg_out(const SwNode* pNode);
59 const char* dbg_out(const SwContentNode* pNode);
60 const char* dbg_out(const SwTextNode* pNode);
61 const char* dbg_out(const SwTextAttr& rAttr);
62 const char* dbg_out(const SwpHints& rHints);
63 const char* dbg_out(const SfxPoolItem& rItem);
64 const char* dbg_out(const SfxPoolItem* pItem);
65 const char* dbg_out(const SfxItemSet& rSet);
66 const char* dbg_out(const SwPosition& rPos);
67 const char* dbg_out(const SwPaM& rPam);
68 const char* dbg_out(const SwNodeNum& rNum);
69 const char* dbg_out(const SwUndo& rUndo);
70 const char* dbg_out(SwOutlineNodes const& rNodes);
71 const char* dbg_out(const SwNumRule& rRule);
72 const char* dbg_out(const SwTextFormatColl& rFormat);
73 const char* dbg_out(const SwFrameFormats& rFrameFormats);
74 const char* dbg_out(const SwNumRuleTable& rTable);
75 const char* dbg_out(const SwNodeRange& rRange);
76 
77 template <typename tKey, typename tMember, typename fHashFunction>
78 OUString lcl_dbg_out(const std::unordered_map<tKey, tMember, fHashFunction>& rMap)
79 {
80  OUStringBuffer aResult("[");
81 
82  typename std::unordered_map<tKey, tMember, fHashFunction>::const_iterator aIt;
83 
84  for (aIt = rMap.begin(); aIt != rMap.end(); ++aIt)
85  {
86  if (aIt != rMap.begin())
87  aResult.append(", ");
88 
89  aResult += aIt->first;
90 
91  char sBuffer[256];
92  sprintf(sBuffer, "(%p)", aIt->second);
93  aResult.appendAscii(sBuffer);
94  }
95 
96  aResult.append("]");
97 
98  return aResult.makeStringAndClear();
99 }
100 
101 template <typename tKey, typename tMember, typename fHashFunction>
102 const char* dbg_out(const std::unordered_map<tKey, tMember, fHashFunction>& rMap)
103 {
104  return dbg_out(lcl_dbg_out(rMap));
105 }
106 const char* dbg_out(const SwFormToken& rToken);
107 const char* dbg_out(const SwFormTokens& rTokens);
108 #endif // DBG_UTIL
109 #endif // INCLUDED_SW_INC_DBGOUTSW_HXX
110 
111 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */
std::vector< SwFormToken > SwFormTokens
Vector of tokens.
Definition: tox.hxx:288
Represents the style of a paragraph.
Definition: fmtcol.hxx:55
Marks a position in the document model.
Definition: pam.hxx:35
Of course Writer needs its own rectangles.
Definition: swrect.hxx:35
Specific frame formats (frames, DrawObjects).
bool bDbgOutPrintAttrSet
Definition: dbgoutsw.cxx:53
PaM is Point and Mark: a selection of the document model.
Definition: pam.hxx:136
Style of a layout element.
Definition: frmfmt.hxx:58
#define SW_DLLPUBLIC
Definition: swdllapi.h:28
OUString lcl_dbg_out(const std::unordered_map< tKey, tMember, fHashFunction > &rMap)
Definition: dbgoutsw.hxx:78
SwTextNode is a paragraph in the document model.
Definition: ndtxt.hxx:80
An SwTextAttr container, stores all directly formatted text portions for a text node.
Definition: ndhints.hxx:67
const char * dbg_out(const void *pVoid)
Definition: dbgoutsw.cxx:76
bool bDbgOutStdErr
Definition: dbgoutsw.cxx:52
Base class of the Writer document model elements.
Definition: node.hxx:79