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
0acde609
Commit
0acde609
authored
Jul 16, 2004
by
bell@sanja.is.com.ua
Browse files
Options
Browse Files
Download
Plain Diff
Merge sanja.is.com.ua:/home/bell/mysql/bk/mysql-5.0
into sanja.is.com.ua:/home/bell/mysql/bk/work-5.0
parents
baa645a6
c5c023a2
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
26 additions
and
22 deletions
+26
-22
sql/parse_file.cc
sql/parse_file.cc
+26
-22
No files found.
sql/parse_file.cc
View file @
0acde609
...
@@ -50,27 +50,27 @@ write_escaped_string(IO_CACHE *file, LEX_STRING *val_s)
...
@@ -50,27 +50,27 @@ write_escaped_string(IO_CACHE *file, LEX_STRING *val_s)
*/
*/
switch
(
*
ptr
)
{
switch
(
*
ptr
)
{
case
'\\'
:
// escape character
case
'\\'
:
// escape character
if
(
my_b_append
(
file
,
"
\\\\
"
,
2
))
if
(
my_b_append
(
file
,
(
const
byte
*
)
"
\\\\
"
,
2
))
return
TRUE
;
return
TRUE
;
break
;
break
;
case
'\n'
:
// parameter value delimiter
case
'\n'
:
// parameter value delimiter
if
(
my_b_append
(
file
,
"
\\
n"
,
2
))
if
(
my_b_append
(
file
,
(
const
byte
*
)
"
\\
n"
,
2
))
return
TRUE
;
return
TRUE
;
break
;
break
;
case
'\0'
:
// problem for some string processing utilites
case
'\0'
:
// problem for some string processing utilites
if
(
my_b_append
(
file
,
"
\\
0"
,
2
))
if
(
my_b_append
(
file
,
(
const
byte
*
)
"
\\
0"
,
2
))
return
TRUE
;
return
TRUE
;
break
;
break
;
case
26
:
// problem for windows utilites (Ctrl-Z)
case
26
:
// problem for windows utilites (Ctrl-Z)
if
(
my_b_append
(
file
,
"
\\
z"
,
2
))
if
(
my_b_append
(
file
,
(
const
byte
*
)
"
\\
z"
,
2
))
return
TRUE
;
return
TRUE
;
break
;
break
;
case
'\''
:
// list of string delimiter
case
'\''
:
// list of string delimiter
if
(
my_b_append
(
file
,
"
\\\'
"
,
2
))
if
(
my_b_append
(
file
,
(
const
byte
*
)
"
\\\'
"
,
2
))
return
TRUE
;
return
TRUE
;
break
;
break
;
default:
default:
if
(
my_b_append
(
file
,
ptr
,
1
))
if
(
my_b_append
(
file
,
(
const
byte
*
)
ptr
,
1
))
return
TRUE
;
return
TRUE
;
}
}
}
}
...
@@ -106,7 +106,7 @@ write_parameter(IO_CACHE *file, gptr base, File_option *parameter,
...
@@ -106,7 +106,7 @@ write_parameter(IO_CACHE *file, gptr base, File_option *parameter,
case
FILE_OPTIONS_STRING
:
case
FILE_OPTIONS_STRING
:
{
{
LEX_STRING
*
val_s
=
(
LEX_STRING
*
)(
base
+
parameter
->
offset
);
LEX_STRING
*
val_s
=
(
LEX_STRING
*
)(
base
+
parameter
->
offset
);
if
(
my_b_append
(
file
,
val_s
->
str
,
val_s
->
length
))
if
(
my_b_append
(
file
,
(
const
byte
*
)
val_s
->
str
,
val_s
->
length
))
DBUG_RETURN
(
TRUE
);
DBUG_RETURN
(
TRUE
);
break
;
break
;
}
}
...
@@ -119,7 +119,7 @@ write_parameter(IO_CACHE *file, gptr base, File_option *parameter,
...
@@ -119,7 +119,7 @@ write_parameter(IO_CACHE *file, gptr base, File_option *parameter,
case
FILE_OPTIONS_ULONGLONG
:
case
FILE_OPTIONS_ULONGLONG
:
{
{
num
.
set
(
*
((
ulonglong
*
)(
base
+
parameter
->
offset
)),
&
my_charset_bin
);
num
.
set
(
*
((
ulonglong
*
)(
base
+
parameter
->
offset
)),
&
my_charset_bin
);
if
(
my_b_append
(
file
,
num
.
ptr
(),
num
.
length
()))
if
(
my_b_append
(
file
,
(
const
byte
*
)
num
.
ptr
(),
num
.
length
()))
DBUG_RETURN
(
TRUE
);
DBUG_RETURN
(
TRUE
);
break
;
break
;
}
}
...
@@ -128,7 +128,7 @@ write_parameter(IO_CACHE *file, gptr base, File_option *parameter,
...
@@ -128,7 +128,7 @@ write_parameter(IO_CACHE *file, gptr base, File_option *parameter,
ulonglong
*
val_i
=
(
ulonglong
*
)(
base
+
parameter
->
offset
);
ulonglong
*
val_i
=
(
ulonglong
*
)(
base
+
parameter
->
offset
);
*
old_version
=
(
*
val_i
)
++
;
*
old_version
=
(
*
val_i
)
++
;
num
.
set
(
*
val_i
,
&
my_charset_bin
);
num
.
set
(
*
val_i
,
&
my_charset_bin
);
if
(
my_b_append
(
file
,
num
.
ptr
(),
num
.
length
()))
if
(
my_b_append
(
file
,
(
const
byte
*
)
num
.
ptr
(),
num
.
length
()))
DBUG_RETURN
(
TRUE
);
DBUG_RETURN
(
TRUE
);
break
;
break
;
}
}
...
@@ -141,7 +141,8 @@ write_parameter(IO_CACHE *file, gptr base, File_option *parameter,
...
@@ -141,7 +141,8 @@ write_parameter(IO_CACHE *file, gptr base, File_option *parameter,
get_date
(
val_s
->
str
,
GETDATE_DATE_TIME
|
GETDATE_GMT
|
GETDATE_FIXEDLENGTH
,
get_date
(
val_s
->
str
,
GETDATE_DATE_TIME
|
GETDATE_GMT
|
GETDATE_FIXEDLENGTH
,
tm
);
tm
);
val_s
->
length
=
PARSE_FILE_TIMESTAMPLENGTH
;
val_s
->
length
=
PARSE_FILE_TIMESTAMPLENGTH
;
if
(
my_b_append
(
file
,
val_s
->
str
,
PARSE_FILE_TIMESTAMPLENGTH
))
if
(
my_b_append
(
file
,
(
const
byte
*
)
val_s
->
str
,
PARSE_FILE_TIMESTAMPLENGTH
))
DBUG_RETURN
(
TRUE
);
DBUG_RETURN
(
TRUE
);
break
;
break
;
}
}
...
@@ -155,10 +156,10 @@ write_parameter(IO_CACHE *file, gptr base, File_option *parameter,
...
@@ -155,10 +156,10 @@ write_parameter(IO_CACHE *file, gptr base, File_option *parameter,
{
{
num
.
set
((
ulonglong
)
str
->
length
,
&
my_charset_bin
);
num
.
set
((
ulonglong
)
str
->
length
,
&
my_charset_bin
);
// ',' after string to detect list continuation
// ',' after string to detect list continuation
if
((
!
first
&&
my_b_append
(
file
,
" "
,
1
))
||
if
((
!
first
&&
my_b_append
(
file
,
(
const
byte
*
)
" "
,
1
))
||
my_b_append
(
file
,
"
\'
"
,
1
)
||
my_b_append
(
file
,
(
const
byte
*
)
"
\'
"
,
1
)
||
my_b_append
(
file
,
str
->
str
,
str
->
length
)
||
my_b_append
(
file
,
(
const
byte
*
)
str
->
str
,
str
->
length
)
||
my_b_append
(
file
,
"
\'
"
,
1
))
my_b_append
(
file
,
(
const
byte
*
)
"
\'
"
,
1
))
{
{
DBUG_RETURN
(
TRUE
);
DBUG_RETURN
(
TRUE
);
}
}
...
@@ -202,6 +203,7 @@ sql_create_definition_file(const LEX_STRING *dir, const LEX_STRING *file_name,
...
@@ -202,6 +203,7 @@ sql_create_definition_file(const LEX_STRING *dir, const LEX_STRING *file_name,
char
path
[
FN_REFLEN
+
1
];
// +1 to put temporary file name for sure
char
path
[
FN_REFLEN
+
1
];
// +1 to put temporary file name for sure
ulonglong
old_version
=
ULONGLONG_MAX
;
ulonglong
old_version
=
ULONGLONG_MAX
;
int
path_end
;
int
path_end
;
File_option
*
param
;
DBUG_ENTER
(
"sql_create_definition_file"
);
DBUG_ENTER
(
"sql_create_definition_file"
);
DBUG_PRINT
(
"enter"
,
(
"Dir: %s, file: %s, base 0x%lx"
,
DBUG_PRINT
(
"enter"
,
(
"Dir: %s, file: %s, base 0x%lx"
,
dir
->
str
,
file_name
->
str
,
(
ulong
)
base
));
dir
->
str
,
file_name
->
str
,
(
ulong
)
base
));
...
@@ -222,18 +224,19 @@ sql_create_definition_file(const LEX_STRING *dir, const LEX_STRING *file_name,
...
@@ -222,18 +224,19 @@ sql_create_definition_file(const LEX_STRING *dir, const LEX_STRING *file_name,
goto
err_w_file
;
goto
err_w_file
;
// write header (file signature)
// write header (file signature)
if
(
my_b_append
(
&
file
,
"TYPE="
,
5
)
||
if
(
my_b_append
(
&
file
,
(
const
byte
*
)
"TYPE="
,
5
)
||
my_b_append
(
&
file
,
type
->
str
,
type
->
length
)
||
my_b_append
(
&
file
,
(
const
byte
*
)
type
->
str
,
type
->
length
)
||
my_b_append
(
&
file
,
"
\n
"
,
1
))
my_b_append
(
&
file
,
(
const
byte
*
)
"
\n
"
,
1
))
goto
err_w_file
;
goto
err_w_file
;
// write parameters to temporary file
// write parameters to temporary file
for
(
File_option
*
param
=
parameters
;
param
->
name
.
str
;
param
++
)
for
(
param
=
parameters
;
param
->
name
.
str
;
param
++
)
{
{
if
(
my_b_append
(
&
file
,
param
->
name
.
str
,
param
->
name
.
length
)
||
if
(
my_b_append
(
&
file
,
(
const
byte
*
)
param
->
name
.
str
,
my_b_append
(
&
file
,
"="
,
1
)
||
param
->
name
.
length
)
||
my_b_append
(
&
file
,
(
const
byte
*
)
"="
,
1
)
||
write_parameter
(
&
file
,
base
,
param
,
&
old_version
)
||
write_parameter
(
&
file
,
base
,
param
,
&
old_version
)
||
my_b_append
(
&
file
,
"
\n
"
,
1
))
my_b_append
(
&
file
,
(
const
byte
*
)
"
\n
"
,
1
))
goto
err_w_cache
;
goto
err_w_cache
;
}
}
...
@@ -367,7 +370,8 @@ sql_parse_prepare(const LEX_STRING *file_name, MEM_ROOT *mem_root,
...
@@ -367,7 +370,8 @@ sql_parse_prepare(const LEX_STRING *file_name, MEM_ROOT *mem_root,
DBUG_RETURN
(
0
);
DBUG_RETURN
(
0
);
}
}
if
((
len
=
my_read
(
file
,
parser
->
buff
,
stat_info
.
st_size
,
MYF
(
MY_WME
)))
==
if
((
len
=
my_read
(
file
,
(
byte
*
)
parser
->
buff
,
stat_info
.
st_size
,
MYF
(
MY_WME
)))
==
MY_FILE_ERROR
)
MY_FILE_ERROR
)
{
{
my_close
(
file
,
MYF
(
MY_WME
));
my_close
(
file
,
MYF
(
MY_WME
));
...
...
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