Merge 10.6 into 10.11

This commit is contained in:
Marko Mäkelä 2024-06-27 10:26:09 +03:00
commit 27a3366663
372 changed files with 7663 additions and 6515 deletions

View file

@ -73,55 +73,55 @@ class federatedx_io_mysql :public federatedx_io
bool test_all_restrict() const;
public:
federatedx_io_mysql(FEDERATEDX_SERVER *);
~federatedx_io_mysql();
~federatedx_io_mysql() override;
int simple_query(const char *fmt, ...);
int query(const char *buffer, size_t length);
virtual FEDERATEDX_IO_RESULT *store_result();
int query(const char *buffer, size_t length) override;
FEDERATEDX_IO_RESULT *store_result() override;
virtual size_t max_query_size() const;
size_t max_query_size() const override;
virtual my_ulonglong affected_rows() const;
virtual my_ulonglong last_insert_id() const;
my_ulonglong affected_rows() const override;
my_ulonglong last_insert_id() const override;
virtual int error_code();
virtual const char *error_str();
int error_code() override;
const char *error_str() override;
void reset();
int commit();
int rollback();
void reset() override;
int commit() override;
int rollback() override;
int savepoint_set(ulong sp);
ulong savepoint_release(ulong sp);
ulong savepoint_rollback(ulong sp);
void savepoint_restrict(ulong sp);
int savepoint_set(ulong sp) override;
ulong savepoint_release(ulong sp) override;
ulong savepoint_rollback(ulong sp) override;
void savepoint_restrict(ulong sp) override;
ulong last_savepoint() const;
ulong actual_savepoint() const;
bool is_autocommit() const;
ulong last_savepoint() const override;
ulong actual_savepoint() const override;
bool is_autocommit() const override;
bool table_metadata(ha_statistics *stats, const char *table_name,
uint table_name_length, uint flag);
uint table_name_length, uint flag) override;
/* resultset operations */
virtual void free_result(FEDERATEDX_IO_RESULT *io_result);
virtual unsigned int get_num_fields(FEDERATEDX_IO_RESULT *io_result);
virtual my_ulonglong get_num_rows(FEDERATEDX_IO_RESULT *io_result);
virtual FEDERATEDX_IO_ROW *fetch_row(FEDERATEDX_IO_RESULT *io_result,
FEDERATEDX_IO_ROWS **current= NULL);
virtual ulong *fetch_lengths(FEDERATEDX_IO_RESULT *io_result);
virtual const char *get_column_data(FEDERATEDX_IO_ROW *row,
unsigned int column);
virtual bool is_column_null(const FEDERATEDX_IO_ROW *row,
unsigned int column) const;
void free_result(FEDERATEDX_IO_RESULT *io_result) override;
unsigned int get_num_fields(FEDERATEDX_IO_RESULT *io_result) override;
my_ulonglong get_num_rows(FEDERATEDX_IO_RESULT *io_result) override;
FEDERATEDX_IO_ROW *fetch_row(FEDERATEDX_IO_RESULT *io_result,
FEDERATEDX_IO_ROWS **current= NULL) override;
ulong *fetch_lengths(FEDERATEDX_IO_RESULT *io_result) override;
const char *get_column_data(FEDERATEDX_IO_ROW *row,
unsigned int column) override;
bool is_column_null(const FEDERATEDX_IO_ROW *row,
unsigned int column) const override;
virtual size_t get_ref_length() const;
virtual void mark_position(FEDERATEDX_IO_RESULT *io_result,
void *ref, FEDERATEDX_IO_ROWS *current);
virtual int seek_position(FEDERATEDX_IO_RESULT **io_result,
const void *ref);
virtual void set_thd(void *thd);
size_t get_ref_length() const override;
void mark_position(FEDERATEDX_IO_RESULT *io_result,
void *ref, FEDERATEDX_IO_ROWS *current) override;
int seek_position(FEDERATEDX_IO_RESULT **io_result,
const void *ref) override;
void set_thd(void *thd) override;
};

