office-gobmx/svl
Eike Rathke 47b4b1633a Resolves: tdf#164239 Can force Y-M-D to ISO 8601 if no date acceptance pattern
... was matched at all, even for a-b-c with MDY a<=12 or DMY a<=31.

Change-Id: Ie2d62c73c91794a96114b787d6ad2357c7affb2a
Reviewed-on: https://gerrit.libreoffice.org/c/core/+/178171
Reviewed-by: Eike Rathke <erack@redhat.com>
Tested-by: Jenkins
2024-12-09 20:34:41 +01:00
..
inc/pch
qa Resolves: tdf#164239 Can force Y-M-D to ISO 8601 if no date acceptance pattern 2024-12-09 20:34:41 +01:00
source Resolves: tdf#164239 Can force Y-M-D to ISO 8601 if no date acceptance pattern 2024-12-09 20:34:41 +01:00
unx/source/svdde
util
AllLangMoTarget_svl.mk migrate to boost::gettext 2017-07-21 08:20:50 +01:00
CppunitTest_svl_adrparse.mk Add an SvAddressParser unit test 2021-06-09 17:01:19 +02:00
CppunitTest_svl_inetcontenttype.mk Introduce INetContentType::scan 2014-03-27 18:06:27 +01:00
CppunitTest_svl_items.mk tdf#158556 simplify StylePool API 2024-08-26 11:22:25 +02:00
CppunitTest_svl_lngmisc.mk gbuild: Remove MSVC 2013 legacy code 2017-04-21 18:18:44 +02:00
CppunitTest_svl_lockfiles.mk Fix more new dependencies on boost_headers 2019-12-07 09:00:26 +01:00
CppunitTest_svl_notify.mk tdf#94698 cleanup Makefiles. Get rid of udkapi and offapi 2016-06-09 09:47:11 +00:00
CppunitTest_svl_qa_cppunit.mk Drop configurability of libnumbertext use 2020-06-11 16:23:52 +02:00
CppunitTest_svl_urihelper.mk gbuild: Remove MSVC 2013 legacy code 2017-04-21 18:18:44 +02:00
IwyuFilter_svl.yaml Recheck modules sv* with IWYU 2022-03-03 09:50:43 +01:00
JunitTest_svl_complex.mk Drop juh.jar dependency from Java UNO tests 2018-12-06 17:40:33 +01:00
Library_fsstorage.mk Generally determine Rdb content from gb_*_set_componentfile calls 2021-12-10 08:14:24 +01:00
Library_passwordcontainer.mk Generally determine Rdb content from gb_*_set_componentfile calls 2021-12-10 08:14:24 +01:00
Library_svl.mk merge CntUnencodedStringItem into SfxStringItem 2024-08-15 16:07:05 +02:00
Makefile switch to include-based build rather than sourced-based build 2012-02-05 19:34:05 -06:00
Module_svl.mk ITEM: No longer register Items at Pool 2024-01-12 12:15:54 +01:00
README.md Updated README.md files to represent current code / use Markdown format 2021-04-07 17:47:16 +02:00

Non-Graphical Helper Code (svtools light)

Contains non-graphical helper code for office applications.

Specifically this module does not depend on or use includes from module vcl. Originally all code in svtools that did not depend on vcl was split off into this svl ("svtools light") module.

In particular the SfxItemSet is a property-bag like container that stores arbitrary sets of properties for everything from text run formats, to Chart regression line properties.

There are lots of other useful helpers in here for various office tasks; much of this code was originally moved from svx/sfx2.

Items, Pools and Sets

SfxPoolItem

A small reference counted piece of data. Many subclasses, each with a unique integer to identify its type (WhichId). Can be compared for equality (operator==), Clone()d, and converted to/from uno::Any (QueryValue/PutValue).

A pool item may have value semantics ("poolable"), meaning that there will generally be only one instance that compares equal per item pool, or not, in which case the item will be Clone()d quite a bit.

SfxItemPool

Usually there is one item pool per document, with a range of valid WhichIds that is specific to the type of document.

The item pool owns all instances of SfxPoolItem or its subclasses that have ever been added to an item set. It also contains a default item for every WhichId, which will be (depending on parameters) returned from item sets if the set does not contain an item at this WhichId.

SfxItemSet

The item set can be created with a user-supplied range of WhichIds; it will accept SfxPoolItems with matching WhichIds and ignore attempts to insert items with non-matching WhichIds.

Items that are successfully inserted into the set will be stored in the set's SfxItemPool, and for poolable items only a single instance that compares equal under the predicate operator== will be stored in the pool, regardless of how many sets contain it, thus conserving memory.

There are members m_pWhichRanges for the valid ranges (as pairs of WhichIds), m_nCount for the number of items contained, and m_pItems for the pointers to the actual items.