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
f6c3587e
Commit
f6c3587e
authored
Feb 19, 2008
by
acurtis/antony@ltamd64.xiphis.org
Browse files
Options
Browse Files
Download
Plain Diff
Merge xiphis.org:/anubis/antony/work/p1-bug34598.2
into xiphis.org:/anubis/antony/work/p1-bug34598.2.merge.1
parents
364a70ef
118ebdf7
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
42 additions
and
16 deletions
+42
-16
include/mysql/plugin.h
include/mysql/plugin.h
+1
-1
sql/sql_plugin.cc
sql/sql_plugin.cc
+41
-15
No files found.
include/mysql/plugin.h
View file @
f6c3587e
...
@@ -187,7 +187,7 @@ typedef int (*mysql_var_check_func)(MYSQL_THD thd,
...
@@ -187,7 +187,7 @@ typedef int (*mysql_var_check_func)(MYSQL_THD thd,
*/
*/
typedef
void
(
*
mysql_var_update_func
)(
MYSQL_THD
thd
,
typedef
void
(
*
mysql_var_update_func
)(
MYSQL_THD
thd
,
struct
st_mysql_sys_var
*
var
,
struct
st_mysql_sys_var
*
var
,
void
*
var_ptr
,
void
*
save
);
void
*
var_ptr
,
const
void
*
save
);
/* the following declarations are for internal use only */
/* the following declarations are for internal use only */
...
...
sql/sql_plugin.cc
View file @
f6c3587e
...
@@ -2088,35 +2088,35 @@ err:
...
@@ -2088,35 +2088,35 @@ err:
static
void
update_func_bool
(
THD
*
thd
,
struct
st_mysql_sys_var
*
var
,
static
void
update_func_bool
(
THD
*
thd
,
struct
st_mysql_sys_var
*
var
,
void
*
tgt
,
void
*
save
)
void
*
tgt
,
const
void
*
save
)
{
{
*
(
my_bool
*
)
tgt
=
*
(
int
*
)
save
?
1
:
0
;
*
(
my_bool
*
)
tgt
=
*
(
int
*
)
save
?
1
:
0
;
}
}
static
void
update_func_int
(
THD
*
thd
,
struct
st_mysql_sys_var
*
var
,
static
void
update_func_int
(
THD
*
thd
,
struct
st_mysql_sys_var
*
var
,
void
*
tgt
,
void
*
save
)
void
*
tgt
,
const
void
*
save
)
{
{
*
(
int
*
)
tgt
=
*
(
int
*
)
save
;
*
(
int
*
)
tgt
=
*
(
int
*
)
save
;
}
}
static
void
update_func_long
(
THD
*
thd
,
struct
st_mysql_sys_var
*
var
,
static
void
update_func_long
(
THD
*
thd
,
struct
st_mysql_sys_var
*
var
,
void
*
tgt
,
void
*
save
)
void
*
tgt
,
const
void
*
save
)
{
{
*
(
long
*
)
tgt
=
*
(
long
*
)
save
;
*
(
long
*
)
tgt
=
*
(
long
*
)
save
;
}
}
static
void
update_func_longlong
(
THD
*
thd
,
struct
st_mysql_sys_var
*
var
,
static
void
update_func_longlong
(
THD
*
thd
,
struct
st_mysql_sys_var
*
var
,
void
*
tgt
,
void
*
save
)
void
*
tgt
,
const
void
*
save
)
{
{
*
(
longlong
*
)
tgt
=
*
(
ulonglong
*
)
save
;
*
(
longlong
*
)
tgt
=
*
(
ulonglong
*
)
save
;
}
}
static
void
update_func_str
(
THD
*
thd
,
struct
st_mysql_sys_var
*
var
,
static
void
update_func_str
(
THD
*
thd
,
struct
st_mysql_sys_var
*
var
,
void
*
tgt
,
void
*
save
)
void
*
tgt
,
const
void
*
save
)
{
{
char
*
old
=
*
(
char
**
)
tgt
;
char
*
old
=
*
(
char
**
)
tgt
;
*
(
char
**
)
tgt
=
*
(
char
**
)
save
;
*
(
char
**
)
tgt
=
*
(
char
**
)
save
;
...
@@ -2673,7 +2673,8 @@ bool sys_var_pluginvar::check(THD *thd, set_var *var)
...
@@ -2673,7 +2673,8 @@ bool sys_var_pluginvar::check(THD *thd, set_var *var)
void
sys_var_pluginvar
::
set_default
(
THD
*
thd
,
enum_var_type
type
)
void
sys_var_pluginvar
::
set_default
(
THD
*
thd
,
enum_var_type
type
)
{
{
void
*
tgt
,
*
src
;
const
void
*
src
;
void
*
tgt
;
DBUG_ASSERT
(
is_readonly
()
||
plugin_var
->
update
);
DBUG_ASSERT
(
is_readonly
()
||
plugin_var
->
update
);
...
@@ -2686,9 +2687,34 @@ void sys_var_pluginvar::set_default(THD *thd, enum_var_type type)
...
@@ -2686,9 +2687,34 @@ void sys_var_pluginvar::set_default(THD *thd, enum_var_type type)
if
(
plugin_var
->
flags
&
PLUGIN_VAR_THDLOCAL
)
if
(
plugin_var
->
flags
&
PLUGIN_VAR_THDLOCAL
)
{
{
src
=
((
int
*
)
(
plugin_var
+
1
)
+
1
);
if
(
type
!=
OPT_GLOBAL
)
if
(
type
!=
OPT_GLOBAL
)
src
=
real_value_ptr
(
thd
,
OPT_GLOBAL
);
src
=
real_value_ptr
(
thd
,
OPT_GLOBAL
);
else
switch
(
plugin_var
->
flags
&
PLUGIN_VAR_TYPEMASK
)
{
case
PLUGIN_VAR_INT
:
src
=
&
((
thdvar_uint_t
*
)
plugin_var
)
->
def_val
;
break
;
case
PLUGIN_VAR_LONG
:
src
=
&
((
thdvar_ulong_t
*
)
plugin_var
)
->
def_val
;
break
;
case
PLUGIN_VAR_LONGLONG
:
src
=
&
((
thdvar_ulonglong_t
*
)
plugin_var
)
->
def_val
;
break
;
case
PLUGIN_VAR_ENUM
:
src
=
&
((
thdvar_enum_t
*
)
plugin_var
)
->
def_val
;
break
;
case
PLUGIN_VAR_SET
:
src
=
&
((
thdvar_set_t
*
)
plugin_var
)
->
def_val
;
break
;
case
PLUGIN_VAR_BOOL
:
src
=
&
((
thdvar_bool_t
*
)
plugin_var
)
->
def_val
;
break
;
case
PLUGIN_VAR_STR
:
src
=
&
((
thdvar_str_t
*
)
plugin_var
)
->
def_val
;
break
;
default:
DBUG_ASSERT
(
0
);
}
}
}
/* thd must equal current_thd if PLUGIN_VAR_THDLOCAL flag is set */
/* thd must equal current_thd if PLUGIN_VAR_THDLOCAL flag is set */
...
@@ -2776,25 +2802,25 @@ static void plugin_opt_set_limits(struct my_option *options,
...
@@ -2776,25 +2802,25 @@ static void plugin_opt_set_limits(struct my_option *options,
case
PLUGIN_VAR_ENUM
:
case
PLUGIN_VAR_ENUM
:
options
->
var_type
=
GET_ENUM
;
options
->
var_type
=
GET_ENUM
;
options
->
typelib
=
((
sysvar_enum_t
*
)
opt
)
->
typelib
;
options
->
typelib
=
((
sysvar_enum_t
*
)
opt
)
->
typelib
;
options
->
def_value
=
*
(
ulong
*
)
((
int
*
)
(
opt
+
1
)
+
1
)
;
options
->
def_value
=
((
sysvar_enum_t
*
)
opt
)
->
def_val
;
options
->
min_value
=
options
->
block_size
=
0
;
options
->
min_value
=
options
->
block_size
=
0
;
options
->
max_value
=
options
->
typelib
->
count
-
1
;
options
->
max_value
=
options
->
typelib
->
count
-
1
;
break
;
break
;
case
PLUGIN_VAR_SET
:
case
PLUGIN_VAR_SET
:
options
->
var_type
=
GET_SET
;
options
->
var_type
=
GET_SET
;
options
->
typelib
=
((
sysvar_set_t
*
)
opt
)
->
typelib
;
options
->
typelib
=
((
sysvar_set_t
*
)
opt
)
->
typelib
;
options
->
def_value
=
*
(
ulonglong
*
)
((
int
*
)
(
opt
+
1
)
+
1
)
;
options
->
def_value
=
((
sysvar_set_t
*
)
opt
)
->
def_val
;
options
->
min_value
=
options
->
block_size
=
0
;
options
->
min_value
=
options
->
block_size
=
0
;
options
->
max_value
=
(
ULL
(
1
)
<<
options
->
typelib
->
count
)
-
1
;
options
->
max_value
=
(
ULL
(
1
)
<<
options
->
typelib
->
count
)
-
1
;
break
;
break
;
case
PLUGIN_VAR_BOOL
:
case
PLUGIN_VAR_BOOL
:
options
->
var_type
=
GET_BOOL
;
options
->
var_type
=
GET_BOOL
;
options
->
def_value
=
*
(
my_bool
*
)
((
void
**
)(
opt
+
1
)
+
1
)
;
options
->
def_value
=
((
sysvar_bool_t
*
)
opt
)
->
def_val
;
break
;
break
;
case
PLUGIN_VAR_STR
:
case
PLUGIN_VAR_STR
:
options
->
var_type
=
((
opt
->
flags
&
PLUGIN_VAR_MEMALLOC
)
?
options
->
var_type
=
((
opt
->
flags
&
PLUGIN_VAR_MEMALLOC
)
?
GET_STR_ALLOC
:
GET_STR
);
GET_STR_ALLOC
:
GET_STR
);
options
->
def_value
=
(
ulonglong
)(
intptr
)
*
((
char
**
)
((
void
**
)
(
opt
+
1
)
+
1
))
;
options
->
def_value
=
(
intptr
)
((
sysvar_str_t
*
)
opt
)
->
def_val
;
break
;
break
;
/* threadlocal variables */
/* threadlocal variables */
case
PLUGIN_VAR_INT
|
PLUGIN_VAR_THDLOCAL
:
case
PLUGIN_VAR_INT
|
PLUGIN_VAR_THDLOCAL
:
...
@@ -2818,25 +2844,25 @@ static void plugin_opt_set_limits(struct my_option *options,
...
@@ -2818,25 +2844,25 @@ static void plugin_opt_set_limits(struct my_option *options,
case
PLUGIN_VAR_ENUM
|
PLUGIN_VAR_THDLOCAL
:
case
PLUGIN_VAR_ENUM
|
PLUGIN_VAR_THDLOCAL
:
options
->
var_type
=
GET_ENUM
;
options
->
var_type
=
GET_ENUM
;
options
->
typelib
=
((
thdvar_enum_t
*
)
opt
)
->
typelib
;
options
->
typelib
=
((
thdvar_enum_t
*
)
opt
)
->
typelib
;
options
->
def_value
=
*
(
ulong
*
)
((
int
*
)
(
opt
+
1
)
+
1
)
;
options
->
def_value
=
((
thdvar_enum_t
*
)
opt
)
->
def_val
;
options
->
min_value
=
options
->
block_size
=
0
;
options
->
min_value
=
options
->
block_size
=
0
;
options
->
max_value
=
options
->
typelib
->
count
-
1
;
options
->
max_value
=
options
->
typelib
->
count
-
1
;
break
;
break
;
case
PLUGIN_VAR_SET
|
PLUGIN_VAR_THDLOCAL
:
case
PLUGIN_VAR_SET
|
PLUGIN_VAR_THDLOCAL
:
options
->
var_type
=
GET_SET
;
options
->
var_type
=
GET_SET
;
options
->
typelib
=
((
thdvar_set_t
*
)
opt
)
->
typelib
;
options
->
typelib
=
((
thdvar_set_t
*
)
opt
)
->
typelib
;
options
->
def_value
=
*
(
ulonglong
*
)
((
int
*
)
(
opt
+
1
)
+
1
)
;
options
->
def_value
=
((
thdvar_set_t
*
)
opt
)
->
def_val
;
options
->
min_value
=
options
->
block_size
=
0
;
options
->
min_value
=
options
->
block_size
=
0
;
options
->
max_value
=
(
ULL
(
1
)
<<
options
->
typelib
->
count
)
-
1
;
options
->
max_value
=
(
ULL
(
1
)
<<
options
->
typelib
->
count
)
-
1
;
break
;
break
;
case
PLUGIN_VAR_BOOL
|
PLUGIN_VAR_THDLOCAL
:
case
PLUGIN_VAR_BOOL
|
PLUGIN_VAR_THDLOCAL
:
options
->
var_type
=
GET_BOOL
;
options
->
var_type
=
GET_BOOL
;
options
->
def_value
=
*
(
my_bool
*
)
((
int
*
)
(
opt
+
1
)
+
1
)
;
options
->
def_value
=
((
thdvar_bool_t
*
)
opt
)
->
def_val
;
break
;
break
;
case
PLUGIN_VAR_STR
|
PLUGIN_VAR_THDLOCAL
:
case
PLUGIN_VAR_STR
|
PLUGIN_VAR_THDLOCAL
:
options
->
var_type
=
((
opt
->
flags
&
PLUGIN_VAR_MEMALLOC
)
?
options
->
var_type
=
((
opt
->
flags
&
PLUGIN_VAR_MEMALLOC
)
?
GET_STR_ALLOC
:
GET_STR
);
GET_STR_ALLOC
:
GET_STR
);
options
->
def_value
=
(
intptr
)
*
((
char
**
)
((
void
**
)
(
opt
+
1
)
+
1
))
;
options
->
def_value
=
(
intptr
)
((
thdvar_str_t
*
)
opt
)
->
def_val
;
break
;
break
;
default:
default:
DBUG_ASSERT
(
0
);
DBUG_ASSERT
(
0
);
...
...
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