View file

@ -56,52 +56,52 @@ class federatedx_io_null :public federatedx_io
{
public:
federatedx_io_null(FEDERATEDX_SERVER *);
~federatedx_io_null();
~federatedx_io_null() override;
int query(const char *buffer, size_t length);
virtual FEDERATEDX_IO_RESULT *store_result();
int query(const char *buffer, size_t length) override;
FEDERATEDX_IO_RESULT *store_result() override;
virtual size_t max_query_size() const;
size_t max_query_size() const override;
virtual my_ulonglong affected_rows() const;
virtual my_ulonglong last_insert_id() const;
my_ulonglong affected_rows() const override;
my_ulonglong last_insert_id() const override;
virtual int error_code();
virtual const char *error_str();
int error_code() override;
const char *error_str() override;
void reset();
int commit();
int rollback();
void reset() override;
int commit() override;
int rollback() override;
int savepoint_set(ulong sp);
ulong savepoint_release(ulong sp);
ulong savepoint_rollback(ulong sp);
void savepoint_restrict(ulong sp);
int savepoint_set(ulong sp) override;
ulong savepoint_release(ulong sp) override;
ulong savepoint_rollback(ulong sp) override;
void savepoint_restrict(ulong sp) override;
ulong last_savepoint() const;
ulong actual_savepoint() const;
bool is_autocommit() const;
ulong last_savepoint() const override;
ulong actual_savepoint() const override;
bool is_autocommit() const override;
bool table_metadata(ha_statistics *stats, const char *table_name,
uint table_name_length, uint flag);
uint table_name_length, uint flag) override;
/* resultset operations */
virtual void free_result(FEDERATEDX_IO_RESULT *io_result);
virtual unsigned int get_num_fields(FEDERATEDX_IO_RESULT *io_result);
virtual my_ulonglong get_num_rows(FEDERATEDX_IO_RESULT *io_result);
virtual FEDERATEDX_IO_ROW *fetch_row(FEDERATEDX_IO_RESULT *io_result,
FEDERATEDX_IO_ROWS **current= NULL);
virtual ulong *fetch_lengths(FEDERATEDX_IO_RESULT *io_result);
virtual const char *get_column_data(FEDERATEDX_IO_ROW *row,
unsigned int column);
virtual bool is_column_null(const FEDERATEDX_IO_ROW *row,
unsigned int column) const;
virtual size_t get_ref_length() const;
virtual void mark_position(FEDERATEDX_IO_RESULT *io_result,
void *ref, FEDERATEDX_IO_ROWS *current);
virtual int seek_position(FEDERATEDX_IO_RESULT **io_result,
const void *ref);
void free_result(FEDERATEDX_IO_RESULT *io_result) override;
unsigned int get_num_fields(FEDERATEDX_IO_RESULT *io_result) override;
my_ulonglong get_num_rows(FEDERATEDX_IO_RESULT *io_result) override;
FEDERATEDX_IO_ROW *fetch_row(FEDERATEDX_IO_RESULT *io_result,
FEDERATEDX_IO_ROWS **current= NULL) override;
ulong *fetch_lengths(FEDERATEDX_IO_RESULT *io_result) override;
const char *get_column_data(FEDERATEDX_IO_ROW *row,
unsigned int column) override;
bool is_column_null(const FEDERATEDX_IO_ROW *row,
unsigned int column) const override;
size_t get_ref_length() const override;
void mark_position(FEDERATEDX_IO_RESULT *io_result,
void *ref, FEDERATEDX_IO_ROWS *current) override;
int seek_position(FEDERATEDX_IO_RESULT **io_result,
const void *ref) override;
};

View file

