blob: 74dcfd07768a570a87ca244255f65a8e7a5e80c1 (
plain)
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
|
<?php
namespace SMW\SQLStore\EntityStore\DIHandlers;
use SMW\SQLStore\EntityStore\DataItemHandler;
use SMW\SQLStore\EntityStore\Exception\DataItemHandlerException;
use SMW\SQLStore\TableBuilder\FieldType;
use SMWDataItem as DataItem;
use SMWDIGeoCoord as DIGeoCoord;
/**
* This class implements store access to DIGeoCoord data items.
*
* @note The table layout and behavior of this class is not coherent with the
* way that other DIs work. This is because of the unfortunate use of the
* concept table to store extra cache data, but also due to the design of
* concept DIs. This will be cleaned up at some point.
*
* @license GNU GPL v2+
* @since 1.8
*
* @author Nischay Nahata
*/
class DIGeoCoordinateHandler extends DataItemHandler {
/**
* Coordinates have three fields: a string version to keep the
* serialized value (exact), and two floating point columns for
* latitude and longitude (inexact, useful for bounding box selects).
* Altitude is not stored in an extra column since no operation uses
* this for anything so far.
*
* @since 1.8
*
* {@inheritDoc}
*/
public function getTableFields() {
return [
'o_serialized' => FieldType::FIELD_TITLE,
'o_lat' => FieldType::TYPE_DOUBLE,
'o_lon' => FieldType::TYPE_DOUBLE
];
}
/**
* @since 1.8
*
* {@inheritDoc}
*/
public function getFetchFields() {
return [
'o_serialized' => FieldType::FIELD_TITLE
];
}
/**
* @since 1.8
*
* {@inheritDoc}
*/
public function getTableIndexes() {
return [
'p_id,o_serialized',
'o_lat,o_lon'
];
}
/**
* @since 1.8
*
* {@inheritDoc}
*/
public function getWhereConds( DataItem $dataItem ) {
return [
'o_serialized' => $dataItem->getSerialization()
];
}
/**
* @since 1.8
*
* {@inheritDoc}
*/
public function getInsertValues( DataItem $dataItem ) {
return [
'o_serialized' => $dataItem->getSerialization(),
'o_lat' => (string)$dataItem->getLatitude(),
'o_lon' => (string)$dataItem->getLongitude()
];
}
/**
* @since 1.8
*
* {@inheritDoc}
*/
public function getIndexField() {
return 'o_serialized';
}
/**
* Coordinates do not have a general string version that
* could be used for string search, so this method returns
* no label column (empty string).
*
* @since 1.8
*
* {@inheritDoc}
*/
public function getLabelField() {
return '';
}
/**
* @since 1.8
*
* {@inheritDoc}
*/
public function dataItemFromDBKeys( $dbkeys ) {
if ( is_string( $dbkeys ) ) {
return DIGeoCoord::doUnserialize( $dbkeys );
}
throw new DataItemHandlerException( 'Failed to create data item from DB keys.' );
}
}
|