mirror of
https://github.com/FirebirdSQL/firebird.git
synced 2025-01-22 18:43:02 +01:00
121 lines
4.6 KiB
HTML
121 lines
4.6 KiB
HTML
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
|
|
<HTML>
|
|
<HEAD>
|
|
<TITLE> New Document </TITLE>
|
|
<META NAME="Generator" CONTENT="EditPlus">
|
|
<META NAME="Author" CONTENT="">
|
|
<META NAME="Keywords" CONTENT="">
|
|
<META NAME="Description" CONTENT="">
|
|
</HEAD>
|
|
|
|
<BODY>
|
|
<H2>MINGW Notes</H2>
|
|
<hr/>
|
|
First version: Mar 6 2003<br>
|
|
Last Update: Sep 26 2003<br>
|
|
Author: Blas Rodriguez Somoza <a href="">blas@puertareal.com</a><br>
|
|
|
|
<h3>0.-Introduction</h3>
|
|
<p>The MSYS/MINGW build was started with 1.5 beta 4.<p>
|
|
<p>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.</p>
|
|
<p>This port is maintained by Blas Rodriguez Somoza and Dmitry Sibiriakov.</p>
|
|
|
|
<h3>1.-TODO</h3>
|
|
<ul>
|
|
<li>Build of fb_util.dll</li>
|
|
<li>Support for ms SEH (superserver).</li>
|
|
<li>Executable size problem. The executables are too great.</li>
|
|
<li>DLL entrypoint definition. The fbclient.dll have a lot of unneeded entrypoints.</li>
|
|
<li>Installer definition.</li>
|
|
</ul>
|
|
|
|
<h3>2.-INSTALLING MSYS and MINGW</h3>
|
|
|
|
<p>The following packages from http://www.mingw.org are needed</p>
|
|
<p>MinGW
|
|
<ul>
|
|
<li>MinGW-3.1.0-1.exe</li>
|
|
<li>bison-1.875.0-2003.02.10-1.exe</li>
|
|
</ul>
|
|
</p>
|
|
<p>MSYS
|
|
<ul>
|
|
<li>MSYS-1.0.9.exe</li>
|
|
<li>msysDTK-1.0.1.exe</li>
|
|
</ul>
|
|
</p>
|
|
<p>STEPS TO INSTALL
|
|
<ol>
|
|
<li>run MinGW-3.1.0-1.exe. You must select the installation directory (default to c:\MINGW)</li>
|
|
<li>run bison-1.875.0-2003.02.10-1.exe. You must give the program the mingw installation directory </li>
|
|
<li>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:<br><br>
|
|
Do you wish to continue with the post install? [yn] ANSWER y<br>
|
|
Do you have mingw installed? [yn] ANSWER y<br>
|
|
Where is your mingw installation? ANSWER your mingw directory using slashes (as in unix) no backslashes (as in windows)<br><br>
|
|
</li>
|
|
<li>run msysDTK-1.0.1.exe. You must the msys installation directory as the installation directory for msysDTK (default to c:\msys\1.0).</li>
|
|
</ol>
|
|
</p>
|
|
|
|
<h3>3.- PATCHES TO MINGW headers</h3>
|
|
|
|
<p>There are an error in the gcc 3.2.3 headers delivered with MINGW.<p>
|
|
<p>You should edit <mingw installdir>/include/c++/3.2.3/cstdio and comment the following lines<br><br>
|
|
using ::vsnprintf;<br>
|
|
using __gnu_cxx::vsnprintf;<br>
|
|
</p>
|
|
|
|
<h3>4.- PATCHES TO BUILD FILES</h3>
|
|
|
|
<ul>
|
|
<li>The lib_fbudf target in Make.in.extlib cannot be built yet, so it must be removed.<br>
|
|
<br>
|
|
Edit the file Makefile.in.extlib in the builds/posix directory and change the line <br>
|
|
<br>
|
|
all: lib_ib_udf lib_ib_util lib_fb_util<br>
|
|
to<br>
|
|
all: lib_ib_udf lib_ib_util <br>
|
|
</li>
|
|
</ul>
|
|
|
|
<h3>5.- BUILD PROCESS</h3>
|
|
|
|
<ol>
|
|
<li>Start msys with the icon.</li>
|
|
<li>Go to the firebird2 root directory. For instance, if your root is d:\cvs\firebird you must do cd /d/cvs/firebird2.</li>
|
|
<li>Start configure with the switches to get super/classic and production/development build, for instance:<br>
|
|
autogen.sh --enable-superserver<br>
|
|
The valid switches for autogen are<br>
|
|
--enable-superserver Select superserver build, default classic build.<br>
|
|
--enable-debug Select debug build, default production build.<br>
|
|
</li>
|
|
<li>Make the build. For instance if you want to get compiler messages isolated from make log<br> make > make.log 2>comp.log</li>
|
|
<li>After the build finish, the firebird directory with the binaries is created as gen/firebird.</li>
|
|
</ol>
|
|
<ul>
|
|
<li>To make a clean build from scratch after making changes to the code use the clean.sh script</li>
|
|
</ul>
|
|
|
|
<p>BUILD NOTE:</p>
|
|
<p>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:</p>
|
|
<p>warning: [...] format, different type arg (arg 3)<br>
|
|
or<br>
|
|
warning: unknown conversion type character `I' in format<br>
|
|
warning: too many arguments for format</p>
|
|
|
|
<h3>6.- TROUBLESHOOTING</h3>
|
|
|
|
<p>AUTOGEN<p>
|
|
<p>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.</p>
|
|
|
|
<p>Some permission problems, most probably related with the CVS client, has been reported. If the autogen gives a permission related error, like<br><br>
|
|
autom4te: cannot open configure: Permission denied<br><br>
|
|
execute in the same directory:<br><br>
|
|
>chmod -R +uw *</p>
|
|
|
|
<br>
|
|
<br>
|
|
<br>
|
|
</BODY>
|
|
</HTML>
|