1
0
Fork 0
libreoffice/sc/source/ui/view/gridwin_dbgutil.cxx
Daniel Baumann 8e63e14cf6
Adding upstream version 4:25.2.3.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
2025-06-22 16:20:04 +02:00

171 lines
5.7 KiB
C++

/* -*- 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/.
*/
#include <iostream>
#include <gridwin.hxx>
#include <svx/svdpage.hxx>
#include <libxml/xmlwriter.h>
#include <viewdata.hxx>
#include <document.hxx>
#include <patattr.hxx>
#include <userdat.hxx>
#include <dpobject.hxx>
namespace {
std::ostream& operator<<(std::ostream& rStrm, const ScAddress& rAddr)
{
rStrm << "Col: " << rAddr.Col() << ", Row: " << rAddr.Row() << ", Tab: " << rAddr.Tab();
return rStrm;
}
void dumpScDrawObjData(const ScGridWindow& rWindow, const ScDrawObjData& rData, MapUnit eMapUnit)
{
const Point& rStartOffset = rData.maStartOffset;
Point aStartOffsetPixel = rWindow.LogicToPixel(rStartOffset, MapMode(eMapUnit));
std::cout << " Start: " << rData.maStart << ", Offset: " << aStartOffsetPixel << std::endl;
const Point& rEndOffset = rData.maEndOffset;
Point aEndOffsetPixel = rWindow.LogicToPixel(rEndOffset, MapMode(eMapUnit));
std::cout << " End: : " << rData.maEnd << ", Offset: " << aEndOffsetPixel << std::endl;
}
}
void ScGridWindow::dumpColumnInformationPixel()
{
ScDocument& rDoc = mrViewData.GetDocument();
SCTAB nTab = mrViewData.GetTabNo();
for (SCCOL nCol = 0; nCol <= 20; ++nCol)
{
sal_uInt16 nWidth = rDoc.GetColWidth(nCol, nTab);
tools::Long nPixel = LogicToPixel(Point(nWidth, 0), MapMode(MapUnit::MapTwip)).getX();
std::cout << "Column: " << nCol << ", Width: " << nPixel << "px" << std::endl;
}
}
void ScGridWindow::dumpColumnInformationHmm()
{
ScDocument& rDoc = mrViewData.GetDocument();
SCTAB nTab = mrViewData.GetTabNo();
for (SCCOL nCol = 0; nCol <= 20; ++nCol)
{
sal_uInt16 nWidth = rDoc.GetColWidth(nCol, nTab);
tools::Long nPixel = o3tl::convert(nWidth, o3tl::Length::twip, o3tl::Length::mm100);
std::cout << "Column: " << nCol << ", Width: " << nPixel << "hmm" << std::endl;
}
}
void ScGridWindow::dumpCellProperties()
{
ScDocument& rDoc = mrViewData.GetDocument();
const ScMarkData& rMark = mrViewData.GetMarkData();
SCTAB nTab = mrViewData.GetTabNo();
ScRangeList aList;
if (rMark.IsMultiMarked())
{
aList = rMark.GetMarkedRangesForTab(nTab);
}
else if (rMark.IsMarked())
{
aList.Join(rMark.GetMarkArea());
}
else
{
SCCOL nCol = mrViewData.GetCurX();
SCROW nRow = mrViewData.GetCurY();
ScRange aRange(nCol, nRow, nTab);
aList.Join(aRange, false);
}
xmlTextWriterPtr writer = xmlNewTextWriterFilename( "dump.xml", 0 );
xmlTextWriterSetIndent(writer,1);
(void)xmlTextWriterSetIndentString(writer, BAD_CAST(" "));
(void)xmlTextWriterStartDocument( writer, nullptr, nullptr, nullptr );
(void)xmlTextWriterStartElement(writer, BAD_CAST("selection"));
for (size_t i = 0, n = aList.size(); i < n; ++i)
{
ScRange const & rRange = aList[i];
for (SCCOL nCol = rRange.aStart.Col(); nCol <= rRange.aEnd.Col(); ++nCol)
{
for (SCROW nRow = rRange.aStart.Row(); nRow <= rRange.aEnd.Row(); ++nRow)
{
const ScPatternAttr* pPatternAttr = rDoc.GetPattern(nCol, nRow, nTab);
(void)xmlTextWriterStartElement(writer, BAD_CAST("cell"));
(void)xmlTextWriterWriteAttribute(writer, BAD_CAST("column"), BAD_CAST(OString::number(nCol).getStr()));
(void)xmlTextWriterWriteAttribute(writer, BAD_CAST("row"), BAD_CAST(OString::number(nRow).getStr()));
(void)xmlTextWriterWriteAttribute(writer, BAD_CAST("tab"), BAD_CAST(OString::number(nTab).getStr()));
pPatternAttr->GetItemSet().dumpAsXml(writer);
(void)xmlTextWriterEndElement(writer);
}
}
}
(void)xmlTextWriterEndElement(writer);
(void)xmlTextWriterEndDocument( writer );
xmlFreeTextWriter (writer);
}
void ScGridWindow::dumpGraphicInformation()
{
ScDocument& rDoc = mrViewData.GetDocument();
ScDrawLayer* pDrawLayer = rDoc.GetDrawLayer();
if (!pDrawLayer)
return;
sal_uInt16 nPageCount = pDrawLayer->GetPageCount();
for (sal_uInt16 nPage = 0; nPage < nPageCount; ++nPage)
{
SdrPage* pPage = pDrawLayer->GetPage(nPage);
size_t nObjCount = pPage->GetObjCount();
for (size_t nObj = 0; nObj < nObjCount; ++nObj)
{
SdrObject* pObj = pPage->GetObj(nObj);
std::cout << "Graphic Object" << std::endl;
ScDrawObjData* pObjData = ScDrawLayer::GetObjData(pObj);
if (pObjData)
dumpScDrawObjData(*this, *pObjData, pDrawLayer->GetScaleUnit());
const tools::Rectangle& rRect = pObj->GetSnapRect();
tools::Rectangle aRect = LogicToPixel(rRect, MapMode(pDrawLayer->GetScaleUnit()));
std::cout << "Snap Rectangle (in pixel): " << aRect << std::endl;
}
}
}
void ScGridWindow::dumpColumnCellStorage()
{
// Get the current cursor position.
ScAddress aCurPos = mrViewData.GetCurPos();
ScDocument& rDoc = mrViewData.GetDocument();
const ScDPObject* pDP = rDoc.GetDPAtCursor(aCurPos.Col(), aCurPos.Row(), aCurPos.Tab());
if (pDP)
{
// Dump the pivot table info if the cursor is over a pivot table.
pDP->Dump();
pDP->DumpCache();
return;
}
// Dump the column cell storage info.
rDoc.DumpColumnStorage(aCurPos.Tab(), aCurPos.Col());
}
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */