本文整理匯總了PHP中SplPriorityQueue類的典型用法代碼示例。如果您正苦於以下問題:PHP SplPriorityQueue類的具體用法?PHP SplPriorityQueue怎麽用?PHP SplPriorityQueue使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
在下文中一共展示了SplPriorityQueue類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。
示例1: find_routes
private function find_routes($org, $dest, &$flights)
{
$result = array();
$queue = new SplPriorityQueue();
foreach ($flights as $flight) {
if ($flight['org_id'] == $org) {
$route = new Route($this->route_opts);
$num_seats = Flight::get_open_seats_on_flight($flight['flight_id'], $this->user);
$route->add_flight($flight, $num_seats);
$queue->insert($route, $route->get_joy());
}
}
//BFS to find all routes that take < 10 hours
$count = 0;
while ($queue->count() > 0 && $count < $this->opts['max_results']) {
$cur_route = $queue->extract();
if ($cur_route->get_dest() == $dest) {
$result[] = $cur_route;
$count++;
continue;
}
foreach ($flights as $flight) {
if (!array_key_exists($flight['dest_id'], $cur_route->visited) && $flight['org_id'] == $cur_route->get_dest() && $flight['e_depart_time'] > 30 * 60 + $cur_route->get_arrival_time()) {
$new_route = $cur_route->copy();
$num_seats = Flight::get_open_seats_on_flight($flight['flight_id'], $this->user);
$new_route->add_flight($flight, $num_seats);
if ($new_route->get_trip_time() < 24 * 60 * 60 && $new_route->seats >= $this->opts['passengers']) {
$queue->insert($new_route, $new_route->get_joy());
}
}
}
}
return $result;
}
示例2: find_routes
private function find_routes($org, $dest, &$flights)
{
$result = array();
$queue = new SplPriorityQueue();
foreach ($flights as $flight) {
if ($flight['org_id'] == $org) {
$route = new Route($this->route_opts);
$route->add_flight($flight);
array_push($this->id, $flight['flight_id']);
$queue->insert($route, $route->get_joy());
}
}
//BFS to find all routes that take < 10 hours
$count = 0;
while ($queue->count() > 0 && $count < $this->opts['max_results']) {
$cur_route = $queue->extract();
if ($cur_route->get_dest() == $dest) {
$result[] = $cur_route;
$count++;
continue;
}
foreach ($flights as $flight) {
if ($flight['org_id'] == $cur_route->get_dest() && $flight['e_depart_time'] > 30 * 60 + $cur_route->get_arrival_time()) {
$new_route = $cur_route->copy();
$new_route->add_flight($flight);
array_push($this->id, $flight['flight_id']);
if ($new_route->get_trip_time() < 24 * 60 * 60) {
$queue->insert($new_route, $new_route->get_joy());
}
}
}
}
return $result;
}
示例3: process
public function process(ContainerBuilder $container)
{
if ($container->hasDefinition('templating')) {
return;
}
if ($container->hasDefinition('templating.engine.php')) {
$helpers = array();
foreach ($container->findTaggedServiceIds('templating.helper') as $id => $attributes) {
if (isset($attributes[0]['alias'])) {
$helpers[$attributes[0]['alias']] = $id;
}
}
$definition = $container->getDefinition('templating.engine.php');
$arguments = $definition->getArguments();
$definition->setArguments($arguments);
if (count($helpers) > 0) {
$definition->addMethodCall('setHelpers', array($helpers));
}
}
if ($container->hasDefinition('templating.engine.delegating')) {
$queue = new \SplPriorityQueue();
foreach ($container->findTaggedServiceIds('templating.engine') as $id => $attributes) {
$queue->insert($id, isset($attributes[0]['priority']) ? $attributes[0]['priority'] : 0);
}
$engines = array();
foreach ($queue as $engine) {
$engines[] = $engine;
}
$container->getDefinition('templating.engine.delegating')->addMethodCall('setEngineIds', array($engines));
}
}
示例4: process
public function process(ContainerBuilder $container)
{
if (false === $container->hasDefinition('profiler')) {
return;
}
$definition = $container->getDefinition('profiler');
$collectors = new \SplPriorityQueue();
$order = PHP_INT_MAX;
foreach ($container->findTaggedServiceIds('data_collector') as $id => $attributes) {
$priority = isset($attributes[0]['priority']) ? $attributes[0]['priority'] : 0;
$template = null;
if (isset($attributes[0]['template'])) {
if (!isset($attributes[0]['id'])) {
throw new \InvalidArgumentException(sprintf('Data collector service "%s" must have an id attribute in order to specify a template', $id));
}
$template = array($attributes[0]['id'], $attributes[0]['template']);
}
$collectors->insert(array($id, $template), array($priority, --$order));
}
$templates = array();
foreach ($collectors as $collector) {
$definition->addMethodCall('add', array(new Reference($collector[0])));
$templates[$collector[0]] = $collector[1];
}
$container->setParameter('data_collector.templates', $templates);
}
示例5: detach
/**
* Detach the listener from the events manager
*
* @param string eventType
* @param object handler
*/
public function detach($eventType, $handler)
{
if (!is_object($handler)) {
throw new \Exception("Event handler must be an Object");
}
if (isset($this->_events[$eventType])) {
if (is_object($this->_events[$eventType])) {
// SplPriorityQueue hasn't method for element deletion, so we need to rebuild queue
$newPriorityQueue = new PriorityQueue();
$newPriorityQueue->setExtractFlags(\SplPriorityQueue::EXTR_DATA);
$priorityQueue->setExtractFlags(PriorityQueue::EXTR_BOTH);
$priorityQueue->top();
while ($priorityQueue->valid()) {
$data = $priorityQueue->current();
$priorityQueue->next();
if ($data['data'] !== $handler) {
$newPriorityQueue->insert($data['data'], $data['priority']);
}
}
$this->_events[$eventType] = $newPriorityQueue;
} else {
$key = array_search($handler, $priorityQueue, true);
if ($key !== false) {
unset($priorityQueue[$key]);
}
$this->_events[$eventType] = $priorityQueue;
}
}
}
示例6: process
/**
* @param \Symfony\Component\DependencyInjection\ContainerBuilder $container
*
* @throws \InvalidArgumentException
*/
public function process(ContainerBuilder $container)
{
// configure the profiler service
if (FALSE === $container->hasDefinition('profiler')) {
return;
}
$definition = $container->getDefinition('profiler');
$collectors = new \SplPriorityQueue();
$order = PHP_INT_MAX;
foreach ($container->findTaggedServiceIds('data_collector') as $id => $attributes) {
$priority = isset($attributes[0]['priority']) ? $attributes[0]['priority'] : 0;
$template = NULL;
if (isset($attributes[0]['template'])) {
if (!isset($attributes[0]['id'])) {
throw new \InvalidArgumentException(sprintf('Data collector service "%s" must have an id attribute in order to specify a template', $id));
}
if (!isset($attributes[0]['title'])) {
throw new \InvalidArgumentException(sprintf('Data collector service "%s" must have a title attribute', $id));
}
$template = [$attributes[0]['id'], $attributes[0]['template'], $attributes[0]['title']];
}
$collectors->insert([$id, $template], [-$priority, --$order]);
}
$templates = [];
foreach ($collectors as $collector) {
$definition->addMethodCall('add', [new Reference($collector[0])]);
$templates[$collector[0]] = $collector[1];
}
$container->setParameter('data_collector.templates', $templates);
// set parameter to store the public folder path
$path = 'file:' . DRUPAL_ROOT . '/' . PublicStream::basePath() . '/profiler';
$container->setParameter('data_collector.storage', $path);
}
示例7: execute
public function execute()
{
// Get the application
$app = JFactory::getApplication();
$params = JComponentHelper::getParams('com_ddcbalanceit');
if ($params->get('required_account') == 1) {
$user = JFactory::getUser();
if ($user->get('guest')) {
$app->redirect('index.php', JText::_('COM_DDCBALANCEIT_ACCOUNT_REQUIRED_MSG'));
}
}
// Get the document object.
$document = JFactory::getDocument();
$viewName = $app->input->getWord('view', 'dashboard');
$viewFormat = $document->getType();
$layoutName = $app->input->getWord('layout', 'default');
$app->input->set('view', $viewName);
// Register the layout paths for the view
$paths = new SplPriorityQueue();
$paths->insert(JPATH_COMPONENT . '/views/' . $viewName . '/tmpl', 'normal');
$viewClass = 'DdcbalanceitViews' . ucfirst($viewName) . ucfirst($viewFormat);
$modelClass = 'DdcbalanceitModels' . ucfirst($viewName);
if (false === class_exists($modelClass)) {
$modelClass = 'DdcbalanceitModelsDefault';
}
$view = new $viewClass(new $modelClass(), $paths);
$view->setLayout($layoutName);
// Render our view.
echo $view->render();
return true;
}
示例8: process
public function process(ContainerBuilder $container)
{
$definitions = new \SplPriorityQueue();
$order = PHP_INT_MAX;
foreach ($container->getDefinitions() as $id => $definition) {
if (!($decorated = $definition->getDecoratedService())) {
continue;
}
$definitions->insert(array($id, $definition), array($decorated[2], --$order));
}
foreach ($definitions as list($id, $definition)) {
list($inner, $renamedId) = $definition->getDecoratedService();
$definition->setDecoratedService(null);
if (!$renamedId) {
$renamedId = $id . '.inner';
}
// we create a new alias/service for the service we are replacing
// to be able to reference it in the new one
if ($container->hasAlias($inner)) {
$alias = $container->getAlias($inner);
$public = $alias->isPublic();
$container->setAlias($renamedId, new Alias((string) $alias, false));
} else {
$definition = $container->getDefinition($inner);
$public = $definition->isPublic();
$definition->setPublic(false);
$container->setDefinition($renamedId, $definition);
}
$container->setAlias($inner, new Alias($id, $public));
}
}
示例9: process
/**
* {@inheritdoc}
*/
public function process(ContainerBuilder $container)
{
if (!$container->hasDefinition('gremo_buzz')) {
return;
}
// Build listeners queue from tagged services
$listeners = new \SplPriorityQueue();
foreach ($container->findTaggedServiceIds('gremo_buzz.listener') as $id => $attrs) {
$class = $container->getDefinition($id)->getClass();
$class = $container->getParameterBag()->resolveValue($class);
$reflector = new \ReflectionClass($class);
$interface = 'Buzz\\Listener\\ListenerInterface';
// Check if the service implements the above interface
if (!$reflector->isSubclassOf($interface)) {
throw new InvalidArgumentException(sprintf("Service '%s' must implement '%s'.", $id, $interface));
}
// Add a reference to the listeners queue providing a default priority
$listeners->insert(new Reference($id), isset($attrs[0]['priority']) ? $attrs[0]['priority'] : 0);
}
if (!empty($listeners)) {
$browser = $container->getDefinition('gremo_buzz');
// Add listeners starting from those with higher priority
foreach ($listeners as $listener) {
$browser->addMethodCall('addListener', array($listener));
}
}
}
示例10: getView
public static function getView($viewName, $layoutName = 'default', $viewFormat = 'html', $vars = null)
{
// Get the application
$app = \Cobalt\Container::fetch('app');
$document = $app->getDocument();
$app->input->set('view', $viewName);
// Register the layout paths for the view
$paths = new \SplPriorityQueue();
$themeOverride = JPATH_THEMES . '/' . $app->get('theme') . '/html/' . strtolower($viewName);
if (is_dir($themeOverride)) {
$paths->insert($themeOverride, 'normal');
}
$paths->insert(JPATH_COBALT . '/View/' . ucfirst($viewName) . '/tmpl', 'normal');
$viewClass = 'Cobalt\\View\\' . ucfirst($viewName) . '\\' . ucfirst($viewFormat);
$modelClass = ucfirst($viewName);
if (class_exists('Cobalt\\Model\\' . $modelClass) === false) {
$modelClass = 'DefaultModel';
}
$model = self::getModel($modelClass);
/** @var $view \Joomla\View\AbstractHtmlView **/
$view = new $viewClass($model, $paths);
$view->setLayout($layoutName);
$view->document = $document;
if (isset($vars)) {
$view->bypass = true;
foreach ($vars as $varName => $var) {
$view->{$varName} = $var;
}
}
return $view;
}
示例11: execute
public function execute()
{
// Get the document object.
$document = $this->getApplication()->getDocument();
$viewFormat = $this->getInput()->getWord('format', 'html');
$viewName = $this->getInput()->getWord('view', 'dashboard');
$layoutName = $this->getInput()->getWord('layout', 'default');
$this->getInput()->set('view', $viewName);
// Register the layout paths for the view
$paths = new \SplPriorityQueue();
$themeOverride = JPATH_THEMES . '/' . $this->getApplication()->get('theme') . '/html/' . strtolower($viewName);
if (is_dir($themeOverride)) {
$paths->insert($themeOverride, 'normal');
}
$paths->insert(JPATH_COBALT . '/View/' . ucfirst($viewName) . '/tmpl', 'normal');
$viewClass = 'Cobalt\\View\\' . ucfirst($viewName) . '\\' . ucfirst($viewFormat);
$modelClass = ucfirst($viewName);
if (class_exists('Cobalt\\Model\\' . $modelClass) === false) {
$modelClass = 'DefaultModel';
}
$model = $this->getModel($modelClass);
/** @var $view \Joomla\View\AbstractHtmlView **/
$view = new $viewClass($model, $paths);
$view->setLayout($layoutName);
$view->document = $document;
// Render our view.
echo $view->render();
return true;
}
示例12: loadConfiguration
protected function loadConfiguration()
{
$sources = new \SplPriorityQueue();
foreach ($this->getKomponents() as $komponent) {
foreach ($komponent->getConfigurationSources($this->getContextName()) as $source) {
$sources->insert($source, $source->getPriority());
}
}
$cfg = new TestConfigLoader();
$this->testLoader->loadConfigurationSources($cfg);
foreach ($this->testLoader->findRules() as $rule) {
$rule->loadConfigurationSources($cfg);
}
foreach ($cfg as $source) {
$sources->insert($source, $source->getPriority());
}
$loader = new ConfigurationLoader();
$loader->registerLoader(new PhpConfigurationLoader());
$loader->registerLoader(new YamlConfigurationLoader());
$config = new Configuration();
$params = $this->getContainerParams();
foreach ($sources as $source) {
$config = $config->mergeWith($source->loadConfiguration($loader, $params));
}
foreach ($this->testLoader->findRules() as $rule) {
$config = $config->mergeWith($rule->loadConfiguration());
}
return $config->mergeWith($this->testLoader->loadConfiguration());
}
示例13: __construct
/**
* {@inheritDoc}
*/
public function __construct($options = null)
{
if (is_array($options) && !array_intersect(array_keys($options), array('constraints', 'stopOnError'))) {
$options = array('constraints' => $options);
}
parent::__construct($options);
// convert array of constraints into SplPriorityQueue
if (is_array($this->constraints)) {
$queue = new \SplPriorityQueue();
$constraints = $this->constraints;
$constraints = array_reverse($constraints);
foreach ($constraints as $index => $constraint) {
$queue->insert($constraint, $index);
}
$this->constraints = $queue;
}
if (!$this->constraints instanceof \SplPriorityQueue) {
throw new ConstraintDefinitionException('The option "constraints" is expected to be a SplPriorityQueue in constraint ' . __CLASS__ . '.');
}
$constraintsCopy = $this->getConstraints();
// set extraction mode to both priority and data
$constraintsCopy->setExtractFlags(\SplPriorityQueue::EXTR_BOTH);
// loop through the priority chain for options validation
while ($constraintsCopy->valid()) {
$constraint = $constraintsCopy->current();
// fail if the constraint is not actually a constraint
if (!$constraint['data'] instanceof Constraint) {
throw new ConstraintDefinitionException('The option "constraints" (priority: ' . $constraint['priority'] . ') is not a Constraint, in ' . __CLASS__ . '.');
}
// move to next constraint
$constraintsCopy->next();
}
}
示例14: refreshQueue
/**
* 刷新監聽者隊列
*/
protected function refreshQueue()
{
$this->storage->rewind();
$this->queue = new \SplPriorityQueue();
foreach ($this->storage as $listener) {
$priority = $this->storage->getInfo();
$this->queue->insert($listener, $priority);
}
}
示例15: getEngine
/**
* getEngine
*
* @return PhpEngine
*/
protected function getEngine()
{
$engine = new PhpEngine();
$paths = new \SplPriorityQueue();
$paths->insert(__DIR__ . '/tmpl', 0);
$engine->setLayout('default');
$engine->setPaths($paths);
return $engine;
}