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


PHP ProgressBar::setCurrent方法代碼示例

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


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

示例1: onStatus

 /**
  * @param array $data
  */
 protected function onStatus(array $data)
 {
     if (isset($data['current'])) {
         $this->progress->setCurrent((int) $data['current']);
         unset($data['current']);
     } else {
         $this->progress->advance();
     }
     foreach ($data as $key => $value) {
         $this->progress->setMessage($value, $key);
     }
 }
開發者ID:flamecore,項目名稱:seabreeze,代碼行數:15,代碼來源:ConsoleProgressResponder.php

示例2: getNotificationCallback

 private function getNotificationCallback($filename)
 {
     $notificationCallback = function ($notification_code, $severity, $message, $messageCode, $bytesTransferred, $bytesMax) use($filename) {
         switch ($notification_code) {
             case STREAM_NOTIFY_FILE_SIZE_IS:
                 $this->progress = new ProgressBar($this->output, $bytesMax);
                 $this->progress->setFormat('%message% %final_report%' . "\n" . '%percent:3s%% of %photo_size% [%bar%] %downloaded_bytes% eta %estimated:6s%');
                 $this->progress->setMessage($filename);
                 $this->progress->setMessage('', 'final_report');
                 $this->progress->start();
                 break;
             case STREAM_NOTIFY_PROGRESS:
                 $this->progress->setCurrent($bytesTransferred);
                 break;
         }
     };
     return $notificationCallback;
 }
開發者ID:michalsanger,項目名稱:cli-flickr-downloadr,代碼行數:18,代碼來源:Downloader.php

示例3: createStreamContext

 /**
  * @param OutputInterface $output
  *
  * @return resource
  */
 protected function createStreamContext(OutputInterface $output)
 {
     $ctx = stream_context_create([], ['notification' => function ($code, $severity, $message, $message_code, $bytesTransferred, $bytesMax) use($output) {
         switch ($code) {
             case STREAM_NOTIFY_FILE_SIZE_IS:
                 $this->progress = new ProgressBar($output, $bytesMax);
                 $this->progress->setBarWidth(75);
                 $this->progress->start();
                 break;
             case STREAM_NOTIFY_PROGRESS:
                 $this->progress->setCurrent($bytesTransferred);
                 if ($bytesTransferred == $bytesMax) {
                     $this->progress->finish();
                     $output->writeln('');
                 }
                 break;
             case STREAM_NOTIFY_COMPLETED:
                 $this->progress->finish();
                 break;
         }
     }]);
     return $ctx;
 }
開發者ID:shakaran,項目名稱:forge-cli,代碼行數:28,代碼來源:SelfUpdateCommand.php

示例4: triggerNegativeEvents


//.........這裏部分代碼省略.........
                             // Timing is not appropriate so move on to next lead
                             unset($eventTiming);
                             continue;
                         }
                         $logDecision = $decisionLogged = false;
                         // Execute or schedule events
                         foreach ($eventTiming as $id => $timing) {
                             // Set event
                             $e = $events[$id];
                             $e['campaign'] = array('id' => $campaignId, 'name' => $campaignName);
                             // Set lead in case this is triggered by the system
                             $leadModel->setSystemCurrentLead($l);
                             if ($timing instanceof \DateTime) {
                                 $processedCount++;
                                 // Schedule the action
                                 $logger->debug('CAMPAIGN: ID# ' . $e['id'] . ' timing is not appropriate and thus scheduled for ' . $timing->format('Y-m-d H:m:i T') . '');
                                 $log = $this->getLogEntity($e['id'], $campaign, $l, null, true);
                                 $log->setLead($l);
                                 $log->setIsScheduled(true);
                                 $log->setTriggerDate($timing);
                                 $repo->saveEntity($log);
                                 $logDecision = true;
                             } else {
                                 $processedCount++;
                                 // Save log first to prevent subsequent triggers from duplicating
                                 $log = $this->getLogEntity($e['id'], $campaign, $l, null, true);
                                 $log->setDateTriggered(new \DateTime());
                                 $repo->saveEntity($log);
                                 $response = $this->invokeEventCallback($e, $eventSettings['action'][$e['type']], $l, null, true);
                                 if ($response === false) {
                                     $repo->deleteEntity($log);
                                     $logger->debug('CAMPAIGN: ID# ' . $e['id'] . ' execution failed.');
                                     $logDecision = true;
                                 } else {
                                     $logger->debug('CAMPAIGN: ID# ' . $e['id'] . ' successfully executed and logged.');
                                     if ($response !== true) {
                                         $log->setMetadata($response);
                                         $repo->saveEntity($log);
                                     }
                                 }
                             }
                             if (!empty($log)) {
                                 $this->em->detach($log);
                             }
                             unset($e, $log);
                             if ($logDecision && !$decisionLogged) {
                                 // Log the decision
                                 $log = $this->getLogEntity($parentId, $campaign, $l, null, true);
                                 $log->setDateTriggered(new \DateTime());
                                 $log->setNonActionPathTaken(true);
                                 $repo->saveEntity($log);
                                 $this->em->detach($log);
                                 unset($log);
                                 $decisionLogged = true;
                             }
                             if ($max && $totalEventCount >= $max) {
                                 // Hit the max
                                 if ($output) {
                                     $progress->finish();
                                     $output->writeln('');
                                 }
                                 return $eventCount;
                             }
                             $eventCount++;
                             $totalEventCount++;
                             unset($utcDateString, $grandParentDate);
                         }
                     } else {
                         $logger->debug('CAMPAIGN: Decision has already been executed.');
                     }
                     $currentCount = $max ? $totalEventCount : $leadProcessedCount;
                     if ($output && $currentCount < $maxCount) {
                         $progress->setCurrent($currentCount);
                     }
                 }
                 // Save RAM
                 $this->em->detach($l);
                 unset($l);
             }
             // Next batch
             $start += $limit;
             $leadProcessedCount += count($campaignLeads);
             // Save RAM
             $this->em->clear('MauticLeadBundle:Lead');
             $this->em->clear('MauticUserBundle:User');
             unset($leads, $campaignLeads, $leadLog);
             $currentCount = $max ? $eventCount : $leadProcessedCount;
             if ($output && $currentCount < $maxCount) {
                 $progress->setCurrent($currentCount);
             }
             // Free some memory
             gc_collect_cycles();
         }
         if ($output) {
             $progress->finish();
             $output->writeln('');
         }
     }
     return $processedCount;
 }
開發者ID:smotalima,項目名稱:mautic,代碼行數:101,代碼來源:EventModel.php

