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
71468996
Commit
71468996
authored
Mar 16, 2006
by
msvensson@shellback.(none)
Browse files
Options
Browse Files
Download
Plain Diff
Merge bk-internal.mysql.com:/home/bk/mysql-5.1-new
into shellback.(none):/home/msvensson/mysql/mysql-5.1
parents
f8ee9e47
8ebf8db6
Changes
11
Show whitespace changes
Inline
Side-by-side
Showing
11 changed files
with
108 additions
and
24 deletions
+108
-24
client/cmakelists.txt
client/cmakelists.txt
+1
-1
extra/cmakelists.txt
extra/cmakelists.txt
+5
-2
libmysql/cmakelists.txt
libmysql/cmakelists.txt
+1
-1
mysql-test/r/events_bugs.result
mysql-test/r/events_bugs.result
+14
-0
mysql-test/t/events_bugs.test
mysql-test/t/events_bugs.test
+21
-0
server-tools/instance-manager/cmakelists.txt
server-tools/instance-manager/cmakelists.txt
+1
-1
sql/cmakelists.txt
sql/cmakelists.txt
+1
-1
sql/event.h
sql/event.h
+43
-5
sql/event_timed.cc
sql/event_timed.cc
+4
-3
sql/sql_parse.cc
sql/sql_parse.cc
+13
-6
sql/sql_yacc.yy
sql/sql_yacc.yy
+4
-4
No files found.
client/cmakelists.txt
View file @
71468996
...
...
@@ -48,7 +48,7 @@ ADD_LIBRARY(mysqlclient ../mysys/array.c ../strings/bchange.c ../strings/bmove.c
../mysys/thr_mutex.c ../mysys/typelib.c ../vio/vio.c ../vio/viosocket.c
../vio/viossl.c ../vio/viosslfactories.c ../strings/xml.c
)
ADD_DEPENDENCIES
(
mysqlclient
comp_er
r
)
ADD_DEPENDENCIES
(
mysqlclient
GenErro
r
)
ADD_EXECUTABLE
(
mysql completion_hash.cc mysql.cc readline.cc sql_string.cc
)
LINK_DIRECTORIES
(
${
MYSQL_BINARY_DIR
}
/mysys
${
MYSQL_BINARY_DIR
}
/zlib
)
TARGET_LINK_LIBRARIES
(
mysql mysqlclient mysys yassl zlib dbug yassl taocrypt wsock32
)
...
...
extra/cmakelists.txt
View file @
71468996
...
...
@@ -16,8 +16,11 @@ ADD_CUSTOM_COMMAND(OUTPUT ${PROJECT_SOURCE_DIR}/include/mysqld_error.h
--name_file=
${
PROJECT_SOURCE_DIR
}
/include/mysqld_ername.h
--state_file=
${
PROJECT_SOURCE_DIR
}
/include/sql_state.h
--in_file=
${
PROJECT_SOURCE_DIR
}
/sql/share/errmsg.txt
MAIN_DEPENDENCY comp_err
DEPENDS
${
PROJECT_SOURCE_DIR
}
/sql/share/errmsg.txt
)
DEPENDS comp_err
${
PROJECT_SOURCE_DIR
}
/sql/share/errmsg.txt
)
ADD_CUSTOM_TARGET
(
GenError
ALL
DEPENDS
${
PROJECT_SOURCE_DIR
}
/include/mysqld_error.h
)
ADD_EXECUTABLE
(
my_print_defaults my_print_defaults.c
)
TARGET_LINK_LIBRARIES
(
my_print_defaults strings mysys dbug taocrypt odbc32 odbccp32 wsock32
)
...
...
libmysql/cmakelists.txt
View file @
71468996
...
...
@@ -45,7 +45,7 @@ ADD_LIBRARY(libmysql MODULE dll.c libmysql.def
../strings/strtoll.c ../strings/strtoull.c ../strings/strxmov.c ../strings/strxnmov.c
../mysys/thr_mutex.c ../mysys/typelib.c ../vio/vio.c ../vio/viosocket.c
../vio/viossl.c ../vio/viosslfactories.c ../strings/xml.c
)
ADD_DEPENDENCIES
(
libmysql dbug vio mysys strings
comp_er
r zlib
)
ADD_DEPENDENCIES
(
libmysql dbug vio mysys strings
GenErro
r zlib
)
TARGET_LINK_LIBRARIES
(
libmysql mysys strings wsock32
)
# ToDo: We should move the mytest.c program out in libmysql/
...
...
mysql-test/r/events_bugs.result
View file @
71468996
create database if not exists events_test;
use events_test;
set @a=3;
CREATE PROCEDURE p_16 () CREATE EVENT e_16 ON SCHEDULE EVERY @a SECOND DO SET @a=5;
call p_16();
"Here we used to crash!"
call p_16();
ERROR HY000: Event 'e_16' already exists
call p_16();
ERROR HY000: Event 'e_16' already exists
DROP EVENT e_16;
CALL p_16();
CALL p_16();
ERROR HY000: Event 'e_16' already exists
DROP PROCEDURE p_16;
DROP EVENT e_16;
set global event_scheduler=0;
"Wait a bit to settle down"
delete from mysql.event;
...
...
mysql-test/t/events_bugs.test
View file @
71468996
create
database
if
not
exists
events_test
;
use
events_test
;
#
# START - BUG#16408: Events: crash for an event in a procedure
#
set
@
a
=
3
;
CREATE
PROCEDURE
p_16
()
CREATE
EVENT
e_16
ON
SCHEDULE
EVERY
@
a
SECOND
DO
SET
@
a
=
5
;
call
p_16
();
--
echo
"Here we used to crash!"
--
error
1516
call
p_16
();
--
error
1516
call
p_16
();
DROP
EVENT
e_16
;
CALL
p_16
();
--
error
1516
CALL
p_16
();
DROP
PROCEDURE
p_16
;
DROP
EVENT
e_16
;
#
# END - BUG#16408: Events: crash for an event in a procedure
#
#
# Start - 16407: Events: Changes in sql_mode won't be taken into account
#
...
...
server-tools/instance-manager/cmakelists.txt
View file @
71468996
...
...
@@ -12,5 +12,5 @@ ADD_EXECUTABLE(mysqlmanager buffer.cc command.cc commands.cc guardian.cc instanc
../../sql/sql_state.c ../../sql-common/client.c ../../libmysql/get_password.c
../../libmysql/errmsg.c
)
ADD_DEPENDENCIES
(
mysqlmanager
comp_er
r
)
ADD_DEPENDENCIES
(
mysqlmanager
GenErro
r
)
TARGET_LINK_LIBRARIES
(
mysqlmanager dbug mysys strings taocrypt vio yassl zlib wsock32
)
sql/cmakelists.txt
View file @
71468996
...
...
@@ -50,7 +50,7 @@ ADD_EXECUTABLE(mysqld ../sql-common/client.c derror.cc des_key_file.cc discover.
${
PROJECT_SOURCE_DIR
}
/sql/handlerton.cc
${
PROJECT_SOURCE_DIR
}
/sql/lex_hash.h
)
TARGET_LINK_LIBRARIES
(
mysqld heap myisam myisammrg innobase mysys yassl zlib dbug yassl taocrypt strings vio regex wsock32
)
ADD_DEPENDENCIES
(
mysqld
comp_er
r
)
ADD_DEPENDENCIES
(
mysqld
GenErro
r
)
# Sql Parser custom command
ADD_CUSTOM_COMMAND
(
...
...
sql/event.h
View file @
71468996
...
...
@@ -40,7 +40,6 @@
#define EVENT_EXEC_NO_MORE (1L << 0)
#define EVENT_NOT_USED (1L << 1)
extern
ulong
opt_event_executor
;
enum
enum_event_on_completion
...
...
@@ -122,6 +121,39 @@ public:
bool
free_sphead_on_delete
;
uint
flags
;
//all kind of purposes
static
void
*
operator
new
(
size_t
size
)
{
void
*
p
;
DBUG_ENTER
(
"Event_timed::new(size)"
);
p
=
my_malloc
(
size
,
MYF
(
0
));
DBUG_PRINT
(
"info"
,
(
"alloc_ptr=0x%lx"
,
p
));
DBUG_RETURN
(
p
);
}
static
void
*
operator
new
(
size_t
size
,
MEM_ROOT
*
mem_root
)
{
return
(
void
*
)
alloc_root
(
mem_root
,
(
uint
)
size
);
}
static
void
operator
delete
(
void
*
ptr
,
size_t
size
)
{
DBUG_ENTER
(
"Event_timed::delete(ptr,size)"
);
DBUG_PRINT
(
"enter"
,
(
"free_ptr=0x%lx"
,
ptr
));
TRASH
(
ptr
,
size
);
my_free
((
gptr
)
ptr
,
MYF
(
0
));
DBUG_VOID_RETURN
;
}
static
void
operator
delete
(
void
*
ptr
,
MEM_ROOT
*
mem_root
)
{
/*
Don't free the memory it will be done by the mem_root but
we need to call the destructor because we free other resources
which are not allocated on the root but on the heap, or we
deinit mutexes.
*/
DBUG_ASSERT
(
0
);
}
Event_timed
()
:
in_spawned_thread
(
0
),
locked_by_thread_id
(
0
),
running
(
0
),
status_changed
(
false
),
last_executed_changed
(
false
),
expression
(
0
),
created
(
0
),
...
...
@@ -137,15 +169,21 @@ public:
~
Event_timed
()
{
pthread_mutex_destroy
(
&
this
->
LOCK_running
);
deinit_mutexes
();
if
(
free_sphead_on_delete
)
free_sp
();
}
void
init
();
void
deinit_mutexes
()
{
pthread_mutex_destroy
(
&
this
->
LOCK_running
);
}
int
init_definer
(
THD
*
thd
);
...
...
sql/event_timed.cc
View file @
71468996
...
...
@@ -1228,12 +1228,12 @@ Event_timed::change_security_context(THD *thd, Security_context *s_ctx,
definer_host
.
str
,
dbname
.
str
))
{
my_error
(
ER_NO_SUCH_USER
,
MYF
(
0
),
definer_user
.
str
,
definer_host
.
str
);
DBUG_RETURN
(
TRUE
);
DBUG_RETURN
(
true
);
}
*
backup
=
thd
->
security_ctx
;
thd
->
security_ctx
=
s_ctx
;
#endif
DBUG_RETURN
(
FALSE
);
DBUG_RETURN
(
false
);
}
...
...
@@ -1368,7 +1368,8 @@ Event_timed::compile(THD *thd, MEM_ROOT *mem_root)
ret
=
0
;
done:
lex
.
et
->
free_sphead_on_delete
=
false
;
delete
lex
.
et
;
lex
.
et
->
deinit_mutexes
();
lex_end
(
&
lex
);
DBUG_PRINT
(
"note"
,
(
"return old data on its place. set back NAMES"
));
...
...
sql/sql_parse.cc
View file @
71468996
...
...
@@ -3804,9 +3804,13 @@ end_with_restore_list:
/* lex->unit.cleanup() is called outside, no need to call it here */
}
while
(
0
);
if
(
!
thd
->
spcont
)
{
lex
->
et
->
free_sphead_on_delete
=
true
;
delete
lex
->
et
;
lex
->
et
=
0
;
lex
->
et
->
free_sp
();
lex
->
et
->
deinit_mutexes
();
}
break
;
}
case
SQLCOM_SHOW_CREATE_EVENT
:
...
...
@@ -5845,7 +5849,9 @@ void mysql_parse(THD *thd, char *inBuf, uint length)
if
(
thd
->
lex
->
et
)
{
thd
->
lex
->
et
->
free_sphead_on_delete
=
true
;
delete
thd
->
lex
->
et
;
/* alloced on thd->mem_root so no real memory free but dtor call */
thd
->
lex
->
et
->
free_sp
();
thd
->
lex
->
et
->
deinit_mutexes
();
thd
->
lex
->
et
=
NULL
;
}
}
...
...
@@ -5886,7 +5892,8 @@ void mysql_parse(THD *thd, char *inBuf, uint length)
if
(
thd
->
lex
->
et
)
{
thd
->
lex
->
et
->
free_sphead_on_delete
=
true
;
delete
thd
->
lex
->
et
;
lex
->
et
->
free_sp
();
lex
->
et
->
deinit_mutexes
();
thd
->
lex
->
et
=
NULL
;
}
}
...
...
sql/sql_yacc.yy
View file @
71468996
...
...
@@ -1275,7 +1275,7 @@ create:
lex->create_info.options= $3;
if (!(lex->et= new Event_timed())) // implicitly calls Event_timed::init()
if (!(lex->et= new
(YYTHD->mem_root)
Event_timed())) // implicitly calls Event_timed::init()
YYABORT;
/*
...
...
@@ -4813,7 +4813,7 @@ alter:
}
lex->spname= 0;//defensive programming
if (!(et= new Event_timed()))// implicitly calls Event_timed::init()
if (!(et= new
(YYTHD->mem_root)
Event_timed()))// implicitly calls Event_timed::init()
YYABORT;
lex->et = et;
...
...
@@ -7717,7 +7717,7 @@ drop:
YYABORT;
}
if (!(lex->et= new Event_timed()))
if (!(lex->et= new
(YYTHD->mem_root)
Event_timed()))
YYABORT;
if (!lex->et_compile_phase)
...
...
@@ -8441,7 +8441,7 @@ show_param:
{
Lex->sql_command = SQLCOM_SHOW_CREATE_EVENT;
Lex->spname= $3;
Lex->et= new Event_timed();
Lex->et= new
(YYTHD->mem_root)
Event_timed();
if (!Lex->et)
YYABORT;
Lex->et->init_definer(YYTHD);
...
...
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