@ -33,10 +33,10 @@ private:
public:
ha_federatedx_derived_handler(THD* thd_arg, TABLE_LIST *tbl);
~ha_federatedx_derived_handler();
int init_scan();
int next_row();
int end_scan();
void print_error(int, unsigned long);
int init_scan() override;
int next_row() override;
int end_scan() override;
void print_error(int, unsigned long) override;
};
@ -56,8 +56,8 @@ private:
public:
ha_federatedx_select_handler(THD* thd_arg, SELECT_LEX *sel);
~ha_federatedx_select_handler();
int init_scan();
int next_row();
int end_scan();
void print_error(int, unsigned long);
int init_scan() override;
int next_row() override;
int end_scan() override;
void print_error(int, unsigned long) override;
};

View file

@ -1824,7 +1824,7 @@ public:
public:
bool handle_condition(THD *thd, uint sql_errno, const char* sqlstate,
Sql_condition::enum_warning_level *level,
const char* msg, Sql_condition ** cond_hdl)
const char* msg, Sql_condition ** cond_hdl) override
{
return sql_errno >= ER_ABORTING_CONNECTION &&
sql_errno <= ER_NET_WRITE_INTERRUPTED;

View file

@ -322,13 +322,13 @@ public:
don't implement this method unless you really have indexes
*/
// perhaps get index type
const char *index_type(uint inx) { return "REMOTE"; }
const char *index_type(uint inx) override { return "REMOTE"; }
/*
This is a list of flags that says what the storage engine
implements. The current table flags are documented in
handler.h
*/
ulonglong table_flags() const
ulonglong table_flags() const override
{
/* fix server to be able to get remote server table flags */
return (HA_PRIMARY_KEY_IN_READ_INDEX | HA_FILE_BASED
@ -348,15 +348,15 @@ public:
index up to and including 'part'.
*/
/* fix server to be able to get remote server index flags */
ulong index_flags(uint inx, uint part, bool all_parts) const
ulong index_flags(uint inx, uint part, bool all_parts) const override
{
return (HA_READ_NEXT | HA_READ_RANGE);
}
uint max_supported_record_length() const { return HA_MAX_REC_LENGTH; }
uint max_supported_keys() const { return MAX_KEY; }
uint max_supported_key_parts() const { return MAX_REF_PARTS; }
uint max_supported_key_length() const { return FEDERATEDX_MAX_KEY_LENGTH; }
uint max_supported_key_part_length() const { return FEDERATEDX_MAX_KEY_LENGTH; }
uint max_supported_record_length() const override { return HA_MAX_REC_LENGTH; }
uint max_supported_keys() const override { return MAX_KEY; }
uint max_supported_key_parts() const override { return MAX_REF_PARTS; }
uint max_supported_key_length() const override { return FEDERATEDX_MAX_KEY_LENGTH; }
uint max_supported_key_part_length() const override { return FEDERATEDX_MAX_KEY_LENGTH; }
/*
Called in test_quick_select to determine if indexes should be used.
Normally, we need to know number of blocks . For federatedx we need to
@ -368,7 +368,7 @@ public:
The reason for "records * 1000" is that such a large number forces
this to use indexes "
*/
double scan_time()
double scan_time() override
{
DBUG_PRINT("info", ("records %lu", (ulong) stats.records));
return (double)(stats.records*1000);
@ -376,7 +376,7 @@ public:
/*
The next method will never be called if you do not implement indexes.
*/
double read_time(uint index, uint ranges, ha_rows rows)
double read_time(uint index, uint ranges, ha_rows rows) override
{
/*
Per Brian, this number is bugus, but this method must be implemented,
@ -385,33 +385,33 @@ public:
return (double) rows / 20.0+1;
}
const key_map *keys_to_use_for_scanning() { return &key_map_full; }
const key_map *keys_to_use_for_scanning() override { return &key_map_full; }
/*
Everything below are methods that we implment in ha_federatedx.cc.
Most of these methods are not obligatory, skip them and
MySQL will treat them as not implemented
*/
int open(const char *name, int mode, uint test_if_locked); // required
int close(void); // required
int open(const char *name, int mode, uint test_if_locked) override; // required
int close(void) override; // required
void start_bulk_insert(ha_rows rows, uint flags);
int end_bulk_insert();
int write_row(const uchar *buf);
int update_row(const uchar *old_data, const uchar *new_data);
int delete_row(const uchar *buf);
int index_init(uint keynr, bool sorted);
ha_rows estimate_rows_upper_bound();
void start_bulk_insert(ha_rows rows, uint flags) override;
int end_bulk_insert() override;
int write_row(const uchar *buf) override;
int update_row(const uchar *old_data, const uchar *new_data) override;
int delete_row(const uchar *buf) override;
int index_init(uint keynr, bool sorted) override;
ha_rows estimate_rows_upper_bound() override;
int index_read(uchar *buf, const uchar *key,
uint key_len, enum ha_rkey_function find_flag);
uint key_len, enum ha_rkey_function find_flag) override;
int index_read_idx(uchar *buf, uint idx, const uchar *key,
uint key_len, enum ha_rkey_function find_flag);
int index_next(uchar *buf);
int index_end();
int index_next(uchar *buf) override;
int index_end() override;
int read_range_first(const key_range *start_key,
const key_range *end_key,
bool eq_range, bool sorted);
int read_range_next();
bool eq_range, bool sorted) override;
int read_range_next() override;
/*
unlike index_init(), rnd_init() can be called two times
without rnd_end() in between (it only makes sense if scan=1).
@ -420,16 +420,16 @@ public:
position it to the start of the table, no need to deallocate
and allocate it again
*/
int rnd_init(bool scan); //required
int rnd_end();
int rnd_next(uchar *buf); //required
int rnd_pos(uchar *buf, uchar *pos); //required
void position(const uchar *record); //required
int rnd_init(bool scan) override; //required
int rnd_end() override;
int rnd_next(uchar *buf) override; //required
int rnd_pos(uchar *buf, uchar *pos) override; //required
void position(const uchar *record) override; //required
/*
A ref is a pointer inside a local buffer. It is not comparable to
other ref's. This is never called as HA_NON_COMPARABLE_ROWID is set.
*/
int cmp_ref(const uchar *ref1, const uchar *ref2)
int cmp_ref(const uchar *ref1, const uchar *ref2) override
{
#ifdef NOT_YET
DBUG_ASSERT(0);
@ -438,29 +438,29 @@ public:
return handler::cmp_ref(ref1,ref2); /* Works if table scan is used */
#endif
}
int info(uint); //required
int extra(ha_extra_function operation);
int info(uint) override; //required
int extra(ha_extra_function operation) override;
void update_auto_increment(void);
int repair(THD* thd, HA_CHECK_OPT* check_opt);
int optimize(THD* thd, HA_CHECK_OPT* check_opt);
int delete_table(const char *name)
int repair(THD* thd, HA_CHECK_OPT* check_opt) override;
int optimize(THD* thd, HA_CHECK_OPT* check_opt) override;
int delete_table(const char *name) override
{
return 0;
}
int delete_all_rows(void);
int delete_all_rows(void) override;
int create(const char *name, TABLE *form,
HA_CREATE_INFO *create_info); //required
HA_CREATE_INFO *create_info) override; //required
ha_rows records_in_range(uint inx, const key_range *start_key,
const key_range *end_key, page_range *pages);
uint8 table_cache_type() { return HA_CACHE_TBL_NOCACHE; }
const key_range *end_key, page_range *pages) override;
uint8 table_cache_type() override { return HA_CACHE_TBL_NOCACHE; }
THR_LOCK_DATA **store_lock(THD *thd, THR_LOCK_DATA **to,
enum thr_lock_type lock_type); //required
bool get_error_message(int error, String *buf);
int start_stmt(THD *thd, thr_lock_type lock_type);
int external_lock(THD *thd, int lock_type);
int reset(void);
enum thr_lock_type lock_type) override; //required
bool get_error_message(int error, String *buf) override;
int start_stmt(THD *thd, thr_lock_type lock_type) override;
int external_lock(THD *thd, int lock_type) override;
int reset(void) override;
int free_result(void);
const FEDERATEDX_SHARE *get_federatedx_share() const { return share; }