Test repository to check push and ssh key
Find a file
Noel Grandin ca5113d4f8 fix asan build
Change-Id: Ie7970629bcf09b8b9c0f4c052d0a9187d56d9d8e
Reviewed-on: https://gerrit.libreoffice.org/c/core/+/172988
Tested-by: Jenkins
Reviewed-by: Noel Grandin <noel.grandin@collabora.co.uk>
2024-09-07 12:31:07 +02:00
.git-hooks
.github
.vscode
accessibility use less dynamic_cast when broadcasting SfxHint 2024-09-05 08:10:26 +02:00
android
animations
apple_remote
avmedia
basctl cool#9992 lok doc sign: make SfxMedium::SignContents_Impl() async 2024-09-06 12:25:48 +02:00
basegfx ImplB2DPolygon could do with a move constructor 2024-09-01 15:19:01 +02:00
basic use less dynamic_cast when broadcasting SfxHint 2024-09-05 08:10:26 +02:00
bean
bin tdf#161826 - Add uniform Glow effect for texts in shapes 2024-08-29 19:59:24 +02:00
binaryurp
bridges tdf#160945: queryInterface must pass back indirect return value address in x0 2024-09-03 14:21:55 +02:00
canvas
chart2 tdf#90733 - support invertIfNegative for bar and bubble chart 2024-08-27 09:21:35 +02:00
cli_ure
codemaker
comphelper tdf#162772 Crash in "Target in Document" in Hyperlink dialog 2024-09-05 13:51:25 +02:00
compilerplugins drop unused eventtesting cmd line option 2024-09-06 12:25:32 +02:00
config_host Add a CUPS config header 2024-08-27 07:30:03 +02:00
configmgr Related: tdf#161599 ChildAccess::asValue() must return Reference<XInterface> 2024-08-27 21:09:35 +02:00
connectivity Use value-initialization instead of conditional compilation 2024-09-04 11:28:53 +02:00
cppcanvas
cppu
cppuhelper throw more useful exception from OPropertySetHelper::getPropertyValue 2024-09-05 13:51:34 +02:00
cpputools
cui cui: fix another plausible crash 2024-09-05 20:06:47 +02:00
dbaccess tsan: data race 2024-09-05 11:29:59 +02:00
desktop drop unused eventtesting cmd line option 2024-09-06 12:25:32 +02:00
dictionaries@2ae8fab6fe
distro-configs
docmodel
drawinglayer drawinglayer: getHeight() -> getWidth() 2024-09-05 20:06:21 +02:00
editeng tdf#151748 editeng: Fix crash in kashida justification after update 2024-09-04 19:29:51 +02:00
embeddedobj Avoid deadlock 2024-09-04 16:56:07 +02:00
embedserv
emfio drawinglayer: getHeight() -> getWidth() 2024-09-05 20:06:21 +02:00
eventattacher
extensions
external lok: add SAL_DISABLE_FSYNC environment to disable fsync. 2024-09-07 11:15:47 +02:00
extras Piano template: replace pictures with shapes 2024-09-01 21:08:34 +02:00
filter tdf#162782 SVG export: fix handling of semi-transparent text inside a list 2024-09-04 16:07:34 +02:00
forms
formula tdf#161543 Enhance the searching functionality in FD & FW 2024-09-03 09:59:16 +02:00
fpicker cid#1606757 Overflowed constant 2024-08-30 12:37:11 +02:00
framework cid#1608206 Double lock 2024-08-26 22:39:57 +02:00
helpcompiler
helpcontent2@8c0678cb66 Update git submodules 2024-09-07 09:44:33 +02:00
hwpfilter cid#1616925 Unintended sign extension 2024-08-28 13:13:43 +02:00
i18nlangtag tdf#158556 avoid a ton of temporary OUString 2024-08-28 19:35:08 +02:00
i18npool
i18nutil Drop newly unused ToggleUnicodeCodepoint::CharsToDelete 2024-08-28 20:52:12 +02:00
icon-themes Resolves tdf#162732 - Donate label not vertical centered 2024-09-03 15:17:22 +02:00
idl
idlc/test/parser
include reduce time spent in RecalcPageNums when importing PDF 2024-09-06 14:48:17 +02:00
instsetoo_native Emscripten: Support --disable-gui 2024-08-28 23:02:51 +02:00
io
ios
javaunohelper
jurt
jvmaccess
jvmfwk
l10ntools
librelogo
libreofficekit
lingucomponent
linguistic
lotuswordpro
m4
msicreator
net_ure
nlpsolver
o3tl
odk
offapi
officecfg Move mnemonic to logical, unique place 2024-09-07 08:20:05 +02:00
oovbaapi
oox tdf#161826 - Add uniform Glow effect for texts in shapes 2024-08-29 19:59:24 +02:00
opencl
osx
package cid#1618664 Self assignment 2024-08-28 12:16:46 +02:00
pch
postprocess
pyuno
qadevOOo
readlicense_oo update credits 2024-09-02 12:58:34 +02:00
registry
remotebridges
reportbuilder
reportdesign use less dynamic_cast when broadcasting SfxHint 2024-09-03 21:41:08 +02:00
ridljar
sal lok: add SAL_DISABLE_FSYNC environment to disable fsync. 2024-09-07 11:15:47 +02:00
salhelper
sax
sc tdf#162829: Dereference before null check 2024-09-07 12:25:33 +02:00
scaddins
sccomp
schema Related: tdf#161826 - Add uniform Glow effect for texts in shapes 2024-09-03 22:52:53 +02:00
scp2 scp2: simplifiy language snippet creation rules 2024-09-02 21:16:10 +02:00
scripting cid#1608218 silence Overflowed return value 2024-09-02 21:14:37 +02:00
sd tdf#162467: fix measurement units in impress/draw 2024-09-06 15:21:34 +02:00
sdext tdf#101611, tdf#108813, tdf#86211, sdext,pdfimport: Clip fills 2024-08-29 14:29:47 +02:00
setup_native
sfx2 cool#9992 lok doc sign: make SfxMedium::SignContents_Impl() async 2024-09-06 12:25:48 +02:00
shell
slideshow
smoketest
solenv Emscripten: Move -sEXPORT_EXCEPTION_HANDLING_HELPERS to gb_LinkTarget_LDFLAGS 2024-09-03 21:04:51 +02:00
soltools
sot tdf#158556 use more comphelper::ByteReader 2024-08-27 09:10:04 +02:00
starmath
static Explicitly .delete() one more interface object in uno.js 2024-09-02 10:57:36 +02:00
stoc
store
svgio
svl Deduplicate some code 2024-09-06 09:36:43 +02:00
svtools cid#1607370 Check of thread-shared field evades lock acquisition 2024-08-29 22:39:19 +02:00
svx reduce time spent in RecalcPageNums when importing PDF 2024-09-06 14:48:17 +02:00
sw fix asan build 2024-09-07 12:31:07 +02:00
swext
sysui
test
testtools
toolkit
tools ofz#70815 optimize this a little 2024-09-01 12:11:53 +02:00
translations@fdf5842af4 Update git submodules 2024-09-06 21:45:06 +02:00
ucb tdf#158556 use more comphelper::ByteReader 2024-08-27 09:10:04 +02:00
ucbhelper
udkapi
uitest
UnoControls
unodevtools
unoidl
unoil
unotest 'use strict' is of no use here... 2024-08-26 16:29:28 +02:00
unotools tdf#161543 Enhance the searching functionality in FD & FW 2024-09-03 09:59:16 +02:00
unoxml
ure
uui cool#9956 uui lok: avoid showing the password dialog for now 2024-09-03 11:28:13 +02:00
vbahelper
vcl tdf#162359 sw: fix the export of comments as PDF annotations 2024-09-05 22:58:30 +02:00
winaccessibility wina11y: Drop unused default params for AccObject ctor 2024-08-30 21:05:20 +02:00
wizards ScriptForge (Database) DMin, DMax return strings or dates 2024-09-05 15:21:53 +02:00
writerperfect
xmerge
xmlhelp
xmloff Related: tdf#161826 - Add uniform Glow effect for texts in shapes 2024-09-03 22:52:53 +02:00
xmlreader
xmlscript
xmlsecurity cid#1607713 silence Overflowed constant 2024-08-31 22:55:04 +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
config_host_lang.mk.in
configure.ac Latest VS 2022 Preview is 17.12.0 now 2024-09-04 01:07:29 +02:00
COPYING
COPYING.LGPL
COPYING.MPL
cpp.hint
download.lst poppler: upgrade to release 24.08.0 2024-09-06 16:45:53 +02:00
g
install-sh
install_deps.sh
leak-suppress.txt
Library_merged.mk
logerrit
Makefile.fetch
Makefile.gbuild
Makefile.in
README.cross
README.help.md
README.md
README.Solaris
Repository.mk Fix Repository.mk after 'add --with-docrepair-fonts option' (tdf#161941) 2024-08-29 11:54:13 +02:00
RepositoryExternal.mk Add a CUPS config header 2024-08-27 07:30:03 +02:00
RepositoryFixes.mk
RepositoryModule_build.mk
RepositoryModule_host.mk
sanitize-ubsan-excludelist
setup.cfg
TEMPLATE.SOURCECODE.HEADER
tsan-suppress.txt

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++ 10
  • 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.

The baseline for Python is version 3.11. It follows the version available in SUSE Linux Enterprise Desktop and the Maintenance Support version of Red Hat Enterprise Linux.

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.