Test repository to check push and ssh key
Find a file
Tamas Bunth 7a9f6df7fb single source file for licensing info with conditional text
... for easier maintenance. This commit only introduces the
framework. Follow up commits will update the license file.
Advantages:
* single source, multiple outputs (html, txt)
* conditional text, i.e. output will not include license
  terms of components that are not configured in the build

Change-Id: I0ffad41119228a0a26fd1b6ce19930ca6085adb2
Reviewed-on: https://gerrit.libreoffice.org/69396
Tested-by: Jenkins
Reviewed-by: Andras Timar <andras.timar@collabora.com>
2019-03-19 15:16:51 +01:00
.git-hooks
accessibility Simplify containers iterations in accessibility, avmedia 2019-03-16 20:18:40 +01:00
android android: Set the FONTCONFIG_FILE envvar to the fonts.conf (if exists). 2019-03-11 17:46:09 +01:00
animations
apple_remote
avmedia Simplify containers iterations in accessibility, avmedia 2019-03-16 20:18:40 +01:00
basctl tdf#120703 PVS: remove redundant static casts 2019-03-17 20:24:17 +01:00
basegfx Simplify containers iterations in basctl, basegfx, basic, bridges 2019-03-16 20:16:46 +01:00
basic Simplify containers iterations in basctl, basegfx, basic, bridges 2019-03-16 20:16:46 +01:00
bean
bin find-unneeded-includes: don't propose debug/set.h if multiset is used 2019-03-18 16:45:34 +01:00
binaryurp
bridges Simplify containers iterations in basctl, basegfx, basic, bridges 2019-03-16 20:16:46 +01:00
canvas
chart2 Removed executable permission on xlsx file 2019-03-19 07:06:42 +01:00
cli_ure Simplify containers iterations in chart2, cli_ure, comphelper, configmgr 2019-03-12 16:10:01 +01:00
codemaker
comphelper tdf#120703 PVS: remove redundant static casts 2019-03-17 20:24:17 +01:00
compilerplugins It is building the generator exe that depends on $(CLANGOUTDIR)/sharedvisitor 2019-03-18 21:24:45 +01:00
config_host
configmgr Simplify containers iterations in chart2, cli_ure, comphelper, configmgr 2019-03-12 16:10:01 +01:00
connectivity connectivity Writer driver: use auto when initializing with new to avoid ... 2019-03-13 15:59:02 +01:00
cppcanvas
cppu
cppuhelper tdf#120703 PVS: remove redundant static casts 2019-03-17 20:24:17 +01:00
cpputools
cui weld SwFieldRefPage 2019-03-18 22:10:57 +01:00
dbaccess clarify that set_visible(true/false) is just show/hide 2019-03-16 01:01:33 +01:00
desktop Added tiled watermark export option for pdf 2019-03-18 13:03:28 +01:00
dictionaries@10e0418ad6
distro-configs
drawinglayer
dtrans
editeng
embeddedobj tdf#120703 PVS: remove redundant static casts 2019-03-17 20:24:17 +01:00
embedserv
emfio
eventattacher
extensions loplugin:unusedmethods 2019-03-14 08:48:09 +01:00
external external: update pdfium to 3730 2019-03-13 09:26:23 +01:00
extras weld SwFieldDBPage 2019-03-19 12:10:13 +01:00
filter Added tiled watermark export option for pdf 2019-03-18 13:03:28 +01:00
forms tdf#42949 Fix IWYU warnings in include/connectivity/* 2019-03-12 10:14:54 +01:00
formula
fpicker getToken() ==> copy() since separator positions are known 2019-03-14 22:43:08 +01:00
framework tdf#45904 Move XEnumerationAccess Java test to C++ 2019-03-17 04:03:59 +01:00
helpcompiler
helpcontent2@86716b1007 Update git submodules 2019-03-19 13:50:24 +01:00
hwpfilter
i18nlangtag Index is not needed for single getToken call 2019-03-18 12:25:24 +01:00
i18npool
i18nutil
icon-themes Cleaned up Tango SVG icons 2019-03-19 12:14:03 +01:00
idl
idlc
include weld SwFieldDBPage 2019-03-19 12:10:13 +01:00
instsetoo_native
io
ios We need share/theme_definitions in the iOS app 2019-03-11 23:33:33 +02:00
javaunohelper
jurt
jvmaccess
jvmfwk Index is not needed for single getToken call 2019-03-18 12:25:24 +01:00
l10ntools Remove broken MergeDataHashMap optimization 2019-03-18 21:24:23 +01:00
librelogo tdf#124035 LibreLogo: support starting colon in variable names 2019-03-13 07:40:36 +01:00
libreofficekit
lingucomponent loplugin:typedefparam (macOS) 2019-03-17 16:40:11 +01:00
linguistic
lotuswordpro
m4
nlpsolver
o3tl
odk single source file for licensing info with conditional text 2019-03-19 15:16:51 +01:00
offapi
officecfg Sifr icon theme update sc_ for draw menubar 2019-03-19 00:07:25 +01:00
onlineupdate
oovbaapi
oox tdf#81437 XLSX import: fix missing chart border 2019-03-18 16:38:55 +01:00
opencl
osx
package tdf#120703 PVS: remove redundant static casts 2019-03-17 20:24:17 +01:00
postprocess tdf#112411 Remove all that remains of the More controls toolbars 2019-03-14 08:52:29 +01:00
pyuno tdf#124011 Add __ne__ method to UNO types 2019-03-18 09:34:41 +01:00
qadevOOo tdf#45904 Move XEnumerationAccess Java test to C++ 2019-03-17 04:03:59 +01:00
readlicense_oo single source file for licensing info with conditional text 2019-03-19 15:16:51 +01:00
registry
remotebridges
reportbuilder
reportdesign tdf#42949 Fix IWYU warnings in include/connectivity/* 2019-03-12 10:14:54 +01:00
ridljar
sal hang in crashtesting, would be nice to know what failed to exec here 2019-03-19 12:10:28 +01:00
salhelper
sax
sc tdf#120161 sc: pdf export unit test 2019-03-19 10:53:24 +01:00
scaddins
sccomp
schema
scp2
scripting tdf#123588 Beanshell editor to indicate whether script is saved 2019-03-13 07:46:20 +01:00
sd PPTX import: save also OOXDrawing in InteropGrabBag 2019-03-18 09:22:45 +01:00
sdext
setup_native
sfx2 single source file for licensing info with conditional text 2019-03-19 15:16:51 +01:00
shell
slideshow
smoketest
solenv single source file for licensing info with conditional text 2019-03-19 15:16:51 +01:00
soltools loplugin:typedefparam 2019-03-15 16:54:31 +01:00
sot
starmath clarify that set_visible(true/false) is just show/hide 2019-03-16 01:01:33 +01:00
stoc
store
svgio svgio: don't use_library_objects in CppunitTest_svgio_read 2019-03-12 14:46:48 +01:00
svl tdf#120703 PVS: remove redundant static casts 2019-03-17 20:24:17 +01:00
svtools clarify that set_visible(true/false) is just show/hide 2019-03-16 01:01:33 +01:00
svx pahole changes in various 2019-03-16 07:17:15 +01:00
sw tdf#86731: Add the dictionary not available message 2019-03-19 13:44:45 +01:00
swext
sysui
test name apitest suites consistently while we still can 2019-03-19 08:38:34 +01:00
testtools
toolkit tdf#120703 PVS: remove redundant static casts 2019-03-17 20:24:17 +01:00
tools
translations@46a65ed743
ucb tdf#120703 PVS: remove redundant static casts 2019-03-17 20:24:17 +01:00
ucbhelper
udkapi
uitest weld SvxMenuConfigPage/SvxToolbarConfigPage 2019-03-11 10:00:31 +01:00
UnoControls
unodevtools
unoidl
unoil
unotest
unotools
unoxml
ure
uui tdf#120703 PVS: remove redundant static casts 2019-03-17 20:24:17 +01:00
vbahelper
vcl weld SwFieldDBPage 2019-03-19 12:10:13 +01:00
winaccessibility
wizards tdf#112411 Remove all that remains of the More controls toolbars 2019-03-14 08:52:29 +01:00
writerfilter DOCX import: fix unexpected page break on autotext insert at end of doc 2019-03-13 21:52:37 +01:00
writerperfect
xmerge
xmlhelp
xmloff tdf#113289: Default value for footnote separator 2019-03-14 18:13:24 +01:00
xmlreader
xmlscript i#119731 Hyperlink Control on dialog Editor 2019-03-11 15:51:16 +01:00
xmlsecurity weld SwEditRegionDlg 2019-03-16 20:03:31 +01:00
.buckconfig
.buckversion
.clang-format
.editorconfig
.gitattributes
.gitignore
.gitmodules
.gitreview
autogen.sh
BUCK
config.guess
config.sub
config_host.mk.in
config_host_lang.mk.in
configure.ac AC_CHECK_HEADER uses both CXX and CXXCPP 2019-03-11 12:43:41 +01:00
COPYING
COPYING.LGPL
COPYING.MPL
download.lst external: update pdfium to 3730 2019-03-13 09:26:23 +01:00
g
install-sh
leak-suppress.txt
Library_merged.mk
lo.xcent
logerrit
Makefile.fetch
Makefile.gbuild
Makefile.in
README.cross
README.md
README.Solaris
Repository.mk single source file for licensing info with conditional text 2019-03-19 15:16:51 +01:00
RepositoryExternal.mk
RepositoryFixes.mk
RepositoryModule_build.mk
RepositoryModule_host.mk
sanitize-ubsan-blacklist
setup.cfg
TEMPLATE.SOURCECODE.HEADER

LibreOffice

Coverity Scan Build Status CII Best Practices

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 here and here. 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 2017
  • macOS:
    • Runtime: 10.10
    • Build: 10.13.2 + Xcode 9.3
  • Linux:
    • Runtime: RHEL 6 or CentOS 6
    • Build: either GCC 7.0.0; or Clang 5.0.2 with libstdc++ 7.3.0
  • iOS (only for LibreOfficeKit):
    • Runtime: 11.4 (only support for newer i devices == 64 bit)
    • Build: Xcode 9.3 and iPhone SDK 11.4

If you want to use Clang with the LibreOffice compiler plugins, the minimal version of Clang is 5.0.2. 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 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 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.freenode.net - 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.