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


PHP wfLogWarning函數代碼示例

本文整理匯總了PHP中wfLogWarning函數的典型用法代碼示例。如果您正苦於以下問題:PHP wfLogWarning函數的具體用法?PHP wfLogWarning怎麽用?PHP wfLogWarning使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。


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

示例1: getSkinNames

 /**
  * Fetch the set of available skins.
  * @return array associative array of strings
  */
 static function getSkinNames()
 {
     global $wgValidSkinNames;
     static $skinsInitialised = false;
     if (!$skinsInitialised || !count($wgValidSkinNames)) {
         # Get a list of available skins
         # Build using the regular expression '^(.*).php$'
         # Array keys are all lower case, array value keep the case used by filename
         #
         wfProfileIn(__METHOD__ . '-init');
         global $wgStyleDirectory;
         $skinDir = dir($wgStyleDirectory);
         if ($skinDir !== false && $skinDir !== null) {
             # while code from www.php.net
             while (false !== ($file = $skinDir->read())) {
                 // Skip non-PHP files, hidden files, and '.dep' includes
                 $matches = array();
                 if (preg_match('/^([^.]*)\\.php$/', $file, $matches)) {
                     $aSkin = $matches[1];
                     // We're still loading core skins via the autodiscovery mechanism... :(
                     if (!in_array($aSkin, array('CologneBlue', 'Modern', 'MonoBook', 'Vector'))) {
                         wfLogWarning("A skin using autodiscovery mechanism, {$aSkin}, was found in your skins/ directory. " . "The mechanism will be removed in MediaWiki 1.25 and the skin will no longer be recognized. " . "See https://www.mediawiki.org/wiki/Manual:Skin_autodiscovery for information how to fix this.");
                     }
                     $wgValidSkinNames[strtolower($aSkin)] = $aSkin;
                 }
             }
             $skinDir->close();
         }
         $skinsInitialised = true;
         wfProfileOut(__METHOD__ . '-init');
     }
     return $wgValidSkinNames;
 }
開發者ID:Tarendai,項目名稱:spring-website,代碼行數:37,代碼來源:Skin.php

示例2: __construct

 /**
  * @param EntityTitleLookup $titleLookup
  * @param EntityContentFactory $entityContentFactory
  * @param IContextSource $context
  */
 public function __construct(EntityTitleLookup $titleLookup, EntityContentFactory $entityContentFactory, IContextSource $context)
 {
     if (!$context instanceof MutableContext) {
         wfLogWarning('$context is not an instanceof MutableContext.');
         $context = new DerivativeContext($context);
     }
     $this->titleLookup = $titleLookup;
     $this->entityContentFactory = $entityContentFactory;
     $this->context = $context;
 }
開發者ID:Benestar,項目名稱:mediawiki-extensions-Wikibase,代碼行數:15,代碼來源:EditFilterHookRunner.php

示例3: getDiff

 /**
  * @since 0.1
  *
  * @param string $cache set to 'cache' to cache the unserialized diff.
  *
  * @return Diff
  */
 public function getDiff($cache = 'no')
 {
     $info = $this->getInfo($cache);
     if (!array_key_exists('diff', $info)) {
         // This shouldn't happen, but we should be robust against corrupt, incomplete
         // obsolete instances in the database, etc.
         wfLogWarning('Cannot get the diff when it has not been set yet.');
         return new Diff();
     } else {
         return $info['diff'];
     }
 }
開發者ID:Benestar,項目名稱:mediawiki-extensions-Wikibase,代碼行數:19,代碼來源:DiffChange.php

示例4: runHook

 /**
  * @param ItemId $itemId
  * @param array $sidebar
  *
  * @return array
  */
 private function runHook(ItemId $itemId, array $sidebar)
 {
     $newSidebar = $sidebar;
     Hooks::run('WikibaseClientOtherProjectsSidebar', array($itemId, &$newSidebar));
     if ($newSidebar === $sidebar) {
         return $sidebar;
     }
     if (!is_array($newSidebar) || !$this->isValidSidebar($newSidebar)) {
         wfLogWarning('Other projects sidebar data invalid after hook run.');
         return $sidebar;
     }
     return $newSidebar;
 }
開發者ID:Benestar,項目名稱:mediawiki-extensions-Wikibase,代碼行數:19,代碼來源:OtherProjectsSidebarGenerator.php

示例5: getSiteLinkDiff

 /**
  * @since 0.3
  *
  * @return Diff
  */
 public function getSiteLinkDiff()
 {
     $diff = $this->getDiff();
     if (!$diff instanceof ItemDiff) {
         // This shouldn't happen, but we should be robust against corrupt, incomplete
         // or obsolete instances in the database, etc.
         $cls = $diff === null ? 'null' : get_class($diff);
         wfLogWarning('Cannot get sitelink diff from ' . $cls . '. Change #' . $this->getId() . ", type " . $this->getType());
         return new Diff();
     } else {
         return $diff->getSiteLinkDiff();
     }
 }
開發者ID:Benestar,項目名稱:mediawiki-extensions-Wikibase,代碼行數:18,代碼來源:ItemChange.php

示例6: getEntityIdFromOutputPage

 /**
  * @param OutputPage $out
  *
  * @return EntityId|null
  */
 public function getEntityIdFromOutputPage(OutputPage $out)
 {
     if (!$this->entityContentFactory->isEntityContentModel($out->getTitle()->getContentModel())) {
         return null;
     }
     $jsConfigVars = $out->getJsConfigVars();
     if (array_key_exists('wbEntityId', $jsConfigVars)) {
         $idString = $jsConfigVars['wbEntityId'];
         try {
             return $this->entityIdParser->parse($idString);
         } catch (EntityIdParsingException $ex) {
             wfLogWarning('Failed to parse EntityId config var: ' . $idString);
         }
     }
     return null;
 }
開發者ID:Benestar,項目名稱:mediawiki-extensions-Wikibase,代碼行數:21,代碼來源:OutputPageEntityIdReader.php

示例7: getValueBuilder

 /**
  * @param string|null $dataTypeId
  * @param string $dataValueType
  *
  * @return null|ValueSnakRdfBuilder
  */
 private function getValueBuilder($dataTypeId, $dataValueType)
 {
     if ($dataTypeId !== null) {
         if (isset($this->valueBuilders["PT:{$dataTypeId}"])) {
             return $this->valueBuilders["PT:{$dataTypeId}"];
         }
     }
     if (isset($this->valueBuilders["VT:{$dataValueType}"])) {
         return $this->valueBuilders["VT:{$dataValueType}"];
     }
     if ($dataTypeId !== null) {
         wfLogWarning(__METHOD__ . ": No RDF builder defined for data type {$dataTypeId} nor for value type {$dataValueType}.");
     } else {
         wfLogWarning(__METHOD__ . ": No RDF builder defined for value type {$dataValueType}.");
     }
     return null;
 }
開發者ID:Benestar,項目名稱:mediawiki-extensions-Wikibase,代碼行數:23,代碼來源:DispatchingValueSnakRdfBuilder.php

示例8: getEntityRevision

 /**
  * @since 0.4
  * @see   EntityRevisionLookup::getEntityRevision
  *
  * @param EntityId $entityId
  * @param int|string $revisionId The desired revision id, or LATEST_FROM_SLAVE or LATEST_FROM_MASTER.
  *
  * @throws RevisionedUnresolvedRedirectException
  * @throws StorageException
  * @return EntityRevision|null
  */
 public function getEntityRevision(EntityId $entityId, $revisionId = self::LATEST_FROM_SLAVE)
 {
     wfDebugLog(__CLASS__, __FUNCTION__ . ': Looking up entity ' . $entityId . " (revision {$revisionId}).");
     // default changed from false to 0 and then to LATEST_FROM_SLAVE
     if ($revisionId === false || $revisionId === 0) {
         wfWarn('getEntityRevision() called with $revisionId = false or 0, ' . 'use EntityRevisionLookup::LATEST_FROM_SLAVE or EntityRevisionLookup::LATEST_FROM_MASTER instead.');
         $revisionId = self::LATEST_FROM_SLAVE;
     }
     /** @var EntityRevision $entityRevision */
     $entityRevision = null;
     if (is_int($revisionId)) {
         $row = $this->entityMetaDataAccessor->loadRevisionInformationByRevisionId($entityId, $revisionId);
     } else {
         $rows = $this->entityMetaDataAccessor->loadRevisionInformation(array($entityId), $revisionId);
         $row = $rows[$entityId->getSerialization()];
     }
     if ($row) {
         /** @var EntityRedirect $redirect */
         try {
             list($entityRevision, $redirect) = $this->loadEntity($row);
         } catch (MWContentSerializationException $ex) {
             throw new StorageException('Failed to unserialize the content object.', 0, $ex);
         }
         if ($redirect !== null) {
             throw new RevisionedUnresolvedRedirectException($entityId, $redirect->getTargetId(), (int) $row->rev_id, $row->rev_timestamp);
         }
         if ($entityRevision === null) {
             // This only happens when there is a problem with the external store.
             wfLogWarning(__METHOD__ . ': Entity not loaded for ' . $entityId);
         }
     }
     if ($entityRevision !== null && !$entityRevision->getEntity()->getId()->equals($entityId)) {
         // This can happen when giving a revision ID that doesn't belong to the given entity,
         // or some meta data is incorrect.
         $actualEntityId = $entityRevision->getEntity()->getId()->getSerialization();
         // Get the revision id we actually loaded, if none was passed explicitly
         $revisionId = is_int($revisionId) ? $revisionId : $entityRevision->getRevisionId();
         throw new BadRevisionException("Revision {$revisionId} belongs to {$actualEntityId} instead of expected {$entityId}");
     }
     if (is_int($revisionId) && $entityRevision === null) {
         // If a revision ID was specified, but that revision doesn't exist:
         throw new BadRevisionException("No such revision found for {$entityId}: {$revisionId}");
     }
     return $entityRevision;
 }
開發者ID:Benestar,項目名稱:mediawiki-extensions-Wikibase,代碼行數:56,代碼來源:WikiPageEntityRevisionLookup.php

示例9: fixSubstructureDiff

 /**
  * Checks the type of a substructure diff, and replaces it if needed.
  * This is needed for backwards compatibility with old versions of
  * MapDiffer: As of commit ff65735a125e, MapDiffer may generate atomic diffs for
  * substructures even in recursive mode (bug 51363).
  *
  * @param array &$operations All change ops; This is a reference, so the
  *        substructure diff can be replaced if need be.
  * @param string $key The key of the substructure
  */
 protected function fixSubstructureDiff(array &$operations, $key)
 {
     if (!isset($operations[$key])) {
         return;
     }
     if (!$operations[$key] instanceof Diff) {
         $warning = "Invalid substructure diff for key {$key}: " . get_class($operations[$key]);
         if (function_exists('wfLogWarning')) {
             wfLogWarning($warning);
         } else {
             trigger_error($warning, E_USER_WARNING);
         }
         // We could look into the atomic diff, see if it uses arrays as values,
         // and construct a new Diff according to these values. But since the
         // actual old behavior of MapDiffer didn't cause that to happen, let's
         // just use an empty diff, which is what MapDiffer should have returned
         // in the actual broken case mentioned in bug 51363.
         $operations[$key] = new Diff(array(), true);
     }
 }
開發者ID:SRMSE,項目名稱:cron-wikidata,代碼行數:30,代碼來源:EntityDiff.php

示例10: searchText

 /**
  * Search revisions with provided term.
  *
  * @param string $term Term to search
  * @return Status
  */
 public function searchText($term)
 {
     // full-text search
     $queryString = new QueryString($term);
     $queryString->setFields(array('revisions.text'));
     $this->query->setQuery($queryString);
     // add aggregation to determine exact amount of matching search terms
     $terms = $this->getTerms($term);
     $this->query->addAggregation($this->termsAggregation($terms));
     // @todo: abstract-away this config? (core/cirrus also has this - share it somehow?)
     $this->query->setHighlight(array('fields' => array(static::HIGHLIGHT_FIELD => array('type' => 'plain', 'order' => 'score', 'number_of_fragments' => 1, 'fragment_size' => 10000)), 'pre_tags' => array(static::HIGHLIGHT_PRE), 'post_tags' => array(static::HIGHLIGHT_POST)));
     // @todo: support insource: queries (and perhaps others)
     $searchable = Connection::getFlowIndex($this->indexBaseName);
     if ($this->type !== false) {
         $searchable = $searchable->getType($this->type);
     }
     $search = $searchable->createSearch($this->query);
     // @todo: PoolCounter config at PoolCounterSettings-eqiad.php
     // @todo: do we want this class to extend from ElasticsearchIntermediary and use its success & failure methods (like CirrusSearch/Searcher does)?
     // Perform the search
     $work = new PoolCounterWorkViaCallback('Flow-Search', "_elasticsearch", array('doWork' => function () use($search) {
         try {
             $result = $search->search();
             return Status::newGood($result);
         } catch (ExceptionInterface $e) {
             if (strpos($e->getMessage(), 'dynamic scripting for [groovy] disabled')) {
                 // known issue with default ES config, let's display a more helpful message
                 return Status::newFatal(new \RawMessage("Couldn't complete search: dynamic scripting needs to be enabled. " . "Please add 'script.disable_dynamic: false' to your elasticsearch.yml"));
             }
             return Status::newFatal('flow-error-search');
         }
     }, 'error' => function (Status $status) {
         $status = $status->getErrorsArray();
         wfLogWarning('Pool error searching Elasticsearch: ' . $status[0][0]);
         return Status::newFatal('flow-error-search');
     }));
     $result = $work->execute();
     return $result;
 }
開發者ID:TarLocesilion,項目名稱:mediawiki-extensions-Flow,代碼行數:45,代碼來源:Searcher.php

示例11: coalesceRuns

 /**
  * Coalesce consecutive changes by the same user to the same entity into one.
  * A run of changes may be broken if the action performed changes (e.g. deletion
  * instead of update) or if a sitelink pointing to the local wiki was modified.
  *
  * Some types of actions, like deletion, will break runs.
  * Interleaved changes to different items will break runs.
  *
  * @param EntityChange[] $changes
  *
  * @return EntityChange[] grouped changes
  */
 private function coalesceRuns(array $changes)
 {
     $coalesced = array();
     $currentRun = array();
     $currentUser = null;
     $currentEntity = null;
     $currentAction = null;
     $breakNext = false;
     foreach ($changes as $change) {
         try {
             $action = $change->getAction();
             $meta = $change->getMetadata();
             $user = $meta['user_text'];
             $entityId = $change->getEntityId()->__toString();
             $break = $breakNext || $currentAction !== $action || $currentUser !== $user || $currentEntity !== $entityId;
             $breakNext = false;
             if (!$break && $change instanceof ItemChange) {
                 $siteLinkDiff = $change->getSiteLinkDiff();
                 if (isset($siteLinkDiff[$this->localSiteId])) {
                     // TODO: don't break if only the link's badges changed
                     $break = true;
                     $breakNext = true;
                 }
             }
             if ($break) {
                 if (!empty($currentRun)) {
                     try {
                         $coalesced[] = $this->mergeChanges($currentRun);
                     } catch (MWException $ex) {
                         // Something went wrong while trying to merge the changes.
                         // Just keep the original run.
                         wfWarn($ex->getMessage());
                         $coalesced = array_merge($coalesced, $currentRun);
                     }
                 }
                 $currentRun = array();
                 $currentUser = $user;
                 $currentEntity = $entityId;
                 $currentAction = $action === EntityChange::ADD ? EntityChange::UPDATE : $action;
             }
             $currentRun[] = $change;
             // skip any change that failed to process in some way (bug T51417)
         } catch (Exception $ex) {
             wfLogWarning(__METHOD__ . ':' . $ex->getMessage());
         }
     }
     if (!empty($currentRun)) {
         try {
             $coalesced[] = $this->mergeChanges($currentRun);
         } catch (MWException $ex) {
             // Something went wrong while trying to merge the changes.
             // Just keep the original run.
             wfWarn($ex->getMessage());
             $coalesced = array_merge($coalesced, $currentRun);
         }
     }
     return $coalesced;
 }
開發者ID:Benestar,項目名稱:mediawiki-extensions-Wikibase,代碼行數:70,代碼來源:ChangeRunCoalescer.php

示例12: fixEditConflict

 /**
  * Attempts to fix an edit conflict by patching the intended change into the latest revision after
  * checking for conflicts. This modifies $this->newEntity but does not write anything to the
  * database. Saving of the new content may still fail.
  *
  * @return bool True if the conflict could be resolved, false otherwise
  */
 public function fixEditConflict()
 {
     $baseRev = $this->getBaseRevision();
     $latestRev = $this->getLatestRevision();
     if (!$latestRev) {
         wfLogWarning('Failed to load latest revision of entity ' . $this->newEntity->getId() . '! ' . 'This may indicate entries missing from thw wb_entities_per_page table.');
         return false;
     }
     $entityDiffer = new EntityDiffer();
     $entityPatcher = new EntityPatcher();
     // calculate patch against base revision
     // NOTE: will fail if $baseRev or $base are null, which they may be if
     // this gets called at an inappropriate time. The data flow in this class
     // should be improved.
     $patch = $entityDiffer->diffEntities($baseRev->getEntity(), $this->newEntity);
     if ($patch->isEmpty()) {
         // we didn't technically fix anything, but if there is nothing to change,
         // so just keep the current content as it is.
         $this->newEntity = $latestRev->getEntity()->copy();
         return true;
     }
     // apply the patch( base -> new ) to the latest revision.
     $patchedLatest = $latestRev->getEntity()->copy();
     $entityPatcher->patchEntity($patchedLatest, $patch);
     // detect conflicts against latest revision
     $cleanPatch = $entityDiffer->diffEntities($latestRev->getEntity(), $patchedLatest);
     $conflicts = $patch->count() - $cleanPatch->count();
     if ($conflicts > 0) {
         // patch doesn't apply cleanly
         if ($this->userWasLastToEdit($this->user, $this->newEntity->getId(), $this->getBaseRevisionId())) {
             // it's a self-conflict
             if ($cleanPatch->count() === 0) {
                 // patch collapsed, possibly because of diff operation change from base to latest
                 return false;
             } else {
                 // we still have a working patch, try to apply
                 $this->status->warning('wikibase-self-conflict-patched');
             }
         } else {
             // there are unresolvable conflicts.
             return false;
         }
     } else {
         // can apply cleanly
         $this->status->warning('wikibase-conflict-patched');
     }
     // remember the patched entity as the actual new entity to save
     $this->newEntity = $patchedLatest;
     return true;
 }
開發者ID:TU-Berlin,項目名稱:WikidataMath,代碼行數:57,代碼來源:EditEntity.php

示例13: transformFilePath

 /**
  * Utility method for transformResourceFilePath().
  *
  * Caller is responsible for ensuring the file exists. Emits a PHP warning otherwise.
  *
  * @since 1.27
  * @param string $remotePath URL path that points to $localPath
  * @param string $localPath File directory exposed at $remotePath
  * @param string $file Path to target file relative to $localPath
  * @return string URL
  */
 public static function transformFilePath($remotePath, $localPath, $file)
 {
     $hash = md5_file("{$localPath}/{$file}");
     if ($hash === false) {
         wfLogWarning(__METHOD__ . ": Failed to hash {$localPath}/{$file}");
         $hash = '';
     }
     return "{$remotePath}/{$file}?" . substr($hash, 0, 5);
 }
