1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
3 * This file is part of the LibreOffice project.
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/.
10 #ifndef INCLUDED_SC_INC_DOCUMENTIMPORT_HXX
11 #define INCLUDED_SC_INC_DOCUMENTIMPORT_HXX
14 #include "address.hxx"
15 #include "attarray.hxx"
17 #include <rtl/ustring.hxx>
28 struct ScSetStringParam
;
30 struct ScDocumentImportImpl
;
31 enum class SvtScriptType
;
34 * Accessor class to ScDocument. Its purpose is to allow import filter to
35 * fill the document model and nothing but that. Filling the document via
36 * this class does not trigger any kind of broadcasting, drawing object
37 * position calculation, or anything else that requires expensive
38 * computation which are unnecessary and undesirable during import.
40 class SC_DLLPUBLIC ScDocumentImport
42 std::unique_ptr
<ScDocumentImportImpl
> mpImpl
;
46 struct SC_DLLPUBLIC Attrs
48 std::vector
<ScAttrEntry
> mvData
;
50 bool mbLatinNumFmtOnly
;
54 Attrs
& operator=( Attrs
const & ) = delete; // MSVC2015 workaround
55 Attrs( Attrs
const & ) = delete; // MSVC2015 workaround
58 ScDocumentImport() = delete;
59 ScDocumentImport(ScDocument
& rDoc
);
60 ScDocumentImport(const ScDocumentImport
&) = delete;
61 const ScDocumentImport
& operator=(const ScDocumentImport
&) = delete;
65 const ScDocument
& getDoc() const;
68 * Initialize the storage for all sheets after all the sheet instances
69 * have been created in the document.
73 void setDefaultNumericScript(SvtScriptType nScript
);
76 * Apply specified cell style to an entire sheet.
78 void setCellStyleToSheet(SCTAB nTab
, const ScStyleSheet
& rStyle
);
81 * @param rName sheet name.
83 * @return 0-based sheet index, or -1 in case no sheet is found by
86 SCTAB
getSheetIndex(const OUString
& rName
) const;
87 SCTAB
getSheetCount() const;
88 bool appendSheet(const OUString
& rName
);
89 void setSheetName(SCTAB nTab
, const OUString
& rName
);
91 void setOriginDate(sal_uInt16 nYear
, sal_uInt16 nMonth
, sal_uInt16 nDay
);
93 void setAutoInput(const ScAddress
& rPos
, const OUString
& rStr
,
94 const ScSetStringParam
* pStringParam
= nullptr);
95 void setNumericCell(const ScAddress
& rPos
, double fVal
);
96 void setStringCell(const ScAddress
& rPos
, const OUString
& rStr
);
97 void setEditCell(const ScAddress
& rPos
, std::unique_ptr
<EditTextObject
> pEditText
);
100 const ScAddress
& rPos
, const OUString
& rFormula
, formula::FormulaGrammar::Grammar eGrammar
,
101 const double* pResult
= nullptr );
104 const ScAddress
& rPos
, const OUString
& rFormula
, formula::FormulaGrammar::Grammar eGrammar
,
105 const OUString
& rResult
);
107 void setFormulaCell(const ScAddress
& rPos
, std::unique_ptr
<ScTokenArray
> pArray
);
108 void setFormulaCell(const ScAddress
& rPos
, ScFormulaCell
* pCell
);
111 const ScRange
& rRange
, const ScTokenArray
& rArray
, formula::FormulaGrammar::Grammar eGrammar
);
113 void setTableOpCells(const ScRange
& rRange
, const ScTabOpParam
& rParam
);
115 void fillDownCells(const ScAddress
& rPos
, SCROW nFillSize
);
118 * Set an array of cell attributes to specified column. This call
119 * transfers the ownership of the ScAttrEntry array from the caller to the
122 void setAttrEntries( SCTAB nTab
, SCCOL nCol
, Attrs
&& rAttrs
);
124 void setRowsVisible(SCTAB nTab
, SCROW nRowStart
, SCROW nRowEnd
, bool bVisible
);
126 void setMergedCells(SCTAB nTab
, SCCOL nCol1
, SCROW nRow1
, SCCOL nCol2
, SCROW nRow2
);
130 /** Broadcast all formula cells that are marked with
131 FormulaTokenArray::IsRecalcModeMustAfterImport() for a subsequent
132 ScDocument::CalcFormulaTree().
134 void broadcastRecalcAfterImport();
137 void initColumn(ScColumn
& rCol
);
138 static void broadcastRecalcAfterImportColumn(ScColumn
& rCol
);
143 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */