Commit 58e759a9 authored by Michael Widenius's avatar Michael Widenius Committed by Oleksandr Byelkin

Added 'final' to some classes to improve generated code

Final added to:
- All reasonable classes inhereted from Field
- All classes inhereted from Protocol
- Almost all Handler classes
- Some important Item classes

The stripped size of mariadbd is just 4K smaller, but several object files
showed notable improvements in common execution paths.
- Checked field.o and item_sum.o

Other things:
- Added 'override' to a few class functions touched by this patch.
- Removed 'virtual' from a new class functions that had/got 'override'
- Changed Protocol_discard to inherit from Protocol instad of Protocol_text
parent 48b5777e
This diff is collapsed.
...@@ -2157,7 +2157,7 @@ class Item_aggregate_ref : public Item_ref ...@@ -2157,7 +2157,7 @@ class Item_aggregate_ref : public Item_ref
const LEX_CSTRING &field_name_arg): const LEX_CSTRING &field_name_arg):
Item_ref(thd, context_arg, item, table_name_arg, field_name_arg) {} Item_ref(thd, context_arg, item, table_name_arg, field_name_arg) {}
virtual inline void print (String *str, enum_query_type query_type) void print (String *str, enum_query_type query_type) override
{ {
if (ref) if (ref)
(*ref)->print(str, query_type); (*ref)->print(str, query_type);
......
...@@ -744,7 +744,7 @@ class Item_func_eq :public Item_bool_rowready_func2 ...@@ -744,7 +744,7 @@ class Item_func_eq :public Item_bool_rowready_func2
{ return get_item_copy<Item_func_eq>(thd, this); } { return get_item_copy<Item_func_eq>(thd, this); }
}; };
class Item_func_equal :public Item_bool_rowready_func2 class Item_func_equal final :public Item_bool_rowready_func2
{ {
public: public:
Item_func_equal(THD *thd, Item *a, Item *b): Item_func_equal(THD *thd, Item *a, Item *b):
...@@ -3331,7 +3331,7 @@ class Item_equal_fields_iterator_slow ...@@ -3331,7 +3331,7 @@ class Item_equal_fields_iterator_slow
}; };
class Item_cond_and :public Item_cond class Item_cond_and final :public Item_cond
{ {
public: public:
COND_EQUAL m_cond_equal; /* contains list of Item_equal objects for COND_EQUAL m_cond_equal; /* contains list of Item_equal objects for
...@@ -3368,7 +3368,7 @@ inline bool is_cond_and(Item *item) ...@@ -3368,7 +3368,7 @@ inline bool is_cond_and(Item *item)
return func_item && func_item->functype() == Item_func::COND_AND_FUNC; return func_item && func_item->functype() == Item_func::COND_AND_FUNC;
} }
class Item_cond_or :public Item_cond class Item_cond_or final :public Item_cond
{ {
public: public:
Item_cond_or(THD *thd): Item_cond(thd) {} Item_cond_or(THD *thd): Item_cond(thd) {}
......
...@@ -1016,7 +1016,7 @@ class Stddev ...@@ -1016,7 +1016,7 @@ class Stddev
class Item_sum_variance : public Item_sum_double class Item_sum_variance :public Item_sum_double
{ {
Stddev m_stddev; Stddev m_stddev;
bool fix_length_and_dec(); bool fix_length_and_dec();
...@@ -1033,13 +1033,13 @@ class Item_sum_variance : public Item_sum_double ...@@ -1033,13 +1033,13 @@ class Item_sum_variance : public Item_sum_double
enum Sumfunctype sum_func () const { return VARIANCE_FUNC; } enum Sumfunctype sum_func () const { return VARIANCE_FUNC; }
void fix_length_and_dec_double(); void fix_length_and_dec_double();
void fix_length_and_dec_decimal(); void fix_length_and_dec_decimal();
void clear(); void clear() override final;
bool add(); bool add() override final;
double val_real(); double val_real();
void reset_field(); void reset_field() override final;
void update_field(); void update_field() override final;
Item *result_item(THD *thd, Field *field); Item *result_item(THD *thd, Field *field);
void no_rows_in_result() {} void no_rows_in_result() override final {}
const char *func_name() const const char *func_name() const
{ return sample ? "var_samp(" : "variance("; } { return sample ? "var_samp(" : "variance("; }
Item *copy_or_same(THD* thd); Item *copy_or_same(THD* thd);
...@@ -1057,7 +1057,7 @@ class Item_sum_variance : public Item_sum_double ...@@ -1057,7 +1057,7 @@ class Item_sum_variance : public Item_sum_double
standard_deviation(a) = sqrt(variance(a)) standard_deviation(a) = sqrt(variance(a))
*/ */
class Item_sum_std :public Item_sum_variance class Item_sum_std final :public Item_sum_variance
{ {
public: public:
Item_sum_std(THD *thd, Item *item_par, uint sample_arg): Item_sum_std(THD *thd, Item *item_par, uint sample_arg):
...@@ -1075,7 +1075,7 @@ class Item_sum_std :public Item_sum_variance ...@@ -1075,7 +1075,7 @@ class Item_sum_std :public Item_sum_variance
}; };
class Item_sum_hybrid: public Item_sum, class Item_sum_hybrid : public Item_sum,
public Type_handler_hybrid_field_type public Type_handler_hybrid_field_type
{ {
public: public:
...@@ -1156,7 +1156,7 @@ class Item_sum_min_max :public Item_sum_hybrid ...@@ -1156,7 +1156,7 @@ class Item_sum_min_max :public Item_sum_hybrid
}; };
class Item_sum_min :public Item_sum_min_max class Item_sum_min final :public Item_sum_min_max
{ {
public: public:
Item_sum_min(THD *thd, Item *item_par): Item_sum_min_max(thd, item_par, 1) {} Item_sum_min(THD *thd, Item *item_par): Item_sum_min_max(thd, item_par, 1) {}
...@@ -1171,7 +1171,7 @@ class Item_sum_min :public Item_sum_min_max ...@@ -1171,7 +1171,7 @@ class Item_sum_min :public Item_sum_min_max
}; };
class Item_sum_max :public Item_sum_min_max class Item_sum_max final :public Item_sum_min_max
{ {
public: public:
Item_sum_max(THD *thd, Item *item_par): Item_sum_min_max(thd, item_par, -1) {} Item_sum_max(THD *thd, Item *item_par): Item_sum_min_max(thd, item_par, -1) {}
...@@ -1260,7 +1260,7 @@ class Item_sum_bit :public Item_sum_int ...@@ -1260,7 +1260,7 @@ class Item_sum_bit :public Item_sum_int
}; };
class Item_sum_or :public Item_sum_bit class Item_sum_or final :public Item_sum_bit
{ {
public: public:
Item_sum_or(THD *thd, Item *item_par): Item_sum_bit(thd, item_par, 0) {} Item_sum_or(THD *thd, Item *item_par): Item_sum_bit(thd, item_par, 0) {}
...@@ -1276,7 +1276,7 @@ class Item_sum_or :public Item_sum_bit ...@@ -1276,7 +1276,7 @@ class Item_sum_or :public Item_sum_bit
}; };
class Item_sum_and :public Item_sum_bit class Item_sum_and final :public Item_sum_bit
{ {
public: public:
Item_sum_and(THD *thd, Item *item_par): Item_sum_and(THD *thd, Item *item_par):
...@@ -1292,7 +1292,7 @@ class Item_sum_and :public Item_sum_bit ...@@ -1292,7 +1292,7 @@ class Item_sum_and :public Item_sum_bit
void set_bits_from_counters(); void set_bits_from_counters();
}; };
class Item_sum_xor :public Item_sum_bit class Item_sum_xor final :public Item_sum_bit
{ {
public: public:
Item_sum_xor(THD *thd, Item *item_par): Item_sum_bit(thd, item_par, 0) {} Item_sum_xor(THD *thd, Item *item_par): Item_sum_bit(thd, item_par, 0) {}
...@@ -1359,7 +1359,7 @@ struct st_sp_security_context; ...@@ -1359,7 +1359,7 @@ struct st_sp_security_context;
Example: Example:
DECLARE CONTINUE HANDLER FOR NOT FOUND RETURN ret_val; DECLARE CONTINUE HANDLER FOR NOT FOUND RETURN ret_val;
*/ */
class Item_sum_sp :public Item_sum, class Item_sum_sp final :public Item_sum,
public Item_sp public Item_sp
{ {
private: private:
......
...@@ -190,7 +190,8 @@ class Protocol ...@@ -190,7 +190,8 @@ class Protocol
Before adding a new type, please make sure Before adding a new type, please make sure
there is enough storage for it in Query_cache_query_flags. there is enough storage for it in Query_cache_query_flags.
*/ */
PROTOCOL_TEXT= 0, PROTOCOL_BINARY= 1, PROTOCOL_LOCAL= 2 PROTOCOL_TEXT= 0, PROTOCOL_BINARY= 1, PROTOCOL_LOCAL= 2,
PROTOCOL_DISCARD= 3 /* Should be last, not used by Query_cache */
}; };
virtual enum enum_protocol_type type()= 0; virtual enum enum_protocol_type type()= 0;
...@@ -204,7 +205,7 @@ class Protocol ...@@ -204,7 +205,7 @@ class Protocol
/** Class used for the old (MySQL 4.0 protocol). */ /** Class used for the old (MySQL 4.0 protocol). */
class Protocol_text :public Protocol class Protocol_text final :public Protocol
{ {
public: public:
Protocol_text(THD *thd_arg, ulong prealloc= 0) Protocol_text(THD *thd_arg, ulong prealloc= 0)
...@@ -242,11 +243,11 @@ class Protocol_text :public Protocol ...@@ -242,11 +243,11 @@ class Protocol_text :public Protocol
bool store_field_metadata_for_list_fields(const THD *thd, Field *field, bool store_field_metadata_for_list_fields(const THD *thd, Field *field,
const TABLE_LIST *table_list, const TABLE_LIST *table_list,
uint pos); uint pos);
virtual enum enum_protocol_type type() { return PROTOCOL_TEXT; }; enum enum_protocol_type type() override { return PROTOCOL_TEXT; };
}; };
class Protocol_binary :public Protocol class Protocol_binary final :public Protocol
{ {
private: private:
uint bit_fields; uint bit_fields;
...@@ -279,7 +280,7 @@ class Protocol_binary :public Protocol ...@@ -279,7 +280,7 @@ class Protocol_binary :public Protocol
virtual bool send_out_parameters(List<Item_param> *sp_params); virtual bool send_out_parameters(List<Item_param> *sp_params);
virtual enum enum_protocol_type type() { return PROTOCOL_BINARY; }; enum enum_protocol_type type() override { return PROTOCOL_BINARY; };
}; };
...@@ -297,37 +298,38 @@ class Protocol_binary :public Protocol ...@@ -297,37 +298,38 @@ class Protocol_binary :public Protocol
select_send::send_data() & co., and also uses Protocol_discard object. select_send::send_data() & co., and also uses Protocol_discard object.
*/ */
class Protocol_discard : public Protocol_text class Protocol_discard final : public Protocol
{ {
public: public:
Protocol_discard(THD *thd_arg) : Protocol_text(thd_arg) {} Protocol_discard(THD *thd_arg) : Protocol(thd_arg) {}
bool write() { return 0; } bool write() override { return 0; }
bool send_result_set_metadata(List<Item> *, uint) { return 0; } bool send_result_set_metadata(List<Item> *, uint) override { return 0; }
bool send_eof(uint, uint) { return 0; } bool send_eof(uint, uint) override { return 0; }
void prepare_for_resend() { IF_DBUG(field_pos= 0,); } void prepare_for_resend() override { IF_DBUG(field_pos= 0,); }
bool send_out_parameters(List<Item_param> *sp_params) override { return false; }
/* /*
Provide dummy overrides for any storage methods so that we Provide dummy overrides for any storage methods so that we
avoid allocating and copying of data avoid allocating and copying of data
*/ */
bool store_null() { return false; } bool store_null() override { return false; }
bool store_tiny(longlong) { return false; } bool store_tiny(longlong) override { return false; }
bool store_short(longlong) { return false; } bool store_short(longlong) override { return false; }
bool store_long(longlong) { return false; } bool store_long(longlong) override { return false; }
bool store_longlong(longlong, bool) { return false; } bool store_longlong(longlong, bool) override { return false; }
bool store_decimal(const my_decimal *) { return false; } bool store_decimal(const my_decimal *) override { return false; }
bool store_str(const char *, size_t, CHARSET_INFO *, my_repertoire_t, bool store_str(const char *, size_t, CHARSET_INFO *, my_repertoire_t,
CHARSET_INFO *) CHARSET_INFO *) override
{ {
return false; return false;
} }
bool store(MYSQL_TIME *, int) { return false; } bool store(MYSQL_TIME *, int) override { return false; }
bool store_date(MYSQL_TIME *) { return false; } bool store_date(MYSQL_TIME *) override { return false; }
bool store_time(MYSQL_TIME *, int) { return false; } bool store_time(MYSQL_TIME *, int) override { return false; }
bool store(float, uint32, String *) { return false; } bool store(float, uint32, String *) override { return false; }
bool store(double, uint32, String *) { return false; } bool store(double, uint32, String *) override { return false; }
bool store(Field *) { return false; } bool store(Field *) override { return false; }
enum enum_protocol_type type() override { return PROTOCOL_DISCARD; };
}; };
......
...@@ -73,7 +73,7 @@ class Archive_share : public Handler_share ...@@ -73,7 +73,7 @@ class Archive_share : public Handler_share
*/ */
#define ARCHIVE_VERSION 3 #define ARCHIVE_VERSION 3
class ha_archive: public handler class ha_archive final : public handler
{ {
THR_LOCK_DATA lock; /* MySQL lock */ THR_LOCK_DATA lock; /* MySQL lock */
Archive_share *share; /* Shared lock info */ Archive_share *share; /* Shared lock info */
......
...@@ -36,7 +36,7 @@ struct st_blackhole_share { ...@@ -36,7 +36,7 @@ struct st_blackhole_share {
Class definition for the blackhole storage engine Class definition for the blackhole storage engine
"Dumbest named feature ever" "Dumbest named feature ever"
*/ */
class ha_blackhole: public handler class ha_blackhole final : public handler
{ {
THR_LOCK_DATA lock; /* MySQL lock */ THR_LOCK_DATA lock; /* MySQL lock */
st_blackhole_share *share; st_blackhole_share *share;
......
...@@ -144,7 +144,7 @@ typedef class ha_connect *PHC; ...@@ -144,7 +144,7 @@ typedef class ha_connect *PHC;
/** @brief /** @brief
Class definition for the storage engine Class definition for the storage engine
*/ */
class ha_connect: public handler class ha_connect final : public handler
{ {
THR_LOCK_DATA lock; ///< MySQL lock THR_LOCK_DATA lock; ///< MySQL lock
CONNECT_SHARE *share; ///< Shared lock info CONNECT_SHARE *share; ///< Shared lock info
......
...@@ -57,7 +57,7 @@ struct tina_set { ...@@ -57,7 +57,7 @@ struct tina_set {
my_off_t end; my_off_t end;
}; };
class ha_tina: public handler class ha_tina final : public handler
{ {
THR_LOCK_DATA lock; /* MySQL lock */ THR_LOCK_DATA lock; /* MySQL lock */
TINA_SHARE *share; /* Shared lock info */ TINA_SHARE *share; /* Shared lock info */
......
...@@ -260,7 +260,7 @@ class federatedx_txn ...@@ -260,7 +260,7 @@ class federatedx_txn
/* /*
Class definition for the storage engine Class definition for the storage engine
*/ */
class ha_federatedx: public handler class ha_federatedx final : public handler
{ {
friend int federatedx_db_init(void *p); friend int federatedx_db_init(void *p);
......
...@@ -25,7 +25,7 @@ ...@@ -25,7 +25,7 @@
#include <heap.h> #include <heap.h>
#include "sql_class.h" /* THD */ #include "sql_class.h" /* THD */
class ha_heap: public handler class ha_heap final : public handler
{ {
HP_INFO *file; HP_INFO *file;
HP_SHARE *internal_share; HP_SHARE *internal_share;
......
...@@ -58,7 +58,7 @@ struct st_handler_tablename ...@@ -58,7 +58,7 @@ struct st_handler_tablename
const char *tablename; const char *tablename;
}; };
/** The class defining a handle to an Innodb table */ /** The class defining a handle to an Innodb table */
class ha_innobase final: public handler class ha_innobase final : public handler
{ {
public: public:
ha_innobase(handlerton* hton, TABLE_SHARE* table_arg); ha_innobase(handlerton* hton, TABLE_SHARE* table_arg);
......
...@@ -39,6 +39,11 @@ C_MODE_END ...@@ -39,6 +39,11 @@ C_MODE_END
extern TYPELIB maria_recover_typelib; extern TYPELIB maria_recover_typelib;
extern ulonglong maria_recover_options; extern ulonglong maria_recover_options;
/*
In the ha_maria class there are a few virtual methods that are not marked as
'final'. This is because they are re-defined by the ha_s3 engine.
*/
class __attribute__((visibility("default"))) ha_maria :public handler class __attribute__((visibility("default"))) ha_maria :public handler
{ {
public: public:
...@@ -61,98 +66,98 @@ class __attribute__((visibility("default"))) ha_maria :public handler ...@@ -61,98 +66,98 @@ class __attribute__((visibility("default"))) ha_maria :public handler
ha_maria(handlerton *hton, TABLE_SHARE * table_arg); ha_maria(handlerton *hton, TABLE_SHARE * table_arg);
~ha_maria() {} ~ha_maria() {}
handler *clone(const char *name, MEM_ROOT *mem_root); handler *clone(const char *name, MEM_ROOT *mem_root);
const char *index_type(uint key_number); const char *index_type(uint key_number) override final;
ulonglong table_flags() const ulonglong table_flags() const override final
{ return int_table_flags; } { return int_table_flags; }
ulong index_flags(uint inx, uint part, bool all_parts) const; ulong index_flags(uint inx, uint part, bool all_parts) const override final;
uint max_supported_keys() const uint max_supported_keys() const override final
{ return MARIA_MAX_KEY; } { return MARIA_MAX_KEY; }
uint max_supported_key_length() const; uint max_supported_key_length() const override final;
uint max_supported_key_part_length() const uint max_supported_key_part_length() const override final
{ return max_supported_key_length(); } { return max_supported_key_length(); }
enum row_type get_row_type() const; enum row_type get_row_type() const override final;
void change_table_ptr(TABLE *table_arg, TABLE_SHARE *share); void change_table_ptr(TABLE *table_arg, TABLE_SHARE *share) override final;
virtual double scan_time(); virtual double scan_time() override final;
int open(const char *name, int mode, uint test_if_locked); int open(const char *name, int mode, uint test_if_locked) override;
int close(void); int close(void) override final;
int write_row(const uchar * buf); int write_row(const uchar * buf) override;
int update_row(const uchar * old_data, const uchar * new_data); int update_row(const uchar * old_data, const uchar * new_data) override;
int delete_row(const uchar * buf); int delete_row(const uchar * buf) override;
int index_read_map(uchar * buf, const uchar * key, key_part_map keypart_map, int index_read_map(uchar * buf, const uchar * key, key_part_map keypart_map,
enum ha_rkey_function find_flag); enum ha_rkey_function find_flag) override final;
int index_read_idx_map(uchar * buf, uint idx, const uchar * key, int index_read_idx_map(uchar * buf, uint idx, const uchar * key,
key_part_map keypart_map, key_part_map keypart_map,
enum ha_rkey_function find_flag); enum ha_rkey_function find_flag) override final;
int index_read_last_map(uchar * buf, const uchar * key, int index_read_last_map(uchar * buf, const uchar * key,
key_part_map keypart_map); key_part_map keypart_map) override final;
int index_next(uchar * buf); int index_next(uchar * buf) override final;
int index_prev(uchar * buf); int index_prev(uchar * buf) override final;
int index_first(uchar * buf); int index_first(uchar * buf) override final;
int index_last(uchar * buf); int index_last(uchar * buf) override final;
int index_next_same(uchar * buf, const uchar * key, uint keylen); int index_next_same(uchar * buf, const uchar * key, uint keylen) override final;
int ft_init() int ft_init() override final
{ {
if (!ft_handler) if (!ft_handler)
return 1; return 1;
ft_handler->please->reinit_search(ft_handler); ft_handler->please->reinit_search(ft_handler);
return 0; return 0;
} }
FT_INFO *ft_init_ext(uint flags, uint inx, String * key); FT_INFO *ft_init_ext(uint flags, uint inx, String * key) override final;
int ft_read(uchar * buf); int ft_read(uchar * buf) override final;
int index_init(uint idx, bool sorted); int index_init(uint idx, bool sorted) override final;
int index_end(); int index_end() override final;
int rnd_init(bool scan); int rnd_init(bool scan) override final;
int rnd_end(void); int rnd_end(void) override final;
int rnd_next(uchar * buf); int rnd_next(uchar * buf) override final;
int rnd_pos(uchar * buf, uchar * pos); int rnd_pos(uchar * buf, uchar * pos) override final;
int remember_rnd_pos(); int remember_rnd_pos() override final;
int restart_rnd_next(uchar * buf); int restart_rnd_next(uchar * buf) override final;
void position(const uchar * record); void position(const uchar * record) override final;
int info(uint); int info(uint) override final;
int info(uint, my_bool); int info(uint, my_bool);
int extra(enum ha_extra_function operation); int extra(enum ha_extra_function operation) override final;
int extra_opt(enum ha_extra_function operation, ulong cache_size); int extra_opt(enum ha_extra_function operation, ulong cache_size) override final;
int reset(void); int reset(void) override final;
int external_lock(THD * thd, int lock_type); int external_lock(THD * thd, int lock_type) override;
int start_stmt(THD *thd, thr_lock_type lock_type); int start_stmt(THD *thd, thr_lock_type lock_type) override final;
int delete_all_rows(void); int delete_all_rows(void) override final;
int disable_indexes(uint mode); int disable_indexes(uint mode) override final;
int enable_indexes(uint mode); int enable_indexes(uint mode) override final;
int indexes_are_disabled(void); int indexes_are_disabled(void) override final;
void start_bulk_insert(ha_rows rows, uint flags); void start_bulk_insert(ha_rows rows, uint flags) override final;
int end_bulk_insert(); int end_bulk_insert() override final;
ha_rows records_in_range(uint inx, const key_range *min_key, ha_rows records_in_range(uint inx, const key_range *min_key,
const key_range *max_key, const key_range *max_key,
page_range *pages); page_range *pages) override final;
void update_create_info(HA_CREATE_INFO * create_info); void update_create_info(HA_CREATE_INFO * create_info) override final;
int create(const char *name, TABLE * form, HA_CREATE_INFO * create_info); int create(const char *name, TABLE * form, HA_CREATE_INFO * create_info) override;
THR_LOCK_DATA **store_lock(THD * thd, THR_LOCK_DATA ** to, THR_LOCK_DATA **store_lock(THD * thd, THR_LOCK_DATA ** to,
enum thr_lock_type lock_type); enum thr_lock_type lock_type) override final;
virtual void get_auto_increment(ulonglong offset, ulonglong increment, virtual void get_auto_increment(ulonglong offset, ulonglong increment,
ulonglong nb_desired_values, ulonglong nb_desired_values,
ulonglong *first_value, ulonglong *first_value,
ulonglong *nb_reserved_values); ulonglong *nb_reserved_values) override final;
int rename_table(const char *from, const char *to); int rename_table(const char *from, const char *to) override;
int delete_table(const char *name); int delete_table(const char *name) override;
void drop_table(const char *name); void drop_table(const char *name) override;
int check(THD * thd, HA_CHECK_OPT * check_opt); int check(THD * thd, HA_CHECK_OPT * check_opt) override;
int analyze(THD * thd, HA_CHECK_OPT * check_opt); int analyze(THD * thd, HA_CHECK_OPT * check_opt) override;
int repair(THD * thd, HA_CHECK_OPT * check_opt); int repair(THD * thd, HA_CHECK_OPT * check_opt) override;
bool check_and_repair(THD * thd); bool check_and_repair(THD * thd) override final;
bool is_crashed() const; bool is_crashed() const override final;
bool is_changed() const; bool is_changed() const;
bool auto_repair(int error) const; bool auto_repair(int error) const override final;
int optimize(THD * thd, HA_CHECK_OPT * check_opt); int optimize(THD * thd, HA_CHECK_OPT * check_opt) override final;
int assign_to_keycache(THD * thd, HA_CHECK_OPT * check_opt); int assign_to_keycache(THD * thd, HA_CHECK_OPT * check_opt) override final;
int preload_keys(THD * thd, HA_CHECK_OPT * check_opt); int preload_keys(THD * thd, HA_CHECK_OPT * check_opt) override;
bool check_if_incompatible_data(HA_CREATE_INFO * info, uint table_changes); bool check_if_incompatible_data(HA_CREATE_INFO * info, uint table_changes) override final;
#ifdef HAVE_QUERY_CACHE #ifdef HAVE_QUERY_CACHE
my_bool register_query_cache_table(THD *thd, const char *table_key, my_bool register_query_cache_table(THD *thd, const char *table_key,
uint key_length, uint key_length,
qc_engine_callback qc_engine_callback
*engine_callback, *engine_callback,
ulonglong *engine_data); ulonglong *engine_data) override final;
#endif #endif
MARIA_HA *file_ptr(void) MARIA_HA *file_ptr(void)
{ {
...@@ -164,21 +169,21 @@ class __attribute__((visibility("default"))) ha_maria :public handler ...@@ -164,21 +169,21 @@ class __attribute__((visibility("default"))) ha_maria :public handler
* Multi Range Read interface * Multi Range Read interface
*/ */
int multi_range_read_init(RANGE_SEQ_IF *seq, void *seq_init_param, int multi_range_read_init(RANGE_SEQ_IF *seq, void *seq_init_param,
uint n_ranges, uint mode, HANDLER_BUFFER *buf); uint n_ranges, uint mode, HANDLER_BUFFER *buf) override final;
int multi_range_read_next(range_id_t *range_info); int multi_range_read_next(range_id_t *range_info) override final;
ha_rows multi_range_read_info_const(uint keyno, RANGE_SEQ_IF *seq, ha_rows multi_range_read_info_const(uint keyno, RANGE_SEQ_IF *seq,
void *seq_init_param, void *seq_init_param,
uint n_ranges, uint *bufsz, uint n_ranges, uint *bufsz,
uint *flags, Cost_estimate *cost); uint *flags, Cost_estimate *cost) override final;
ha_rows multi_range_read_info(uint keyno, uint n_ranges, uint keys, ha_rows multi_range_read_info(uint keyno, uint n_ranges, uint keys,
uint key_parts, uint *bufsz, uint key_parts, uint *bufsz,
uint *flags, Cost_estimate *cost); uint *flags, Cost_estimate *cost) override final;
int multi_range_read_explain_info(uint mrr_mode, char *str, size_t size); int multi_range_read_explain_info(uint mrr_mode, char *str, size_t size) override final;
/* Index condition pushdown implementation */ /* Index condition pushdown implementation */
Item *idx_cond_push(uint keyno, Item* idx_cond); Item *idx_cond_push(uint keyno, Item* idx_cond) override final;
int find_unique_row(uchar *record, uint unique_idx); int find_unique_row(uchar *record, uint unique_idx) override final;
/* Following functions are needed by the S3 handler */ /* Following functions are needed by the S3 handler */
virtual S3_INFO *s3_open_args() { return 0; } virtual S3_INFO *s3_open_args() { return 0; }
......
...@@ -19,7 +19,7 @@ ...@@ -19,7 +19,7 @@
#include "ha_maria.h" #include "ha_maria.h"
class ha_s3 :public ha_maria class ha_s3 final :public ha_maria
{ {
enum alter_table_op enum alter_table_op
{ S3_NO_ALTER, S3_ALTER_TABLE, S3_ADD_PARTITION, S3_ADD_TMP_PARTITION }; { S3_NO_ALTER, S3_ALTER_TABLE, S3_ADD_PARTITION, S3_ADD_TMP_PARTITION };
...@@ -31,52 +31,52 @@ class ha_s3 :public ha_maria ...@@ -31,52 +31,52 @@ class ha_s3 :public ha_maria
~ha_s3() {} ~ha_s3() {}
int create(const char *name, TABLE *table_arg, int create(const char *name, TABLE *table_arg,
HA_CREATE_INFO *ha_create_info) final; HA_CREATE_INFO *ha_create_info);
int open(const char *name, int mode, uint open_flags) final; int open(const char *name, int mode, uint open_flags);
int write_row(const uchar *buf) final; int write_row(const uchar *buf);
int update_row(const uchar * old_data, const uchar * new_data) final int update_row(const uchar * old_data, const uchar * new_data)
{ {
DBUG_ENTER("update_row"); DBUG_ENTER("update_row");
DBUG_RETURN(HA_ERR_WRONG_COMMAND); DBUG_RETURN(HA_ERR_WRONG_COMMAND);
} }
int delete_row(const uchar * buf) final int delete_row(const uchar * buf)
{ {
DBUG_ENTER("delete_row"); DBUG_ENTER("delete_row");
DBUG_RETURN(HA_ERR_WRONG_COMMAND); DBUG_RETURN(HA_ERR_WRONG_COMMAND);
} }
int check(THD * thd, HA_CHECK_OPT * check_opt) final int check(THD * thd, HA_CHECK_OPT * check_opt)
{ {
DBUG_ENTER("delete_row"); DBUG_ENTER("delete_row");
DBUG_RETURN(HA_ERR_WRONG_COMMAND); DBUG_RETURN(HA_ERR_WRONG_COMMAND);
} }
int analyze(THD * thd, HA_CHECK_OPT * check_opt) final int analyze(THD * thd, HA_CHECK_OPT * check_opt)
{ {
DBUG_ENTER("analyze"); DBUG_ENTER("analyze");
DBUG_RETURN(HA_ERR_WRONG_COMMAND); DBUG_RETURN(HA_ERR_WRONG_COMMAND);
} }
int repair(THD * thd, HA_CHECK_OPT * check_opt) final int repair(THD * thd, HA_CHECK_OPT * check_opt)
{ {
DBUG_ENTER("repair"); DBUG_ENTER("repair");
DBUG_RETURN(HA_ERR_WRONG_COMMAND); DBUG_RETURN(HA_ERR_WRONG_COMMAND);
} }
int preload_keys(THD * thd, HA_CHECK_OPT * check_opt) final int preload_keys(THD * thd, HA_CHECK_OPT * check_opt)
{ {
DBUG_ENTER("preload_keys"); DBUG_ENTER("preload_keys");
DBUG_RETURN(HA_ERR_WRONG_COMMAND); DBUG_RETURN(HA_ERR_WRONG_COMMAND);
} }
int external_lock(THD * thd, int lock_type) final; int external_lock(THD * thd, int lock_type);
/* /*
drop_table() is only used for internal temporary tables, drop_table() is only used for internal temporary tables,
not applicable for s3 not applicable for s3
*/ */
void drop_table(const char *name) final void drop_table(const char *name)
{ {
} }
int delete_table(const char *name) final; int delete_table(const char *name);
int rename_table(const char *from, const char *to) final; int rename_table(const char *from, const char *to);
int discover_check_version() override; int discover_check_version() override;
int rebind(); int rebind();
S3_INFO *s3_open_args() final { return open_args; } S3_INFO *s3_open_args() { return open_args; }
void register_handler(MARIA_HA *file) final; void register_handler(MARIA_HA *file);
}; };
#endif /* HA_S3_INCLUDED */ #endif /* HA_S3_INCLUDED */
...@@ -41,7 +41,7 @@ C_MODE_START ...@@ -41,7 +41,7 @@ C_MODE_START
check_result_t index_cond_func_myisam(void *arg); check_result_t index_cond_func_myisam(void *arg);
C_MODE_END C_MODE_END
class ha_myisam: public handler class ha_myisam final : public handler
{ {
MI_INFO *file; MI_INFO *file;
ulonglong int_table_flags; ulonglong int_table_flags;
......
...@@ -68,7 +68,7 @@ class Mrg_child_def: public Sql_alloc ...@@ -68,7 +68,7 @@ class Mrg_child_def: public Sql_alloc
}; };
class ha_myisammrg: public handler class ha_myisammrg final : public handler
{ {
MYRG_INFO *file; MYRG_INFO *file;
my_bool is_cloned; /* This instance has been cloned */ my_bool is_cloned; /* This instance has been cloned */
......
...@@ -41,7 +41,7 @@ class PFS_engine_table; ...@@ -41,7 +41,7 @@ class PFS_engine_table;
extern const char *pfs_engine_name; extern const char *pfs_engine_name;
/** A handler for a PERFORMANCE_SCHEMA table. */ /** A handler for a PERFORMANCE_SCHEMA table. */
class ha_perfschema : public handler class ha_perfschema final : public handler
{ {
public: public:
/** /**
......
...@@ -53,7 +53,7 @@ class Sequence_share : public Handler_share { ...@@ -53,7 +53,7 @@ class Sequence_share : public Handler_share {
} }
}; };
class ha_seq: public handler class ha_seq final : public handler
{ {
private: private:
THR_LOCK_DATA lock; THR_LOCK_DATA lock;
......
...@@ -30,7 +30,7 @@ struct CSphSEStats; ...@@ -30,7 +30,7 @@ struct CSphSEStats;
struct CSphSEThreadTable; struct CSphSEThreadTable;
/// Sphinx SE handler class /// Sphinx SE handler class
class ha_sphinx : public handler class ha_sphinx final : public handler
{ {
protected: protected:
THR_LOCK_DATA m_tLock; ///< MySQL lock THR_LOCK_DATA m_tLock; ///< MySQL lock
......
...@@ -49,7 +49,7 @@ struct st_spider_ft_info ...@@ -49,7 +49,7 @@ struct st_spider_ft_info
String *key; String *key;
}; };
class ha_spider: public handler class ha_spider final : public handler
{ {
public: public:
SPIDER_SHARE *share; SPIDER_SHARE *share;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment