Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
mariadb
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
mariadb
Commits
6f3984bb
Commit
6f3984bb
authored
Jan 21, 2001
by
monty@donna.mysql.com
Browse files
Options
Browse Files
Download
Plain Diff
Merge
parents
62771338
2f940e03
Changes
16
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
16 changed files
with
292 additions
and
113 deletions
+292
-113
BitKeeper/etc/logging_ok
BitKeeper/etc/logging_ok
+4
-1
Docs/Makefile.am
Docs/Makefile.am
+2
-2
Docs/Support/test-make-manual
Docs/Support/test-make-manual
+68
-0
Docs/manual.texi
Docs/manual.texi
+52
-40
client/mysqltest.c
client/mysqltest.c
+38
-7
include/mysql.h
include/mysql.h
+4
-0
libmysql/libmysql.c
libmysql/libmysql.c
+65
-0
mysql-test/r/dirty-close.result
mysql-test/r/dirty-close.result
+4
-0
mysql-test/t/dirty-close.test
mysql-test/t/dirty-close.test
+10
-0
mysql-test/t/rpl000001.test
mysql-test/t/rpl000001.test
+2
-0
mysys/my_vsnprintf.c
mysys/my_vsnprintf.c
+37
-2
mysys/test_vsnprintf.c
mysys/test_vsnprintf.c
+0
-45
sql/ha_myisam.cc
sql/ha_myisam.cc
+2
-12
sql/ha_myisam.h
sql/ha_myisam.h
+1
-1
sql/sql_acl.cc
sql/sql_acl.cc
+2
-2
sql/sql_parse.cc
sql/sql_parse.cc
+1
-1
No files found.
BitKeeper/etc/logging_ok
View file @
6f3984bb
jcole@tetra.spaceapes.com
monty@donna.mysql.com
mwagner@work.mysql.com
mwagner@work.mysql.com
paul@central.snake.net
sasha@mysql.sashanet.com
sasha@mysql.sashanet.com
sasha@work.mysql.com
sasha@work.mysql.com
serg@donna.mysql.com
tim@cane.mysql.fi
tim@cane.mysql.fi
monty@donna.mysql.com
Docs/Makefile.am
View file @
6f3984bb
...
@@ -39,8 +39,8 @@ paper: manual_a4.ps manual_letter.ps $(PDFMANUAL)
...
@@ -39,8 +39,8 @@ paper: manual_a4.ps manual_letter.ps $(PDFMANUAL)
# The Makefile contains the previous version so we can not use that
# The Makefile contains the previous version so we can not use that
include.texi
:
../configure.in
include.texi
:
../configure.in
echo
-n
"@c This file is autogenerated by the Makefile"
>
$@
echo
"@c This file is autogenerated by the Makefile"
>
$@
echo
-n
"@set mysql_version "
>
$@
echo
-n
"@set mysql_version "
>
>
$@
grep
"AM_INIT_AUTOMAKE(mysql, "
../configure.in |
\
grep
"AM_INIT_AUTOMAKE(mysql, "
../configure.in |
\
sed
-e
's;AM_INIT_AUTOMAKE(mysql, ;;'
-e
's;);;'
>>
$@
sed
-e
's;AM_INIT_AUTOMAKE(mysql, ;;'
-e
's;);;'
>>
$@
echo
-n
"@set default_port "
>>
$@
echo
-n
"@set default_port "
>>
$@
...
...
Docs/Support/test-make-manual
View file @
6f3984bb
...
@@ -7,6 +7,54 @@ function die
...
@@ -7,6 +7,54 @@ function die
exit
1
exit
1
}
}
needed_flags
=
0
needed_texi2html
=
0
needed_texinfo_tex
=
0
needed_include_texi
=
0
if
[
-e
Flags/usa.txt
]
;
then
echo
"Good, Flags are there."
else
echo
-n
"Checking out Flags..."
bk edit Flags
>
/dev/null 2>&1
echo
" Done."
needed_flags
=
1
fi
if
[
-e
Support/texi2html
]
;
then
echo
"Good, texi2html is there."
else
echo
-n
"Checking out texi2html..."
bk edit Support/texi2html
>
/dev/null 2>&1
echo
" Done."
needed_texi2html
=
1
fi
if
[
-e
Support/texinfo.tex
]
;
then
echo
"Good, texinfo.tex is there."
else
echo
-n
"Checking out texinfo.tex..."
bk edit Support/texinfo.tex
>
/dev/null 2>&1
echo
" Done."
needed_texinfo_tex
=
1
fi
if
[
-e
include.texi
]
;
then
echo
"Good, include.texi is there."
else
echo
-n
"Creating include.texi..."
bk edit ../configure.in
>
/dev/null 2>&1
echo
"@c This file was generated by test-make-manual"
>
include.texi
echo
-n
"@set mysql_version "
>>
include.texi
grep
"AM_INIT_AUTOMAKE(mysql, "
../configure.in |
\
sed
-e
's;AM_INIT_AUTOMAKE(mysql, ;;'
-e
's;);;'
>>
include.texi
echo
-n
"@set default_port "
>>
include.texi
grep
"MYSQL_TCP_PORT_DEFAULT="
../configure.in |
\
sed
-e
's;MYSQL_TCP_PORT_DEFAULT=;;'
>>
include.texi
echo
" Done."
needed_include_texi
=
1
fi
echo
-n
"Running makeinfo..."
echo
-n
"Running makeinfo..."
makeinfo
--no-split
-I
.
manual.texi
makeinfo
--no-split
-I
.
manual.texi
...
@@ -36,6 +84,26 @@ else
...
@@ -36,6 +84,26 @@ else
echo
" Looks good."
echo
" Looks good."
fi
fi
needed_flags
=
0
needed_texi2html
=
0
needed_texinfo_tex
=
0
needed_include_texi
=
0
if
[
$needed_flags
]
;
then
bk clean Flags
fi
if
[
$needed_texi2html
]
;
then
bk clean Support/texi2html
fi
if
[
$needed_texinfo_tex
]
;
then
bk clean Support/texinfo.tex
fi
if
[
$needed_include_texi
]
;
then
rm
-f
include.texi
fi
[
-z
$BROWSER
]
&&
BROWSER
=
netscape
[
-z
$BROWSER
]
&&
BROWSER
=
netscape
...
...
Docs/manual.texi
View file @
6f3984bb
This diff is collapsed.
Click to expand it.
client/mysqltest.c
View file @
6f3984bb
...
@@ -61,6 +61,7 @@
...
@@ -61,6 +61,7 @@
#include <sys/stat.h>
#include <sys/stat.h>
#include <unistd.h>
#include <unistd.h>
#include <errno.h>
#include <errno.h>
#include <violite.h>
#define MAX_QUERY 65536
#define MAX_QUERY 65536
#define PAD_SIZE 128
#define PAD_SIZE 128
...
@@ -71,6 +72,8 @@
...
@@ -71,6 +72,8 @@
#define MIN_VAR_ALLOC 32
#define MIN_VAR_ALLOC 32
#define BLOCK_STACK_DEPTH 32
#define BLOCK_STACK_DEPTH 32
#define MAX_EXPECTED_ERRORS 10
#define MAX_EXPECTED_ERRORS 10
#define QUERY_SEND 1
#define QUERY_REAP 2
static
int
record
=
0
,
verbose
=
0
,
silent
=
0
,
opt_sleep
=
0
;
static
int
record
=
0
,
verbose
=
0
,
silent
=
0
,
opt_sleep
=
0
;
static
char
*
db
=
0
,
*
pass
=
0
;
static
char
*
db
=
0
,
*
pass
=
0
;
...
@@ -147,14 +150,14 @@ struct st_query
...
@@ -147,14 +150,14 @@ struct st_query
Q_SLEEP
,
Q_INC
,
Q_DEC
,
Q_SOURCE
,
Q_SLEEP
,
Q_INC
,
Q_DEC
,
Q_SOURCE
,
Q_DISCONNECT
,
Q_LET
,
Q_ECHO
,
Q_WHILE
,
Q_END_BLOCK
,
Q_DISCONNECT
,
Q_LET
,
Q_ECHO
,
Q_WHILE
,
Q_END_BLOCK
,
Q_SYSTEM
,
Q_RESULT
,
Q_REQUIRE
,
Q_SAVE_MASTER_POS
,
Q_SYSTEM
,
Q_RESULT
,
Q_REQUIRE
,
Q_SAVE_MASTER_POS
,
Q_SYNC_WITH_MASTER
,
Q_ERROR
,
Q_SYNC_WITH_MASTER
,
Q_ERROR
,
Q_SEND
,
Q_REAP
,
Q_DIRTY_CLOSE
,
Q_UNKNOWN
,
Q_COMMENT
,
Q_COMMENT_WITH_COMMAND
}
type
;
Q_UNKNOWN
,
Q_COMMENT
,
Q_COMMENT_WITH_COMMAND
}
type
;
};
};
const
char
*
command_names
[]
=
{
const
char
*
command_names
[]
=
{
"connection"
,
"query"
,
"connect"
,
"sleep"
,
"inc"
,
"dec"
,
"source"
,
"disconnect"
,
"connection"
,
"query"
,
"connect"
,
"sleep"
,
"inc"
,
"dec"
,
"source"
,
"disconnect"
,
"let"
,
"echo"
,
"while"
,
"end"
,
"system"
,
"result"
,
"require"
,
"save_master_pos"
,
"let"
,
"echo"
,
"while"
,
"end"
,
"system"
,
"result"
,
"require"
,
"save_master_pos"
,
"sync_with_master"
,
"error"
,
0
"sync_with_master"
,
"error"
,
"send"
,
"reap"
,
"dirty_close"
,
0
};
};
TYPELIB
command_typelib
=
{
array_elements
(
command_names
),
""
,
TYPELIB
command_typelib
=
{
array_elements
(
command_names
),
""
,
...
@@ -661,6 +664,15 @@ int close_connection(struct st_query* q)
...
@@ -661,6 +664,15 @@ int close_connection(struct st_query* q)
{
{
if
(
!
strcmp
(
con
->
name
,
name
))
if
(
!
strcmp
(
con
->
name
,
name
))
{
{
if
(
q
->
type
==
Q_DIRTY_CLOSE
)
{
if
(
con
->
mysql
.
net
.
vio
)
{
vio_delete
(
con
->
mysql
.
net
.
vio
);
con
->
mysql
.
net
.
vio
=
0
;
}
}
mysql_close
(
&
con
->
mysql
);
mysql_close
(
&
con
->
mysql
);
DBUG_RETURN
(
0
);
DBUG_RETURN
(
0
);
}
}
...
@@ -1211,7 +1223,7 @@ void reject_dump(const char* record_file, char* buf, int size)
...
@@ -1211,7 +1223,7 @@ void reject_dump(const char* record_file, char* buf, int size)
}
}
int
run_query
(
MYSQL
*
mysql
,
struct
st_query
*
q
)
int
run_query
(
MYSQL
*
mysql
,
struct
st_query
*
q
,
int
flags
)
{
{
MYSQL_RES
*
res
=
0
;
MYSQL_RES
*
res
=
0
;
MYSQL_FIELD
*
fields
;
MYSQL_FIELD
*
fields
;
...
@@ -1220,6 +1232,7 @@ int run_query(MYSQL* mysql, struct st_query* q)
...
@@ -1220,6 +1232,7 @@ int run_query(MYSQL* mysql, struct st_query* q)
unsigned
long
*
lengths
;
unsigned
long
*
lengths
;
char
*
val
;
char
*
val
;
int
len
;
int
len
;
int
q_error
=
0
;
DYNAMIC_STRING
*
ds
;
DYNAMIC_STRING
*
ds
;
DYNAMIC_STRING
ds_tmp
;
DYNAMIC_STRING
ds_tmp
;
DBUG_ENTER
(
"run_query"
);
DBUG_ENTER
(
"run_query"
);
...
@@ -1232,7 +1245,13 @@ int run_query(MYSQL* mysql, struct st_query* q)
...
@@ -1232,7 +1245,13 @@ int run_query(MYSQL* mysql, struct st_query* q)
else
else
ds
=
&
ds_res
;
ds
=
&
ds_res
;
if
(
mysql_query
(
mysql
,
q
->
query
))
if
((
flags
&
QUERY_SEND
)
&&
(
q_error
=
mysql_send_query
(
mysql
,
q
->
query
)))
die
(
"At line %u: unable to send query '%s'"
,
start_lineno
,
q
->
query
);
if
(
!
(
flags
&
QUERY_REAP
))
return
0
;
if
(
mysql_reap_query
(
mysql
))
{
{
if
(
q
->
require_file
)
if
(
q
->
require_file
)
abort_not_supported_test
();
abort_not_supported_test
();
...
@@ -1416,7 +1435,9 @@ int main(int argc, char** argv)
...
@@ -1416,7 +1435,9 @@ int main(int argc, char** argv)
switch
(
q
->
type
)
{
switch
(
q
->
type
)
{
case
Q_CONNECT
:
do_connect
(
q
);
break
;
case
Q_CONNECT
:
do_connect
(
q
);
break
;
case
Q_CONNECTION
:
select_connection
(
q
);
break
;
case
Q_CONNECTION
:
select_connection
(
q
);
break
;
case
Q_DISCONNECT
:
close_connection
(
q
);
break
;
case
Q_DISCONNECT
:
case
Q_DIRTY_CLOSE
:
close_connection
(
q
);
break
;
case
Q_SOURCE
:
do_source
(
q
);
break
;
case
Q_SOURCE
:
do_source
(
q
);
break
;
case
Q_SLEEP
:
do_sleep
(
q
);
break
;
case
Q_SLEEP
:
do_sleep
(
q
);
break
;
case
Q_INC
:
do_inc
(
q
);
break
;
case
Q_INC
:
do_inc
(
q
);
break
;
...
@@ -1425,15 +1446,25 @@ int main(int argc, char** argv)
...
@@ -1425,15 +1446,25 @@ int main(int argc, char** argv)
case
Q_SYSTEM
:
do_system
(
q
);
break
;
case
Q_SYSTEM
:
do_system
(
q
);
break
;
case
Q_LET
:
do_let
(
q
);
break
;
case
Q_LET
:
do_let
(
q
);
break
;
case
Q_QUERY
:
case
Q_QUERY
:
case
Q_REAP
:
{
{
int
flags
=
QUERY_REAP
;
if
(
q
->
type
==
Q_QUERY
)
flags
|=
QUERY_SEND
;
if
(
save_file
[
0
])
if
(
save_file
[
0
])
{
{
strmov
(
q
->
record_file
,
save_file
);
strmov
(
q
->
record_file
,
save_file
);
q
->
require_file
=
require_file
;
q
->
require_file
=
require_file
;
save_file
[
0
]
=
0
;
save_file
[
0
]
=
0
;
}
}
error
|=
run_query
(
&
cur_con
->
mysql
,
q
);
break
;
error
|=
run_query
(
&
cur_con
->
mysql
,
q
,
QUERY_SEND
|
QUERY_REAP
);
break
;
}
}
case
Q_SEND
:
q
->
query
+=
q
->
first_word_len
;
error
|=
run_query
(
&
cur_con
->
mysql
,
q
,
QUERY_SEND
);
break
;
case
Q_RESULT
:
case
Q_RESULT
:
get_file_name
(
save_file
,
q
);
get_file_name
(
save_file
,
q
);
require_file
=
0
;
require_file
=
0
;
...
...
include/mysql.h
View file @
6f3984bb
...
@@ -229,8 +229,12 @@ MYSQL * STDCALL mysql_real_connect(MYSQL *mysql, const char *host,
...
@@ -229,8 +229,12 @@ MYSQL * STDCALL mysql_real_connect(MYSQL *mysql, const char *host,
void
STDCALL
mysql_close
(
MYSQL
*
sock
);
void
STDCALL
mysql_close
(
MYSQL
*
sock
);
int
STDCALL
mysql_select_db
(
MYSQL
*
mysql
,
const
char
*
db
);
int
STDCALL
mysql_select_db
(
MYSQL
*
mysql
,
const
char
*
db
);
int
STDCALL
mysql_query
(
MYSQL
*
mysql
,
const
char
*
q
);
int
STDCALL
mysql_query
(
MYSQL
*
mysql
,
const
char
*
q
);
int
STDCALL
mysql_send_query
(
MYSQL
*
mysql
,
const
char
*
q
);
int
STDCALL
mysql_reap_query
(
MYSQL
*
mysql
);
int
STDCALL
mysql_real_query
(
MYSQL
*
mysql
,
const
char
*
q
,
int
STDCALL
mysql_real_query
(
MYSQL
*
mysql
,
const
char
*
q
,
unsigned
int
length
);
unsigned
int
length
);
int
STDCALL
mysql_real_send_query
(
MYSQL
*
mysql
,
const
char
*
q
,
unsigned
int
len
);
int
STDCALL
mysql_create_db
(
MYSQL
*
mysql
,
const
char
*
DB
);
int
STDCALL
mysql_create_db
(
MYSQL
*
mysql
,
const
char
*
DB
);
int
STDCALL
mysql_drop_db
(
MYSQL
*
mysql
,
const
char
*
DB
);
int
STDCALL
mysql_drop_db
(
MYSQL
*
mysql
,
const
char
*
DB
);
int
STDCALL
mysql_shutdown
(
MYSQL
*
mysql
);
int
STDCALL
mysql_shutdown
(
MYSQL
*
mysql
);
...
...
libmysql/libmysql.c
View file @
6f3984bb
...
@@ -1708,6 +1708,71 @@ mysql_query(MYSQL *mysql, const char *query)
...
@@ -1708,6 +1708,71 @@ mysql_query(MYSQL *mysql, const char *query)
return
mysql_real_query
(
mysql
,
query
,
(
uint
)
strlen
(
query
));
return
mysql_real_query
(
mysql
,
query
,
(
uint
)
strlen
(
query
));
}
}
int
STDCALL
mysql_send_query
(
MYSQL
*
mysql
,
const
char
*
query
)
{
return
mysql_real_send_query
(
mysql
,
query
,
strlen
(
query
));
}
/* send the query and return so we can do something else */
/* needs to be followed by mysql_reap_query() when we want to
finish processing it
*/
int
STDCALL
mysql_real_send_query
(
MYSQL
*
mysql
,
const
char
*
query
,
uint
len
)
{
return
simple_command
(
mysql
,
COM_QUERY
,
query
,
len
,
1
);
}
int
STDCALL
mysql_reap_query
(
MYSQL
*
mysql
)
{
uchar
*
pos
;
ulong
field_count
;
MYSQL_DATA
*
fields
;
uint
len
;
DBUG_ENTER
(
"mysql_reap_query"
);
DBUG_PRINT
(
"enter"
,(
"handle: %lx"
,
mysql
));
if
((
len
=
net_safe_read
(
mysql
))
==
packet_error
)
DBUG_RETURN
(
-
1
);
free_old_query
(
mysql
);
/* Free old result */
get_info:
pos
=
(
uchar
*
)
mysql
->
net
.
read_pos
;
if
((
field_count
=
net_field_length
(
&
pos
))
==
0
)
{
mysql
->
affected_rows
=
net_field_length_ll
(
&
pos
);
mysql
->
insert_id
=
net_field_length_ll
(
&
pos
);
if
(
mysql
->
server_capabilities
&
CLIENT_TRANSACTIONS
)
{
mysql
->
server_status
=
uint2korr
(
pos
);
pos
+=
2
;
}
if
(
pos
<
mysql
->
net
.
read_pos
+
len
&&
net_field_length
(
&
pos
))
mysql
->
info
=
(
char
*
)
pos
;
DBUG_RETURN
(
0
);
}
if
(
field_count
==
NULL_LENGTH
)
/* LOAD DATA LOCAL INFILE */
{
int
error
=
send_file_to_server
(
mysql
,(
char
*
)
pos
);
if
((
len
=
net_safe_read
(
mysql
))
==
packet_error
||
error
)
DBUG_RETURN
(
-
1
);
goto
get_info
;
/* Get info packet */
}
if
(
!
(
mysql
->
server_status
&
SERVER_STATUS_AUTOCOMMIT
))
mysql
->
server_status
|=
SERVER_STATUS_IN_TRANS
;
mysql
->
extra_info
=
net_field_length_ll
(
&
pos
);
/* Maybe number of rec */
if
(
!
(
fields
=
read_rows
(
mysql
,(
MYSQL_FIELD
*
)
0
,
5
)))
DBUG_RETURN
(
-
1
);
if
(
!
(
mysql
->
fields
=
unpack_fields
(
fields
,
&
mysql
->
field_alloc
,
(
uint
)
field_count
,
0
,
(
my_bool
)
test
(
mysql
->
server_capabilities
&
CLIENT_LONG_FLAG
))))
DBUG_RETURN
(
-
1
);
mysql
->
status
=
MYSQL_STATUS_GET_RESULT
;
mysql
->
field_count
=
field_count
;
DBUG_RETURN
(
0
);
}
int
STDCALL
int
STDCALL
mysql_real_query
(
MYSQL
*
mysql
,
const
char
*
query
,
uint
length
)
mysql_real_query
(
MYSQL
*
mysql
,
const
char
*
query
,
uint
length
)
...
...
mysql-test/r/dirty-close.result
0 → 100644
View file @
6f3984bb
n
1
2
3
mysql-test/t/dirty-close.test
0 → 100644
View file @
6f3984bb
connect
(
con1
,
localhost
,
root
,,
test
,
0
,
mysql
-
master
.
sock
);
connect
(
con2
,
localhost
,
root
,,
test
,
0
,
mysql
-
master
.
sock
);
connection
con1
;
dirty_close
con1
;
connection
con2
;
drop
table
if
exists
t1
;
create
table
t1
(
n
int
);
insert
into
t1
values
(
1
),(
2
),(
3
);
select
*
from
t1
;
drop
table
t1
;
mysql-test/t/rpl000001.test
View file @
6f3984bb
...
@@ -5,6 +5,8 @@ drop table if exists t1;
...
@@ -5,6 +5,8 @@ drop table if exists t1;
create
table
t1
(
word
char
(
20
)
not
null
);
create
table
t1
(
word
char
(
20
)
not
null
);
load
data
infile
'../../std_data/words.dat'
into
table
t1
;
load
data
infile
'../../std_data/words.dat'
into
table
t1
;
drop
table
if
exists
foo
;
drop
table
if
exists
foo
;
set
password
=
password
(
'foo'
);
set
password
=
password
(
''
);
create
table
foo
(
n
int
);
create
table
foo
(
n
int
);
insert
into
foo
values
(
1
),(
2
);
insert
into
foo
values
(
1
),(
2
);
save_master_pos
;
save_master_pos
;
...
...
mysys/my_vsnprintf.c
View file @
6f3984bb
...
@@ -24,7 +24,6 @@
...
@@ -24,7 +24,6 @@
int
my_vsnprintf
(
char
*
to
,
size_t
n
,
const
char
*
fmt
,
va_list
ap
)
int
my_vsnprintf
(
char
*
to
,
size_t
n
,
const
char
*
fmt
,
va_list
ap
)
{
{
char
*
start
=
to
,
*
end
=
to
+
n
-
1
;
char
*
start
=
to
,
*
end
=
to
+
n
-
1
;
for
(;
*
fmt
;
fmt
++
)
for
(;
*
fmt
;
fmt
++
)
{
{
if
(
fmt
[
0
]
!=
'%'
)
if
(
fmt
[
0
]
!=
'%'
)
...
@@ -38,10 +37,14 @@ int my_vsnprintf(char *to, size_t n, const char* fmt, va_list ap)
...
@@ -38,10 +37,14 @@ int my_vsnprintf(char *to, size_t n, const char* fmt, va_list ap)
fmt
++
;
fmt
++
;
while
(
isdigit
(
*
fmt
)
||
*
fmt
==
'.'
||
*
fmt
==
'-'
)
while
(
isdigit
(
*
fmt
)
||
*
fmt
==
'.'
||
*
fmt
==
'-'
)
fmt
++
;
fmt
++
;
if
(
*
fmt
==
'l'
)
fmt
++
;
if
(
*
fmt
==
's'
)
/* String parameter */
if
(
*
fmt
==
's'
)
/* String parameter */
{
{
reg2
char
*
par
=
va_arg
(
ap
,
char
*
);
reg2
char
*
par
=
va_arg
(
ap
,
char
*
);
uint
plen
=
(
uint
)
strlen
(
par
);
uint
plen
;
if
(
!
par
)
par
=
(
char
*
)
"(null)"
;
plen
=
(
uint
)
strlen
(
par
);
if
((
uint
)
(
end
-
to
)
>
plen
)
/* Replace if possible */
if
((
uint
)
(
end
-
to
)
>
plen
)
/* Replace if possible */
{
{
to
=
strmov
(
to
,
par
);
to
=
strmov
(
to
,
par
);
...
@@ -68,3 +71,35 @@ int my_vsnprintf(char *to, size_t n, const char* fmt, va_list ap)
...
@@ -68,3 +71,35 @@ int my_vsnprintf(char *to, size_t n, const char* fmt, va_list ap)
*
to
=
'\0'
;
/* End of errmessage */
*
to
=
'\0'
;
/* End of errmessage */
return
(
uint
)
(
to
-
start
);
return
(
uint
)
(
to
-
start
);
}
}
#ifdef MAIN
static
void
my_printf
(
const
char
*
fmt
,
...)
{
char
buf
[
32
];
int
n
;
va_list
ar
;
va_start
(
ar
,
fmt
);
n
=
my_vsnprintf
(
buf
,
sizeof
(
buf
),
fmt
,
ar
);
printf
(
buf
);
printf
(
"n=%d, strlen=%d
\n
"
,
n
,
strlen
(
buf
));
va_end
(
ar
);
}
int
main
()
{
my_printf
(
"Hello
\n
"
);
my_printf
(
"Hello int, %d
\n
"
,
1
);
my_printf
(
"Hello string '%s'
\n
"
,
"I am a string"
);
my_printf
(
"Hello hack hack hack hack hack hack hack %d
\n
"
,
1
);
my_printf
(
"Hello %d hack %d
\n
"
,
1
,
4
);
my_printf
(
"Hello %d hack hack hack hack hack %d
\n
"
,
1
,
4
);
my_printf
(
"Hello '%s' hhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhh
\n
"
,
"hack"
);
my_printf
(
"Hello hhhhhhhhhhhhhh %d sssssssssssssss
\n
"
,
1
);
my_printf
(
"Hello %u
\n
"
,
1
);
my_printf
(
"conn %ld to: '%-.64s' user: '%-.32s' host:\
`%-.64s' (%-.64s)"
,
1
,
0
,
0
,
0
,
0
);
return
0
;
}
#endif
mysys/test_vsnprintf.c
deleted
100644 → 0
View file @
62771338
/* Copyright (C) 2000 MySQL AB & MySQL Finland AB & TCX DataKonsult AB
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Library General Public
License as published by the Free Software Foundation; either
version 2 of the License, or (at your option) any later version.
This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Library General Public License for more details.
You should have received a copy of the GNU Library General Public
License along with this library; if not, write to the Free
Software Foundation, Inc., 59 Temple Place - Suite 330, Boston,
MA 02111-1307, USA */
#include "mysys_priv.h"
static
void
my_printf
(
const
char
*
fmt
,
...)
{
char
buf
[
32
];
int
n
;
va_list
ar
;
va_start
(
ar
,
fmt
);
n
=
my_vsnprintf
(
buf
,
sizeof
(
buf
),
fmt
,
ar
);
printf
(
buf
);
printf
(
"n=%d, strlen=%d
\n
"
,
n
,
strlen
(
buf
));
va_end
(
ar
);
}
int
main
()
{
my_printf
(
"Hello
\n
"
);
my_printf
(
"Hello int, %d
\n
"
,
1
);
my_printf
(
"Hello string '%s'
\n
"
,
"I am a string"
);
my_printf
(
"Hello hack hack hack hack hack hack hack %d
\n
"
,
1
);
my_printf
(
"Hello %d hack %d
\n
"
,
1
,
4
);
my_printf
(
"Hello %d hack hack hack hack hack %d
\n
"
,
1
,
4
);
my_printf
(
"Hello '%s' hhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhh
\n
"
,
"hack"
);
my_printf
(
"Hello hhhhhhhhhhhhhh %d sssssssssssssss
\n
"
,
1
);
my_printf
(
"Hello %u
\n
"
,
1
);
return
0
;
}
sql/ha_myisam.cc
View file @
6f3984bb
...
@@ -1136,19 +1136,9 @@ int ha_myisam::ft_read(byte * buf)
...
@@ -1136,19 +1136,9 @@ int ha_myisam::ft_read(byte * buf)
thread_safe_increment
(
ha_read_next_count
,
&
LOCK_status
);
// why ?
thread_safe_increment
(
ha_read_next_count
,
&
LOCK_status
);
// why ?
if
((
error
=
ft_read_next
((
FT_DOCLIST
*
)
ft_handler
,(
char
*
)
buf
)))
error
=
ft_read_next
((
FT_DOCLIST
*
)
ft_handler
,(
char
*
)
buf
);
ft_handler
=
NULL
;
// Magic here ! See Item_func_match::val()
// and ha_myisam::index_init()
table
->
status
=
error
?
STATUS_NOT_FOUND
:
0
;
table
->
status
=
error
?
STATUS_NOT_FOUND
:
0
;
return
error
;
return
error
;
}
}
int
ha_myisam
::
index_init
(
uint
idx
)
{
if
(
idx
!=
active_index
)
ft_handler
=
NULL
;
// Magic here !
active_index
=
idx
;
return
0
;
}
sql/ha_myisam.h
View file @
6f3984bb
...
@@ -71,7 +71,7 @@ class ha_myisam: public handler
...
@@ -71,7 +71,7 @@ class ha_myisam: public handler
int
index_first
(
byte
*
buf
);
int
index_first
(
byte
*
buf
);
int
index_last
(
byte
*
buf
);
int
index_last
(
byte
*
buf
);
int
index_next_same
(
byte
*
buf
,
const
byte
*
key
,
uint
keylen
);
int
index_next_same
(
byte
*
buf
,
const
byte
*
key
,
uint
keylen
);
int
index_
init
(
uint
idx
);
int
index_
end
()
{
ft_handler
=
NULL
;
return
0
;
}
int
ft_init
()
int
ft_init
()
{
if
(
!
ft_handler
)
return
1
;
ft_reinit_search
(
ft_handler
);
return
0
;
}
{
if
(
!
ft_handler
)
return
1
;
ft_reinit_search
(
ft_handler
);
return
0
;
}
void
*
ft_init_ext
(
uint
inx
,
const
byte
*
key
,
uint
keylen
,
bool
presort
)
void
*
ft_init_ext
(
uint
inx
,
const
byte
*
key
,
uint
keylen
,
bool
presort
)
...
...
sql/sql_acl.cc
View file @
6f3984bb
...
@@ -781,8 +781,8 @@ bool change_password(THD *thd, const char *host, const char *user,
...
@@ -781,8 +781,8 @@ bool change_password(THD *thd, const char *host, const char *user,
length
=
(
uint
)
strlen
(
new_password
);
length
=
(
uint
)
strlen
(
new_password
);
new_password
[
length
&
16
]
=
0
;
new_password
[
length
&
16
]
=
0
;
if
(
!
thd
||
strcmp
(
thd
->
user
,
user
)
||
if
(
!
thd
||
(
!
thd
->
slave_thread
&&
(
strcmp
(
thd
->
user
,
user
)
||
my_strcasecmp
(
host
,
thd
->
host
?
thd
->
host
:
thd
->
ip
))
my_strcasecmp
(
host
,
thd
->
host
?
thd
->
host
:
thd
->
ip
))
))
{
{
if
(
check_access
(
thd
,
UPDATE_ACL
,
"mysql"
,
0
,
1
))
if
(
check_access
(
thd
,
UPDATE_ACL
,
"mysql"
,
0
,
1
))
return
1
;
return
1
;
...
...
sql/sql_parse.cc
View file @
6f3984bb
...
@@ -408,7 +408,7 @@ pthread_handler_decl(handle_one_connection,arg)
...
@@ -408,7 +408,7 @@ pthread_handler_decl(handle_one_connection,arg)
{
{
sql_print_error
(
ER
(
ER_NEW_ABORTING_CONNECTION
),
sql_print_error
(
ER
(
ER_NEW_ABORTING_CONNECTION
),
thd
->
thread_id
,(
thd
->
db
?
thd
->
db
:
"unconnected"
),
thd
->
thread_id
,(
thd
->
db
?
thd
->
db
:
"unconnected"
),
thd
->
user
,
thd
->
user
?
thd
->
user
:
"unauthenticated"
,
(
thd
->
host
?
thd
->
host
:
thd
->
ip
?
thd
->
ip
:
"unknown"
),
(
thd
->
host
?
thd
->
host
:
thd
->
ip
?
thd
->
ip
:
"unknown"
),
(
net
->
last_errno
?
ER
(
net
->
last_errno
)
:
(
net
->
last_errno
?
ER
(
net
->
last_errno
)
:
ER
(
ER_UNKNOWN_ERROR
)));
ER
(
ER_UNKNOWN_ERROR
)));
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment