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
ec45217c
Commit
ec45217c
authored
Mar 04, 2006
by
ingo@mysql.com
Browse files
Options
Browse Files
Download
Plain Diff
Merge mysql.com:/home/mydev/mysql-5.0
into mysql.com:/home/mydev/mysql-5.0-bug11527
parents
b9ed183a
33dfa2a9
Changes
8
Hide whitespace changes
Inline
Side-by-side
Showing
8 changed files
with
224 additions
and
95 deletions
+224
-95
client/mysqltest.c
client/mysqltest.c
+20
-19
mysql-test/README.stress
mysql-test/README.stress
+59
-55
mysql-test/mysql-stress-test.pl
mysql-test/mysql-stress-test.pl
+11
-10
mysql-test/r/sp.result
mysql-test/r/sp.result
+56
-0
mysql-test/t/sp.test
mysql-test/t/sp.test
+55
-0
sql/sp_pcontext.cc
sql/sp_pcontext.cc
+12
-4
sql/sp_pcontext.h
sql/sp_pcontext.h
+7
-3
sql/sql_yacc.yy
sql/sql_yacc.yy
+4
-4
No files found.
client/mysqltest.c
View file @
ec45217c
...
@@ -1647,19 +1647,20 @@ int do_sleep(struct st_query *query, my_bool real_sleep)
...
@@ -1647,19 +1647,20 @@ int do_sleep(struct st_query *query, my_bool real_sleep)
char
*
p
=
query
->
first_argument
;
char
*
p
=
query
->
first_argument
;
char
*
sleep_start
,
*
sleep_end
=
query
->
end
;
char
*
sleep_start
,
*
sleep_end
=
query
->
end
;
double
sleep_val
;
double
sleep_val
;
char
*
cmd
=
(
real_sleep
?
"real_sleep"
:
"sleep"
);
while
(
my_isspace
(
charset_info
,
*
p
))
while
(
my_isspace
(
charset_info
,
*
p
))
p
++
;
p
++
;
if
(
!*
p
)
if
(
!*
p
)
die
(
"Missing argument to %
s"
,
cmd
);
die
(
"Missing argument to %
.*s"
,
query
->
first_word_len
,
query
->
query
);
sleep_start
=
p
;
sleep_start
=
p
;
/* Check that arg starts with a digit, not handled by my_strtod */
/* Check that arg starts with a digit, not handled by my_strtod */
if
(
!
my_isdigit
(
charset_info
,
*
sleep_start
))
if
(
!
my_isdigit
(
charset_info
,
*
sleep_start
))
die
(
"Invalid argument to %s
\"
%s
\"
"
,
cmd
,
query
->
first_argument
);
die
(
"Invalid argument to %.*s
\"
%s
\"
"
,
query
->
first_word_len
,
query
->
query
,
query
->
first_argument
);
sleep_val
=
my_strtod
(
sleep_start
,
&
sleep_end
,
&
error
);
sleep_val
=
my_strtod
(
sleep_start
,
&
sleep_end
,
&
error
);
if
(
error
)
if
(
error
)
die
(
"Invalid argument to %s
\"
%s
\"
"
,
cmd
,
query
->
first_argument
);
die
(
"Invalid argument to %.*s
\"
%s
\"
"
,
query
->
first_word_len
,
query
->
query
,
query
->
first_argument
);
/* Fixed sleep time selected by --sleep option */
/* Fixed sleep time selected by --sleep option */
if
(
opt_sleep
&&
!
real_sleep
)
if
(
opt_sleep
&&
!
real_sleep
)
...
@@ -2529,8 +2530,8 @@ my_bool end_of_query(int c)
...
@@ -2529,8 +2530,8 @@ my_bool end_of_query(int c)
size size of the buffer i.e max size to read
size size of the buffer i.e max size to read
DESCRIPTION
DESCRIPTION
This function actually reads several lines an adds them to the
This function actually reads several lines an
d
adds them to the
buffer buf. It
will continue
to read until it finds what it believes
buffer buf. It
continues
to read until it finds what it believes
is a complete query.
is a complete query.
Normally that means it will read lines until it reaches the
Normally that means it will read lines until it reaches the
...
@@ -3760,7 +3761,7 @@ static void handle_no_error(struct st_query *q)
...
@@ -3760,7 +3761,7 @@ static void handle_no_error(struct st_query *q)
command - currrent command pointer
command - currrent command pointer
query - query string to execute
query - query string to execute
query_len - length query string to execute
query_len - length query string to execute
ds - output buffer wher
t
e to store result form query
ds - output buffer where to store result form query
RETURN VALUE
RETURN VALUE
error - function will not return
error - function will not return
...
@@ -3778,7 +3779,7 @@ static void run_query_stmt(MYSQL *mysql, struct st_query *command,
...
@@ -3778,7 +3779,7 @@ static void run_query_stmt(MYSQL *mysql, struct st_query *command,
DBUG_PRINT
(
"query"
,
(
"'%-.60s'"
,
query
));
DBUG_PRINT
(
"query"
,
(
"'%-.60s'"
,
query
));
/*
/*
Init a new stmt if it's not alre
day one created for this connecto
on
Init a new stmt if it's not alre
ady one created for this connecti
on
*/
*/
if
(
!
(
stmt
=
cur_con
->
stmt
))
if
(
!
(
stmt
=
cur_con
->
stmt
))
{
{
...
@@ -3867,7 +3868,7 @@ static void run_query_stmt(MYSQL *mysql, struct st_query *command,
...
@@ -3867,7 +3868,7 @@ static void run_query_stmt(MYSQL *mysql, struct st_query *command,
goto
end
;
goto
end
;
}
}
/* If we got here the statement was both executed and read succe
e
sfully */
/* If we got here the statement was both executed and read succe
s
sfully */
handle_no_error
(
command
);
handle_no_error
(
command
);
if
(
!
disable_result_log
)
if
(
!
disable_result_log
)
{
{
...
@@ -4594,7 +4595,7 @@ int main(int argc, char **argv)
...
@@ -4594,7 +4595,7 @@ int main(int argc, char **argv)
case
Q_QUERY_HORIZONTAL
:
case
Q_QUERY_HORIZONTAL
:
{
{
my_bool
old_display_result_vertically
=
display_result_vertically
;
my_bool
old_display_result_vertically
=
display_result_vertically
;
/* fix up query pointer if this is
*
first iteration for this line */
/* fix up query pointer if this is first iteration for this line */
if
(
q
->
query
==
q
->
query_buf
)
if
(
q
->
query
==
q
->
query_buf
)
q
->
query
+=
q
->
first_word_len
+
1
;
q
->
query
+=
q
->
first_word_len
+
1
;
display_result_vertically
=
(
q
->
type
==
Q_QUERY_VERTICAL
);
display_result_vertically
=
(
q
->
type
==
Q_QUERY_VERTICAL
);
...
@@ -4639,15 +4640,15 @@ int main(int argc, char **argv)
...
@@ -4639,15 +4640,15 @@ int main(int argc, char **argv)
case
Q_SEND
:
case
Q_SEND
:
if
(
!
q
->
query
[
q
->
first_word_len
])
if
(
!
q
->
query
[
q
->
first_word_len
])
{
{
/* This happens when we use 'send' on it
'
s own line */
/* This happens when we use 'send' on its own line */
q_send_flag
=
1
;
q_send_flag
=
1
;
break
;
break
;
}
}
/* fix up query pointer if this is
*
first iteration for this line */
/* fix up query pointer if this is first iteration for this line */
if
(
q
->
query
==
q
->
query_buf
)
if
(
q
->
query
==
q
->
query_buf
)
q
->
query
+=
q
->
first_word_len
;
q
->
query
+=
q
->
first_word_len
;
/*
/*
run_query() can execute a query partially, depending on the flags
run_query() can execute a query partially, depending on the flags
.
QUERY_SEND flag without QUERY_REAP tells it to just send the
QUERY_SEND flag without QUERY_REAP tells it to just send the
query and read the result some time later when reap instruction
query and read the result some time later when reap instruction
is given on this connection.
is given on this connection.
...
@@ -4731,7 +4732,7 @@ int main(int argc, char **argv)
...
@@ -4731,7 +4732,7 @@ int main(int argc, char **argv)
break
;
break
;
case
Q_ENABLE_PARSING
:
case
Q_ENABLE_PARSING
:
/*
/*
Ensure we don't get parsing_disabled < 0 as this would accidently
Ensure we don't get parsing_disabled < 0 as this would accident
al
ly
disable code we don't want to have disabled
disable code we don't want to have disabled
*/
*/
if
(
parsing_disabled
>
0
)
if
(
parsing_disabled
>
0
)
...
@@ -4777,9 +4778,9 @@ int main(int argc, char **argv)
...
@@ -4777,9 +4778,9 @@ int main(int argc, char **argv)
start_lineno
=
0
;
start_lineno
=
0
;
/*
/*
The whole test has been executed _sucessfully_
The whole test has been executed _sucessfully_
.
Time to compare result or save it to record file
Time to compare result or save it to record file
.
The entire output from test is now kept in ds_res
The entire output from test is now kept in ds_res
.
*/
*/
if
(
ds_res
.
length
)
if
(
ds_res
.
length
)
{
{
...
@@ -5509,7 +5510,7 @@ static int get_next_bit(REP_SET *set,uint lastpos)
...
@@ -5509,7 +5510,7 @@ static int get_next_bit(REP_SET *set,uint lastpos)
}
}
/* find if there is a same set in sets. If there is, use it and
/* find if there is a same set in sets. If there is, use it and
free given set, else put in given set in sets and return it
'
s
free given set, else put in given set in sets and return its
position */
position */
static
int
find_set
(
REP_SETS
*
sets
,
REP_SET
*
find
)
static
int
find_set
(
REP_SETS
*
sets
,
REP_SET
*
find
)
...
@@ -5528,7 +5529,7 @@ static int find_set(REP_SETS *sets,REP_SET *find)
...
@@ -5528,7 +5529,7 @@ static int find_set(REP_SETS *sets,REP_SET *find)
/* find if there is a found_set with same table_offset & found_offset
/* find if there is a found_set with same table_offset & found_offset
If there is return offset to it, else add new offset and return pos.
If there is return offset to it, else add new offset and return pos.
Pos returned is -offset-2 in found_set_structure because it
's
is
Pos returned is -offset-2 in found_set_structure because it is
saved in set->next and set->next[] >= 0 points to next set and
saved in set->next and set->next[] >= 0 points to next set and
set->next[] == -1 is reserved for end without replaces.
set->next[] == -1 is reserved for end without replaces.
*/
*/
...
...
mysql-test/README.stress
View file @
ec45217c
...
@@ -2,114 +2,118 @@
...
@@ -2,114 +2,118 @@
Overview
Overview
--------
--------
Stress script is designed to perform testsing of mysql
server in
The stress script is designed to perform testing of the MySQL
server in
multi-threa
d environment.
a multi-threade
d environment.
Stress script allows:
All functionality regarding stress testing is implemented in the
mysql-stress-test.pl script.
The stress script allows:
- to use for stress testing mysqltest binary as test engine
- To stress test the mysqltest binary test engine.
- to use for stress testing both regular test suite and any
- To stress test the regular test suite and any additional test suites
additional test suites (e.g. mysql-test-extra-5.0)
(such as mysql-test-extra-5.0).
- to specify files with lists of tests both for initialization of
- To specify files with lists of tests both for initialization of
stress db and for further testing itself
stress db and for further testing itself.
- to define number of threads that will be concurrently used in testing
- To define the number of threads to be concurrently used in testing.
- to define limitations for test run. e.g. number of tests or loops
- To define limitations for the test run. such as the number of tests or
for execution or duration of testing, delay between test executions, etc.
loops for execution or duration of testing, delay between test
- to get readable log file which can be used for identification of
executions, and so forth.
errors arose during testing
- To get a readable log file that can be used for identification of
errors that occur during testing.
All functionality regarding stress testing was implemeted in
mysql-stress-test.pl script and there are two ways to run stress test:
There are two ways to run the mysql-stress-test.pl script:
- for most cases it is enough to use options below for starting of
- For most cases, it is enough to use the options below for starting
stress test from mysql-test-run wrapper. In this case server will
the stress test from the mysql-test-run wrapper. In this case, the
be run automatically, all preparation steps will be performed
server is run automatically, all preparation steps are performed,
and after that stress test will be started.
and after that the stress test is started.
- in advanced case one can run mysql-stress-test.pl script directly.
- In advanced case, you can run the mysql-stress-test.pl script directly.
But it requires to perform some preparation steps and to specify a
But this requires that you perform some preparation steps and to specify
bunch of options as well so this way may look a bit complicate.
a bunch of options as well, so this invocation method may be a bit
complicated.
Usage
Usage
-----
-----
Below is list of stress test specific options for mysql-test-run
:
The following mysql-test-run options are specific to stress-testing
:
--stress
--stress
Enable stress mode
Enable stress mode
--stress-suite=<suite name>
--stress-suite=<suite name>
Test suite name t
hat will be used in stress testing.
Test suite name t
o use in stress testing. We assume that all suites
We assume that all suites are located in mysql-test/suite directory
are located in the mysql-test/suite directory.
There is one special suite name - <main|default> that corresponds
There is one special suite name - <main|default> that corresponds
to
regular test suite located in
mysql-test directory.
to
the regular test suite located in the
mysql-test directory.
--stress-threads=<number of threads>
--stress-threads=<number of threads>
Number of threads that will be used in stress testing
The number of threads to use in stress testing.
--stress-tests-file=<filename with list of tests>
--stress-tests-file=<filename with list of tests>
Filename with list of tests(without .test suffix) that will be used
in
The file that contains the list of tests (without .test suffix) to use
in
stress testing.
Default filename is stress_tests.txt and
default
stress testing.
The default filename is stress_tests.txt and the
default
location of this file is suite/<suite name>/stress_tests.txt
location of this file is suite/<suite name>/stress_tests.txt
--stress-init-file=<filename with list of tests>
--stress-init-file=<filename with list of tests>
Filename with list of tests(without .test suffix) that will be used
in
The file that contains list of tests (without .test suffix) to use
in
stress testing for initialization of stress db. These tests will be
stress testing for initialization of
the
stress db. These tests will be
executed only once before starting
of test itself. D
efault filename
executed only once before starting
the test itself. The d
efault filename
is stress_init.txt and default location of this file is
is stress_init.txt and
the
default location of this file is
suite/<suite name>/stress_init.txt
suite/<suite name>/stress_init.txt
--stress-mode=<method which will be used for choosing tests from the list>
--stress-mode=<method which will be used for choosing tests from the list>
Possible values are: random(default), seq
Possible values are: random(default), seq
There are two possible modes
which affect order of selecting of tests
There are two possible modes
that affect the order of test selection
from the list:
from the list:
-
in random mode tests will b
e selected in random order
-
In random mode, tests ar
e selected in random order
-
in seq mode each thread will execute tests in the loop one by one as
-
In seq mode, each thread executes tests in a loop one by one in
they
specified in the list file.
the order
specified in the list file.
--stress-test-count=
<number>
--stress-test-count=<number>
Total number of tests that will be executed concurrently by all threads
Total number of tests that will be executed concurrently by all threads
--stress-loop-count=
<number>
--stress-loop-count=<number>
Total number of loops in seq mode that will be executed concurrently
Total number of loops in seq mode that will be executed concurrently
by all threads
by all threads
--stress-test-duration=
<number>
--stress-test-duration=<number>
Duration of stress testing in seconds
Duration of stress testing in seconds
Examples
Examples
--------
--------
1. Example of
simple command line to start
stress test:
1. Example of
a simple command line to start a
stress test:
mysql-test-run --stress alias
mysql-test-run --stress alias
Runs
stress test with default values for number of threads and number of tests,
Runs
a stress test with default values for number of threads and number
with test 'alias' from suite 'main'.
of tests,
with test 'alias' from suite 'main'.
2. Using in stress testing tests from other suites:
2. Using in stress testing tests from other suites:
- mysql-test-run --stress --stress-threads=10 --stress-test-count=1000 \
- mysql-test-run --stress --stress-threads=10 --stress-test-count=1000 \
--stress-suite=example --stress-tests-file=testslist.txt
--stress-suite=example --stress-tests-file=testslist.txt
Will run stress test with 10 threads, will execute
1000 tests by all
Runs a stress test with 10 threads, executes
1000 tests by all
threads, test
will be used from suite 'example', list of test will be
threads, test
s are used from suite 'example', the list of tests is
taken from file 'testslist.txt'
taken from file 'testslist.txt'
- mysql-test-run --stress --stress-threads=10 --stress-test-count=1000 \
- mysql-test-run --stress --stress-threads=10 --stress-test-count=1000 \
--stress-suite=example sum_distinct
--stress-suite=example sum_distinct
Will run stress test with 10 threads, will execute
1000 tests by all
Runs stress test with 10 threads, executes
1000 tests by all
threads, test
will be used from suite 'example', list of test contains
threads, test
s are used from suite 'example', the list of tests
only one test 'sum_distinct'
contains
only one test 'sum_distinct'
3. Debugging of issues found with stress test
3. Debugging of issues found with stress test
Right now stress test is not fully integrated in mysql-test-run
Right now
, the
stress test is not fully integrated in mysql-test-run
and does not support
--gdb option so to debug issue found with stress
and does not support
the --gdb option. To debug issues found with the
test you have to start separately mysql server under debuger and then
stress test, you must start the MySQL server separately under a debugger
run stress test a
s:
and then run the stress test like thi
s:
- mysql-test-run --extern --stress --stress-threads=10 \
- mysql-test-run --extern --stress --stress-threads=10 \
--stress-test-count=1000 --stress-suite=example \
--stress-test-count=1000 --stress-suite=example \
...
...
mysql-test/mysql-stress-test.pl
View file @
ec45217c
...
@@ -14,16 +14,17 @@
...
@@ -14,16 +14,17 @@
#
#
# Design of stress script should allow one:
# Design of stress script should allow one:
#
#
# - to use for stress testing mysqltest binary as test engine
# - To stress test the mysqltest binary test engine.
# - to use for stress testing both regular test suite and any
# - To stress test the regular test suite and any additional test suites
# additional test suites (e.g. mysql-test-extra-5.0)
# (such as mysql-test-extra-5.0).
# - to specify files with lists of tests both for initialization of
# - To specify files with lists of tests both for initialization of
# stress db and for further testing itself
# stress db and for further testing itself.
# - to define number of threads that will be concurrently used in testing
# - To define the number of threads to be concurrently used in testing.
# - to define limitations for test run. e.g. number of tests or loops
# - To define limitations for the test run. such as the number of tests or
# for execution or duration of testing, delay between test executions, etc.
# loops for execution or duration of testing, delay between test
# - to get readable log file which can be used for identification of
# executions, and so forth.
# errors arose during testing
# - To get a readable log file that can be used for identification of
# errors that occur during testing.
#
#
# Basic scenarios:
# Basic scenarios:
#
#
...
...
mysql-test/r/sp.result
View file @
ec45217c
...
@@ -4801,4 +4801,60 @@ date_format(t3.d, pDateFormat) count(*)
...
@@ -4801,4 +4801,60 @@ date_format(t3.d, pDateFormat) count(*)
2005-02 2
2005-02 2
drop table t3|
drop table t3|
drop procedure bug17476|
drop procedure bug17476|
drop table if exists t3|
drop procedure if exists bug16887|
create table t3 ( c varchar(1) )|
insert into t3 values
(' '),('.'),(';'),(','),('-'),('_'),('('),(')'),('/'),('\\')|
create procedure bug16887()
begin
declare i int default 10;
again:
while i > 0 do
begin
declare breakchar varchar(1);
declare done int default 0;
declare t3_cursor cursor for select c from t3;
declare continue handler for not found set done = 1;
set i = i - 1;
select i;
if i = 3 then
iterate again;
end if;
open t3_cursor;
loop
fetch t3_cursor into breakchar;
if done = 1 then
begin
close t3_cursor;
iterate again;
end;
end if;
end loop;
end;
end while;
end|
call bug16887()|
i
9
i
8
i
7
i
6
i
5
i
4
i
3
i
2
i
1
i
0
drop table t3|
drop procedure bug16887|
drop table t1,t2;
drop table t1,t2;
mysql-test/t/sp.test
View file @
ec45217c
...
@@ -5638,6 +5638,7 @@ drop function bug17615|
...
@@ -5638,6 +5638,7 @@ drop function bug17615|
drop
table
t3
|
drop
table
t3
|
#
# BUG#17476: Stored procedure not returning data when it is called first
# BUG#17476: Stored procedure not returning data when it is called first
# time per connection
# time per connection
#
#
...
@@ -5662,6 +5663,60 @@ drop table t3|
...
@@ -5662,6 +5663,60 @@ drop table t3|
drop
procedure
bug17476
|
drop
procedure
bug17476
|
#
# BUG#16887: Cursor causes server segfault
#
--
disable_warnings
drop
table
if
exists
t3
|
drop
procedure
if
exists
bug16887
|
--
enable_warnings
create
table
t3
(
c
varchar
(
1
)
)
|
insert
into
t3
values
(
' '
),(
'.'
),(
';'
),(
','
),(
'-'
),(
'_'
),(
'('
),(
')'
),(
'/'
),(
'\\'
)
|
create
procedure
bug16887
()
begin
declare
i
int
default
10
;
again
:
while
i
>
0
do
begin
declare
breakchar
varchar
(
1
);
declare
done
int
default
0
;
declare
t3_cursor
cursor
for
select
c
from
t3
;
declare
continue
handler
for
not
found
set
done
=
1
;
set
i
=
i
-
1
;
select
i
;
if
i
=
3
then
iterate
again
;
end
if
;
open
t3_cursor
;
loop
fetch
t3_cursor
into
breakchar
;
if
done
=
1
then
begin
close
t3_cursor
;
iterate
again
;
end
;
end
if
;
end
loop
;
end
;
end
while
;
end
|
call
bug16887
()
|
drop
table
t3
|
drop
procedure
bug16887
|
#
#
# BUG#NNNN: New bug synopsis
# BUG#NNNN: New bug synopsis
#
#
...
...
sql/sp_pcontext.cc
View file @
ec45217c
...
@@ -122,30 +122,38 @@ sp_pcontext::pop_context()
...
@@ -122,30 +122,38 @@ sp_pcontext::pop_context()
}
}
uint
uint
sp_pcontext
::
diff_handlers
(
sp_pcontext
*
ctx
)
sp_pcontext
::
diff_handlers
(
sp_pcontext
*
ctx
,
bool
exclusive
)
{
{
uint
n
=
0
;
uint
n
=
0
;
sp_pcontext
*
pctx
=
this
;
sp_pcontext
*
pctx
=
this
;
sp_pcontext
*
last_ctx
=
NULL
;
while
(
pctx
&&
pctx
!=
ctx
)
while
(
pctx
&&
pctx
!=
ctx
)
{
{
n
+=
pctx
->
m_handlers
;
n
+=
pctx
->
m_handlers
;
last_ctx
=
pctx
;
pctx
=
pctx
->
parent_context
();
pctx
=
pctx
->
parent_context
();
}
}
if
(
pctx
)
if
(
pctx
)
return
n
;
return
(
exclusive
&&
last_ctx
?
n
-
last_ctx
->
m_handlers
:
n
)
;
return
0
;
// Didn't find ctx
return
0
;
// Didn't find ctx
}
}
uint
uint
sp_pcontext
::
diff_cursors
(
sp_pcontext
*
ctx
)
sp_pcontext
::
diff_cursors
(
sp_pcontext
*
ctx
,
bool
exclusive
)
{
{
uint
n
=
0
;
sp_pcontext
*
pctx
=
this
;
sp_pcontext
*
pctx
=
this
;
sp_pcontext
*
last_ctx
=
NULL
;
while
(
pctx
&&
pctx
!=
ctx
)
while
(
pctx
&&
pctx
!=
ctx
)
{
n
+=
pctx
->
m_cursor
.
elements
;
last_ctx
=
pctx
;
pctx
=
pctx
->
parent_context
();
pctx
=
pctx
->
parent_context
();
}
if
(
pctx
)
if
(
pctx
)
return
ctx
->
current_cursors
()
-
pctx
->
current_cursors
(
);
return
(
exclusive
&&
last_ctx
?
n
-
last_ctx
->
m_cursor
.
elements
:
n
);
return
0
;
// Didn't find ctx
return
0
;
// Didn't find ctx
}
}
...
...
sql/sp_pcontext.h
View file @
ec45217c
...
@@ -119,11 +119,15 @@ class sp_pcontext : public Sql_alloc
...
@@ -119,11 +119,15 @@ class sp_pcontext : public Sql_alloc
return
m_parent
;
return
m_parent
;
}
}
/*
Number of handlers/cursors to pop between this context and 'ctx'.
If 'exclusive' is true, don't count the last block we are leaving;
this is used for LEAVE where we will jump to the cpop/hpop instructions.
*/
uint
uint
diff_handlers
(
sp_pcontext
*
ctx
);
diff_handlers
(
sp_pcontext
*
ctx
,
bool
exclusive
);
uint
uint
diff_cursors
(
sp_pcontext
*
ctx
);
diff_cursors
(
sp_pcontext
*
ctx
,
bool
exclusive
);
//
//
...
...
sql/sql_yacc.yy
View file @
ec45217c
...
@@ -2080,10 +2080,10 @@ sp_proc_stmt:
...
@@ -2080,10 +2080,10 @@ sp_proc_stmt:
uint ip= sp->instructions();
uint ip= sp->instructions();
uint n;
uint n;
n= ctx->diff_handlers(lab->ctx
);
n= ctx->diff_handlers(lab->ctx
, TRUE); /* Exclusive the dest. */
if (n)
if (n)
sp->add_instr(new sp_instr_hpop(ip++, ctx, n));
sp->add_instr(new sp_instr_hpop(ip++, ctx, n));
n= ctx->diff_cursors(lab->ctx
);
n= ctx->diff_cursors(lab->ctx
, TRUE); /* Exclusive the dest. */
if (n)
if (n)
sp->add_instr(new sp_instr_cpop(ip++, ctx, n));
sp->add_instr(new sp_instr_cpop(ip++, ctx, n));
i= new sp_instr_jump(ip, ctx);
i= new sp_instr_jump(ip, ctx);
...
@@ -2109,10 +2109,10 @@ sp_proc_stmt:
...
@@ -2109,10 +2109,10 @@ sp_proc_stmt:
uint ip= sp->instructions();
uint ip= sp->instructions();
uint n;
uint n;
n= ctx->diff_handlers(lab->ctx
);
n= ctx->diff_handlers(lab->ctx
, FALSE); /* Inclusive the dest. */
if (n)
if (n)
sp->add_instr(new sp_instr_hpop(ip++, ctx, n));
sp->add_instr(new sp_instr_hpop(ip++, ctx, n));
n= ctx->diff_cursors(lab->ctx
);
n= ctx->diff_cursors(lab->ctx
, FALSE); /* Inclusive the dest. */
if (n)
if (n)
sp->add_instr(new sp_instr_cpop(ip++, ctx, n));
sp->add_instr(new sp_instr_cpop(ip++, ctx, n));
i= new sp_instr_jump(ip, ctx, lab->ip); /* Jump back */
i= new sp_instr_jump(ip, ctx, lab->ip); /* Jump back */
...
...
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