Resolves tdf#72152: respect page orientation of Calc files in recent docs
[LibreOffice.git] / README.cross
blobefaa8c24ed7a9235063d090ed0344e05c3736976
1 Cross-compiling LibreOffice
2 ***************************
4 Cross-compilation works, to various degree, to the following
5 platforms: Windows, iOS, Android, and Raspbian.
8 General
9 -------
11 In GNU Autoconf terminology, "build" is the platform on which you are
12 running a build of some software and "host" is the platform on which
13 the software you are building will run. Only in the specific case of
14 building compilers and other programming tools is the term "target"
15 used to indicate the platform for which the tools your are building
16 will produce code. As LibreOffice is not a compiler, the "target" term
17 should not be used in the context of cross-compilation.
19 (For a case where all three of "build", "host" and "target" are
20 different: consider a gcc cross-compiler running on Windows, producing
21 code for Android, where the cross-compiler itself was built on
22 Linux. (This is a real case.) An interesting tidbit is that such
23 configurations are called "Canadian Cross".)
25 Even though the LibreOffice build mechanism is highly unorthodox, the
26 configure script takes the normal --build and --host options like any
27 GNU Autoconf -based configure script. To cross-compile, you basically
28 need just to specify a suitable --host option and things should work
29 out nicely. In practice, many details need to be handled. See examples
30 below.
32 Note that in the case of LibreOffice, it is uncommon to run the
33 configure script directly. Normally one uses the autogen.sh script.
34 The autogen.sh script reads command-line options from file called
35 autogen.input if it exists. The typical way of working is to keep
36 the configure parameters in that file and edit it as needed.
39 What is so hard, then?
40 ----------------------
42 Despite the fact that the configure script takes normal --build and
43 --host options, that is just the beginning. It was necessary to
44 separate tests for "host" and "build" platforms in the configure
45 script. See the git log for details. And the reasonably "standard"
46 configure.in is just the top level; when we get down to the actual
47 makefilery used to build the bits of LibreOffice, it gets much worse.
50 Windows
51 *******
53 There was some support in LibreOffice already from OpenOffice.org days
54 for building it locally on Windows with the GNU tool-chain (MinGW).
55 Apparently, those doing that work never attempted cross-compilation.
57 This OOo-originated MinGW support attempts to be for both running the
58 Cygwin gcc in its -mno-cygwin mode, and a Windows-native MinGW
59 compiler. The -mno-cygwin mechanism in the Cygwin gcc is rapidly being
60 obsoleted, if it isn't already, and we have not attempted to try to
61 keep it working; in fact we have actively cleaned out mechanisms
62 related to this. Ditto for native MinGW. If one compiles natively on
63 Windows, just use a version of Microsoft's compiler. OpenOffice.org
64 and LibreOffice have been built for Windows all the time using that.
66 The only case where it makes sense to use MinGW is for
67 cross-compilation. There is just too much crack involved on Windows
68 anyway, and it is a semi-miracle that the MSVC build under Cygwin
69 works as nicely as it does.
71 MinGW is available as cross-build toolchains pre-packaged in more or
72 less official packages for many Linux distros including Debian, Fedora
73 and openSUSE. For instance, the mingw32 packages in the Open Build
74 Service, running on openSUSE, can be found at:
76 http://download.opensuse.org/repositories/windows:/mingw:/win32/
78 For example, you can install it like this:
80 zypper ar http://download.opensuse.org/repositories/windows:/mingw:/win32/<your_os>/windows:mingw:win32.repo
82 where <your_os> is one of SLE_11, SLE_11_SP1, openSUSE_XX.Y, or
83 openSUSE_Factory.
85 zypper in mingw32-cross-gcc mingw32-cross-gcc-c++ mingw32-python-devel \
86     mingw32-python mingw32-libboost_date_time \
87     mingw32-libexpat-devel mingw32-libexpat mingw32-boost-devel \
88     mingw32-libhyphen-devel mingw32-libhyphen mingw32-hyphen-en \
89     mingw32-liblpsolve mingw32-liblpsolve-devel \
90     mingw32-libxml2-devel mingw32-libxslt-devel mingw32-libicu \
91     mingw32-libicu-devel mingw32-libgraphite2 mingw32-libgraphite2-devel \
92     mingw32-libcairo2 mingw32-cairo-devel mingw32-librsvg mingw32-librsvg-devel \
93     mingw32-hunspell mingw32-hunspell-devel mingw32-libcurl \
94     mingw32-libcurl-devel mingw32-libneon mingw32-libneon-devel \
95     mingw32-libopenssl mingw32-libopenssl-devel mingw32-libexttextcat \
96     mingw32-libexttextcat-devel mingw32-libdb mingw32-libdb-devel \
97     mingw32-cross-pkg-config mingw32-pkg-config mingw32-libcppunit \
98     mingw32-libcppunit-devel mingw32-libredland mingw32-libredland-devel \
99     mingw32-libmythes mingw32-libmythes-devel mingw32-mozilla-nss \
100     mingw32-mozilla-nss-devel mingw32-mozilla-nspr \
101     mingw32-mozilla-nspr-devel mingw32-libpoppler mingw32-libpoppler-devel
103 You also need wine, ideally:
105 zypper ar http://download.opensuse.org/repositories/Emulators:/Wine/<your_os>/Emulators:Wine.repo
107 zypper in wine wine-devel wine-devel-32bit
109 And in order to be able to use 'winegcc -m32', also
111 zypper in glibc-devel-32bit gcc-32bit
113 There might be more that are missing, please read carefully what autogen.sh
114 tells you, and either remove one of the --with-system-*, or install the
115 missing dependency.
117 It also looks like graphite2.pc needs tweaking in order to work right; but
118 that's likely to be fixed in the openSUSE project.
120 It is somewhat unclear how well thought-out the conditionals and code
121 for MinGW inside the OOo-originated code in LibreOffice actually
122 are. It often seems a bit randomish, with copy-pasting having been
123 preferred to factoring out differences.
125 Most of the configuration settings are maintained in the
126 distro-configs/LibreOfficeMinGW.conf file, so in your autogen.input,
127 you can use:
129 CC=ccache i686-w64-mingw32-gcc
130 CXX=ccache i686-w64-mingw32-g++
131 CC_FOR_BUILD=ccache gcc
132 CXX_FOR_BUILD=ccache g++
133 --with-distro=LibreOfficeMinGW
135 Alternatively, you can use something like the following; but the
136 preferred way is to keep the LibreOfficeMinGW.conf file up-to-date.
138 CC=ccache i686-w64-mingw32-gcc
139 CXX=ccache i686-w64-mingw32-g++
140 CC_FOR_BUILD=ccache gcc
141 CXX_FOR_BUILD=ccache g++
142 --build=x86_64-unknown-linux-gnu
143 --host=i686-w64-mingw32
144 --with-distro=LibreOfficeWin32
145 --disable-activex
146 --disable-directx
147 --disable-ext-nlpsolver
148 --disable-report-builder
149 --disable-scripting-beanshell
150 --disable-scripting-javascript
151 --disable-ext-wiki-publisher
152 --disable-pdfimport
153 --enable-python=system
154 --with-system-altlinuxhyph
155 --with-system-boost
156 --with-system-cairo
157 --with-system-cppunit
158 --with-system-curl
159 --with-system-expat
160 --with-system-hunspell
161 --with-system-icu
162 --with-system-libpng
163 --with-system-libwpd
164 --with-system-libwpg
165 --with-system-libwps
166 --with-system-libxml
167 --with-system-lpsolve
168 --with-system-mythes
169 --with-system-neon
170 --with-system-openssl
171 --with-system-redland
172 --with-vendor=no
173 --without-help
174 --without-helppack-integration
175 --without-myspell-dicts
177 Once you have compiled it, you may want to try to run it, for instance
178 using Wine:
180 $ cd /tmp
181 $ tar xf <your-build-dir>/workdir/wntgcci.pro/installation/LibreOffice_Dev/archive/install/en-US/LibO-Dev_4.1.0.0.alpha0_Win_x86_archive.tar.gz
182 $ cd LibO-Dev_4.1.0.0.alpha0_Win_x86_archive/LOdev\ 4.1/program/
183 $ wine soffice.exe
185 NB. it is important to unpack somewhere low in the hierarchy structure (like
186 in /tmp as advised above), otherwise you'll get BerkeleyDB errors on startup.
188 And if you are brave enough, you can even debug it.  First you have to add the
189 URE dll's to the wine's PATH using 'wine regedit' - see
190 http://www.winehq.org/docs/wineusr-guide/environment-variables, and add
191 Z:\tmp\LibO-Dev_4.1.0.0.alpha0_Win_x86_archive/LOdev\ 4.1\URE\bin
192 to "Path" in My Computer->HKEY_CURRENT_USER->Environment.
194 And start debugging:
196 $ winedbg soffice.bin
198 Would be great to be able to use winedbg --gdb, but it was crashing here :-( -
199 but maybe you'll be more lucky.
201 Tricks of some use with winedbg:
202 --------------------------------
204 To examine OUStrings, you might want to use the following trick (prints 50
205 unicode characters of rLibName OUString - the +10 is where the buffer starts):
207 Wine-dbg>x /50u rLibName->pData+10
208 0x0909b6c8: vnd.sun.star.expand:$LO_LIB_DIR/abplo.dll
210 TODO:
212 - make the debugging more convenient on (native) Windows
213   - check possibilities like WinGDB - http://www.wingdb.com/
214   - or find / write a MSVS / WinDBG extension that can read MinGW debugging
215     symbols natively; more info
216     http://windbg.info/forum/12-symbol-and-source-files-/21-debugging-mingwgcc-built-dll-in-visual-studio.html
218 - installation
219   - so far the make_installer.pl calls makecab.exe, uuidgen.exe, and
220     others; would be best to avoid that if at all possible (using a free
221     cab implementation, part of Wine or something)
222   - MSI generation
224 - runtime
225   - no idea if the entire thing works after the installation at all; I
226     suppose there will be runtime problems to look at too
228 - cleanup
229   - enable & fix pieces that are currently disabled
230     - --without-myspell-dicts
231     - --disable-directx
232     - --disable-activex
233   - much of the stuff currently relies on --with-system-*, and
234     consequently on the mingw32-* openSUSE packages; might be good to be
235     able to build with as few dependencies as possible - but that is low
236     prio
238 - profiling
239   - when all the above is sorted out, we should look at the speed of
240     this vs. the speed of the MSVC version
246 iOS is the operating system on Apple's mobile devices. Clearly for a
247 device like the iPad it would not be acceptable to run a normal
248 LibreOffice application with overlapping windows and mouse-oriented
249 GUI widgets.
251 It makes sense to use only a part of LibreOffice's code for iOS. Lots
252 of the GUI-oriented code should be left out. iOS apps that want to use
253 the applicable LibreOffice code will handle all their GUI in a
254 platform-dependent manner. How well it will be possible to do such a
255 split remains to be seen.
257 Obviously we want it to be possible to eventually distribute apps
258 using LibreOffice code through the App Store. Technically, one
259 important special aspect of iOS is that apps in the App Store are not
260 allowed to load own dynamic libraries. (System libraries are used in
261 the form of dynamic libraries, just like on Mac OS X, of which iOS is
262 a variant.)
264 Thus all the libraries in LibreOffice that normally are shared
265 libraries (DLLs on Windows, shared objects (.so) on Linux, dynamic
266 libraries on Mac OS X (.dylib)) must be built as static archives
267 instead. This has some interesting consequences for how UNO is
268 implemented and used.
270 An iOS app is a "bundle" that contains a single executable, In an app
271 using LibreOffice code, that eecutable then congtains the necessary
272 LibreOffice libraries and UNO components statically linked.
274 The Apple tool-chain for iOS cross-building is available only for OS
275 X. In order to be able to run and debug an app on an actual device
276 (and not just the iOS Simulator) you need to be registered in the iOS
277 Developer Program.
279 Here is an autogen.input for iOS (device) using Xcode 4.6, on OS X 10.8:
281 --build=i386-apple-darwin10.7.0
282 --host=arm-apple-darwin10
283 --enable-dbgutil
284 --enable-debug
285 --enable-werror
287 For the iOS Simulator, but note that building for the simulator is
288 broken at the moment (July 2014):
290 --build=i386-apple-darwin10.7.0
291 --host=arm-apple-darwin10
292 --enable-ios-simulator
293 --enable-dbgutil
294 --enable-debug
295 --enable-werror
297 You will have to install autoconf and automake yourself before running
298 autogen.sh. They are no longer included in Xcode 4.3 and later (not
299 even in the add-on "command line tools").
301 The -mmacosx-version-min=10.7 is necessary when building for the iOS
302 simulator to avoid clang replacing simple calls to fprintf with calls
303 to fwrite$UNIX2003 which Xcode then warns that doesn't exist on iOS.
306 Android
307 *******
309 From a technical point of view the core Android OS (the kernel) is
310 Linux, but everything else is different. Unlike iOS, an Android app
311 can use shared objects just fine, so that aspect of UNO doesn't need
312 special handling. Except that there is a silly low limit in the
313 Android dynamic linker on the number of libraries you can dlopen. This
314 is a limitation in user-level (but system-provided and not really
315 replaceable) code, not the kernel.
317 Thus, just like for iOS, also for Android the LibreOffice libraries
318 and UNO components are built as static archives. For Android, those
319 static archives, and any app-specific native code, are linked into one
320 single app-specific shared library, called liblo-native-code.so.
322 For the GUI, the same holds as said above for iOS. The GUI layer needs
323 to be platform-specific, written in Java.
325 Android cross-compilation work has been done mainly on Linux (openSUSE
326 in particular). Earlier also cross-compiling from OS X was tried. The
327 Android cross-compilation tool-chain (the "Native Development Kit", or
328 NDK) is available for Linux, OS X and Windows, but trying to
329 cross-compile LibreOffice from Windows will probably drive you insane.
331 You will also need the Android SDK as full "make" also builds a couple
332 of Android apps where the upper layer is written in Java.
334 Use the "android" tool from the SDK to install the SDK Tools, SDK
335 Platform Tools, the API 15 SDK Platform and the Android Support
336 Library. If you want to run the Android apps in the emulator, you of
337 course need an appropriate system image for that.
339 Here is an autogen.input for Android on ARM when cross-compiling
340 from Linux:
342 --enable-dbgutil
343 --enable-werror
344 --with-distro=LibreOfficeAndroid
346 And here is an (quite old) autogen.input for Android on X86:
348 --with-android-ndk=/opt/libreoffice/android-ndk-r8b
349 --with-android-ndk-toolchain-version=4.6
350 --with-android-sdk=/opt/libreoffice/android-sdk-linux
351 --build=i586-suse-linux
352 --enable-ccache
353 --with-distro=LibreOfficeAndroidX86
355 There are a couple of (more or less) interactive apps that you can run
356 on the emulator or on a device that use LibreOffice code. Look in
357 android/experimental. DocumentLoader is just a testbench, really for
358 code to load a document (just Writer ones so far) and display one page
359 at a time. LibreOffice4Android is what resulted from a Google Summer
360 of Code project in 2012, a document viewer. desktop is a totally
361 different app, where the actual LibreOffice desktop GUI is present.
362 Note that none of these apps in any way are claimed to be ready for
363 end-users. No "beta testing" offers needed, it is painfully obvious
364 what problems they have.
366 To run some of the apps, do "make install" followed by either "make run" or
367 starting it from Android itself. You most likely want to have an "adb logcat"
368 running in another window. To debug, run "make debugrun".
370 NB: If you happen to upgrade to Android SDK Tools 23, and the build (using
371 'make verbose=t android') fails for you with:
373        [dx] UNEXPECTED TOP-LEVEL EXCEPTION:
374        [dx] java.io.FileNotFoundException: /local/libreoffice/android-sdk-linux/tools/support/annotations.jar (no such file or directory)
376 you need to copy the annotations.jar from an older sdk; like
378 wget 'http://dl-ssl.google.com/android/repository/tools_r22.6.2-linux.zip'
379 unzip tools_r22.6.2-linux.zip
380 cp tools/support/annotations.jar <android-sdk-linux>/tools/support/
382 Raspbian
383 ********
385 In theory, this should work also for another Linux, it does not need to be Raspbian.
386 But this cross-compilation work is tested from Debian and openSUSE to Raspbian.
388 You will need headers, pkg-config files and libraries from a Raspbian
389 system to build against. Available at
390 http://dev-www.libreoffice.org/extern/ . Look for the latest
391 raspbian-root-*.tar.gz . For instance:
393 $ wget http://dev-www.libreoffice.org/extern/raspbian-root-20140120.tar.gz
394 $ mkdir raspbian-root
395 $ cd raspbian-root
396 $ tar -xf raspbian-root-20140120.tar.gz
398 You can build cross-compiler yourself or get the executables here:
399 $ git clone git://github.com/raspberrypi/tools
401 tools/arm-bcm2708/gcc-linaro-arm-linux-gnueabihf-raspbian is known to work.
403 Then create pkg-config wrapper, something like:
404 $ cat > pkg-config-wrapper-host << _EOF
405 #!/bin/sh
407 if [ "$CROSS_COMPILING" = TRUE ]; then
408    SYSROOT=$HOME/lo/raspbian-root
409    export PKG_CONFIG_PATH=${SYSROOT}/usr/lib/arm-linux-gnueabihf/pkgconfig:${SYSROOT}/usr/share/pkgconfig
410    export PKG_CONFIG_LIBDIR=${SYSROOT}/usr/lib/pkgconfig
411    export PKG_CONFIG_SYSROOT_DIR=${SYSROOT}
414 exec pkg-config "\$@"
415 _EOF
416 $ chmod +x pkg-config-wrapper-host
418 This does not work with pkg-config 0.23. 0.26 is known to work.
420 And you are ready to build with autogen.input similar to:
422 PKG_CONFIG=<path-to-pkg-config-wrapper-host>
423 CC=<path-to-arm-linux-gnueabihf-gcc> --sysroot=<path-to-raspbian_rootfs>
424 CXX=<path-to-arm-linux-gnueabihf-g++> --sysroot=<path-to-raspbian_rootfs>
425 --build=x86_64-unknown-linux-gnu
426 --host=arm-unknown-linux-gnueabihf
427 --disable-sdk
428 --enable-python=system
429 PYTHON_CFLAGS=-I<path-to-raspbian_rootfs>/usr/include/python2.7
430 PYTHON_LIBS=-lpython2.7
431 --with-java
432 JAVAINC=-I<path-to-raspbian_rootfs>/usr/lib/jvm/java-6-openjdk-armhf/include
433 --with-system-cairo
434 --with-system-cppunit
435 --with-system-icu
436 --with-system-neon
437 --with-system-nss
438 --with-system-openldap
439 --with-system-openssl
440 --with-system-redland
442 Finally, when you are ready to run the binaries in Raspbian,
443 you may need to get more system libraries, who knows.
444 $ sudo apt-get install libreoffice # or similar
445 That installs libreoffice too, which you don't need because you have
446 just built one, but I don't know how to avoid it easily.