c04de7a6f2
where the use_count() call was happening without any kind of synchronisation - switch to use std::atomic which does the right thing for us Change-Id: I79a6452f42bd425ea494bb0298dc134de5678813 Reviewed-on: https://gerrit.libreoffice.org/c/core/+/170217 Reviewed-by: Noel Grandin <noel.grandin@collabora.co.uk> Tested-by: Jenkins |
||
---|---|---|
.. | ||
qa | ||
CompilerTest_o3tl_temporary.mk | ||
CompilerTest_o3tl_unsafe_downcast.mk | ||
CppunitTest_o3tl_tests.mk | ||
IwyuFilter_o3tl.yaml | ||
Makefile | ||
Module_o3tl.mk | ||
README.md |
LibreOffice Template Library
Very basic template functionality, a bit like boost or STL, but specific to LibreOffice.
o3tl stands for "OOo [o3, get it?] template library", in which OOo stands for OpenOffice.org, predecessor of LibreOffice.
From https://blog.thebehrens.net/2006/01/15/update-cow_wrapper-is-available-now/ The scope for o3tl is admittedly kind of ambitious, as it should contain "...very basic (template) functionality, comparable to what's provided by boost or stl, but specific to OOo (what comes to mind are e.g. STL adapters for our own data types and UNO, and stuff that could in principle be upstreamed to boost, but isn't as of now)."
Class Overview
-
[git:include/o3tl/cow_wrapper.hxx]
A copy-on-write wrapper.
-
[git:include/o3tl/lazy_update.hxx]
This template collects data in input type, and updates the output type with the given update functor, but only if the output is requested. Useful if updating is expensive, or input changes frequently, but output is only comparatively seldom used.
-
[git:include/o3tl/vector_pool.hxx]
Simple vector-based memory pool allocator.
-
[git:include/o3tl/functional.hxx]
Some more templates, leftovers in spirit of STLport's old functional header that are not part of the C++ standard (STLport has been replaced by direct use of the C++ STL in LibreOffice).