mirror of
https://github.com/MariaDB/server.git
synced 2025-08-01 03:47:19 +03:00
merged
BitKeeper/etc/ignore: auto-union include/my_global.h: Auto merged mysys/mf_tempfile.c: Auto merged mysql-test/r/rpl_heap.result: Auto merged mysql-test/t/rpl_heap.test: Auto merged sql/ha_innodb.cc: Auto merged
This commit is contained in:
187
.bzrignore
187
.bzrignore
@ -77,6 +77,7 @@ Docs/mysql.xml
|
|||||||
Docs/safe-mysql.xml
|
Docs/safe-mysql.xml
|
||||||
Docs/tex.fmt
|
Docs/tex.fmt
|
||||||
Docs/texi2dvi.out
|
Docs/texi2dvi.out
|
||||||
|
EXCEPTIONS-CLIENT
|
||||||
INSTALL-SOURCE
|
INSTALL-SOURCE
|
||||||
INSTALL-WIN-SOURCE
|
INSTALL-WIN-SOURCE
|
||||||
Logs/*
|
Logs/*
|
||||||
@ -272,11 +273,13 @@ emacs.h
|
|||||||
extra/comp_err
|
extra/comp_err
|
||||||
extra/my_print_defaults
|
extra/my_print_defaults
|
||||||
extra/mysql_install
|
extra/mysql_install
|
||||||
|
extra/mysql_tzinfo_to_sql
|
||||||
extra/mysql_waitpid
|
extra/mysql_waitpid
|
||||||
extra/perror
|
extra/perror
|
||||||
extra/replace
|
extra/replace
|
||||||
extra/resolve_stack_dump
|
extra/resolve_stack_dump
|
||||||
extra/resolveip
|
extra/resolveip
|
||||||
|
extra/tztime.cc
|
||||||
fcns.c
|
fcns.c
|
||||||
fcns.h
|
fcns.h
|
||||||
gmon.out
|
gmon.out
|
||||||
@ -316,6 +319,7 @@ isam/test3
|
|||||||
libmysql/*.c
|
libmysql/*.c
|
||||||
libmysql/conf_to_src
|
libmysql/conf_to_src
|
||||||
libmysql/my_static.h
|
libmysql/my_static.h
|
||||||
|
libmysql/my_time.c
|
||||||
libmysql/mysys_priv.h
|
libmysql/mysys_priv.h
|
||||||
libmysql/net.c
|
libmysql/net.c
|
||||||
libmysql/vio_priv.h
|
libmysql/vio_priv.h
|
||||||
@ -382,6 +386,7 @@ libmysqld/log_event.cc
|
|||||||
libmysqld/md5.c
|
libmysqld/md5.c
|
||||||
libmysqld/mf_iocache.cc
|
libmysqld/mf_iocache.cc
|
||||||
libmysqld/mini_client.cc
|
libmysqld/mini_client.cc
|
||||||
|
libmysqld/my_time.c
|
||||||
libmysqld/net_pkg.cc
|
libmysqld/net_pkg.cc
|
||||||
libmysqld/net_serv.cc
|
libmysqld/net_serv.cc
|
||||||
libmysqld/opt_ft.cc
|
libmysqld/opt_ft.cc
|
||||||
@ -644,7 +649,71 @@ ndb/lib/libREP_API.so
|
|||||||
ndb/lib/libndbclient.so
|
ndb/lib/libndbclient.so
|
||||||
ndb/lib/libndbclient_extra.so
|
ndb/lib/libndbclient_extra.so
|
||||||
ndb/src/common/mgmcommon/printConfig/*.d
|
ndb/src/common/mgmcommon/printConfig/*.d
|
||||||
|
ndb/src/cw/cpcd/ndb_cpcd
|
||||||
|
ndb/src/kernel/blocks/backup/restore/ndb_restore
|
||||||
|
ndb/src/kernel/ndbd
|
||||||
|
ndb/src/mgmclient/ndb_mgm
|
||||||
ndb/src/mgmclient/test_cpcd/*.d
|
ndb/src/mgmclient/test_cpcd/*.d
|
||||||
|
ndb/src/mgmsrv/ndb_mgmd
|
||||||
|
ndb/test/ndbapi/bank/bankCreator
|
||||||
|
ndb/test/ndbapi/bank/bankMakeGL
|
||||||
|
ndb/test/ndbapi/bank/bankSumAccounts
|
||||||
|
ndb/test/ndbapi/bank/bankTimer
|
||||||
|
ndb/test/ndbapi/bank/bankTransactionMaker
|
||||||
|
ndb/test/ndbapi/bank/bankValidateAllGLs
|
||||||
|
ndb/test/ndbapi/bank/testBank
|
||||||
|
ndb/test/ndbapi/create_all_tabs
|
||||||
|
ndb/test/ndbapi/create_tab
|
||||||
|
ndb/test/ndbapi/drop_all_tabs
|
||||||
|
ndb/test/ndbapi/flexAsynch
|
||||||
|
ndb/test/ndbapi/flexBench
|
||||||
|
ndb/test/ndbapi/flexHammer
|
||||||
|
ndb/test/ndbapi/flexTT
|
||||||
|
ndb/test/ndbapi/testBackup
|
||||||
|
ndb/test/ndbapi/testBasic
|
||||||
|
ndb/test/ndbapi/testBasicAsynch
|
||||||
|
ndb/test/ndbapi/testBlobs
|
||||||
|
ndb/test/ndbapi/testDataBuffers
|
||||||
|
ndb/test/ndbapi/testDeadlock
|
||||||
|
ndb/test/ndbapi/testDict
|
||||||
|
ndb/test/ndbapi/testIndex
|
||||||
|
ndb/test/ndbapi/testMgm
|
||||||
|
ndb/test/ndbapi/testNdbApi
|
||||||
|
ndb/test/ndbapi/testNodeRestart
|
||||||
|
ndb/test/ndbapi/testOIBasic
|
||||||
|
ndb/test/ndbapi/testOperations
|
||||||
|
ndb/test/ndbapi/testRestartGci
|
||||||
|
ndb/test/ndbapi/testScan
|
||||||
|
ndb/test/ndbapi/testScanInterpreter
|
||||||
|
ndb/test/ndbapi/testScanPerf
|
||||||
|
ndb/test/ndbapi/testSystemRestart
|
||||||
|
ndb/test/ndbapi/testTimeout
|
||||||
|
ndb/test/ndbapi/testTransactions
|
||||||
|
ndb/test/ndbapi/test_event
|
||||||
|
ndb/test/run-test/atrt
|
||||||
|
ndb/test/tools/copy_tab
|
||||||
|
ndb/test/tools/create_index
|
||||||
|
ndb/test/tools/hugoCalculator
|
||||||
|
ndb/test/tools/hugoFill
|
||||||
|
ndb/test/tools/hugoLoad
|
||||||
|
ndb/test/tools/hugoLockRecords
|
||||||
|
ndb/test/tools/hugoPkDelete
|
||||||
|
ndb/test/tools/hugoPkRead
|
||||||
|
ndb/test/tools/hugoPkReadRecord
|
||||||
|
ndb/test/tools/hugoPkUpdate
|
||||||
|
ndb/test/tools/hugoScanRead
|
||||||
|
ndb/test/tools/hugoScanUpdate
|
||||||
|
ndb/test/tools/ndb_cpcc
|
||||||
|
ndb/test/tools/restart
|
||||||
|
ndb/test/tools/verify_index
|
||||||
|
ndb/tools/ndb_delete_all
|
||||||
|
ndb/tools/ndb_desc
|
||||||
|
ndb/tools/ndb_drop_index
|
||||||
|
ndb/tools/ndb_drop_table
|
||||||
|
ndb/tools/ndb_select_all
|
||||||
|
ndb/tools/ndb_select_count
|
||||||
|
ndb/tools/ndb_show_tables
|
||||||
|
ndb/tools/ndb_waiter
|
||||||
pull.log
|
pull.log
|
||||||
regex/re
|
regex/re
|
||||||
repl-tests/test-repl-ts/repl-timestamp.master.reject
|
repl-tests/test-repl-ts/repl-timestamp.master.reject
|
||||||
@ -715,7 +784,10 @@ sql/gen_lex_hash
|
|||||||
sql/gmon.out
|
sql/gmon.out
|
||||||
sql/lex_hash.h
|
sql/lex_hash.h
|
||||||
sql/mini_client_errors.c
|
sql/mini_client_errors.c
|
||||||
|
sql/my_time.c
|
||||||
sql/mysql_tzinfo_to_sql
|
sql/mysql_tzinfo_to_sql
|
||||||
|
sql/mysql_tzinfo_to_sql.cc
|
||||||
|
sql/mysql_tzinfo_to_sql_tztime.cc
|
||||||
sql/mysqlbinlog
|
sql/mysqlbinlog
|
||||||
sql/mysqld
|
sql/mysqld
|
||||||
sql/mysqld-purecov
|
sql/mysqld-purecov
|
||||||
@ -770,41 +842,13 @@ support-files/mysql-log-rotate
|
|||||||
support-files/mysql.server
|
support-files/mysql.server
|
||||||
support-files/mysql.spec
|
support-files/mysql.spec
|
||||||
tags
|
tags
|
||||||
test_xml
|
test/ndbapi/bank/bankCreator
|
||||||
tests/client_test
|
test/ndbapi/bank/bankMakeGL
|
||||||
tests/connect_test
|
test/ndbapi/bank/bankSumAccounts
|
||||||
thread_test
|
test/ndbapi/bank/bankTimer
|
||||||
tmp/*
|
test/ndbapi/bank/bankTransactionMaker
|
||||||
tools/my_vsnprintf.c
|
test/ndbapi/bank/bankValidateAllGLs
|
||||||
tools/mysqlmanager
|
test/ndbapi/bank/testBank
|
||||||
tools/mysqlmngd
|
|
||||||
tools/mysys_priv.h
|
|
||||||
vi.h
|
|
||||||
vio/test-ssl
|
|
||||||
vio/test-sslclient
|
|
||||||
vio/test-sslserver
|
|
||||||
vio/viotest-ssl
|
|
||||||
extra/tztime.cc
|
|
||||||
extra/mysql_tzinfo_to_sql
|
|
||||||
sql/mysql_tzinfo_to_sql_tztime.cc
|
|
||||||
sql/my_time.c
|
|
||||||
libmysql/my_time.c
|
|
||||||
libmysqld/my_time.c
|
|
||||||
sql/mysql_tzinfo_to_sql
|
|
||||||
sql/mysql_tzinfo_to_sql.cc
|
|
||||||
ndb/src/cw/cpcd/ndb_cpcd
|
|
||||||
ndb/src/kernel/ndbd
|
|
||||||
ndb/src/kernel/blocks/backup/restore/ndb_restore
|
|
||||||
ndb/src/mgmclient/ndb_mgm
|
|
||||||
ndb/src/mgmsrv/ndb_mgmd
|
|
||||||
ndb/tools/ndb_delete_all
|
|
||||||
ndb/tools/ndb_desc
|
|
||||||
ndb/tools/ndb_drop_index
|
|
||||||
ndb/tools/ndb_drop_table
|
|
||||||
ndb/tools/ndb_select_all
|
|
||||||
ndb/tools/ndb_select_count
|
|
||||||
ndb/tools/ndb_show_tables
|
|
||||||
ndb/tools/ndb_waiter
|
|
||||||
test/ndbapi/create_all_tabs
|
test/ndbapi/create_all_tabs
|
||||||
test/ndbapi/create_tab
|
test/ndbapi/create_tab
|
||||||
test/ndbapi/drop_all_tabs
|
test/ndbapi/drop_all_tabs
|
||||||
@ -833,13 +877,6 @@ test/ndbapi/testSystemRestart
|
|||||||
test/ndbapi/testTimeout
|
test/ndbapi/testTimeout
|
||||||
test/ndbapi/testTransactions
|
test/ndbapi/testTransactions
|
||||||
test/ndbapi/test_event
|
test/ndbapi/test_event
|
||||||
test/ndbapi/bank/bankCreator
|
|
||||||
test/ndbapi/bank/bankMakeGL
|
|
||||||
test/ndbapi/bank/bankSumAccounts
|
|
||||||
test/ndbapi/bank/bankTimer
|
|
||||||
test/ndbapi/bank/bankTransactionMaker
|
|
||||||
test/ndbapi/bank/bankValidateAllGLs
|
|
||||||
test/ndbapi/bank/testBank
|
|
||||||
test/run-test/atrt
|
test/run-test/atrt
|
||||||
test/tools/copy_tab
|
test/tools/copy_tab
|
||||||
test/tools/create_index
|
test/tools/create_index
|
||||||
@ -856,55 +893,17 @@ test/tools/hugoScanUpdate
|
|||||||
test/tools/ndb_cpcc
|
test/tools/ndb_cpcc
|
||||||
test/tools/restart
|
test/tools/restart
|
||||||
test/tools/verify_index
|
test/tools/verify_index
|
||||||
ndb/test/ndbapi/create_all_tabs
|
test_xml
|
||||||
ndb/test/ndbapi/create_tab
|
tests/client_test
|
||||||
ndb/test/ndbapi/drop_all_tabs
|
tests/connect_test
|
||||||
ndb/test/ndbapi/flexAsynch
|
thread_test
|
||||||
ndb/test/ndbapi/flexBench
|
tmp/*
|
||||||
ndb/test/ndbapi/flexHammer
|
tools/my_vsnprintf.c
|
||||||
ndb/test/ndbapi/flexTT
|
tools/mysqlmanager
|
||||||
ndb/test/ndbapi/testBackup
|
tools/mysqlmngd
|
||||||
ndb/test/ndbapi/testBasic
|
tools/mysys_priv.h
|
||||||
ndb/test/ndbapi/testBasicAsynch
|
vi.h
|
||||||
ndb/test/ndbapi/testBlobs
|
vio/test-ssl
|
||||||
ndb/test/ndbapi/testDataBuffers
|
vio/test-sslclient
|
||||||
ndb/test/ndbapi/testDeadlock
|
vio/test-sslserver
|
||||||
ndb/test/ndbapi/testDict
|
vio/viotest-ssl
|
||||||
ndb/test/ndbapi/testIndex
|
|
||||||
ndb/test/ndbapi/testMgm
|
|
||||||
ndb/test/ndbapi/testNdbApi
|
|
||||||
ndb/test/ndbapi/testNodeRestart
|
|
||||||
ndb/test/ndbapi/testOIBasic
|
|
||||||
ndb/test/ndbapi/testOperations
|
|
||||||
ndb/test/ndbapi/testRestartGci
|
|
||||||
ndb/test/ndbapi/testScan
|
|
||||||
ndb/test/ndbapi/testScanInterpreter
|
|
||||||
ndb/test/ndbapi/testScanPerf
|
|
||||||
ndb/test/ndbapi/testSystemRestart
|
|
||||||
ndb/test/ndbapi/testTimeout
|
|
||||||
ndb/test/ndbapi/testTransactions
|
|
||||||
ndb/test/ndbapi/test_event
|
|
||||||
ndb/test/ndbapi/bank/bankCreator
|
|
||||||
ndb/test/ndbapi/bank/bankMakeGL
|
|
||||||
ndb/test/ndbapi/bank/bankSumAccounts
|
|
||||||
ndb/test/ndbapi/bank/bankTimer
|
|
||||||
ndb/test/ndbapi/bank/bankTransactionMaker
|
|
||||||
ndb/test/ndbapi/bank/bankValidateAllGLs
|
|
||||||
ndb/test/ndbapi/bank/testBank
|
|
||||||
ndb/test/run-test/atrt
|
|
||||||
ndb/test/tools/copy_tab
|
|
||||||
ndb/test/tools/create_index
|
|
||||||
ndb/test/tools/hugoCalculator
|
|
||||||
ndb/test/tools/hugoFill
|
|
||||||
ndb/test/tools/hugoLoad
|
|
||||||
ndb/test/tools/hugoLockRecords
|
|
||||||
ndb/test/tools/hugoPkDelete
|
|
||||||
ndb/test/tools/hugoPkRead
|
|
||||||
ndb/test/tools/hugoPkReadRecord
|
|
||||||
ndb/test/tools/hugoPkUpdate
|
|
||||||
ndb/test/tools/hugoScanRead
|
|
||||||
ndb/test/tools/hugoScanUpdate
|
|
||||||
ndb/test/tools/ndb_cpcc
|
|
||||||
ndb/test/tools/restart
|
|
||||||
ndb/test/tools/verify_index
|
|
||||||
EXCEPTIONS-CLIENT
|
|
||||||
|
@ -644,29 +644,17 @@ typedef SOCKET_SIZE_TYPE size_socket;
|
|||||||
#endif
|
#endif
|
||||||
#endif /* defined (HAVE_LONG_LONG) && !defined(ULONGLONG_MAX)*/
|
#endif /* defined (HAVE_LONG_LONG) && !defined(ULONGLONG_MAX)*/
|
||||||
|
|
||||||
#if SIZEOF_LONG == 4
|
#define INT_MIN32 (~0x7FFFFFFFL)
|
||||||
#define INT_MIN32 ((long) 0x80000000L)
|
#define INT_MAX32 0x7FFFFFFFL
|
||||||
#define INT_MAX32 ((long) 0x7FFFFFFFL)
|
#define UINT_MAX32 0xFFFFFFFFL
|
||||||
#define UINT_MAX32 ((long) 0xFFFFFFFFL)
|
#define INT_MIN24 (~0x007FFFFF)
|
||||||
#define INT_MIN24 ((long) 0xFF800000L)
|
#define INT_MAX24 0x007FFFFF
|
||||||
#define INT_MAX24 0x007FFFFFL
|
#define UINT_MAX24 0x00FFFFFF
|
||||||
#define UINT_MAX24 0x00FFFFFFL
|
#define INT_MIN16 (~0x7FFF)
|
||||||
#define INT_MIN16 ((short int) 0x8000)
|
|
||||||
#define INT_MAX16 0x7FFF
|
#define INT_MAX16 0x7FFF
|
||||||
#define UINT_MAX16 0xFFFF
|
#define UINT_MAX16 0xFFFF
|
||||||
#define INT_MIN8 ((char) 0x80)
|
#define INT_MIN8 (~0x7F)
|
||||||
#define INT_MAX8 ((char) 0x7F)
|
#define INT_MAX8 0x7F
|
||||||
#else /* Probably Alpha */
|
|
||||||
#define INT_MIN32 ((long) (int) 0x80000000)
|
|
||||||
#define INT_MAX32 ((long) (int) 0x7FFFFFFF)
|
|
||||||
#define UINT_MAX32 ((long) (int) 0xFFFFFFFF)
|
|
||||||
#define INT_MIN24 ((long) (int) 0xFF800000)
|
|
||||||
#define INT_MAX24 ((long) (int) 0x007FFFFF)
|
|
||||||
#define UINT_MAX24 ((long) (int) 0x00FFFFFF)
|
|
||||||
#define INT_MIN16 ((short int) 0xFFFF8000)
|
|
||||||
#define INT_MAX16 ((short int) 0x00007FFF)
|
|
||||||
#define UINT_MAX16 ((short int) 0x0000FFFF)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* From limits.h instead */
|
/* From limits.h instead */
|
||||||
#ifndef DBL_MIN
|
#ifndef DBL_MIN
|
||||||
|
@ -135,6 +135,9 @@ t1 CREATE TABLE `t1` (
|
|||||||
`b` double(200,30) default NULL
|
`b` double(200,30) default NULL
|
||||||
) ENGINE=MyISAM DEFAULT CHARSET=latin1
|
) ENGINE=MyISAM DEFAULT CHARSET=latin1
|
||||||
drop table t1;
|
drop table t1;
|
||||||
|
create table t1 (c20 char);
|
||||||
|
insert into t1 values (5000.0);
|
||||||
|
drop table t1;
|
||||||
create table t1 (f float(54));
|
create table t1 (f float(54));
|
||||||
ERROR 42000: Incorrect column specifier for column 'f'
|
ERROR 42000: Incorrect column specifier for column 'f'
|
||||||
drop table if exists t1;
|
drop table if exists t1;
|
||||||
|
@ -72,6 +72,13 @@ select * from t1;
|
|||||||
show create table t1;
|
show create table t1;
|
||||||
drop table t1;
|
drop table t1;
|
||||||
|
|
||||||
|
#
|
||||||
|
# float in a char(1) field
|
||||||
|
#
|
||||||
|
create table t1 (c20 char);
|
||||||
|
insert into t1 values (5000.0);
|
||||||
|
drop table t1;
|
||||||
|
|
||||||
# Errors
|
# Errors
|
||||||
|
|
||||||
--error 1063
|
--error 1063
|
||||||
@ -79,3 +86,4 @@ create table t1 (f float(54)); # Should give an error
|
|||||||
--disable_warnings
|
--disable_warnings
|
||||||
drop table if exists t1;
|
drop table if exists t1;
|
||||||
--enable_warnings
|
--enable_warnings
|
||||||
|
|
||||||
|
@ -98,7 +98,7 @@ File create_temp_file(char *to, const char *dir, const char *prefix,
|
|||||||
if (strlen(dir)+ pfx_len > FN_REFLEN-2)
|
if (strlen(dir)+ pfx_len > FN_REFLEN-2)
|
||||||
{
|
{
|
||||||
errno=my_errno= ENAMETOOLONG;
|
errno=my_errno= ENAMETOOLONG;
|
||||||
return 1;
|
DBUG_RETURN(file);
|
||||||
}
|
}
|
||||||
strmov(convert_dirname(to,dir,NullS),prefix_buff);
|
strmov(convert_dirname(to,dir,NullS),prefix_buff);
|
||||||
org_file=mkstemp(to);
|
org_file=mkstemp(to);
|
||||||
@ -124,7 +124,7 @@ File create_temp_file(char *to, const char *dir, const char *prefix,
|
|||||||
#ifdef OS2
|
#ifdef OS2
|
||||||
/* changing environ variable doesn't work with VACPP */
|
/* changing environ variable doesn't work with VACPP */
|
||||||
char buffer[256], *end;
|
char buffer[256], *end;
|
||||||
buffer[sizeof[buffer)-1]= 0;
|
buffer[sizeof(buffer)-1]= 0;
|
||||||
end= strxnmov(buffer, sizeof(buffer)-1, (char*) "TMP=", dir, NullS);
|
end= strxnmov(buffer, sizeof(buffer)-1, (char*) "TMP=", dir, NullS);
|
||||||
/* remove ending backslash */
|
/* remove ending backslash */
|
||||||
if (end[-1] == '\\')
|
if (end[-1] == '\\')
|
||||||
|
20
sql/field.cc
20
sql/field.cc
@ -4279,7 +4279,7 @@ int Field_str::store(double nr)
|
|||||||
{
|
{
|
||||||
bool use_scientific_notation=TRUE;
|
bool use_scientific_notation=TRUE;
|
||||||
char buff[DOUBLE_TO_STRING_CONVERSION_BUFFER_SIZE];
|
char buff[DOUBLE_TO_STRING_CONVERSION_BUFFER_SIZE];
|
||||||
int length;
|
uint length;
|
||||||
if (field_length < 32 && nr > 1) // TODO: negative numbers
|
if (field_length < 32 && nr > 1) // TODO: negative numbers
|
||||||
{
|
{
|
||||||
if (ceiling == 0)
|
if (ceiling == 0)
|
||||||
@ -4295,11 +4295,19 @@ int Field_str::store(double nr)
|
|||||||
}
|
}
|
||||||
use_scientific_notation= (ceiling < nr);
|
use_scientific_notation= (ceiling < nr);
|
||||||
}
|
}
|
||||||
length= sprintf(buff, "%-.*g",
|
length= (uint)sprintf(buff, "%-.*g",
|
||||||
use_scientific_notation ? max(0,field_length-5) : field_length,
|
use_scientific_notation ? max(0,(int)field_length-5) : field_length,
|
||||||
nr);
|
nr);
|
||||||
DBUG_ASSERT(length <= field_length);
|
/*
|
||||||
return store((const char *)buff, (uint) length, charset());
|
+1 below is because "precision" in %g above means the
|
||||||
|
max. number of significant digits, not the output width.
|
||||||
|
Thus the width can be larger than number of significant digits by 1
|
||||||
|
(for decimal point)
|
||||||
|
the test for field_length < 5 is for extreme cases,
|
||||||
|
like inserting 500.0 in char(1)
|
||||||
|
*/
|
||||||
|
DBUG_ASSERT(field_length < 5 || length <= field_length+1);
|
||||||
|
return store((const char *)buff, min(length, field_length), charset());
|
||||||
}
|
}
|
||||||
|
|
||||||
int Field_string::store(longlong nr)
|
int Field_string::store(longlong nr)
|
||||||
|
@ -40,6 +40,7 @@ have disables the InnoDB inlining in this file. */
|
|||||||
#include <m_ctype.h>
|
#include <m_ctype.h>
|
||||||
#include <hash.h>
|
#include <hash.h>
|
||||||
#include <myisampack.h>
|
#include <myisampack.h>
|
||||||
|
#include <mysys_err.h>
|
||||||
|
|
||||||
#define MAX_ULONG_BIT ((ulong) 1 << (sizeof(ulong)*8-1))
|
#define MAX_ULONG_BIT ((ulong) 1 << (sizeof(ulong)*8-1))
|
||||||
|
|
||||||
@ -433,6 +434,7 @@ innobase_mysql_tmpfile(void)
|
|||||||
/* out: temporary file descriptor, or < 0 on error */
|
/* out: temporary file descriptor, or < 0 on error */
|
||||||
{
|
{
|
||||||
char filename[FN_REFLEN];
|
char filename[FN_REFLEN];
|
||||||
|
int fd2 = -1;
|
||||||
File fd = create_temp_file(filename, NullS, "ib",
|
File fd = create_temp_file(filename, NullS, "ib",
|
||||||
#ifdef __WIN__
|
#ifdef __WIN__
|
||||||
O_BINARY | O_TRUNC | O_SEQUENTIAL |
|
O_BINARY | O_TRUNC | O_SEQUENTIAL |
|
||||||
@ -440,12 +442,31 @@ innobase_mysql_tmpfile(void)
|
|||||||
#endif /* __WIN__ */
|
#endif /* __WIN__ */
|
||||||
O_CREAT | O_EXCL | O_RDWR,
|
O_CREAT | O_EXCL | O_RDWR,
|
||||||
MYF(MY_WME));
|
MYF(MY_WME));
|
||||||
#ifndef __WIN__
|
|
||||||
if (fd >= 0) {
|
if (fd >= 0) {
|
||||||
|
#ifndef __WIN__
|
||||||
|
/* On Windows, open files cannot be removed, but files can be
|
||||||
|
created with the O_TEMPORARY flag to the same effect
|
||||||
|
("delete on close"). */
|
||||||
unlink(filename);
|
unlink(filename);
|
||||||
}
|
|
||||||
#endif /* !__WIN__ */
|
#endif /* !__WIN__ */
|
||||||
return(fd);
|
/* Copy the file descriptor, so that the additional resources
|
||||||
|
allocated by create_temp_file() can be freed by invoking
|
||||||
|
my_close().
|
||||||
|
|
||||||
|
Because the file descriptor returned by this function
|
||||||
|
will be passed to fdopen(), it will be closed by invoking
|
||||||
|
fclose(), which in turn will invoke close() instead of
|
||||||
|
my_close(). */
|
||||||
|
fd2 = dup(fd);
|
||||||
|
if (fd2 < 0) {
|
||||||
|
DBUG_PRINT("error",("Got error %d on dup",fd2));
|
||||||
|
my_errno=errno;
|
||||||
|
my_error(EE_OUT_OF_FILERESOURCES,
|
||||||
|
MYF(ME_BELL+ME_WAITTANG), filename, my_errno);
|
||||||
|
}
|
||||||
|
my_close(fd, MYF(MY_WME));
|
||||||
|
}
|
||||||
|
return(fd2);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*************************************************************************
|
/*************************************************************************
|
||||||
|
@ -1878,11 +1878,10 @@ void MYSQL_LOG::set_max_size(ulong max_size_arg)
|
|||||||
|
|
||||||
|
|
||||||
Disable_binlog::Disable_binlog(THD *thd_arg) :
|
Disable_binlog::Disable_binlog(THD *thd_arg) :
|
||||||
thd(thd_arg),
|
thd(thd_arg), save_options(thd_arg->options)
|
||||||
save_options(thd_arg->options)
|
|
||||||
{
|
{
|
||||||
thd_arg->options&= ~OPTION_BIN_LOG;
|
thd_arg->options&= ~OPTION_BIN_LOG;
|
||||||
};
|
}
|
||||||
|
|
||||||
|
|
||||||
Disable_binlog::~Disable_binlog()
|
Disable_binlog::~Disable_binlog()
|
||||||
|
@ -519,6 +519,7 @@ int mysql_create_table(THD *thd,const char *db, const char *table_name,
|
|||||||
HA_CREATE_INFO *create_info,
|
HA_CREATE_INFO *create_info,
|
||||||
List<create_field> &fields, List<Key> &keys,
|
List<create_field> &fields, List<Key> &keys,
|
||||||
bool tmp_table, uint select_field_count);
|
bool tmp_table, uint select_field_count);
|
||||||
|
|
||||||
TABLE *create_table_from_items(THD *thd, HA_CREATE_INFO *create_info,
|
TABLE *create_table_from_items(THD *thd, HA_CREATE_INFO *create_info,
|
||||||
const char *db, const char *name,
|
const char *db, const char *name,
|
||||||
List<create_field> *extra_fields,
|
List<create_field> *extra_fields,
|
||||||
|
@ -1026,7 +1026,7 @@ public:
|
|||||||
so we internally disable it temporarily by creating the Disable_binlog
|
so we internally disable it temporarily by creating the Disable_binlog
|
||||||
object and reset the state by destroying the object (don't forget that! or
|
object and reset the state by destroying the object (don't forget that! or
|
||||||
write code so that the object gets automatically destroyed when leaving a
|
write code so that the object gets automatically destroyed when leaving a
|
||||||
function...).
|
block, see example in sql_table.cc).
|
||||||
*/
|
*/
|
||||||
class Disable_binlog {
|
class Disable_binlog {
|
||||||
private:
|
private:
|
||||||
|
Reference in New Issue
Block a user