I had done these a while ago, when I looked into extending loplugin:ostr to do more automatic rewriting, and these were places where I needed to do something manually, for one reason or another, because the automatic rewriting would not pick it up correctly. However, I got distracted, and a wholesale automatic rewrite would still run into cases where an _ostr/_ustr instance from a library's .rodata would still be referenced after the library has already been dlcose'd. So I never came around to finishing all that. But there appears to be renewed interest in (automatic) rewritings here now, so it probably makes sense if I share this part of my work anyway. Change-Id: I3da9d38398e4bca373cb0000a9d34b49a36ad58a Reviewed-on: https://gerrit.libreoffice.org/c/core/+/166792 Reviewed-by: Stephan Bergmann <stephan.bergmann@allotropia.de> Tested-by: Jenkins
Spreadsheet Application Code
You can dump some information in a dbgutil build:
Shortcuts
CTRL+SHIFT+F12
Dumps the column width of the first 20 columns.
CTRL+SHIFT+F11
Dumps the graphic objects and their position and size in pixel.
CTRL+SHIFT+F6
Dumps the SfxItemSet representing the cell properties' of the current selection as a xml file. The file will be named dump.xml
The Cache Format
ScDocument::StoreTabToCache allows storing the content (not the formatting) of a table to a binary cache format.
The format is column orientated which allows quick serialization of the table.
-
Header:
- Number of Columns: 64 bit unsigned integer
-
Column:
- Column Index: 64 bit unsigned integer
- Column Size: 64 bit unsigned integer
- For each cell type block a new ColumnBlock
-
ColumnBlock:
- Start Row: 64 bit unsigned integer
- Block Size: 64 bit unsigned integer
- Type: 8 bit unsigned integer
- 0 : empty
- 1 : numeric
- for each cell: 64 bit IEEE 754 double precision value
- 2 : string
- for each cell: 32 bit signed string length followed by string length bytes of the string (UTF-8)
- 3 : formula
- for each cell: 32 bit signed string length followed by the formula in R1C1 notation as a string
Functions Supporting Wildcards or Regular Expressions
As this comes up every now and then, and rather should be documented in an extra list of the Help system, functions that support Wildcards or Regular Expressions and depend on the setting under Tools -> Options -> Calc -> Calculate are those that in ODF OpenFormula (ODFF) are defined to depend on the HOST-USE-REGULAR-EXPRESSIONS or HOST-USE-WILDCARDS properties, see ODF v1.3 part4 3.4 Host-Defined Behaviors https://docs.oasis-open.org/office/OpenDocument/v1.3/os/part4-formula/OpenDocument-v1.3-os-part4-formula.html#__RefHeading__1017868_715980110
- Database Functions
- DAVERAGE
- DCOUNT
- DCOUNTA
- DGET
- DMAX
- DMIN
- DPRODUCT
- DSTDEV
- DSTDEVP
- DSUM
- DVAR
- DVARP
- Information Functions
- COUNTIF
- COUNTIFS
- Lookup Functions
- HLOOKUP
- LOOKUP
- MATCH
- XMATCH
- VLOOKUP
- XLOOKUP
- FILTER
- SORT
- SORTBY
- Mathematical Functions
- SEQUENCE
- SUMIF
- SUMIFS
- Statistical Functions
- AVERAGEIF
- AVERAGEIFS
- Text Functions
- SEARCH