-
Notifications
You must be signed in to change notification settings - Fork 4k
/
Copy pathspatial_reference_systems.cc
114 lines (94 loc) · 4.46 KB
/
spatial_reference_systems.cc
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
/* Copyright (c) 2016, 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 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,
51 Franklin Street, Suite 500, Boston, MA 02110-1335 USA */
#include "dd/impl/tables/spatial_reference_systems.h"
#include "dd/impl/raw/object_keys.h" // Parent_id_range_key
namespace dd {
namespace tables {
const Spatial_reference_systems & Spatial_reference_systems::instance()
{
static Spatial_reference_systems *s_instance=
new Spatial_reference_systems();
return *s_instance;
}
///////////////////////////////////////////////////////////////////////////
Spatial_reference_systems::Spatial_reference_systems()
{
m_target_def.table_name(table_name());
m_target_def.dd_version(1);
m_target_def.add_field(FIELD_ID,
"FIELD_ID",
"id INTEGER UNSIGNED NOT NULL");
m_target_def.add_field(FIELD_CATALOG_ID, "FIELD_CATALOG_ID",
"catalog_id BIGINT UNSIGNED NOT NULL");
m_target_def.add_field(FIELD_NAME,
"FIELD_NAME",
"name CHARACTER VARYING(256)\n"
"NOT NULL");
m_target_def.add_field(FIELD_LAST_ALTERED,
"FIELD_LAST_ALTERED",
"last_altered TIMESTAMP NOT NULL\n"
"DEFAULT CURRENT_TIMESTAMP\n"
"ON UPDATE CURRENT_TIMESTAMP");
m_target_def.add_field(FIELD_CREATED,
"FIELD_CREATED",
"created TIMESTAMP NOT NULL\n"
"DEFAULT CURRENT_TIMESTAMP");
m_target_def.add_field(FIELD_ORGANIZATION,
"FIELD_ORGANIZATION",
"organization CHARACTER VARYING(256)\n");
m_target_def.add_field(FIELD_ORGANIZATION_COORDSYS_ID,
"FIELD_ORGANIZATION_COORDSYS_ID",
"organization_coordsys_id INTEGER UNSIGNED");
m_target_def.add_field(FIELD_DEFINITION,
"FIELD_DEFINITION",
"definition CHARACTER VARYING(4096)\n"
"NOT NULL");
m_target_def.add_field(FIELD_DESCRIPTION,
"FIELD_DESCRIPTION",
"description CHARACTER VARYING(2048)");
m_target_def.add_index("PRIMARY KEY (id)");
m_target_def.add_index("UNIQUE KEY (catalog_id, name)");
m_target_def.add_foreign_key("FOREIGN KEY (catalog_id) REFERENCES \
catalogs(id)");
m_target_def.add_option("ENGINE=INNODB");
m_target_def.add_option("DEFAULT CHARSET=utf8");
m_target_def.add_option("COLLATE=utf8_general_ci");
m_target_def.add_option("STATS_PERSISTENT=0");
}
///////////////////////////////////////////////////////////////////////////
bool Spatial_reference_systems::update_object_key(Item_name_key *key,
Object_id catalog_id,
const std::string &name)
{
// Construct a lowercase version of the key. The collation of the
// name column is also accent insensitive, but we don't have a
// function to make a canonical accent insensitive representation
// yet. We have to settle for a lowercase name here and reject
// accent variations when trying to store the object.
char lowercase_name[257];
memcpy(lowercase_name, name.c_str(), name.size() + 1);
my_casedn_str(&my_charset_utf8_general_ci, lowercase_name);
key->update(FIELD_CATALOG_ID, catalog_id, FIELD_NAME, lowercase_name);
return false;
}
///////////////////////////////////////////////////////////////////////////
/* purecov: begin deadcode */
Object_key *
Spatial_reference_systems::create_key_by_catalog_id(Object_id catalog_id)
{
return new (std::nothrow) Parent_id_range_key(1, FIELD_CATALOG_ID,
catalog_id);
}
/* purecov: end */
///////////////////////////////////////////////////////////////////////////
}
}