mariadb/client/client_metadata.h

58 lines
1.8 KiB
C
Raw Permalink Normal View History

#ifndef SQL_CLIENT_METADATA_INCLUDED
#define SQL_CLIENT_METADATA_INCLUDED
/*
Copyright (c) 2020, MariaDB Corporation.
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; version 2 of the License.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1335 USA */
#include "sql_string.h"
/*
Print MYSQL_FIELD metadata in human readable format
*/
class Client_field_metadata
{
const MYSQL_FIELD *m_field;
public:
Client_field_metadata(MYSQL_FIELD *field)
:m_field(field)
{ }
void print_attr(Binary_string *to,
const LEX_CSTRING &name,
mariadb_field_attr_t attr,
uint orig_to_length) const
{
MARIADB_CONST_STRING tmp;
if (!mariadb_field_attr(&tmp, m_field, attr) && tmp.length)
{
if (to->length() != orig_to_length)
to->append(" ", 1);
to->append(name);
to->append(tmp.str, tmp.length);
}
}
void print_data_type_related_attributes(Binary_string *to) const
{
static const LEX_CSTRING type= {C_STRING_WITH_LEN("type=")};
static const LEX_CSTRING format= {C_STRING_WITH_LEN("format=")};
uint to_length_orig= to->length();
print_attr(to, type, MARIADB_FIELD_ATTR_DATA_TYPE_NAME, to_length_orig);
print_attr(to, format, MARIADB_FIELD_ATTR_FORMAT_NAME, to_length_orig);
}
};
#endif // SQL_CLIENT_METADATA_INCLUDED