示例5: rebuildListLeads

 /**
  * Rebuild lead lists
  *
  * @param LeadList        $entity
  * @param int             $limit
  * @param bool            $maxLeads
  * @param OutputInterface $output
  *
  * @return int
  */
 public function rebuildListLeads(LeadList $entity, $limit = 1000, $maxLeads = false, OutputInterface $output = null)
 {
     defined('MAUTIC_REBUILDING_LEAD_LISTS') or define('MAUTIC_REBUILDING_LEAD_LISTS', 1);
     $id = $entity->getId();
     $list = array('id' => $id, 'filters' => $entity->getFilters());
     $dtHelper = $this->factory->getDate();
     $batchLimiters = array('dateTime' => $dtHelper->toUtcString());
     $localDateTime = $dtHelper->getLocalDateTime();
     // Get a count of leads to add
     $newLeadsCount = $this->getLeadsByList($list, true, array('countOnly' => true, 'newOnly' => true, 'dynamic' => true, 'includeManual' => false, 'batchLimiters' => $batchLimiters));
     // Ensure the same list is used each batch
     $batchLimiters['maxId'] = (int) $newLeadsCount[$id]['maxId'];
     // Number of total leads to process
     $leadCount = (int) $newLeadsCount[$id]['count'];
     if ($output) {
         $output->writeln($this->translator->trans('mautic.lead.list.rebuild.to_be_added', array('%leads%' => $leadCount, '%batch%' => $limit)));
     }
     // Handle by batches
     $start = $lastRoundPercentage = $leadsProcessed = 0;
     // Try to save some memory
     gc_enable();
     if ($leadCount) {
         $maxCount = $maxLeads ? $maxLeads : $leadCount;
         if ($output) {
             $progress = new ProgressBar($output, $maxCount);
             $progress->start();
         }
         // Add leads
         while ($start < $leadCount) {
             // Keep CPU down for large lists; sleep per $limit batch
             sleep($this->batchSleepTime);
             $newLeadList = $this->getLeadsByList($list, true, array('dynamic' => true, 'newOnly' => true, 'includeManual' => false, 'limit' => $limit, 'batchLimiters' => $batchLimiters));
             if (empty($newLeadList[$id])) {
                 // Somehow ran out of leads so break out
                 break;
             }
             foreach ($newLeadList[$id] as $l) {
                 $this->addLead($l, $entity, false, true, -1, $localDateTime);
                 unset($l);
                 $leadsProcessed++;
                 if ($output && $leadsProcessed < $maxCount) {
                     $progress->setCurrent($leadsProcessed);
                 }
                 if ($maxLeads && $leadsProcessed >= $maxLeads) {
                     break;
                 }
             }
             $start += $limit;
             // Dispatch batch event
             if ($this->dispatcher->hasListeners(LeadEvents::LEAD_LIST_BATCH_CHANGE)) {
                 $event = new ListChangeEvent($newLeadList[$id], $entity, true);
                 $this->dispatcher->dispatch(LeadEvents::LEAD_LIST_BATCH_CHANGE, $event);
                 unset($event);
             }
             unset($newLeadList);
             // Free some memory
             gc_collect_cycles();
             if ($maxLeads && $leadsProcessed >= $maxLeads) {
                 if ($output) {
                     $progress->finish();
                     $output->writeln('');
                 }
                 return $leadsProcessed;
             }
         }
         if ($output) {
             $progress->finish();
             $output->writeln('');
         }
     }
     $fullList = $this->getLeadsByList($list, true, array('dynamic' => true, 'existingOnly' => true, 'includeManual' => false, 'batchLimiters' => $batchLimiters));
     // Get a count of leads to be removed
     $removeLeadCount = $this->getLeadsByList($list, true, array('countOnly' => true, 'includeManual' => false, 'filterOutIds' => $fullList[$id], 'batchLimiters' => $batchLimiters));
     // Restart batching
     $start = $lastRoundPercentage = 0;
     $leadCount = $removeLeadCount[$id]['count'];
     if ($output) {
         $output->writeln($this->translator->trans('mautic.lead.list.rebuild.to_be_removed', array('%leads%' => $leadCount, '%batch%' => $limit)));
     }
     if ($leadCount) {
         $maxCount = $maxLeads ? $maxLeads : $leadCount;
         if ($output) {
             $progress = new ProgressBar($output, $maxCount);
             $progress->start();
         }
         // Remove leads
         while ($start < $leadCount) {
             // Keep CPU down for large lists; sleep per $limit batch
             sleep($this->batchSleepTime);
             $removeLeadList = $this->getLeadsByList($list, true, array('limit' => $limit, 'filterOutIds' => $fullList[$id], 'batchLimiters' => $batchLimiters));
//.........這裏部分代碼省略.........
開發者ID:smotalima,項目名稱:mautic,代碼行數:101,代碼來源:ListModel.php

示例6: doDumpDatabase

 /**
  * @param Driver   $sourceDriver The source driver.
  * @param callable $output       A function to call with every SQL statement.
  * @param string   $message      The message going next to the progress bar.
  *
  * @return void
  */
 private function doDumpDatabase(Driver $sourceDriver, callable $output, string $message)
 {
     $dumper = new Dumper($sourceDriver);
     $progress = new ProgressBar($this->output);
     $progress->setMessage('Counting objects');
     $progress->setFormat('%message% [%bar%] %current%');
     $progress->start();
     $objectCount = 0;
     $dumper->countObjects(function ($count) use($progress, &$objectCount) {
         $objectCount += $count;
         $progress->setCurrent($objectCount);
     });
     $progress->finish();
     $this->output->writeln('');
     $progress = new ProgressBar($this->output, $objectCount);
     $progress->setMessage($message);
     $progress->setFormat('%message% [%bar%] %current%/%max% %percent:3s%%');
     $progress->start();
     $dumper->dumpDatabase(function ($query) use($output, $progress) {
         $output($query);
         $progress->advance();
     });
     $progress->finish();
     $this->output->writeln('');
 }
開發者ID:dversion,項目名稱:dversion,代碼行數:32,代碼來源:Controller.php

示例7: rebuildCampaignLeads

 /**
  * @param Campaign        $campaign
  * @param int             $limit
  * @param bool            $maxLeads
  * @param OutputInterface $output
  *
  * @return int
  */
 public function rebuildCampaignLeads(Campaign $campaign, $limit = 1000, $maxLeads = false, OutputInterface $output = null)
 {
     defined('MAUTIC_REBUILDING_CAMPAIGNS') or define('MAUTIC_REBUILDING_CAMPAIGNS', 1);
     $repo = $this->getRepository();
     // Get a list of leads for all lists associated with the campaign
     $lists = $this->getCampaignListIds($campaign->getId());
     if (empty($lists)) {
         if ($output) {
             $output->writeln($this->translator->trans('mautic.campaign.rebuild.no_lists'));
         }
         return 0;
     }
     $batchLimiters = array('dateTime' => $this->factory->getDate()->toUtcString());
     // Get a count of new leads
     $newLeadsCount = $repo->getCampaignLeadsFromLists($campaign->getId(), $lists, array('newOnly' => true, 'countOnly' => true, 'batchLimiters' => $batchLimiters));
     // Ensure the same list is used each batch
     $batchLimiters['maxId'] = (int) $newLeadsCount['maxId'];
     // Number of total leads to process
     $leadCount = (int) $newLeadsCount['count'];
     if ($output) {
         $output->writeln($this->translator->trans('mautic.campaign.rebuild.to_be_added', array('%leads%' => $leadCount, '%batch%' => $limit)));
     }
     // Handle by batches
     $start = $leadsProcessed = 0;
     // Try to save some memory
     gc_enable();
     if ($leadCount) {
         $maxCount = $maxLeads ? $maxLeads : $leadCount;
         if ($output) {
             $progress = new ProgressBar($output, $maxCount);
             $progress->start();
         }
         // Add leads
         while ($start < $leadCount) {
             // Keep CPU down for large lists; sleep per $limit batch
             sleep($this->batchSleepTime);
             // Get a count of new leads
             $newLeadList = $repo->getCampaignLeadsFromLists($campaign->getId(), $lists, array('newOnly' => true, 'limit' => $limit, 'batchLimiters' => $batchLimiters));
             $start += $limit;
             foreach ($newLeadList as $l) {
                 $this->addLeads($campaign, array($l), false, true, -1);
                 $leadsProcessed++;
                 if ($output && $leadsProcessed < $maxCount) {
                     $progress->setCurrent($leadsProcessed);
                 }
                 unset($l);
                 if ($maxLeads && $leadsProcessed >= $maxLeads) {
                     // done for this round, bye bye
                     if ($output) {
                         $progress->finish();
                     }
                     return $leadsProcessed;
                 }
             }
             unset($newLeadList);
             // Free some memory
             gc_collect_cycles();
         }
         if ($output) {
             $progress->finish();
             $output->writeln('');
         }
     }
     // Get a count of leads to be removed
     $removeLeadCount = $repo->getCampaignOrphanLeads($campaign->getId(), $lists, array('notInLists' => true, 'countOnly' => true, 'batchLimiters' => $batchLimiters));
     // Restart batching
     $start = $lastRoundPercentage = 0;
     $leadCount = $removeLeadCount['count'];
     if ($output) {
         $output->writeln($this->translator->trans('mautic.lead.list.rebuild.to_be_removed', array('%leads%' => $leadCount, '%batch%' => $limit)));
     }
     if ($leadCount) {
         $maxCount = $maxLeads ? $maxLeads : $leadCount;
         if ($output) {
             $progress = new ProgressBar($output, $maxCount);
             $progress->start();
         }
         // Remove leads
         while ($start < $leadCount) {
             // Keep CPU down for large lists; sleep per $limit batch
             sleep($this->batchSleepTime);
             $removeLeadList = $repo->getCampaignOrphanLeads($campaign->getId(), $lists, array('limit' => $limit, 'batchLimiters' => $batchLimiters));
             foreach ($removeLeadList as $l) {
                 $this->removeLeads($campaign, array($l), false, true, true);
                 $leadsProcessed++;
                 if ($output && $leadsProcessed < $maxCount) {
                     $progress->setCurrent($leadsProcessed);
                 }
                 if ($maxLeads && $leadsProcessed >= $maxLeads) {
                     // done for this round, bye bye
                     $progress->finish();
                     return $leadsProcessed;
//.........這裏部分代碼省略.........
開發者ID:Jandersolutions,項目名稱:mautic,代碼行數:101,代碼來源:CampaignModel.php

示例8: testClear

 public function testClear()
 {
     $bar = new ProgressBar($output = $this->getOutputStream(), 50);
     $bar->start();
     $bar->setCurrent(25);
     $bar->clear();
     rewind($output->getStream());
     $this->assertEquals($this->generateOutput('  0/50 [>---------------------------]   0%') . $this->generateOutput(' 25/50 [==============>-------------]  50%') . $this->generateOutput('                                          '), stream_get_contents($output->getStream()));
 }
開發者ID:NivalM,項目名稱:VacantesJannaMotors,代碼行數:9,代碼來源:ProgressBarTest.php


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