blob: b7b52d248e78775b0a7e1b37d587a621b39907f9 (
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
|
<?php
namespace SMW\SQLStore\QueryEngine\DescriptionInterpreters;
use SMW\Query\Language\Description;
use SMW\Query\Language\NamespaceDescription;
use SMW\SQLStore\QueryEngine\DescriptionInterpreter;
use SMW\SQLStore\QueryEngine\QuerySegment;
use SMW\SQLStore\QueryEngine\QuerySegmentListBuilder;
use SMWSql3SmwIds;
/**
* @license GNU GPL v2+
* @since 2.2
*
* @author Markus Krötzsch
* @author Jeroen De Dauw
* @author mwjames
*/
class NamespaceDescriptionInterpreter implements DescriptionInterpreter {
/**
* @var QuerySegmentListBuilder
*/
private $querySegmentListBuilder;
/**
* @since 2.2
*
* @param QuerySegmentListBuilder $querySegmentListBuilder
*/
public function __construct( QuerySegmentListBuilder $querySegmentListBuilder ) {
$this->querySegmentListBuilder = $querySegmentListBuilder;
}
/**
* @since 2.2
*
* @return boolean
*/
public function canInterpretDescription( Description $description ) {
return $description instanceof NamespaceDescription;
}
/**
* TODO: One instance of the SMW IDs table on s_id always suffices (swm_id is KEY)! Doable in execution ... (PERFORMANCE)
*
* @since 2.2
*
* @param Description $description
*
* @return QuerySegment
*/
public function interpretDescription( Description $description ) {
$db = $this->querySegmentListBuilder->getStore()->getConnection( 'mw.db.queryengine' );
$query = new QuerySegment();
$query->joinTable = SMWSql3SmwIds::TABLE_NAME;
$query->joinfield = "$query->alias.smw_id";
$query->where = "$query->alias.smw_namespace=" . $db->addQuotes( $description->getNamespace() );
return $query;
}
}
|