Test repository to check push and ssh key
Find a file
Andrea Gelmini de44eadeb7 Update git submodules
* Update helpcontent2 from branch 'master'
  to 4f83321e274052b64e16dba7b50ddee41db53ab3
  - Removed exec bits on PNG files
    
    Change-Id: Ib7c4c917bb7a9c661ee1f28b7c4359acdbac767b
    Reviewed-on: https://gerrit.libreoffice.org/c/help/+/176425
    Tested-by: Jenkins
    Reviewed-by: Julien Nabet <serval2412@yahoo.fr>
2024-11-12 09:54:06 +01:00
.configurations Fix typo 2024-10-11 14:01:05 +02:00
.git-hooks
.github
.vscode vscode-ide-integration: add license-header template (snippet) 2023-11-06 13:55:12 +01:00
accessibility com::sun::star -> css 2024-11-10 10:50:15 +01:00
android android-viewer translated using Weblate 2024-11-04 13:51:47 +01:00
animations
apple_remote
avmedia no need to take a copy of the getProcessComponentContext return value 2024-11-08 15:23:52 +01:00
basctl clang-tidy: performance-unnecessary-copy-initialization in basctl 2024-11-11 15:46:42 +01:00
basegfx com::sun::star -> css 2024-11-10 10:50:15 +01:00
basic tdf#163486: PVS: Identical branches 2024-11-12 01:35:14 +01:00
bean
bin find-unneeded-includes: nicer output with --finderror option 2024-10-28 10:39:41 +01:00
binaryurp clang-tidy: performance-unnecessary-copy-initialization in binaryurp 2024-11-11 15:47:00 +01:00
bridges com::sun::star -> css 2024-11-10 10:50:15 +01:00
canvas clang-tidy: performance-unnecessary-copy-initialization in canvas 2024-11-11 15:47:08 +01:00
chart2 tdf#163486: PVS: Identical branches 2024-11-12 01:24:30 +01:00
cli_ure Simplify a bit 2024-11-08 05:34:20 +01:00
codemaker loplugin:reftotemp in codemaker..connectivity 2024-11-08 17:33:29 +01:00
comphelper com::sun::star -> css 2024-11-10 10:50:15 +01:00
compilerplugins loplugin:passstuffbyref make some small improvements 2024-11-07 17:20:09 +01:00
config_host Add experimental support for Emscripten JSPI 2024-11-04 20:47:05 +01:00
configmgr Simplify a bit 2024-11-08 05:34:20 +01:00
connectivity clang-tidy: performance-unnecessary-copy-initialization in connectivity 2024-11-11 10:58:45 +01:00
cppcanvas loplugin:reftotemp in cppcanvas..cui 2024-11-08 17:33:10 +01:00
cppu Simplify a bit 2024-11-08 05:34:20 +01:00
cppuhelper loplugin:reftotemp in cppcanvas..cui 2024-11-08 17:33:10 +01:00
cpputools cid#1555171 Data race condition 2024-10-17 20:25:15 +02:00
cui tdf#162753 - Hyperlink dialog: trim leading/trailing whitespaces of URLs 2024-11-12 07:35:29 +01:00
dbaccess clang-tidy: performance-unnecessary-copy-initialization in dbaccess 2024-11-11 10:58:19 +01:00
desktop clang-tidy: performance-unnecessary-copy-initialization in desktop 2024-11-11 15:47:17 +01:00
dictionaries@1ca6cb9f31 Update git submodules 2024-11-10 11:45:27 +01:00
distro-configs add a --with-system-java-websocket 2024-09-20 17:43:42 +02:00
docmodel
drawinglayer loplugin:reftotemp in drawinglayer..framework 2024-11-11 18:28:57 +01:00
editeng loplugin:reftotemp in dbaccess..editeng 2024-11-08 19:38:38 +01:00
embeddedobj UnoApiTest: rename load to loadFromURL and use it everywhere 2024-10-29 09:11:37 +01:00
embedserv
emfio convert KernArray from sal_Int32 to double 2024-10-31 12:10:52 +01:00
eventattacher Simplify a bit 2024-11-08 05:34:20 +01:00
extensions clang-tidy: performance-unnecessary-copy-initialization in extensions 2024-11-11 20:11:11 +01:00
external gpgme: Upgrade to 1.24.0 2024-11-08 22:49:42 +01:00
extras tdf#87605: Add new words to technical dictionary. 2024-10-20 07:09:19 +02:00
filter clang-tidy: performance-unnecessary-copy-initialization in filter 2024-11-11 20:11:34 +01:00
forms clang-tidy: performance-unnecessary-copy-initialization in fpicker 2024-11-11 21:02:38 +01:00
formula loplugin:reftotemp in drawinglayer..framework 2024-11-11 18:28:57 +01:00
fpicker clang-tidy: performance-unnecessary-copy-initialization in fpicker 2024-11-11 21:02:38 +01:00
framework add AbortOnLoadFailure to optionally assert on failure to load 2024-11-11 22:33:36 +01:00
helpcompiler loplugin:reftotemp in helpcompiler..i18npool 2024-11-11 18:29:07 +01:00
helpcontent2@4f83321e27 Update git submodules 2024-11-12 09:54:06 +01:00
hwpfilter no need to heap allocate these 2024-11-01 07:27:27 +01:00
i18nlangtag tdf#90341 Clean up excessive const_cast'ing 2024-10-23 15:15:38 +02:00
i18npool loplugin:reftotemp in helpcompiler..i18npool 2024-11-11 18:29:07 +01:00
i18nutil tdf#163486: PVS: Identical branches 2024-11-01 01:20:27 +01:00
icon-themes Resolves tdf148513 - Illustration for line break options 2024-10-24 10:04:17 +02:00
idl
idlc/test/parser
include clang-tidy: performance-unnecessary-copy-initialization in oox 2024-11-12 07:26:07 +01:00
instsetoo_native Adapt to generation of .worker.js files gone from 3.1.68 2024-10-30 13:51:40 +01:00
io cid#1556875 COPY_INSTEAD_OF_MOVE 2024-10-26 21:54:56 +02:00
ios
javaunohelper
jurt
jvmaccess
jvmfwk clang-tidy: performance-unnecessary-copy-initialization in various 2024-11-11 21:02:55 +01:00
l10ntools add Tagalog (tl) langauge- & helppack 2024-10-23 18:22:36 +02:00
librelogo
libreofficekit loplugin:reftotemp in libreofficekit..oox 2024-11-11 20:11:23 +01:00
lingucomponent no need to take a copy of the getProcessComponentContext return value 2024-11-08 15:23:52 +01:00
linguistic clang-tidy: performance-unnecessary-copy-initialization in various 2024-11-11 21:02:55 +01:00
lotuswordpro clang-tidy: performance-unnecessary-copy-initialization in various 2024-11-11 21:02:55 +01:00
m4
msicreator comphelper, msicreator, odk: fix issues found by Ruff linter 2024-07-27 15:42:26 +02:00
net_ure .NET Bindings: Native bridge for .NET 2024-09-18 08:10:36 +02:00
nlpsolver
o3tl
odk
offapi [API CHANGE] a11y: Switch AccessibleRelationType to enum 2024-11-07 08:50:13 +01:00
officecfg Related tdf#74386 - Improvements for text boundaries options 2024-11-08 10:16:58 +01:00
oovbaapi
oox clang-tidy: performance-unnecessary-copy-initialization in oox 2024-11-12 07:26:07 +01:00
opencl
osx Remove archaic xmerge 2024-10-24 16:28:18 +02:00
package tdf#163486: PVS: exception thrown by pointer 2024-11-11 17:48:07 +01:00
pch
postprocess
pyuno clang-tidy: performance-unnecessary-copy-initialization in various 2024-11-11 21:02:55 +01:00
qadevOOo cid#1557158 Unguarded read 2024-09-17 13:23:25 +02:00
readlicense_oo update credits 2024-11-08 12:18:09 +01:00
registry version COVERITY conditionals 2024-10-14 13:07:37 +02:00
remotebridges
reportbuilder
reportdesign clang-tidy: performance-unnecessary-copy-initialization in reportdesgn 2024-11-12 07:25:33 +01:00
ridljar
sal clang-tidy: performance-unnecessary-copy-initialization in sal 2024-11-12 07:25:22 +01:00
salhelper Do not try to notify, if the thread is already killed 2024-08-20 11:14:01 +02:00
sax loplugin:reftotemp in pyuno..sax 2024-11-11 15:47:38 +01:00
sc loplugin:reftotemp in sc 2024-11-12 07:25:57 +01:00
scaddins tdf#163486: PVS: Identical branches 2024-11-06 22:42:47 +01:00
sccomp Fix typo 2024-10-09 22:41:42 +02:00
schema tdf#162686 tdf#162687 ODF 1.4 extrusion-metal-type 2024-11-10 18:50:37 +01:00
scp2 add Tagalog (tl) langauge- & helppack 2024-10-23 18:22:36 +02:00
scripting tdf#163486: PVS: simplify while loop 2024-11-11 15:52:07 +01:00
sd tdf#163486: PVS: Identical branches 2024-11-12 02:05:19 +01:00
sdext new loplugin:staticconstexpr 2024-11-04 08:51:00 +01:00
setup_native
sfx2 clang-tidy: performance-unnecessary-copy-initialization in sfx2 2024-11-12 09:03:02 +01:00
shell
slideshow clang-tidy: performance-unnecessary-copy-initialization in svx 2024-11-12 08:41:41 +01:00
smoketest
solenv move CryptTools from oox to comphelper so we can reuse it 2024-11-04 21:51:32 +01:00
soltools Drop C/C++ DEBUG macro 2024-03-21 16:30:59 +01:00
sot loplugin:passstuffbyref make some small improvements 2024-11-07 17:20:09 +01:00
starmath no need to take a copy of the getProcessComponentContext return value 2024-11-08 15:23:52 +01:00
static Simplify a bit 2024-11-08 05:34:20 +01:00
stoc Simplify a bit 2024-11-08 05:34:20 +01:00
store drop a static 2024-11-10 15:19:38 +01:00
svgio Simplify a bit 2024-11-05 06:36:16 +01:00
svl cool#9992 lok doc sign, hash extract: time for getCommandValues('Signature') 2024-11-11 21:54:23 +01:00
svtools clang-tidy: performance-unnecessary-copy-initialization in svx 2024-11-12 08:41:41 +01:00
svx tdf#163486: PVS: simplify while loop 2024-11-12 09:24:23 +01:00
sw clang-tidy: performance-unnecessary-copy-initialization in sw 2024-11-12 09:03:13 +01:00
swext
sysui
test com::sun::star -> css 2024-11-10 10:50:15 +01:00
testtools Simplify a bit 2024-11-08 05:34:20 +01:00
toolkit clang-tidy: performance-unnecessary-copy-initialization in various 2024-11-12 09:03:21 +01:00
tools cid#1606697 silence Overflowed constant 2024-11-07 11:57:42 +01:00
translations@50f69fbf13 Update git submodules 2024-11-05 14:09:30 +01:00
ucb clang-tidy: performance-unnecessary-copy-initialization in various 2024-11-12 09:03:21 +01:00
ucbhelper cid#1556442 COPY_INSTEAD_OF_MOVE 2024-11-06 13:58:54 +01:00
udkapi
uitest Document LIBO_TEST_DEFAULT_DESKTOP environment variable 2024-10-21 10:48:29 +02:00
UnoControls XTopWindowListener is unused here 2024-11-09 19:33:09 +01:00
unodevtools
unoidl
unoil
unotest no need to take a copy of the getProcessComponentContext return value 2024-11-08 15:23:52 +01:00
unotools clang-tidy: performance-unnecessary-copy-initialization in various 2024-11-12 09:03:21 +01:00
unoxml com::sun::star -> css 2024-11-10 10:50:15 +01:00
ure
uui cool#9956 uui lok: avoid showing the password dialog for now 2024-09-03 11:28:13 +02:00
vbahelper clang-tidy: performance-unnecessary-copy-initialization in various 2024-11-12 09:03:21 +01:00
vcl tdf#163486: PVS: Identical branches 2024-11-12 01:55:53 +01:00
winaccessibility com::sun::star -> css 2024-11-10 10:50:15 +01:00
wizards tdf#144702 Base Fields in Report Label Display Clipped 2024-10-23 07:47:34 +02:00
writerperfect com::sun::star -> css 2024-11-10 10:50:15 +01:00
xmlhelp no need to take a copy of the getProcessComponentContext return value 2024-11-08 15:23:52 +01:00
xmloff tdf#163486: PVS: pointer not released in destructor 2024-11-11 15:52:24 +01:00
xmlreader
xmlscript no need to take a copy of the getProcessComponentContext return value 2024-11-08 15:23:52 +01:00
xmlsecurity cool#9992 lok doc sign, hash extract: time for getCommandValues('Signature') 2024-11-11 21:54:23 +01:00
.buckconfig
.buckversion Add build toolchain to upload LibreOffice API to Maven Central 2015-12-03 23:32:11 +00:00
.clang-format
.editorconfig We have some Objective-C source files, too 2017-12-01 12:59:43 +02:00
.git-blame-ignore-revs tdf#157638 Added to git blame ignore list 2023-12-29 17:01:32 +01:00
.gitattributes SVG is a textual XML format after all 2022-06-24 16:36:36 +02:00
.gitignore add secmod.db files to .gitignore 2024-01-15 08:48:52 +01:00
.gitmodules gitmodules: use relative paths 2020-10-21 21:51:54 +02:00
.gitpod.dockerfile Upgrade .gitpod.dockerfile to Ubuntu focal 2021-05-22 19:35:47 +02:00
.gitpod.yml
.gitreview
.vsconfig winget configuration files for installing Visual Studio Community 2022 2024-10-10 23:49:19 +02:00
antivirusDetection.vbs tdf#84553 Correctly handle failures while getting a WMI Object. 2020-02-12 09:14:03 +01:00
autogen.sh
BUCK Adapt buck build to jars merged into libreoffice.jar 2020-11-30 11:27:47 +01:00
config.guess Update config.guess & .sub to latest 2022-12-12 15:46:46 +00:00
config.sub
config_host.mk.in Add experimental support for Emscripten JSPI 2024-11-04 20:47:05 +01:00
config_host_lang.mk.in
configure.ac Add experimental support for Emscripten JSPI 2024-11-04 20:47:05 +01:00
COPYING
COPYING.LGPL Licencing files 2011-01-11 21:49:39 +00:00
COPYING.MPL
cpp.hint sw: drop DECLARE_FODFEXPORT_TEST macro 2024-10-16 15:28:13 +02:00
download.lst gpgme: Upgrade to 1.24.0 2024-11-08 22:49:42 +01:00
g git-hooks: remove hint in './g -z' 2023-04-01 13:28:14 +02:00
install-sh Fix typos 2019-08-12 22:12:57 +02:00
install_deps.sh Make some scripts more portable 2021-08-20 12:32:22 +02:00
leak-suppress.txt
Library_merged.mk gbuild: Remove MSVC 2013 legacy code 2017-04-21 18:18:44 +02:00
logerrit When no branch is specified, fallback to the tracked branch first 2024-04-11 14:08:29 +02:00
Makefile.fetch Bundle fonts of Google's DocRepair Project 2024-07-05 15:37:11 +02:00
Makefile.gbuild
Makefile.in
README.cross
README.help.md Fix typo 2022-07-30 23:26:39 +02:00
README.md
README.Solaris
Repository.mk Remove archaic xmerge 2024-10-24 16:28:18 +02:00
RepositoryExternal.mk
RepositoryFixes.mk
RepositoryModule_build.mk
RepositoryModule_host.mk Remove archaic xmerge 2024-10-24 16:28:18 +02:00
sanitize-ubsan-excludelist replace usage of blacklist with denylist 2020-07-10 01:34:54 +02:00
setup.cfg
TEMPLATE.SOURCECODE.HEADER Make it clear that the text is in addition to the previous 2021-01-27 08:02:35 +01:00
tsan-suppress.txt update tsan suppressions 2024-07-11 13:04:30 +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++ 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.

SAST Tools

PVS-Studio - static analyzer for C, C++, C#, and Java code.