Building on Windows
Contents
Overview
For general information on how to build Apache OpenOffice from source code, see the platform independent page.
For building Apache OpenOffice the Cygwin environment is required. Cygwin is a set of programs that run on Windows but emulate a complete Unix command line environment.
As compiler we use Microsoft's Visual C++ 2008 SP1, not the gcc from Cygwin. Therefore Visual Studio Express/Professional (version 2008 or later) can be used for debugging.
To use this document you should be familiar with a bourne command line interpreter (sh or bash), but you need not be a UNIX shell wizard.
If you have never used a Unix shell, you might want to take a look at the shell introduction at TLDP. |
Build requirements
Additionally to the general build requirements you need
What | Where to get | How to install | |
---|---|---|---|
Windows 7 (recommended), Windows Vista, Windows XP | |||
Cygwin | https://www.cygwin.com, 32bit version, minimum version: 1.5.10, preferred: current version]
See below for setting up cygwin and the required packages. |
(default) | |
Microsoft Windows SDK for Windows 7 and .NET Framework 3.5 SP1 | https://web.archive.org/web/20160112223658/http://www.microsoft.com/en-us/download/details.aspx?id=18950
It brings the Visual Studio 2008 C++ compiler with it. This is available as a DVD image only (there was a net installer but it no longer works). You can either mount the DVD with a suitable tool, burn it do a DVD or use tools like winrar or 7zip to extract files from the ISO file directly. You don't need to install samples or documentation (saves a lot of disk space). It will also install the .NET Framework 3.5 SDK. It might be best to install the Windows SDK into the default directory, and if not that into one without capital letters in the path. |
||
Microsoft Visual C++ 2008 SP1 Redistributable Package (x86) | vcredist_x86.exe, download found here
It is just packed as it is into the installation package. The exact download URL may have changed. In that case you have to search Microsoft's website. |
main/external/vcredist | |
Microsoft Visual C++ 2008 SP1 Redistributable Package (x64) | vcredist_x64.exe, download found here
It is just packed as it is into the installation package. The exact download URL may have changed. In that case you have to search Microsoft's website. |
main/external/vcredist | |
GDI+ Redistributable | https://www.microsoft.com/downloads/details.aspx?familyid=6A63AB9C-DF12-4D41-933C-BE590FEAA05A&displaylang=en. Genuine Windows Validation required. | main/external/gdiplus | |
Runtime libraries 10.0 | msvcp100.dll and msvcr100.dll for Java 7 support - see issue 120979.
Get them from the Microsoft Visual C++ 2010 Redistributable Package (x86) from the Microsoft site - https://www.microsoft.com/en-us/download/search.aspx?q=Microsoft+Visual+C%2b%2b+2010+Redistributable |
main/external/msvcp100 | |
dbghelp.dll | https://msdn.microsoft.com/en-us/library/windows/desktop/ms679309%28v=vs.85%29.aspx
The exact download URL may have changed. In that case you have to search Microsoft's website. Search for it on your PC or on the web. E.g., it is part of the Windows Driver Kit. |
main/external/dbghelp | |
Windows Driver Kit Version 7.1.0 | https://www.microsoft.com/downloads/details.aspx?id=11800
To enable ATL and ActiveX in the build - it is optional related configure options are: --with-atl-include, --with-atl-lib-dir, --with-mfc-include-dir, --with-mfc-lib-dir |
||
Microsoft DirectX SDK | https://www.microsoft.com/download/en/details.aspx?displaylang=en&id=6812
To enable DirectX in the build - it is optional related configure option is: --with-directx-home |
||
NSIS, version >= 3.0 | Since branch AOO413 and trunk revision 1766031, NSIS version 3.0 or greater is required if you want to build a Windows installer.
http://nsis.sourceforge.net/Download For previous versions, use Unicode NSIS, version 2.46.5 from http://code.google.com/p/unsis/downloads/detail?name=nsis-2.46.5-Unicode-setup.exe&can=2&q= |
When building Apache OpenOffice 3.4.x or 4.0.x you need to provide some additional binaries:
Runtime libraries 7.1 | msvcr71.dll for Mozilla libraries. Search for them on the web or on your PC. These files should be named as all lower case. Sometimes when downloaded they are upper case and this will cause 'file not found' errors towards the end of the build)) | main/external/msvcp71 |
Runtime libraries 8.0 | msvcp80.dll and msvcr80.dll for Mozilla libraries. Search for them on the web or on your PC. | main/external/msvcp80 |
Remarks
Setting up Cygwin
Go to https://www.cygwin.com/ and download and install the current 32bit version.
Make sure that the PATH variable in your cygwin shell does not contain any unquoted blanks and quotes, otherwise configure will not work |
Additional packages for Cygwin to serve the Apache OpenOffice build
Cygwin consists of some basic and a lot of optional packages. As building Apache OpenOffice needs some of these optional packages you have to select them in the installer. Here's a complete list of the required packages:
- Category Archive:
- unzip
- zip
- Category Devel :
- autoconf
- bison
- flex
- gcc-g++
- gperf
- make
- patch
- readline
- subversion (if you want to use svn inside the cygwin shell to checkout and update your working copy of Apache OpenOffice (which is highly recommended as Windows Tools can mess up Line breaks))
- Category Libs
- libexpat-devel
- Category Net
- openssh
- openssl
- Category Perl
- perl - see General Build Requirements for additional Perl modules
- Category Shells
- mintty
- Category Utils
- gnupg
- Category Web
- wget
The installer will automatically check and download some more packages needed by whose listed here. The whole process takes roughly 20 minutes. |
Breaking links to executable
Within the Cygwin Toolkit, some executables might be symlinks: awk.exe and gunzip.exe, tar.exe (in older releases only). This can lead to a break of the build later, and the symlinks should be replaced by copies of the command they link to.
To check this, execute:
ls -l /bin/awk.exe
whether e.g. awk.exe is a symlink. In version 1.5.24-2 awk.exe is a link to gawk.exe. The shell will show this by putting out “awk.exe -> gawk.exe”. In this case gawk.exe must be copied to awk.exe by executing:
cd /bin rm awk.exe cp gawk.exe awk.exe
In case you overlook something here or you have a newer Cygwin version with additional symlinks not mentioned here it's not a problem. You will get a helpful error message about an existing link in the configuration step (configure) later. The message will tell you which link you have to remove and you can do it following the advice given above for the awk.exe/gawk.exe pair.
Installing additional perl modules in cygwin
As explained some perl modules must be installed with CPAN. The necessary command in the cygwin shell is
perl -MCPAN -e shell
If this command is executed the first time CPAN will ask for configuration. Choose autoconfiguration.
At the end the CPAN shell appeared and is ready to accept commands for installations. Each module is installed by typing install $MODULENAME
. The modules that must be installed are:
- Archive::Zip
- LWP::UserAgent
- XML::Parser (though it seems that this is already installed; doesn't hurt to do it)
CPAN will detect if a selected module depends on other modules and it will offer to download them also. As explained please just confirm this.
Configure switches (Windows specific)
Additionally to the general configure switches there are several that only have to be used on Windows or have Windows specific values.
Typical values for the compiler and SDK. If default installation paths are used these configure switches are not needed:
--with-frame-home="/cygdrive/c/Program Files/Microsoft SDKs/Windows/v7.0" --with-psdk-home="/cygdrive/c/Program Files/Microsoft SDKs/Windows/v7.0" --with-midl-path="/cygdrive/c/Program Files/Microsoft SDKs/Windows/v7.0/Bin"
For DirectX:
--with-directx-home="C:/Program Files (x86)/Microsoft DirectX SDK (June 2010)"
For ATL and ActiveX:
--with-atl-include-dir=/cygdrive/c/WinDDK/7600.16385.1/inc/atl71 --with-atl-lib-dir=/cygdrive/c/WinDDK/7600.16385.1/lib/ATL/i386 --with-mfc-include-dir=/cygdrive/c/WinDDK/7600.16385.1/inc/mfc42 --with-mfc-lib-dir=/cygdrive/c/WinDDK/7600.16385.1/lib/Mfc/i386
And some more:
--enable-pch --enable-dbgutil