summaryrefslogtreecommitdiff
path: root/classes
diff options
context:
space:
mode:
Diffstat (limited to 'classes')
-rw-r--r--classes/Memcached_DataObject.php15
-rw-r--r--classes/Profile.php15
-rw-r--r--classes/SearchEngines.php10
3 files changed, 21 insertions, 19 deletions
diff --git a/classes/Memcached_DataObject.php b/classes/Memcached_DataObject.php
index f8e1b9acc..e1d58dd70 100644
--- a/classes/Memcached_DataObject.php
+++ b/classes/Memcached_DataObject.php
@@ -169,4 +169,19 @@ class Memcached_DataObject extends DB_DataObject
return $c->get(Memcached_DataObject::cacheKey($cls, $pkeys, $pvals));
}
}
+
+ function getSearchEngine($table) {
+ require_once INSTALLDIR.'/classes/SearchEngines.php';
+ static $search_engine;
+ if (!isset($search_engine)) {
+ if (common_config('sphinx', 'enabled')) {
+ $search_engine = new SphinxSearch($this, $table);
+ } elseif ('mysql' === common_config('db', 'type')) {
+ $search_engine = new MySQLSearch($this, $table);
+ } else {
+ $search_engine = new PGSearch($this, $table);
+ }
+ }
+ return $search_engine;
+ }
}
diff --git a/classes/Profile.php b/classes/Profile.php
index 9de92ec4b..794dc1de9 100644
--- a/classes/Profile.php
+++ b/classes/Profile.php
@@ -46,21 +46,6 @@ class Profile extends Memcached_DataObject
/* the code above is auto generated do not remove the tag below */
###END_AUTOCODE
- function getSearchEngine() {
- require_once INSTALLDIR.'/classes/SearchEngines.php';
- static $search_engine;
- if (!isset($search_engine)) {
- if (common_config('sphinx', 'enabled')) {
- $search_engine = new SphinxSearch($this);
- } elseif ('mysql' === common_config('db', 'type')) {
- $search_engine = new MySQLSearch($this);
- } else {
- $search_engine = new PGSearch($this);
- }
- }
- return $search_engine;
- }
-
function getAvatar($width, $height=NULL) {
if (is_null($height)) {
$height = $width;
diff --git a/classes/SearchEngines.php b/classes/SearchEngines.php
index e5f4e14ea..253e0028b 100644
--- a/classes/SearchEngines.php
+++ b/classes/SearchEngines.php
@@ -21,9 +21,11 @@ if (!defined('LACONICA')) { exit(1); }
class SearchEngine {
protected $profile;
+ protected $table;
- function __construct($profile) {
+ function __construct($profile, $table) {
$this->profile = $profile;
+ $this->table = $table;
}
function query($q) {
@@ -37,8 +39,8 @@ class SearchEngine {
class SphinxSearch extends SearchEngine {
private $sphinx;
- function __construct($profile) {
- parent::__construct($profile);
+ function __construct($profile, $table) {
+ parent::__construct($profile, $table);
$this->sphinx = new SphinxClient;
$this->sphinx->setServer(common_config('sphinx', 'server'), common_config('sphinx', 'port'));
}
@@ -49,7 +51,7 @@ class SphinxSearch extends SearchEngine {
}
function query($q) {
- $result = $this->sphinx->query($q);
+ $result = $this->sphinx->query($q, $this->table);
if (!isset($result['matches'])) return false;
$id_set = join(', ', array_keys($result['matches']));
return $this->profile->whereAdd("id in ($id_set)");