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
4dbd101c
Commit
4dbd101c
authored
Dec 30, 2004
by
marko@hundin.mysql.fi
Browse files
Options
Browse Files
Download
Plain Diff
Merge marko@bk-internal.mysql.com:/home/bk/mysql-5.0
into hundin.mysql.fi:/home/marko/j/mysql-5.0
parents
b1387f5d
3653b089
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
20 additions
and
17 deletions
+20
-17
innobase/include/rem0rec.ic
innobase/include/rem0rec.ic
+6
-5
innobase/rem/rem0rec.c
innobase/rem/rem0rec.c
+14
-12
No files found.
innobase/include/rem0rec.ic
View file @
4dbd101c
...
@@ -880,7 +880,6 @@ rec_get_nth_field(
...
@@ -880,7 +880,6 @@ rec_get_nth_field(
length = rec_offs_base(offsets)[1 + n];
length = rec_offs_base(offsets)[1 + n];
if (length & REC_OFFS_SQL_NULL) {
if (length & REC_OFFS_SQL_NULL) {
field = NULL;
length = UNIV_SQL_NULL;
length = UNIV_SQL_NULL;
} else {
} else {
length &= REC_OFFS_MASK;
length &= REC_OFFS_MASK;
...
@@ -1185,6 +1184,7 @@ rec_set_nth_field(
...
@@ -1185,6 +1184,7 @@ rec_set_nth_field(
byte* data2;
byte* data2;
ulint len2;
ulint len2;
ut_ad(rec);
ut_ad(rec_offs_validate(rec, NULL, offsets));
ut_ad(rec_offs_validate(rec, NULL, offsets));
if (len == UNIV_SQL_NULL) {
if (len == UNIV_SQL_NULL) {
...
@@ -1195,14 +1195,15 @@ rec_set_nth_field(
...
@@ -1195,14 +1195,15 @@ rec_set_nth_field(
}
}
data2 = rec_get_nth_field(rec, offsets, n, &len2);
data2 = rec_get_nth_field(rec, offsets, n, &len2);
ut_ad(len2 == len);
ut_memcpy(data2, data, len);
if (len2 == UNIV_SQL_NULL) {
if (len2 == UNIV_SQL_NULL) {
ut_ad(!rec_offs_comp(offsets));
ut_ad(!rec_offs_comp(offsets));
rec_set_nth_field_null_bit(rec, n, FALSE);
rec_set_nth_field_null_bit(rec, n, FALSE);
ut_ad(len == rec_get_nth_field_size(rec, n));
} else {
ut_ad(len2 == len);
}
}
ut_memcpy(data2, data, len);
}
}
/**************************************************************
/**************************************************************
...
...
innobase/rem/rem0rec.c
View file @
4dbd101c
...
@@ -137,16 +137,18 @@ rec_validate_old(
...
@@ -137,16 +137,18 @@ rec_validate_old(
rec_t
*
rec
);
/* in: physical record */
rec_t
*
rec
);
/* in: physical record */
/**********************************************************
/**********************************************************
The following function determines the offsets to each field
The following function determines the offsets to each field in the
in the record. The offsets are written to an array of
record. The offsets are written to a previously allocated array of
ulint[n+2], with [0] being the number of fields (n), [1] being the
ulint, where rec_offs_n_fields(offsets) has been initialized to the
extra size (if REC_OFFS_COMPACT is set, the record is in the new
number of fields in the record. The rest of the array will be
format), and [2]..[n+1] being the offsets past the end of
initialized by this function. rec_offs_base(offsets)[0] will be set
fields 0..n, or to the beginning of fields 1..n+1. When the
to the extra size (if REC_OFFS_COMPACT is set, the record is in the
high-order bit of the offset at [n+1] is set (REC_OFFS_SQL_NULL),
new format), and rec_offs_base(offsets)[1..n_fields] will be set to
the field n is NULL. When the second high-order bit of the offset
offsets past the end of fields 0..n_fields, or to the beginning of
at [n+1] is set (REC_OFFS_EXTERNAL), the field n is being stored
fields 1..n_fields+1. When the high-order bit of the offset at [i+1]
externally. */
is set (REC_OFFS_SQL_NULL), the field i is NULL. When the second
high-order bit of the offset at [i+1] is set (REC_OFFS_EXTERNAL), the
field i is being stored externally. */
static
static
void
void
rec_init_offsets
(
rec_init_offsets
(
...
@@ -154,8 +156,8 @@ rec_init_offsets(
...
@@ -154,8 +156,8 @@ rec_init_offsets(
/* out: the offsets */
/* out: the offsets */
rec_t
*
rec
,
/* in: physical record */
rec_t
*
rec
,
/* in: physical record */
dict_index_t
*
index
,
/* in: record descriptor */
dict_index_t
*
index
,
/* in: record descriptor */
ulint
*
offsets
)
/* in
:/out: ulint[n+2]
;
ulint
*
offsets
)
/* in
/out: array of offsets
;
n=rec_offs_n_fields(offsets) */
in:
n=rec_offs_n_fields(offsets) */
{
{
ulint
n_fields
=
rec_offs_n_fields
(
offsets
);
ulint
n_fields
=
rec_offs_n_fields
(
offsets
);
ulint
i
=
0
;
ulint
i
=
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