Test repository to check push and ssh key
Find a file
Patrick Luby fc69d6b227 tdf#101376 don't detach thread if it is the main thread on macOS
On macOS, many AWT classes do their work on the main thread
deep in native methods in the java.awt.* classes. The problem
is that Oracle's and OpenJDK's JVMs don't bracket their
"perform on main thread" native calls with "attach/detach
current thread" calls to the JVM.

Change-Id: I0859dc9e20f34bd0b43bb321898507764fd530fb
Reviewed-on: https://gerrit.libreoffice.org/c/core/+/157985
Tested-by: Jenkins
Reviewed-by: Patrick Luby <plubius@neooffice.org>
2023-10-15 15:33:09 +02:00
.git-hooks
.github
.vscode
accessibility a11y: Add include to fix clang-cl build 2023-10-15 00:10:37 +02:00
android tdf#147906 used StrictMath.hypot for Pythagorean addition 2023-09-21 07:15:22 +02:00
animations animations : remove useless use of XComponentContext 2023-09-23 11:29:24 +02:00
apple_remote
avmedia Make NC_ constexpr-friendly 2023-10-12 18:17:49 +02:00
basctl Make NC_ constexpr-friendly 2023-10-12 18:17:49 +02:00
basegfx Drop temporary aliases from Tuple2D and Tuple3D 2023-10-08 18:53:00 +02:00
basic tdf#147132 tdf#154285 Flatten and check param count of IsMissing fn 2023-10-13 17:04:16 +02:00
bean
bin Drop o3tl::span, can use C++20 std::span directly now 2023-10-11 21:53:13 +02:00
binaryurp Revert "loplugin:unodispose in binaryurp" 2023-09-13 12:29:13 +02:00
bridges bridge/powerpc64: fix integer ABI 2023-09-12 19:42:54 +02:00
canvas Drop o3tl::span, can use C++20 std::span directly now 2023-10-11 21:53:13 +02:00
chart2 Make NC_ constexpr-friendly 2023-10-12 18:17:49 +02:00
cli_ure
codemaker Follow-up on "Make sure __cpp_lib_source_location is consistently defined" 2023-10-13 16:46:07 +02:00
comphelper Drop o3tl::span, can use C++20 std::span directly now 2023-10-11 21:53:13 +02:00
compilerplugins get_iter_abs_pos doesn't neeed to be virtual 2023-10-14 21:51:32 +02:00
config_host Drop o3tl::span, can use C++20 std::span directly now 2023-10-11 21:53:13 +02:00
configmgr SAL_WARN->SAL_INFO in Access::getChild 2023-08-31 21:50:18 +02:00
connectivity Use exception ctors, instead of setting members later 2023-10-14 15:37:17 +02:00
cppcanvas Drop o3tl::span, can use C++20 std::span directly now 2023-10-11 21:53:13 +02:00
cppu cid#1546008 silence Using invalid iterator 2023-09-28 13:38:40 +02:00
cppuhelper loplugin:ostr: automatic rewrite 2023-10-07 00:47:20 +02:00
cpputools Use less libxml2 external headers dependency 2023-09-29 00:20:57 +02:00
cui Add NUMBERSIGN key handler. 2023-10-14 21:51:43 +02:00
dbaccess Use exception ctors, instead of setting members later 2023-10-14 15:37:17 +02:00
desktop Remove duplicated include 2023-10-14 16:30:51 +02:00
dictionaries@272686e247 Update git submodules 2023-09-10 00:00:47 +02:00
distro-configs distro-configs: Switch from JDK 11 to 17 2023-09-01 17:21:51 +02:00
docmodel tdf#146619 Recheck include/d* with IWYU 2023-09-23 07:22:53 +02:00
drawinglayer drawinglayer,svx: PDF/UA export: put Form SE into anchor paragraph SE 2023-10-12 11:54:51 +02:00
editeng Make NC_ constexpr-friendly 2023-10-12 18:17:49 +02:00
embeddedobj Make NC_ constexpr-friendly 2023-10-12 18:17:49 +02:00
embedserv Revert "use more Reference::query instead of UNO_QUERY_THROW" 2023-08-25 14:15:56 +02:00
emfio loplugin:ostr: automatic rewrite 2023-10-07 00:47:20 +02:00
eventattacher
extensions Use exception ctors, instead of setting members later 2023-10-14 15:37:17 +02:00
external Upgrade libffi to 3.4.4 2023-10-14 15:51:09 +02:00
extras tdf#101970 Introduce config option for building with or 2023-10-05 21:37:09 +02:00
filter Impress presentation engine (svg): 2023-10-14 16:49:51 +02:00
forms Use exception ctors, instead of setting members later 2023-10-14 15:37:17 +02:00
formula Make NC_ constexpr-friendly 2023-10-12 18:17:49 +02:00
fpicker Make NC_ constexpr-friendly 2023-10-12 18:17:49 +02:00
framework Add NUMBERSIGN key handler. 2023-10-14 21:51:43 +02:00
helpcompiler Use less libxml2 external headers dependency 2023-09-29 00:20:57 +02:00
helpcontent2@e7ec227d83 Update git submodules 2023-10-11 19:24:35 +02:00
hwpfilter ofz#62935 avoid negative numbers in olHanglJaso 2023-10-03 12:13:16 +02:00
i18nlangtag loplugin:ostr: automatic rewrite 2023-10-07 00:47:20 +02:00
i18npool tdf#42982 Improved UNO API error reporting 2023-10-13 20:00:19 +02:00
i18nutil i18nutil: Make unicode::getUnicodeType() take a UTF-32 code point 2023-07-25 02:14:56 +02:00
icon-themes Resolves tdf#155561 - Notification for the overwrite mode 2023-09-27 17:04:57 +02:00
idl tdf#145538 Use range based for loops in idl:object 2023-10-03 22:08:54 +02:00
idlc/test/parser
include Add NUMBERSIGN key handler. 2023-10-14 21:51:43 +02:00
instsetoo_native
io
ios
javaunohelper
jurt
jvmaccess
jvmfwk loplugin:stringstatic look for more strings 2023-06-27 13:10:44 +02:00
l10ntools tdf#147021 Use std::size() instead of SAL_N_ELEMENTS() macro 2023-07-28 07:07:11 +02:00
librelogo tdf#157388: LibreLogo sqrt undefined 2023-09-24 13:32:45 +02:00
libreofficekit lok: a11y: when we are inside a table notify table and current cell info 2023-08-14 08:09:53 +02:00
lingucomponent loplugin:ostr: automatic rewrite 2023-10-07 00:47:20 +02:00
linguistic Drop o3tl::span, can use C++20 std::span directly now 2023-10-11 21:53:13 +02:00
lotuswordpro loplugin:ostr: automatic rewrite 2023-10-07 00:47:20 +02:00
m4
msicreator
nlpsolver
o3tl Drop o3tl::span, can use C++20 std::span directly now 2023-10-11 21:53:13 +02:00
odk remove obsolete -single_module linker flag (is the default) 2023-10-04 15:00:31 +02:00
offapi Add NUMBERSIGN key handler. 2023-10-14 21:51:43 +02:00
officecfg Add NUMBERSIGN key handler. 2023-10-14 21:51:43 +02:00
onlineupdate
oovbaapi
oox tdf#141908 change sal_Int32 to Color 2023-10-14 08:29:55 +02:00
opencl Use less libxml2 external headers dependency 2023-09-29 00:20:57 +02:00
osx Add all source directories as folder references to the Xcode project 2023-07-05 10:30:37 +02:00
package incorrect usage of erase..remove idion 2023-08-28 12:59:32 +02:00
pch
postprocess Fix postprocess/README packimages.pl has been replaced by pack_images.py 2023-07-16 18:54:15 +02:00
pyuno Use exception ctors, instead of setting members later 2023-10-14 15:37:17 +02:00
qadevOOo tdf#146150 Use dispatch cmd for the corresponding SID 2023-09-25 13:04:27 +02:00
readlicense_oo update credits 2023-09-22 20:05:54 +02:00
registry
remotebridges
reportbuilder
reportdesign Use exception ctors, instead of setting members later 2023-10-14 15:37:17 +02:00
ridljar drop use of urp: followed by newline of space 2023-10-02 17:30:31 +02:00
sal split up the backtrace implementations into separate files 2023-10-12 16:11:16 +02:00
salhelper tdf#146619 Remove unused #includes from C/C++ files 2023-08-01 21:13:47 +02:00
sax Use exception ctors, instead of setting members later 2023-10-14 15:37:17 +02:00
sc tdf#150466 notebookbar: hide PrintDefault on compact and standardize 2023-10-15 02:48:40 +02:00
scaddins Make NC_ constexpr-friendly 2023-10-12 18:17:49 +02:00
sccomp Make NC_ constexpr-friendly 2023-10-12 18:17:49 +02:00
schema tdf#154449 Add support for hidden named ranges 2023-10-01 13:01:32 +02:00
scp2
scripting no need to use UNO_QUERY_THROW here 2023-09-02 22:49:12 +02:00
sd tdf#150466 notebookbar: hide PrintDefault on compact and standardize 2023-10-15 02:48:40 +02:00
sdext loplugin:ostr: automatic rewrite 2023-10-07 00:47:20 +02:00
setup_native tdf#144053 Compare version to ProductKey entry in bootstraprc 2023-07-26 14:40:02 +02:00
sfx2 Keep some information when switching between exceptions and ErrCodeMsg 2023-10-14 17:36:30 +02:00
shell Make NC_ constexpr-friendly 2023-10-12 18:17:49 +02:00
slideshow Drop o3tl::span, can use C++20 std::span directly now 2023-10-11 21:53:13 +02:00
smoketest
solenv split up the backtrace implementations into separate files 2023-10-12 16:11:16 +02:00
soltools
sot Use std::span 2023-10-11 08:50:20 +02:00
starmath Make NC_ constexpr-friendly 2023-10-12 18:17:49 +02:00
static JavaScript uno bindings for WASM with Embind - first cut 2023-09-18 19:59:57 +02:00
stoc tdf#101376 don't detach thread if it is the main thread on macOS 2023-10-15 15:33:09 +02:00
store
svgio tdf#97710: do not create nonzero conform for polyline 2023-09-26 21:53:32 +02:00
svl Drop o3tl::span, can use C++20 std::span directly now 2023-10-11 21:53:13 +02:00
svtools Make NC_ constexpr-friendly 2023-10-12 18:17:49 +02:00
svx Use exception ctors, instead of setting members later 2023-10-14 15:37:17 +02:00
sw tdf#143148 use pragma once and removed include guards 2023-10-15 12:08:09 +02:00
swext Fix typo 2023-06-28 21:44:39 +02:00
sysui Only pass -I... arguments to g-ir-scanner by using pkg-config's --cflags-only-I 2023-07-23 15:10:47 +02:00
test make testCondFormatFormulaListenerXLSX reliable 2023-10-08 19:12:46 +02:00
testtools Use exception ctors, instead of setting members later 2023-10-14 15:37:17 +02:00
toolkit Use exception ctors, instead of setting members later 2023-10-14 15:37:17 +02:00
tools loplugin:ostr: automatic rewrite 2023-10-07 00:47:20 +02:00
translations@73620e7f6b Update git submodules 2023-10-11 15:27:25 +02:00
ucb Use exception ctors, instead of setting members later 2023-10-14 15:37:17 +02:00
ucbhelper Use exception ctors, instead of setting members later 2023-10-14 15:37:17 +02:00
udkapi
uitest SW comments: Provide parent / child relations without position. 2023-10-05 16:46:15 +02:00
UnoControls loplugin:unodispose in UnoControls 2023-09-12 14:57:24 +02:00
unodevtools new loplugin:constexprliteral 2023-06-26 13:12:31 +02:00
unoidl Use less zlib external headers dependency 2023-09-18 08:34:34 +02:00
unoil
unotest
unotools Use exception ctors, instead of setting members later 2023-10-14 15:37:17 +02:00
unoxml Use exception ctors, instead of setting members later 2023-10-14 15:37:17 +02:00
ure Add a FunctionBasedURPConnection and a websocket URP connector 2023-09-01 16:55:37 +02:00
uui Make NC_ constexpr-friendly 2023-10-12 18:17:49 +02:00
vbahelper Drop o3tl::span, can use C++20 std::span directly now 2023-10-11 21:53:13 +02:00
vcl Add NUMBERSIGN key handler. 2023-10-14 21:51:43 +02:00
winaccessibility wina11y: Drop CAccTextBase::GetXInterface 2023-10-11 07:20:21 +02:00
wizards Fix typos 2023-10-06 10:05:11 +02:00
writerfilter writerfilter: clean-up PushPageHeaderFooter method impl. 2023-10-12 09:31:09 +02:00
writerperfect Make NC_ constexpr-friendly 2023-10-12 18:17:49 +02:00
xmerge
xmlhelp
xmloff add LibreOffice_settings.xml_config-items.fods to document settings.xml 2023-10-13 14:35:21 +02:00
xmlreader
xmlscript
xmlsecurity Make NC_ constexpr-friendly 2023-10-12 18:17:49 +02:00
.buckconfig
.buckversion
.clang-format
.editorconfig
.git-blame-ignore-revs
.gitattributes
.gitignore
.gitmodules
.gitpod.dockerfile
.gitpod.yml
.gitreview
antivirusDetection.vbs
autogen.sh
BUCK
config.guess
config.sub
config_host.mk.in tdf#101970 Introduce config option for building with or 2023-10-05 21:37:09 +02:00
config_host_lang.mk.in
configure.ac tdf#116412 include bz2 module in internal python 2023-10-14 08:53:14 +02:00
COPYING
COPYING.LGPL
COPYING.MPL
cpp.hint Add some entries into cpp.hint 2023-10-07 17:20:38 +02:00
download.lst Upgrade libffi to 3.4.4 2023-10-14 15:51:09 +02:00
g
hardened_runtime.xcent.in
install-sh
install_deps.sh
leak-suppress.txt
Library_merged.mk
lo.xcent.in
logerrit
Makefile.fetch tdf#124591: Rename *noto.mk to *noto_kufi_arabic.mk 2023-09-26 22:00:56 +02:00
Makefile.gbuild
Makefile.in
README.cross
README.help.md
README.md Adjust for new linux baseline 2023-09-19 08:23:19 +02:00
README.Solaris
Repository.mk Related: tdf#101970 Add missing bits for --without-template flag 2023-10-13 17:48:10 +02:00
RepositoryExternal.mk tdf#116412 include bz2 module in internal python 2023-10-14 08:53:14 +02:00
RepositoryFixes.mk
RepositoryModule_build.mk
RepositoryModule_host.mk
sanitize-ubsan-excludelist
setup.cfg
TEMPLATE.SOURCECODE.HEADER
tsan-suppress.txt fix duplicate I introduced to tsan-suppress 2023-08-28 14:33:10 +02:00

