159 lines
5.3 KiB
C++
159 lines
5.3 KiB
C++
/* Copyright (c) 2017, 2019, Oracle and/or its affiliates. All rights reserved.
|
|
|
|
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 also distributed 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 included with MySQL.
|
|
|
|
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_POC_PLUGIN_COUNTRY_H_
|
|
#define PLUGIN_PFS_TABLE_PLUGIN_POC_PLUGIN_COUNTRY_H_
|
|
|
|
#include <mysql/components/service_implementation.h>
|
|
#include <mysql/components/services/pfs_plugin_table_service.h>
|
|
|
|
#include "pfs_example_component_population.h"
|
|
#include "thr_mutex.h"
|
|
|
|
/* Global share pointer for pfs_example_country table */
|
|
extern PFS_engine_table_share_proxy country_st_share;
|
|
|
|
/* Maximum number of rows in the table */
|
|
#define COUNTRY_MAX_ROWS 10
|
|
|
|
/* A mutex instance to protect:
|
|
* - country_rows_in_table
|
|
* - country_next_available_index
|
|
* - country_records_array
|
|
*/
|
|
extern native_mutex_t LOCK_country_records_array;
|
|
|
|
/* A structure to denote a single row of the table. */
|
|
class Country_record {
|
|
public:
|
|
char name[20];
|
|
unsigned int name_length;
|
|
char continent_name[20];
|
|
unsigned int continent_name_length;
|
|
PSI_year year;
|
|
PSI_bigint population;
|
|
PSI_double growth_factor;
|
|
/* 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 Country_record country_records_array[COUNTRY_MAX_ROWS];
|
|
|
|
/* A class to define position of cursor in table. */
|
|
class Country_POS {
|
|
private:
|
|
unsigned int m_index;
|
|
|
|
public:
|
|
~Country_POS() {}
|
|
Country_POS() { m_index = 0; }
|
|
|
|
bool has_more() {
|
|
if (m_index < COUNTRY_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(Country_POS *pos) { m_index = pos->m_index; }
|
|
|
|
void set_after(Country_POS *pos) { m_index = pos->m_index + 1; }
|
|
};
|
|
|
|
class Country_index {
|
|
public:
|
|
virtual ~Country_index() {}
|
|
|
|
virtual bool match(Country_record *record) = 0;
|
|
};
|
|
|
|
/* An index on Country Name */
|
|
class Country_index_by_name : public Country_index {
|
|
public:
|
|
PSI_plugin_key_string m_continent_name;
|
|
char m_continent_name_buffer[20];
|
|
|
|
PSI_plugin_key_string m_country_name;
|
|
char m_country_name_buffer[20];
|
|
|
|
bool match(Country_record *record) {
|
|
return mysql_service_pfs_plugin_table->match_key_string(
|
|
false, record->name, record->name_length, &m_country_name) &&
|
|
mysql_service_pfs_plugin_table->match_key_string(
|
|
false, record->continent_name, record->continent_name_length,
|
|
&m_continent_name);
|
|
}
|
|
};
|
|
|
|
/* A structure to define a handle for table in plugin/component code. */
|
|
typedef struct {
|
|
/* Current position instance */
|
|
Country_POS m_pos;
|
|
/* Next position instance */
|
|
Country_POS m_next_pos;
|
|
|
|
/* Current row for the table */
|
|
Country_record current_row;
|
|
|
|
/* Current index for the table */
|
|
Country_index_by_name m_index;
|
|
|
|
/* Index indicator */
|
|
unsigned int index_num;
|
|
} Country_Table_Handle;
|
|
|
|
PSI_table_handle *country_open_table(PSI_pos **pos);
|
|
void country_close_table(PSI_table_handle *handle);
|
|
int country_rnd_next(PSI_table_handle *handle);
|
|
int country_rnd_init(PSI_table_handle *h, bool scan);
|
|
int country_rnd_pos(PSI_table_handle *handle);
|
|
int country_index_init(PSI_table_handle *handle, unsigned int idx, bool sorted,
|
|
PSI_index_handle **index);
|
|
int country_index_read(PSI_index_handle *index, PSI_key_reader *reader,
|
|
unsigned int idx, int find_flag);
|
|
int country_index_next(PSI_table_handle *handle);
|
|
void country_reset_position(PSI_table_handle *handle);
|
|
int country_read_column_value(PSI_table_handle *handle, PSI_field *field,
|
|
unsigned int index);
|
|
int country_write_row_values(PSI_table_handle *handle);
|
|
int country_write_column_value(PSI_table_handle *handle, PSI_field *field,
|
|
unsigned int index);
|
|
int country_update_row_values(PSI_table_handle *handle);
|
|
int country_update_column_value(PSI_table_handle *handle, PSI_field *field,
|
|
unsigned int index);
|
|
int country_delete_row_values(PSI_table_handle *handle);
|
|
int country_delete_all_rows(void);
|
|
unsigned long long country_get_row_count(void);
|
|
void init_country_share(PFS_engine_table_share_proxy *share);
|
|
|
|
#endif /* PLUGIN_PFS_TABLE_PLUGIN_POC_PLUGIN_COUNTRY_H_ */
|