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
dd3c64a4
Commit
dd3c64a4
authored
Nov 11, 2000
by
sasha@laptop.slkc.uswest.net
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
laptop commit - bk wants me commit again!
parent
57093008
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
22 additions
and
22 deletions
+22
-22
sql/log_event.cc
sql/log_event.cc
+22
-22
No files found.
sql/log_event.cc
View file @
dd3c64a4
...
@@ -207,14 +207,17 @@ Log_event* Log_event::read_log_event(FILE* file, pthread_mutex_t* log_lock)
...
@@ -207,14 +207,17 @@ Log_event* Log_event::read_log_event(FILE* file, pthread_mutex_t* log_lock)
return
NULL
;
return
NULL
;
}
}
Log_event
*
Log_event
::
read_log_event
(
const
char
*
buf
,
int
max_buf
)
Log_event
*
Log_event
::
read_log_event
(
const
char
*
buf
,
int
event_len
)
{
{
if
(
event_len
<
EVENT_LEN_OFFSET
||
(
uint
)
event_len
!=
uint4korr
(
buf
+
EVENT_LEN_OFFSET
))
return
NULL
;
// general sanity check - will fail on a partial read
switch
(
buf
[
EVENT_TYPE_OFFSET
])
switch
(
buf
[
EVENT_TYPE_OFFSET
])
{
{
case
QUERY_EVENT
:
case
QUERY_EVENT
:
{
{
Query_log_event
*
q
=
new
Query_log_event
(
buf
,
max_buf
);
Query_log_event
*
q
=
new
Query_log_event
(
buf
,
event_len
);
if
(
!
q
->
query
)
if
(
!
q
->
query
)
{
{
delete
q
;
delete
q
;
...
@@ -226,7 +229,7 @@ Log_event* Log_event::read_log_event(const char* buf, int max_buf)
...
@@ -226,7 +229,7 @@ Log_event* Log_event::read_log_event(const char* buf, int max_buf)
case
LOAD_EVENT
:
case
LOAD_EVENT
:
{
{
Load_log_event
*
l
=
new
Load_log_event
(
buf
,
max_buf
);
Load_log_event
*
l
=
new
Load_log_event
(
buf
,
event_len
);
if
(
!
l
->
table_name
)
if
(
!
l
->
table_name
)
{
{
delete
l
;
delete
l
;
...
@@ -238,7 +241,7 @@ Log_event* Log_event::read_log_event(const char* buf, int max_buf)
...
@@ -238,7 +241,7 @@ Log_event* Log_event::read_log_event(const char* buf, int max_buf)
case
ROTATE_EVENT
:
case
ROTATE_EVENT
:
{
{
Rotate_log_event
*
r
=
new
Rotate_log_event
(
buf
,
max_buf
);
Rotate_log_event
*
r
=
new
Rotate_log_event
(
buf
,
event_len
);
if
(
!
r
->
new_log_ident
)
if
(
!
r
->
new_log_ident
)
{
{
delete
r
;
delete
r
;
...
@@ -357,12 +360,12 @@ Start_log_event::Start_log_event(const char* buf) :Log_event(buf)
...
@@ -357,12 +360,12 @@ Start_log_event::Start_log_event(const char* buf) :Log_event(buf)
created
=
uint4korr
(
buf
+
2
+
sizeof
(
server_version
));
created
=
uint4korr
(
buf
+
2
+
sizeof
(
server_version
));
}
}
Rotate_log_event
::
Rotate_log_event
(
const
char
*
buf
,
int
max_buf
)
:
Rotate_log_event
::
Rotate_log_event
(
const
char
*
buf
,
int
event_len
)
:
Log_event
(
buf
),
new_log_ident
(
NULL
),
alloced
(
0
)
Log_event
(
buf
),
new_log_ident
(
NULL
),
alloced
(
0
)
{
{
ulong
event_len
;
// the caller will ensure that event_len is what we have at
event_len
=
uint4korr
(
buf
+
EVENT_LEN_OFFSET
);
// EVENT_LEN_OFFSET
if
(
event_len
<
ROTATE_EVENT_OVERHEAD
||
event_len
>
(
ulong
)
max_buf
)
if
(
event_len
<
ROTATE_EVENT_OVERHEAD
)
return
;
return
;
ident_len
=
(
uchar
)(
event_len
-
ROTATE_EVENT_OVERHEAD
);
ident_len
=
(
uchar
)(
event_len
-
ROTATE_EVENT_OVERHEAD
);
...
@@ -415,16 +418,15 @@ Query_log_event::Query_log_event(FILE* file, time_t when_arg,
...
@@ -415,16 +418,15 @@ Query_log_event::Query_log_event(FILE* file, time_t when_arg,
*
((
char
*
)
query
+
q_len
)
=
0
;
*
((
char
*
)
query
+
q_len
)
=
0
;
}
}
Query_log_event
::
Query_log_event
(
const
char
*
buf
,
int
max_buf
)
:
Query_log_event
::
Query_log_event
(
const
char
*
buf
,
int
event_len
)
:
Log_event
(
buf
),
data_buf
(
0
),
query
(
NULL
),
db
(
NULL
)
Log_event
(
buf
),
data_buf
(
0
),
query
(
NULL
),
db
(
NULL
)
{
{
if
(
event_len
<
QUERY_EVENT_OVERHEAD
)
return
;
ulong
data_len
;
ulong
data_len
;
buf
+=
EVENT_LEN_OFFSET
;
buf
+=
EVENT_LEN_OFFSET
;
data_len
=
uint4korr
(
buf
);
data_len
=
event_len
-
QUERY_EVENT_OVERHEAD
;
if
(
data_len
<
QUERY_EVENT_OVERHEAD
||
data_len
>
(
ulong
)
max_buf
)
return
;
// tear-drop attack protection :)
data_len
-=
QUERY_EVENT_OVERHEAD
;
exec_time
=
uint4korr
(
buf
+
8
);
exec_time
=
uint4korr
(
buf
+
8
);
error_code
=
uint2korr
(
buf
+
13
);
error_code
=
uint2korr
(
buf
+
13
);
...
@@ -603,7 +605,7 @@ Load_log_event::Load_log_event(FILE* file, time_t when, uint32 server_id):
...
@@ -603,7 +605,7 @@ Load_log_event::Load_log_event(FILE* file, time_t when, uint32 server_id):
fname_len
=
data_len
-
2
-
db_len
-
table_name_len
-
num_fields
-
field_block_len
;
fname_len
=
data_len
-
2
-
db_len
-
table_name_len
-
num_fields
-
field_block_len
;
}
}
Load_log_event
::
Load_log_event
(
const
char
*
buf
,
int
max_buf
)
:
Load_log_event
::
Load_log_event
(
const
char
*
buf
,
int
event_len
)
:
Log_event
(
when
,
0
,
0
,
server_id
),
data_buf
(
0
),
num_fields
(
0
),
fields
(
0
),
Log_event
(
when
,
0
,
0
,
server_id
),
data_buf
(
0
),
num_fields
(
0
),
fields
(
0
),
field_lens
(
0
),
field_block_len
(
0
),
field_lens
(
0
),
field_block_len
(
0
),
table_name
(
0
),
db
(
0
),
fname
(
0
)
table_name
(
0
),
db
(
0
),
fname
(
0
)
...
@@ -611,14 +613,12 @@ Load_log_event::Load_log_event(const char* buf, int max_buf):
...
@@ -611,14 +613,12 @@ Load_log_event::Load_log_event(const char* buf, int max_buf):
{
{
ulong
data_len
;
ulong
data_len
;
if
(
(
uint
)
max_buf
<
(
LOAD_EVENT_OVERHEAD
+
LOG_EVENT_HEADER_LEN
))
if
(
event_len
<
(
LOAD_EVENT_OVERHEAD
+
LOG_EVENT_HEADER_LEN
))
return
;
return
;
buf
+=
EVENT_LEN_OFFSET
;
buf
+=
EVENT_LEN_OFFSET
;
data_len
=
uint4korr
(
buf
);
data_len
=
event_len
;
if
((
uint
)
data_len
>
(
uint
)
max_buf
)
return
;
thread_id
=
uint4korr
(
buf
+
4
);
thread_id
=
uint4korr
(
buf
+
4
);
exec_time
=
uint4korr
(
buf
+
8
);
exec_time
=
uint4korr
(
buf
+
8
);
...
...
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