LibreOffice

Coverity Scan Build Status CII Best Practices Translation status

LibreOffice is an integrated office suite based on copyleft licenses and compatible with most document formats and standards. Libreoffice is backed by The Document Foundation, which represents a large independent community of enterprises, developers and other volunteers moved by the common goal of bringing to the market the best software for personal productivity. LibreOffice is open source, and free to download, use and distribute.

A quick overview of the LibreOffice code structure.

Overview

You can develop for LibreOffice in one of two ways, one recommended and one much less so. First the somewhat less recommended way: it is possible to use the SDK to develop an extension, for which you can read the API docs and Developers Guide. This re-uses the (extremely generic) UNO APIs that are also used by macro scripting in StarBasic.

The best way to add a generally useful feature to LibreOffice is to work on the code base however. Overall this way makes it easier to compile and build your code, it avoids any arbitrary limitations of our scripting APIs, and in general is far more simple and intuitive - if you are a reasonably able C++ programmer.

The Build Chain and Runtime Baselines

These are the current minimal operating system and compiler versions to run and compile LibreOffice, also used by the TDF builds:

  • Windows:
    • Runtime: Windows 7
    • Build: Cygwin + Visual Studio 2019 version 16.10
  • macOS:
    • Runtime: 10.15
    • Build: 12 (13 for aarch64) + Xcode 14
  • Linux:
    • Runtime: RHEL 8 or CentOS 8 and comparable
    • Build: either GCC 12; or Clang 12 with libstdc++ 8.5
  • iOS (only for LibreOfficeKit):
    • Runtime: 11.4 (only support for newer i devices == 64 bit)
    • Build: Xcode 9.3 and iPhone SDK 11.4
  • Android:
    • Build: NDK r23 and SDK 30.0.3
  • Emscripten / WASM:
    • Runtime: a browser with SharedMemory support (threads + atomics)
    • Build: Qt 5.15 with Qt supported Emscripten 1.39.8
    • See README.wasm

