8
0
mirror of https://github.com/FirebirdSQL/firebird.git synced 2025-01-22 15:23:03 +01:00
This commit is contained in:
asfernandes 2013-04-21 02:09:45 +00:00
parent f91bc11492
commit f2b24d02ca
8 changed files with 41 additions and 39 deletions

View File

@ -79,7 +79,7 @@
# I.e. when # I.e. when
# include some_file.conf # include some_file.conf
# is used in /opt/config/master.conf, we include /opt/config/some_file.conf. # is used in /opt/config/master.conf, we include /opt/config/some_file.conf.
# Traditional wildcards * and ? may be used in icnlude operator. In this case # Traditional wildcards * and ? may be used in include operator. In this case
# all matching files will be included in undefined order. Example: # all matching files will be included in undefined order. Example:
# include $(dir_plugins)/config/*.conf # include $(dir_plugins)/config/*.conf
# #

View File

@ -58,7 +58,7 @@ Authors: Blas Rodriguez Somoza (blas at puertareal dot com), Dmitry Sibiryakov (
<ol> <ol>
<li>Start msys with the icon.</li> <li>Start msys with the icon.</li>
<li>Go to the firebird2 root directory. For instance, if your root is d:\svn\firebird you must do cd /d/svn/firebird2.</li> <li>Go to the firebird root directory. For instance, if your root is d:\svn\firebird you must do cd /d/svn/firebird.</li>
<li>Start configure with the switches to get super/classic and production/development build, for instance:<br> <li>Start configure with the switches to get super/classic and production/development build, for instance:<br>
autogen.sh --enable-superserver<br> autogen.sh --enable-superserver<br>
The valid switches for autogen are<br> The valid switches for autogen are<br>
@ -81,11 +81,11 @@ warning: too many arguments for format</p>
<h3>4.- INSTALL.</h3> <h3>4.- INSTALL.</h3>
<p>To create an installable build you need to execute the InnoSetup script.</p> <p>To create an installable build you need to execute the InnoSetup script.</p>
<ol> <ol>
<li>Open firebird2/builds/install/arch-specific/mingw/super/FirebirdInstall_15.iss with InnoSetup.</li> <li>Open firebird/builds/install/arch-specific/mingw/super/FirebirdInstall_15.iss with InnoSetup.</li>
<li>Run the script with F9 or Run-&gt;Run</li> <li>Run the script with F9 or Run-&gt;Run</li>
<li>Close InnoSetup</li> <li>Close InnoSetup</li>
</ol> </ol>
<p>A executable installer will be in firebird2/builds/install/arch-specific/mingw/super/</p> <p>A executable installer will be in firebird/builds/install/arch-specific/mingw/super/</p>
<p>To install the build, simply run the resulting exe.</p> <p>To install the build, simply run the resulting exe.</p>
<h3>5.- TROUBLESHOOTING</h3> <h3>5.- TROUBLESHOOTING</h3>

View File

@ -104,7 +104,7 @@ with the default options (next, next, next)</li>
<h4>4.1.-Standard build</h4> <h4>4.1.-Standard build</h4>
<ol> <ol>
<li>Eliminate the fb2control from firebird2 solution if you are using Visual Studio Express (doesn't support MFC) and it's only the control pannel applet and try to build it, it should give you no errors when you build the solution.</li> <li>Eliminate the fb2control from firebird3 solution if you are using Visual Studio Express (doesn't support MFC) and it's only the control pannel applet and try to build it, it should give you no errors when you build the solution.</li>
<li>Open a command line window.</li> <li>Open a command line window.</li>
<li>Go to the builds\win32 directory.</li> <li>Go to the builds\win32 directory.</li>
<li>Run the following batches in order (your version of VisualStudio is detected automatically)</li> <li>Run the following batches in order (your version of VisualStudio is detected automatically)</li>
@ -115,7 +115,7 @@ with the default options (next, next, next)</li>
</ol> </ol>
</ol> </ol>
<ul> <ul>
<p>After the build finish, an output directory with the binaries is created below your firebird2 directory.</p> <p>After the build finish, an output directory with the binaries is created below your firebird3 directory.</p>
<li>To make a clean build from scratch after making changes to the code use the clean_all.bat script</li> <li>To make a clean build from scratch after making changes to the code use the clean_all.bat script</li>
</ul> </ul>
<h4>4.2.-Parser rebuild</h4> <h4>4.2.-Parser rebuild</h4>
@ -137,7 +137,7 @@ Where DEBUG means if the build is a debug one or not and CS means classic server
</ul> </ul>
<h4>4.5.-Building samples</h4> <h4>4.5.-Building samples</h4>
<p>After the standard build is finished, an output directory with the same structure as the installed FB directory is created.</p> <p>After the standard build is finished, an output directory with the same structure as the installed FB directory is created.</p>
<p>If you want to build the examples just cd to firebird2\output\examples\build_win32 and run run_all.bat</p> <p>If you want to build the examples just cd to firebird3\output\examples\build_win32 and run run_all.bat</p>
<p>Run_all.bat calls four other bats to make the example sets. Any example set can be build independently with its make_XXX script.</p> <p>Run_all.bat calls four other bats to make the example sets. Any example set can be build independently with its make_XXX script.</p>
<p>The example sets are:</p> <p>The example sets are:</p>
<ul> <ul>

View File

@ -17,13 +17,13 @@
<P STYLE="margin-bottom: 0in"><FONT SIZE=4>Firebird plugins.</FONT></P> <P STYLE="margin-bottom: 0in"><FONT SIZE=4>Firebird plugins.</FONT></P>
<P STYLE="margin-bottom: 0in"><BR> <P STYLE="margin-bottom: 0in"><BR>
</P> </P>
<P STYLE="margin-bottom: 0in"><FONT SIZE=4>Since version 3 firebird <P STYLE="margin-bottom: 0in"><FONT SIZE=4>Since version 3, Firebird
supports plugins architecture. This means that for a number of supports plugins architecture. This means that for a number of
predefined points in firebird code user can write his own fragment of predefined points in Firebird code, user can write his own fragment of
code which will be executed when needed. Plugin is not necessarily code which will be executed when needed. Plugin is not necessarily
always written be user - firebird already has a number of plugins always written be user - Firebird already has a number of plugins
which are it's native part. Moreover, as you will see later, some which are its native part. Moreover, as you will see later, some
core parts of firebird are implemented as plugins. </FONT> core parts of Firebird are implemented as plugins. </FONT>
</P> </P>
<P STYLE="margin-bottom: 0in"><BR> <P STYLE="margin-bottom: 0in"><BR>
</P> </P>
@ -39,7 +39,7 @@ related but different things. Plugin is used to name:</FONT></P>
library may contain code for more than one plugin;</FONT></P> library may contain code for more than one plugin;</FONT></P>
<LI><P STYLE="margin-bottom: 0in"><FONT SIZE=4>plugin's factory - an <LI><P STYLE="margin-bottom: 0in"><FONT SIZE=4>plugin's factory - an
object created by that code (pure virtual C++ class), creating object created by that code (pure virtual C++ class), creating
plugin instances on firebird request;</FONT></P> plugin instances on Firebird request;</FONT></P>
<LI><P STYLE="margin-bottom: 0in"><FONT SIZE=4>instance of plugin, <LI><P STYLE="margin-bottom: 0in"><FONT SIZE=4>instance of plugin,
created by factory.</FONT></P> created by factory.</FONT></P>
</UL> </UL>
@ -49,12 +49,12 @@ clarified explicitly.</FONT></P>
<P STYLE="margin-bottom: 0in"><BR> <P STYLE="margin-bottom: 0in"><BR>
</P> </P>
<P STYLE="margin-bottom: 0in"><FONT SIZE=4>One should not expect that <P STYLE="margin-bottom: 0in"><FONT SIZE=4>One should not expect that
firebird plugin architecture will make it possible to create any kind Firebird plugin architecture will make it possible to create any kind
of plugin you want. To be able to have plugin (for example) of plugin you want. To be able to have plugin (for example)
encrypting database on the disk firebird code should be prepared for encrypting database on the disk, Firebird code should be prepared for
it must have a point from which plugin is called. I.e. each it must have a point from which plugin is called. I.e. each
version has a fixed set of plugins which are supported. To add one version has a fixed set of plugins which are supported. To add one
more type first of all firebird code should be modified. What DOES more type, first of all Firebird code should be modified. What DOES
our plugin architecture it helps to make both adding new types of our plugin architecture it helps to make both adding new types of
plugins and writing plugin code simple and as universal between plugins and writing plugin code simple and as universal between
plugins as possible.</FONT></P> plugins as possible.</FONT></P>
@ -71,7 +71,7 @@ set of plugin types:</FONT></P>
<LI><P STYLE="margin-bottom: 0in"><FONT SIZE=4>ExternalEngine <LI><P STYLE="margin-bottom: 0in"><FONT SIZE=4>ExternalEngine
controls use of various engines, see README.external_routines;</FONT></P> controls use of various engines, see README.external_routines;</FONT></P>
<LI><P STYLE="margin-bottom: 0in"><FONT SIZE=4>Trace plugin is known <LI><P STYLE="margin-bottom: 0in"><FONT SIZE=4>Trace plugin is known
from firebird 2.5, but a way how it interacts with engine was from Firebird 2.5, but a way how it interacts with engine was
changed to match new generic rules; </FONT> changed to match new generic rules; </FONT>
</P> </P>
<LI><P STYLE="margin-bottom: 0in"><FONT SIZE=4>encrypting plugins <LI><P STYLE="margin-bottom: 0in"><FONT SIZE=4>encrypting plugins
@ -87,8 +87,8 @@ set of plugin types:</FONT></P>
<P STYLE="margin-bottom: 0in"><BR> <P STYLE="margin-bottom: 0in"><BR>
</P> </P>
<P STYLE="margin-bottom: 0in"><FONT SIZE=4>Plugins are using a set of <P STYLE="margin-bottom: 0in"><FONT SIZE=4>Plugins are using a set of
special firebird interfaces (see README.interfaces about interfaces special Firebird interfaces (see README.interfaces about interfaces
in firebird). All plugin-specific interfaces are reference counted, in Firebird). All plugin-specific interfaces are reference counted,
i.e. have explicitly controlled lifetime. Interfaces are declared in i.e. have explicitly controlled lifetime. Interfaces are declared in
Plugin.h include file. There is a simple example of writing plugin Plugin.h include file. There is a simple example of writing plugin
module DbCrypt_example. It does not perform any actual encryption module DbCrypt_example. It does not perform any actual encryption
@ -105,14 +105,14 @@ short list of plugin features:</FONT></P>
attention to word “reasonable” - asking a question from plugin attention to word “reasonable” - asking a question from plugin
at server's console is hardly good idea;</FONT></P> at server's console is hardly good idea;</FONT></P>
<LI><P STYLE="margin-bottom: 0in"><FONT SIZE=4>it's OK to use <LI><P STYLE="margin-bottom: 0in"><FONT SIZE=4>it's OK to use
firebird API calls in your plugin if needed (for example, default Firebird API calls in your plugin if needed (for example, default
authentication server and user manager are using firebird database authentication server and user manager are using Firebird database
to store accounts);</FONT></P> to store accounts);</FONT></P>
<LI><P STYLE="margin-bottom: 0in"><FONT SIZE=4>additionally firebird <LI><P STYLE="margin-bottom: 0in"><FONT SIZE=4>additionally Firebird
provides a set of interfaces, helping you to configure your plugins provides a set of interfaces, helping you to configure your plugins
(certainly, you are not forced to use them plugin is generic (certainly, you are not forced to use them plugin is generic
code, which may use any way of providing configuration information, code, which may use any way of providing configuration information,
but with standard tools you get common for the rest of firebird but with standard tools you get common for the rest of Firebird
configuration style and sooner of all save you efforts).</FONT></P> configuration style and sooner of all save you efforts).</FONT></P>
</UL> </UL>
<P STYLE="margin-bottom: 0in"><BR> <P STYLE="margin-bottom: 0in"><BR>
@ -142,7 +142,7 @@ complicated.</FONT></P>
<P STYLE="margin-bottom: 0in"><BR> <P STYLE="margin-bottom: 0in"><BR>
</P> </P>
<P STYLE="margin-bottom: 0in"><FONT SIZE=4>As it was already <P STYLE="margin-bottom: 0in"><FONT SIZE=4>As it was already
mentioned single plugin module may implement more than single plugin. mentioned, single plugin module may implement more than single plugin.
Moreover, single plugin may have at the same time more than one Moreover, single plugin may have at the same time more than one
configuration and for each configuration separate plugin's configuration and for each configuration separate plugin's
factory is created. Each of this 3 objects (module implementation factory is created. Each of this 3 objects (module implementation
@ -151,7 +151,7 @@ dynamic library. Plugin implementation's name is one given to it by
plugin developer and hard-coded inside module. Factory's name by plugin developer and hard-coded inside module. Factory's name by
default equals to plugin implementation's name (and it's factory name default equals to plugin implementation's name (and it's factory name
which is actually used in firebird.conf). Certainly in typical which is actually used in firebird.conf). Certainly in typical
trivial case module contains one plugin, and that plugin works with trivial case, module contains one plugin, and that plugin works with
only one configuration, and all 3 names are equal, and no more only one configuration, and all 3 names are equal, and no more
configuration is needed for example libEngine12.so or configuration is needed for example libEngine12.so or
Engine12.dll contains implementation of provider Engine12, and Engine12.dll contains implementation of provider Engine12, and
@ -159,7 +159,7 @@ nothing else except record </FONT>
</P> </P>
<P STYLE="margin-bottom: 0in"><FONT SIZE=4>Providers = Engine12</FONT></P> <P STYLE="margin-bottom: 0in"><FONT SIZE=4>Providers = Engine12</FONT></P>
<P STYLE="margin-bottom: 0in"><FONT SIZE=4>in firebird.conf is needed <P STYLE="margin-bottom: 0in"><FONT SIZE=4>in firebird.conf is needed
to load it. But if you have something complex file hwill help to load it. But if you have something complex file will help
you to have such plugin factories which you really want.</FONT></P> you to have such plugin factories which you really want.</FONT></P>
<P STYLE="margin-bottom: 0in"><BR> <P STYLE="margin-bottom: 0in"><BR>
</P> </P>
@ -180,14 +180,14 @@ name of config record to be used</I></FONT></P>
## name of a file, containing plugin's configuration</I></FONT></P> ## name of a file, containing plugin's configuration</I></FONT></P>
<P STYLE="margin-bottom: 0in"><FONT SIZE=4><I>}</I></FONT></P> <P STYLE="margin-bottom: 0in"><FONT SIZE=4><I>}</I></FONT></P>
<P STYLE="margin-bottom: 0in"><FONT SIZE=4>i.e. when plugin PlugName <P STYLE="margin-bottom: 0in"><FONT SIZE=4>i.e. when plugin PlugName
is needed firebird loads library LibName, finds in it plugin is needed Firebird loads library LibName, finds in it plugin
registered with name RegName and passes it configuration from config registered with name RegName and passes it configuration from config
record ConfName or config file ConfFile (config record is used if record ConfName or config file ConfFile (config record is used if
bith are given). Each parameter in this record may be missing, in both are given). Each parameter in this record may be missing, in
that case the default PlugName is used. The only exception is that case the default PlugName is used. The only exception is
ConfigFile by default file with same name as module's dynamic ConfigFile by default, file with same name as module's dynamic
library but .conf extension is used. ConfigFile is expected to have library but .conf extension is used. ConfigFile is expected to have
format Key=Value (like other firebird configuration files), same format Key=Value (like other Firebird configuration files), same
format is used for plugin record:</FONT></P> format is used for plugin record:</FONT></P>
<P STYLE="margin-bottom: 0in"><FONT SIZE=4><I>Config = ConfName</I></FONT></P> <P STYLE="margin-bottom: 0in"><FONT SIZE=4><I>Config = ConfName</I></FONT></P>
<P STYLE="margin-bottom: 0in"><FONT SIZE=4><I>{</I></FONT></P> <P STYLE="margin-bottom: 0in"><FONT SIZE=4><I>{</I></FONT></P>
@ -203,8 +203,8 @@ vendor and others from another one (and have different licenses
for appropriate client parts), but each vendor calls his plugin for appropriate client parts), but each vendor calls his plugin
BestCrypt. Certainly, first of all you have to rename libraries to BestCrypt. Certainly, first of all you have to rename libraries to
something like WC1 and WC2 one can't have 2 files with same name something like WC1 and WC2 one can't have 2 files with same name
in one directory. But after it modules stop to load automatically in one directory. But after it, modules stop to load automatically
they are not named BestCrypt any more. To fix it plugins.conf should they are not named BestCrypt any more. To fix it, plugins.conf should
contain something like this:</FONT></P> contain something like this:</FONT></P>
<P STYLE="margin-bottom: 0in"><FONT SIZE=4><I>Plugin = WC1</I></FONT></P> <P STYLE="margin-bottom: 0in"><FONT SIZE=4><I>Plugin = WC1</I></FONT></P>
<P STYLE="margin-bottom: 0in"><FONT SIZE=4><I>{</I></FONT></P> <P STYLE="margin-bottom: 0in"><FONT SIZE=4><I>{</I></FONT></P>
@ -227,7 +227,7 @@ automatically select appropriate plugin to talk to client.</FONT></P>
<P STYLE="margin-bottom: 0in"><BR> <P STYLE="margin-bottom: 0in"><BR>
</P> </P>
<P STYLE="margin-bottom: 0in"><FONT SIZE=4>Another sample may be <P STYLE="margin-bottom: 0in"><FONT SIZE=4>Another sample may be
found in distributed with firebird plugins.conf. One of standard found in distributed with Firebird plugins.conf. One of standard
plugins, UDR, is written to use non-default configuration. Therefore plugins, UDR, is written to use non-default configuration. Therefore
module name and one configuration parameter are given explicitly.</FONT></P> module name and one configuration parameter are given explicitly.</FONT></P>
<P STYLE="margin-bottom: 0in"><BR> <P STYLE="margin-bottom: 0in"><BR>
@ -241,7 +241,7 @@ with such names. How do they work?</FONT></P>
<P STYLE="margin-bottom: 0in"><FONT SIZE=4>A. That are so-called <P STYLE="margin-bottom: 0in"><FONT SIZE=4>A. That are so-called
'built-in' plugins. They are built into fbclient library, and 'built-in' plugins. They are built into fbclient library, and
therefore are always present. Arrival of such plugins is due to old therefore are always present. Arrival of such plugins is due to old
ability to distribute windows firebird client as single dll. It was ability to distribute windows Firebird client as single dll. It was
decided to keep such feature at least for a case when standard set of decided to keep such feature at least for a case when standard set of
plugins is used.</FONT></P> plugins is used.</FONT></P>
<P STYLE="margin-bottom: 0in"><BR> <P STYLE="margin-bottom: 0in"><BR>
@ -250,7 +250,7 @@ plugins is used.</FONT></P>
and Arc4 plugins mean?</FONT></P> and Arc4 plugins mean?</FONT></P>
<P STYLE="margin-bottom: 0in"><FONT SIZE=4>A. Srp implements Secure <P STYLE="margin-bottom: 0in"><FONT SIZE=4>A. Srp implements Secure
Remote Passwords protocol which is default way of authenticating Remote Passwords protocol which is default way of authenticating
users in firebird 3. It has efficient passwords length equal to 20 users in Firebird 3. It has efficient passwords length equal to 20
bytes, resistant to most of attacks (including man in the middle) and bytes, resistant to most of attacks (including man in the middle) and
does not require exchanging any keys between client and server to does not require exchanging any keys between client and server to
work. Arc4 means Alleged RC4 - an implementation of RC4 cypher. The work. Arc4 means Alleged RC4 - an implementation of RC4 cypher. The

View File

@ -55,7 +55,7 @@ BOOLEAN (FB 3.0)
2. CREATE TABLE TABLE1 (FIELD1 BOOLEAN); 2. CREATE TABLE TABLE1 (FIELD1 BOOLEAN);
Note(s): Note(s):
1. Quote from the SQL-99 specification: 1. Quote from the SQL-2008 specification:
The data type boolean comprises the distinct truth values TRUE and FALSE. Unless prohibited The data type boolean comprises the distinct truth values TRUE and FALSE. Unless prohibited
by a NOT NULL constraint, the boolean data type also supports the truth value UNKNOWN as the by a NOT NULL constraint, the boolean data type also supports the truth value UNKNOWN as the

View File

@ -1449,8 +1449,10 @@ void CVT_move_common(const dsc* from, dsc* to, Callbacks* cb)
ptr += sizeof(USHORT); ptr += sizeof(USHORT);
if (l < from->dsc_length) if (l < from->dsc_length)
{
cb->err(Arg::Gds(isc_arith_except) << Arg::Gds(isc_string_truncation) << cb->err(Arg::Gds(isc_arith_except) << Arg::Gds(isc_string_truncation) <<
Arg::Gds(isc_trunc_limits) << Arg::Num(l) << Arg::Num(from->dsc_length)); Arg::Gds(isc_trunc_limits) << Arg::Num(l) << Arg::Num(from->dsc_length));
}
Jrd::CharSet* charSet = cb->getToCharset(to->getCharSet()); Jrd::CharSet* charSet = cb->getToCharset(to->getCharSet());
cb->validateData(charSet, from->dsc_length, from->dsc_address); cb->validateData(charSet, from->dsc_length, from->dsc_address);

View File

@ -449,7 +449,7 @@ namespace
return request->req_rpb.getCount() > n && request->req_rpb[n].rpb_number.isValid() ? return request->req_rpb.getCount() > n && request->req_rpb[n].rpb_number.isValid() ?
&request->req_rpb[n] : NULL; &request->req_rpb[n] : NULL;
} }
private: private:
const ExtEngineManager::Trigger* trigger; const ExtEngineManager::Trigger* trigger;

View File

@ -831,7 +831,7 @@ inline Jrd::Database* GET_DBB()
/*-------------------------------------------------------------------------* /*-------------------------------------------------------------------------*
* macros used to set thread_db and Database pointers when there are not set already * * macros used to set thread_db and Database pointers when there are not set already *
*-------------------------------------------------------------------------*/ *-------------------------------------------------------------------------*/
inline void SET_TDBB(Jrd::thread_db* &tdbb) inline void SET_TDBB(Jrd::thread_db*& tdbb)
{ {
if (tdbb == NULL) { if (tdbb == NULL) {
tdbb = JRD_get_thread_data(); tdbb = JRD_get_thread_data();
@ -839,7 +839,7 @@ inline void SET_TDBB(Jrd::thread_db* &tdbb)
CHECK_TDBB(tdbb); CHECK_TDBB(tdbb);
} }
inline void SET_DBB(Jrd::Database* &dbb) inline void SET_DBB(Jrd::Database*& dbb)
{ {
if (dbb == NULL) { if (dbb == NULL) {
dbb = GET_DBB(); dbb = GET_DBB();