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
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
nexedi
MariaDB
Commits
88315c9e
Commit
88315c9e
authored
Oct 17, 2006
by
tsmith/mysqldev@mysql.com/production.mysql.com
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
mysql.cc, log.cc:
WL #3516: MySQL Enterprise: implement Version Display Specification
parent
f6ad9e51
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
51 additions
and
14 deletions
+51
-14
client/mysql.cc
client/mysql.cc
+44
-10
sql/log.cc
sql/log.cc
+7
-4
No files found.
client/mysql.cc
View file @
88315c9e
...
@@ -49,6 +49,9 @@ const char *VER= "14.12";
...
@@ -49,6 +49,9 @@ const char *VER= "14.12";
/* Don't try to make a nice table if the data is too big */
/* Don't try to make a nice table if the data is too big */
#define MAX_COLUMN_LENGTH 1024
#define MAX_COLUMN_LENGTH 1024
/* Buffer to hold 'version' and 'version_comment' */
#define MAX_SERVER_VERSION_LENGTH 128
gptr
sql_alloc
(
unsigned
size
);
// Don't use mysqld alloc for these
gptr
sql_alloc
(
unsigned
size
);
// Don't use mysqld alloc for these
void
sql_element_free
(
void
*
ptr
);
void
sql_element_free
(
void
*
ptr
);
#include "sql_string.h"
#include "sql_string.h"
...
@@ -208,6 +211,7 @@ static int com_nopager(String *str, char*), com_pager(String *str, char*),
...
@@ -208,6 +211,7 @@ static int com_nopager(String *str, char*), com_pager(String *str, char*),
static
int
read_and_execute
(
bool
interactive
);
static
int
read_and_execute
(
bool
interactive
);
static
int
sql_connect
(
char
*
host
,
char
*
database
,
char
*
user
,
char
*
password
,
static
int
sql_connect
(
char
*
host
,
char
*
database
,
char
*
user
,
char
*
password
,
uint
silent
);
uint
silent
);
static
const
char
*
server_version_string
(
MYSQL
*
mysql
);
static
int
put_info
(
const
char
*
str
,
INFO_TYPE
info
,
uint
error
=
0
,
static
int
put_info
(
const
char
*
str
,
INFO_TYPE
info
,
uint
error
=
0
,
const
char
*
sql_state
=
0
);
const
char
*
sql_state
=
0
);
static
int
put_error
(
MYSQL
*
mysql
);
static
int
put_error
(
MYSQL
*
mysql
);
...
@@ -432,8 +436,8 @@ int main(int argc,char *argv[])
...
@@ -432,8 +436,8 @@ int main(int argc,char *argv[])
put_info
(
"Welcome to the MySQL monitor. Commands end with ; or
\\
g."
,
put_info
(
"Welcome to the MySQL monitor. Commands end with ; or
\\
g."
,
INFO_INFO
);
INFO_INFO
);
sprintf
((
char
*
)
glob_buffer
.
ptr
(),
sprintf
((
char
*
)
glob_buffer
.
ptr
(),
"Your MySQL connection id is %lu
to s
erver version: %s
\n
"
,
"Your MySQL connection id is %lu
\n
S
erver version: %s
\n
"
,
mysql_thread_id
(
&
mysql
),
mysql_get_server_info
(
&
mysql
));
mysql_thread_id
(
&
mysql
),
server_version_string
(
&
mysql
));
put_info
((
char
*
)
glob_buffer
.
ptr
(),
INFO_INFO
);
put_info
((
char
*
)
glob_buffer
.
ptr
(),
INFO_INFO
);
#ifdef HAVE_READLINE
#ifdef HAVE_READLINE
...
@@ -3335,16 +3339,13 @@ com_status(String *buffer __attribute__((unused)),
...
@@ -3335,16 +3339,13 @@ com_status(String *buffer __attribute__((unused)),
tee_fprintf
(
stdout
,
"Using outfile:
\t\t
'%s'
\n
"
,
opt_outfile
?
outfile
:
""
);
tee_fprintf
(
stdout
,
"Using outfile:
\t\t
'%s'
\n
"
,
opt_outfile
?
outfile
:
""
);
#endif
#endif
tee_fprintf
(
stdout
,
"Using delimiter:
\t
%s
\n
"
,
delimiter
);
tee_fprintf
(
stdout
,
"Using delimiter:
\t
%s
\n
"
,
delimiter
);
tee_fprintf
(
stdout
,
"Server version:
\t\t
%s
\n
"
,
mysql_get_server_info
(
&
mysql
));
tee_fprintf
(
stdout
,
"Server version:
\t\t
%s
\n
"
,
server_version_string
(
&
mysql
));
tee_fprintf
(
stdout
,
"Protocol version:
\t
%d
\n
"
,
mysql_get_proto_info
(
&
mysql
));
tee_fprintf
(
stdout
,
"Protocol version:
\t
%d
\n
"
,
mysql_get_proto_info
(
&
mysql
));
tee_fprintf
(
stdout
,
"Connection:
\t\t
%s
\n
"
,
mysql_get_host_info
(
&
mysql
));
tee_fprintf
(
stdout
,
"Connection:
\t\t
%s
\n
"
,
mysql_get_host_info
(
&
mysql
));
if
((
id
=
mysql_insert_id
(
&
mysql
)))
if
((
id
=
mysql_insert_id
(
&
mysql
)))
tee_fprintf
(
stdout
,
"Insert id:
\t\t
%s
\n
"
,
llstr
(
id
,
buff
));
tee_fprintf
(
stdout
,
"Insert id:
\t\t
%s
\n
"
,
llstr
(
id
,
buff
));
/*
/* "limit 1" is protection against SQL_SELECT_LIMIT=0 */
Don't remove "limit 1",
it is protection againts SQL_SELECT_LIMIT=0
*/
if
(
!
mysql_query
(
&
mysql
,
"select @@character_set_client, @@character_set_connection, @@character_set_server, @@character_set_database limit 1"
)
&&
if
(
!
mysql_query
(
&
mysql
,
"select @@character_set_client, @@character_set_connection, @@character_set_server, @@character_set_database limit 1"
)
&&
(
result
=
mysql_use_result
(
&
mysql
)))
(
result
=
mysql_use_result
(
&
mysql
)))
{
{
...
@@ -3409,6 +3410,39 @@ select_limit, max_join_size);
...
@@ -3409,6 +3410,39 @@ select_limit, max_join_size);
return
0
;
return
0
;
}
}
static
const
char
*
server_version_string
(
MYSQL
*
mysql
)
{
static
char
buf
[
MAX_SERVER_VERSION_LENGTH
]
=
""
;
/* Only one thread calls this, so no synchronization is needed */
if
(
buf
[
0
]
==
'\0'
)
{
char
*
bufp
=
buf
;
MYSQL_RES
*
result
;
MYSQL_ROW
cur
;
bufp
=
strnmov
(
buf
,
mysql_get_server_info
(
mysql
),
sizeof
buf
);
/* "limit 1" is protection against SQL_SELECT_LIMIT=0 */
if
(
!
mysql_query
(
mysql
,
"select @@version_comment limit 1"
)
&&
(
result
=
mysql_use_result
(
mysql
)))
{
MYSQL_ROW
cur
=
mysql_fetch_row
(
result
);
if
(
cur
&&
cur
[
0
])
{
bufp
=
strxnmov
(
bufp
,
sizeof
buf
-
(
bufp
-
buf
),
" "
,
cur
[
0
],
NullS
);
}
mysql_free_result
(
result
);
}
/* str*nmov doesn't guarantee NUL-termination */
if
(
bufp
==
buf
+
sizeof
buf
)
buf
[
sizeof
buf
-
1
]
=
'\0'
;
}
return
buf
;
}
static
int
static
int
put_info
(
const
char
*
str
,
INFO_TYPE
info_type
,
uint
error
,
const
char
*
sqlstate
)
put_info
(
const
char
*
str
,
INFO_TYPE
info_type
,
uint
error
,
const
char
*
sqlstate
)
...
@@ -3536,14 +3570,14 @@ void tee_puts(const char *s, FILE *file)
...
@@ -3536,14 +3570,14 @@ void tee_puts(const char *s, FILE *file)
{
{
NETWARE_YIELD
;
NETWARE_YIELD
;
fputs
(
s
,
file
);
fputs
(
s
,
file
);
fput
s
(
"
\n
"
,
file
);
fput
c
(
'\n'
,
file
);
#ifdef OS2
#ifdef OS2
fflush
(
file
);
fflush
(
file
);
#endif
#endif
if
(
opt_outfile
)
if
(
opt_outfile
)
{
{
fputs
(
s
,
OUTFILE
);
fputs
(
s
,
OUTFILE
);
fput
s
(
"
\n
"
,
OUTFILE
);
fput
c
(
'\n'
,
OUTFILE
);
}
}
}
}
...
...
sql/log.cc
View file @
88315c9e
...
@@ -566,15 +566,18 @@ bool MYSQL_LOG::open(const char *log_name,
...
@@ -566,15 +566,18 @@ bool MYSQL_LOG::open(const char *log_name,
case
LOG_NORMAL
:
case
LOG_NORMAL
:
{
{
char
*
end
;
char
*
end
;
int
len
=
my_snprintf
(
buff
,
sizeof
(
buff
),
"%s, Version: %s. "
int
len
=
my_snprintf
(
buff
,
sizeof
(
buff
),
"%s, Version: %s
(%s)
. "
#ifdef EMBEDDED_LIBRARY
#ifdef EMBEDDED_LIBRARY
"embedded library
\n
"
,
my_progname
,
server_version
"embedded library
\n
"
,
my_progname
,
server_version
,
MYSQL_COMPILATION_COMMENT
#elif __NT__
#elif __NT__
"started with:
\n
TCP Port: %d, Named Pipe: %s
\n
"
,
"started with:
\n
TCP Port: %d, Named Pipe: %s
\n
"
,
my_progname
,
server_version
,
mysqld_port
,
mysqld_unix_port
my_progname
,
server_version
,
MYSQL_COMPILATION_COMMENT
,
mysqld_port
,
mysqld_unix_port
#else
#else
"started with:
\n
Tcp port: %d Unix socket: %s
\n
"
,
"started with:
\n
Tcp port: %d Unix socket: %s
\n
"
,
my_progname
,
server_version
,
mysqld_port
,
mysqld_unix_port
my_progname
,
server_version
,
MYSQL_COMPILATION_COMMENT
,
mysqld_port
,
mysqld_unix_port
#endif
#endif
);
);
end
=
strnmov
(
buff
+
len
,
"Time Id Command Argument
\n
"
,
end
=
strnmov
(
buff
+
len
,
"Time Id Command Argument
\n
"
,
...
...
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