Java is required for building many parts of LibreOffice. In TDF Wiki article Development/Java, the exact modules that depend on Java are listed.

The baseline for Java is Java Development Kit (JDK) Version 17 or later. It is possible to build LibreOffice with JDK version 9, but it is no longer supported by the JDK vendors, thus it should be avoided.

If you want to use Clang with the LibreOffice compiler plugins, the minimal version of Clang is 12.0.1. Since Xcode doesn't provide the compiler plugin headers, you have to compile your own Clang to use them on macOS.

You can find the TDF configure switches in the distro-configs/ directory.

To setup your initial build environment on Windows and macOS, we provide the LibreOffice Development Environment (LODE) scripts.

For more information see the build instructions for your platform in the TDF wiki.

The Important Bits of Code

Each module should have a README.md file inside it which has some degree of documentation for that module; patches are most welcome to improve those. We have those turned into a web page here:

https://docs.libreoffice.org/

However, there are two hundred modules, many of them of only peripheral interest for a specialist audience. So - where is the good stuff, the code that is most useful. Here is a quick overview of the most important ones:

Module Description
sal/ this provides a simple System Abstraction Layer
tools/ this provides basic internal types: Rectangle, Color etc.
vcl/ this is the widget toolkit library and one rendering abstraction
framework/ UNO framework, responsible for building toolbars, menus, status bars, and the chrome around the document using widgets from VCL, and XML descriptions from /uiconfig/ files
sfx2/ legacy core framework used by Writer/Calc/Draw: document model / load/save / signals for actions etc.
svx/ drawing model related helper code, including much of Draw/Impress

Then applications

Module Description
desktop/ this is where the main() for the application lives, init / bootstrap. the name dates back to an ancient StarOffice that also drew a desktop
sw/ Writer
sc/ Calc
sd/ Draw / Impress

There are several other libraries that are helpful from a graphical perspective:

Module Description
basegfx/ algorithms and data-types for graphics as used in the canvas
canvas/ new (UNO) canvas rendering model with various backends
cppcanvas/ C++ helper classes for using the UNO canvas
drawinglayer/ View code to render drawable objects and break them down into primitives we can render more easily.

Rules for #include Directives (C/C++)

Use the "..." form if and only if the included file is found next to the including file. Otherwise, use the <...> form. (For further details, see the mail Re: C[++]: Normalizing include syntax ("" vs <>).)

The UNO API include files should consistently use double quotes, for the benefit of external users of this API.

loplugin:includeform (compilerplugins/clang/includeform.cxx) enforces these rules.

Finding Out More

Beyond this, you can read the README.md files, send us patches, ask on the mailing list libreoffice@lists.freedesktop.org (no subscription required) or poke people on IRC #libreoffice-dev on irc.libera.chat - we're a friendly and generally helpful mob. We know the code can be hard to get into at first, and so there are no silly questions.