1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167
|
/* Copyright (c) 2017, 2025, Oracle and/or its affiliates.
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License, version 2.0,
as published by the Free Software Foundation.
This program is designed to work with certain software (including
but not limited to OpenSSL) that is licensed under separate terms,
as designated in a particular file or component or in included license
documentation. The authors of MySQL hereby grant you an additional
permission to link the program and your derivative works with the
separately licensed software that they have either included with
the program or referenced in the documentation.
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, version 2.0, 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-1301 USA */
#ifndef PLUGIN_PFS_TABLE_PLUGIN_pfs_example_employee_name_H_
#define PLUGIN_PFS_TABLE_PLUGIN_pfs_example_employee_name_H_
#include <mysql/components/service_implementation.h>
#include <mysql/components/services/pfs_plugin_table_service.h>
#include <mysql/plugin.h>
/* Service handle */
extern SERVICE_TYPE(pfs_plugin_column_integer_v1) * col_int_svc;
extern SERVICE_TYPE(pfs_plugin_column_string_v2) * col_string_svc;
/* Global share pointer for pfs_example_employee_name table */
extern PFS_engine_table_share_proxy ename_st_share;
/* Number of characters * max multibyte length */
#define EMPLOYEE_NAME_LEN 20 * 4
/* Maximum number of rows in the table */
#define EMPLOYEEE_NAME_MAX_ROWS 100
/* A mutex instance to protect:
* - ename_rows_in_table
* - ename_next_available_index
* - ename_records_array
*/
extern mysql_mutex_t LOCK_ename_records_array;
/* A structure to denote a single row of the table. */
struct Ename_Record {
public:
PSI_int e_number;
char f_name[EMPLOYEE_NAME_LEN];
unsigned int f_name_length;
char l_name[EMPLOYEE_NAME_LEN];
unsigned int l_name_length;
/* If there is a value in this row */
bool m_exist;
};
/**
* An array to keep rows of the tables.
* When a row is inserted in plugin table, it will be stored here.
* When a row is queried from plugin table, it will be fetched from here.
*/
extern Ename_Record ename_records_array[EMPLOYEEE_NAME_MAX_ROWS];
/* A class to define position of cursor in table. */
class Ename_POS {
private:
unsigned int m_index;
public:
~Ename_POS() = default;
Ename_POS() { m_index = 0; }
bool has_more() {
if (m_index < EMPLOYEEE_NAME_MAX_ROWS) return true;
return false;
}
void next() { m_index++; }
void reset() { m_index = 0; }
unsigned int get_index() { return m_index; }
void set_at(unsigned int index) { m_index = index; }
void set_at(Ename_POS *pos) { m_index = pos->m_index; }
void set_after(Ename_POS *pos) { m_index = pos->m_index + 1; }
};
class Ename_index {
public:
virtual ~Ename_index() = default;
virtual bool match(Ename_Record *record) = 0;
};
/* And index on Employee Number */
class Ename_index_by_emp_num : public Ename_index {
public:
PSI_plugin_key_integer m_emp_num;
bool match(Ename_Record *record) override {
return col_int_svc->match_key(false, record->e_number.val, &m_emp_num);
}
};
/* An index on Employee First Name */
class Ename_index_by_emp_fname : public Ename_index {
public:
PSI_plugin_key_string m_emp_fname;
char m_emp_fname_buffer[EMPLOYEE_NAME_LEN];
bool match(Ename_Record *record) override {
return col_string_svc->match_key_string(
false, record->f_name, record->f_name_length, &m_emp_fname);
}
};
/* A structure to define a handle for table in plugin/component code. */
struct Ename_Table_Handle {
/* Current position instance */
Ename_POS m_pos;
/* Next position instance */
Ename_POS m_next_pos;
/* Current row for the table */
Ename_Record current_row;
/* Index on table */
Ename_index_by_emp_num m_emp_num_index;
Ename_index_by_emp_fname m_emp_fname_index;
/* Index indicator */
unsigned int index_num;
};
PSI_table_handle *ename_open_table(PSI_pos **pos);
void ename_close_table(PSI_table_handle *handle);
int ename_rnd_next(PSI_table_handle *handle);
int ename_rnd_init(PSI_table_handle *h, bool scan);
int ename_rnd_pos(PSI_table_handle *handle);
int ename_index_init(PSI_table_handle *handle, uint idx, bool sorted,
PSI_index_handle **index);
int ename_index_read(PSI_index_handle *index, PSI_key_reader *reader,
unsigned int idx, int find_flag);
int ename_index_next(PSI_table_handle *handle);
void ename_reset_position(PSI_table_handle *handle);
int ename_read_column_value(PSI_table_handle *handle, PSI_field *field,
uint index);
int ename_write_row_values(PSI_table_handle *handle);
int ename_write_column_value(PSI_table_handle *handle, PSI_field *field,
unsigned int index);
int ename_update_row_values(PSI_table_handle *handle);
int ename_update_column_value(PSI_table_handle *handle, PSI_field *field,
unsigned int index);
int ename_delete_row_values(PSI_table_handle *handle);
int ename_delete_all_rows(void);
unsigned long long ename_get_row_count(void);
void init_ename_share(PFS_engine_table_share_proxy *share);
#endif /* PLUGIN_PFS_TABLE_PLUGIN_pfs_example_employee_name_H_ */
|