當前位置: 首頁>>代碼示例>>PHP>>正文


PHP KalturaLog::getEnableTests方法代碼示例

本文整理匯總了PHP中KalturaLog::getEnableTests方法的典型用法代碼示例。如果您正苦於以下問題:PHP KalturaLog::getEnableTests方法的具體用法?PHP KalturaLog::getEnableTests怎麽用?PHP KalturaLog::getEnableTests使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在KalturaLog的用法示例。


在下文中一共展示了KalturaLog::getEnableTests方法的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: applyFilters

 public function applyFilters()
 {
     if (KalturaLog::getEnableTests()) {
         KalturaLog::debug('kaltura_entry_criteria ' . serialize($this));
     }
     $this->criteriasLeft = 0;
     KalturaLog::debug("Applies " . count($this->filters) . " filters");
     foreach ($this->filters as $index => $filter) {
         KalturaLog::debug("Applies filter {$index}");
         $this->applyFilter(clone $filter);
     }
     // attach all default criteria from peer
     $this->getDefaultCriteriaFilter()->applyFilter($this);
     if (!$this->hasAdvancedSearchFilter && !count($this->matchClause) && $this->shouldSkipSphinx()) {
         KalturaLog::debug('Skip Sphinx');
         $this->sphinxSkiped = true;
         return;
     }
     $criterionsMap = $this->getMap();
     uksort($criterionsMap, array('SphinxCriteria', 'sortFieldsByPriority'));
     // go over all criterions and try to move them to the sphinx
     foreach ($criterionsMap as $field => $criterion) {
         if (!$criterion instanceof SphinxCriterion) {
             KalturaLog::debug("Criterion [" . $criterion->getColumn() . "] is not sphinx criteria");
             $this->criteriasLeft++;
             continue;
         }
         if ($criterion->apply($this)) {
             KalturaLog::debug("Criterion [" . $criterion->getColumn() . "] attached");
             $this->keyToRemove[] = $field;
         } else {
             KalturaLog::debug("Criterion [" . $criterion->getColumn() . "] failed");
             $this->criteriasLeft++;
         }
     }
     KalturaLog::debug("Applied " . count($this->matchClause) . " matches, " . count($this->whereClause) . " clauses, " . count($this->keyToRemove) . " keys removed, {$this->criteriasLeft} keys left");
     if (count($this->matchClause)) {
         $this->matchClause = array_unique($this->matchClause);
         $matches = reset($this->matchClause);
         if (count($this->matchClause) > 1) {
             $matches = '( ' . implode(' ) ( ', $this->matchClause) . ' )';
         }
         $this->addWhere("MATCH('{$matches}')");
     }
     $conditions = '';
     $i = 0;
     foreach ($this->conditionClause as $conditionClause) {
         if ($this->conditionClause[$i] == '') {
             continue;
         }
         $conditions .= ', (' . $this->conditionClause[$i] . ') as cnd' . $i . ' ';
         $this->addWhere('cnd' . $i . ' > 0');
         $i++;
     }
     $wheres = '';
     KalturaLog::debug("Where clause: " . print_r($this->whereClause, true));
     $this->whereClause = array_unique($this->whereClause);
     if (count($this->whereClause)) {
         $wheres = 'WHERE ' . implode(' AND ', $this->whereClause);
     }
     $orderBy = '';
     $orderByColumns = $this->getOrderByColumns();
     $orderByColumns = array_unique($orderByColumns);
     $setLimit = true;
     $orders = array();
     if (count($orderByColumns)) {
         $replace = $this->getSphinxOrderFields();
         $search = array_keys($replace);
         $this->clearOrderByColumns();
         foreach ($orderByColumns as $orderByColumn) {
             $arr = explode(' ', $orderByColumn);
             $orderField = $arr[0];
             if (isset($replace[$orderField])) {
                 KalturaLog::debug("Add sort field[{$orderField}] copy from [{$orderByColumn}]");
                 $orders[] = str_replace($search, $replace, $orderByColumn);
             } else {
                 KalturaLog::debug("Skip sort field[{$orderField}] from [{$orderByColumn}] limit won't be used in sphinx query");
                 $setLimit = false;
                 $matches = null;
                 if (preg_match('/^\\s*([^\\s]+)\\s+(ASC|DESC)\\s*$/i', $orderByColumn, $matches)) {
                     list($match, $column, $direction) = $matches;
                     if (strtoupper($direction) == Criteria::DESC) {
                         $this->addDescendingOrderByColumn($column);
                     } else {
                         $this->addAscendingOrderByColumn($column);
                     }
                 }
             }
         }
     }
     foreach ($this->orderByClause as $orderByClause) {
         $orders[] = $orderByClause;
     }
     if (count($orders)) {
         $this->applySortRequired = true;
         $orders = array_unique($orders);
         $orderBy = 'ORDER BY ' . implode(',', $orders);
     } else {
         $this->applySortRequired = false;
     }
//.........這裏部分代碼省略.........
開發者ID:EfncoPlugins,項目名稱:Media-Management-based-on-Kaltura,代碼行數:101,代碼來源:SphinxCriteria.php

示例2: applyFilters

 public function applyFilters()
 {
     $objectClass = $this->getIndexObjectName();
     if (KalturaLog::getEnableTests()) {
         KalturaLog::debug('kaltura_entry_criteria ' . serialize($this));
     }
     $this->criteriasLeft = 0;
     KalturaLog::debug("Applies " . count($this->filters) . " filters");
     foreach ($this->filters as $index => $filter) {
         KalturaLog::debug("Applies filter {$index}");
         $this->applyFilter(clone $filter);
     }
     // attach all default criteria from peer
     $objectClass::getDefaultCriteriaFilter()->applyFilter($this);
     if (!$this->hasAdvancedSearchFilter && !count($this->matchClause) && $this->shouldSkipSphinx() && !isset($this->groupByColumn) && !isset($this->selectColumn)) {
         KalturaLog::debug('Skip Sphinx');
         $this->sphinxSkipped = true;
         return;
     }
     $fieldsToKeep = $objectClass::getSphinxConditionsToKeep();
     $criterionsMap = $this->getMap();
     uksort($criterionsMap, array('SphinxCriteria', 'sortFieldsByPriority'));
     // go over all criterions and try to move them to the sphinx
     foreach ($criterionsMap as $field => $criterion) {
         if (!$criterion instanceof SphinxCriterion) {
             KalturaLog::debug("Criterion [" . $criterion->getColumn() . "] is not sphinx criteria");
             $this->criteriasLeft++;
             continue;
         }
         if ($criterion->apply($this)) {
             KalturaLog::debug("Criterion [" . $criterion->getColumn() . "] attached");
             if (!in_array($field, $fieldsToKeep)) {
                 $this->keyToRemove[] = $field;
             }
         } else {
             KalturaLog::debug("Criterion [" . $criterion->getColumn() . "] failed");
             $this->criteriasLeft++;
         }
     }
     KalturaLog::debug("Applied " . count($this->matchClause) . " matches, " . count($this->whereClause) . " clauses, " . count($this->keyToRemove) . " keys removed, {$this->criteriasLeft} keys left");
     // Adds special sphinx optimizations matches
     $this->addSphinxOptimizationMatches($criterionsMap);
     if (count($this->matchClause)) {
         $this->matchClause = array_unique($this->matchClause);
         $matches = reset($this->matchClause);
         if (count($this->matchClause) > 1) {
             $matches = '( ' . implode(' ) ( ', $this->matchClause) . ' )';
         }
         $this->addWhere("MATCH('{$matches}')");
     }
     $conditions = '';
     $i = 0;
     foreach ($this->conditionClause as $conditionClause) {
         if ($this->conditionClause[$i] == '') {
             continue;
         }
         $conditions .= ', (' . $this->conditionClause[$i] . ') as cnd' . $i . ' ';
         $this->addWhere('cnd' . $i . ' > 0');
         $i++;
     }
     $wheres = '';
     KalturaLog::debug("Where clause: " . print_r($this->whereClause, true));
     $this->whereClause = array_unique($this->whereClause);
     if (count($this->whereClause)) {
         $wheres = 'WHERE ' . implode(' AND ', $this->whereClause);
     }
     $orderBy = '';
     $orderByColumns = $this->getOrderByColumns();
     $orderByColumns = array_unique($orderByColumns);
     $usesWeight = false;
     $setLimit = true;
     $orders = array();
     if (count($orderByColumns)) {
         $replace = $objectClass::getIndexOrderList();
         $search = array_keys($replace);
         $this->clearOrderByColumns();
         foreach ($orderByColumns as $orderByColumn) {
             $arr = explode(' ', $orderByColumn);
             $orderField = $arr[0];
             $orderFieldParts = explode(".", $orderField);
             $isWeight = end($orderFieldParts) == "WEIGHT";
             if (isset($replace[$orderField]) || $isWeight) {
                 if ($isWeight) {
                     $replace[$orderField] = "w";
                     $conditions .= ",weight() as w";
                     $usesWeight = true;
                     $search = array_keys($replace);
                 }
                 KalturaLog::debug("Add sort field[{$orderField}] copy from [{$orderByColumn}]");
                 $orders[] = str_replace($search, $replace, $orderByColumn);
             } else {
                 KalturaLog::debug("Skip sort field[{$orderField}] from [{$orderByColumn}] limit won't be used in sphinx query");
                 $setLimit = false;
                 $matches = null;
                 if (preg_match('/^\\s*([^\\s]+)\\s+(ASC|DESC)\\s*$/i', $orderByColumn, $matches)) {
                     list($match, $column, $direction) = $matches;
                     if (strtoupper($direction) == Criteria::DESC) {
                         $this->addDescendingOrderByColumn($column);
                     } else {
                         $this->addAscendingOrderByColumn($column);
//.........這裏部分代碼省略.........
開發者ID:kubrickfr,項目名稱:server,代碼行數:101,代碼來源:SphinxCriteria.php


注:本文中的KalturaLog::getEnableTests方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。