MINGW Notes


First version: Mar 6 2003
Last Update: Nov 18 2003
Author: Blas Rodriguez Somoza blas@puertareal.com

0.-Introduction

The MSYS/MINGW build was started with 1.5 beta 4.

The only difference between the msvc build and the mingw build, is that the later one does not support the ms SEH exception handling. This means that some exceptions will not be catched and thus FB will abort.The sources using this exception handling are jrd/blob_filter.cpp, jrd/exe.cpp and jrd/fun.epp.

This port is maintained by Blas Rodriguez Somoza and Dmitry Sibiriakov.

1.-TODO

2.-INSTALLING MSYS and MINGW

The following packages from http://www.mingw.org are needed

MinGW

MSYS

STEPS TO INSTALL

  1. run MinGW-3.1.0-1.exe. You must select the installation directory (default to c:\MINGW)
  2. run bison-1.875.0-2003.02.10-1.exe. You must give the program the mingw installation directory
  3. run MSYS-1.0.9.exe. First you must select your installation directory (default to c:\msys\1.0), then, in a command window, you must awswer some questions:

    Do you wish to continue with the post install? [yn] ANSWER y
    Do you have mingw installed? [yn] ANSWER y
    Where is your mingw installation? ANSWER your mingw directory using slashes (as in unix) no backslashes (as in windows)

  4. run msysDTK-1.0.1.exe. You must the msys installation directory as the installation directory for msysDTK (default to c:\msys\1.0).

3.- BUILD PROCESS

  1. Start msys with the icon.
  2. Go to the firebird2 root directory. For instance, if your root is d:\cvs\firebird you must do cd /d/cvs/firebird2.
  3. Start configure with the switches to get super/classic and production/development build, for instance:
    autogen.sh --enable-superserver
    The valid switches for autogen are
    --enable-superserver Select superserver build, default classic build.
    --enable-debug Select debug build, default production build.
  4. Make the build. For instance if you want to get compiler messages isolated from make log
    make > make.log 2>comp.log
  5. After the build finish, the firebird directory with the binaries is created as gen/firebird.

BUILD NOTE:

There is a bug in mingw (3.2) related with msvc format for 64bit integers. When the I64 format is used, the compiler throws warnings of two types:

warning: [...] format, different type arg (arg 3)
or
warning: unknown conversion type character `I' in format
warning: too many arguments for format

4.- INSTALL.

To create an installable build you need to do it in two steps, first prepare the output directory and then run the msvc BuildExecutableInstall.bat

First change to builds/install/arch-specific/mingw directory and run

      ./prepare_mingw.sh

After the script finish you need to open a dos window and cd to the builds/install/arch-specific/win32 directory under the firebird sources root.

The batch to build the installer is

      BuildExecutableInstall.bat [DEBUG] [CS]

Where DEBUG means if the build is a debug one or not and CS means classic server installer.

After you start the batch, you will get a InnoSetup window. To build the install exe select the option compile. The installer will be located in builds/win32/install_image.

To install the build, simply run the resulting exe and copy MINGWM10.DLL file to the bin directory in the firebird install directory

5.- TROUBLESHOOTING

AUTOGEN

The autogen script creates an output file in the same directory where it is executed with the name config.out. If the autogen fails look at config.out first.

Some permission problems, most probably related with the CVS client, has been reported. If the autogen gives a permission related error, like

      autom4te: cannot open configure: Permission denied

execute in the same directory:

      >chmod -R +uw *