開發者ID:OrBin,項目名稱:mediawiki,代碼行數:20,代碼來源:OutputPage.php

示例14: decompressRevisionText

 /**
  * Re-converts revision text according to it's flags.
  *
  * @param mixed $text Reference to a text
  * @param array $flags Compression flags
  * @return string|bool Decompressed text, or false on failure
  */
 public static function decompressRevisionText($text, $flags)
 {
     if (in_array('gzip', $flags)) {
         # Deal with optional compression of archived pages.
         # This can be done periodically via maintenance/compressOld.php, and
         # as pages are saved if $wgCompressRevisions is set.
         $text = gzinflate($text);
         if ($text === false) {
             wfLogWarning(__METHOD__ . ': gzinflate() failed');
             return false;
         }
     }
     if (in_array('object', $flags)) {
         # Generic compressed storage
         $obj = unserialize($text);
         if (!is_object($obj)) {
             // Invalid object
             return false;
         }
         $text = $obj->getText();
     }
     global $wgLegacyEncoding;
     if ($text !== false && $wgLegacyEncoding && !in_array('utf-8', $flags) && !in_array('utf8', $flags)) {
         # Old revisions kept around in a legacy encoding?
         # Upconvert on demand.
         # ("utf8" checked for compatibility with some broken
         #  conversion scripts 2008-12-30)
         global $wgContLang;
         $text = $wgContLang->iconv($wgLegacyEncoding, 'UTF-8', $text);
     }
     return $text;
 }
開發者ID:OrBin,項目名稱:mediawiki,代碼行數:39,代碼來源:Revision.php

示例15: getLegacySkinNames

 /**
  * @return array
  */
 private function getLegacySkinNames()
 {
     static $skinsInitialised = false;
     if (!$skinsInitialised || !count($this->legacySkins)) {
         # Get a list of available skins
         # Build using the regular expression '^(.*).php$'
         # Array keys are all lower case, array value keep the case used by filename
         #
         wfProfileIn(__METHOD__ . '-init');
         global $wgStyleDirectory;
         $skinDir = dir($wgStyleDirectory);
         if ($skinDir !== false && $skinDir !== null) {
             # while code from www.php.net
             while (false !== ($file = $skinDir->read())) {
                 // Skip non-PHP files, hidden files, and '.dep' includes
                 $matches = array();
                 if (preg_match('/^([^.]*)\\.php$/', $file, $matches)) {
                     $aSkin = $matches[1];
                     // Explicitly disallow loading core skins via the autodiscovery mechanism.
                     //
                     // They should be loaded already (in a non-autodicovery way), but old files might still
                     // exist on the server because our MW version upgrade process is widely documented as
                     // requiring just copying over all files, without removing old ones.
                     //
                     // This is one of the reasons we should have never used autodiscovery in the first
                     // place. This hack can be safely removed when autodiscovery is gone.
                     if (in_array($aSkin, array('CologneBlue', 'Modern', 'MonoBook', 'Vector'))) {
                         wfLogWarning("An old copy of the {$aSkin} skin was found in your skins/ directory. " . "You should remove it to avoid problems in the future." . "See https://www.mediawiki.org/wiki/Manual:Skin_autodiscovery for details.");
                         continue;
                     }
                     wfLogWarning("A skin using autodiscovery mechanism, {$aSkin}, was found in your skins/ directory. " . "The mechanism will be removed in MediaWiki 1.25 and the skin will no longer be recognized. " . "See https://www.mediawiki.org/wiki/Manual:Skin_autodiscovery for information how to fix this.");
                     $this->legacySkins[strtolower($aSkin)] = $aSkin;
                 }
             }
             $skinDir->close();
         }
         $skinsInitialised = true;
         wfProfileOut(__METHOD__ . '-init');
     }
     return $this->legacySkins;
 }
開發者ID:whysasse,項目名稱:kmwiki,代碼行數:44,代碼來源:SkinFactory.php


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