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


PHP Unicode::encodingFromBOM方法代碼示例

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


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

示例1: optimize

 /**
  * {@inheritdoc}
  */
 public function optimize(array $js_asset)
 {
     if ($js_asset['type'] !== 'file') {
         throw new \Exception('Only file JavaScript assets can be optimized.');
     }
     if ($js_asset['type'] === 'file' && !$js_asset['preprocess']) {
         throw new \Exception('Only file JavaScript assets with preprocessing enabled can be optimized.');
     }
     // If a BOM is found, convert the file to UTF-8, then use substr() to
     // remove the BOM from the result.
     $data = file_get_contents($js_asset['data']);
     if ($encoding = Unicode::encodingFromBOM($data)) {
         $data = Unicode::substr(Unicode::convertToUtf8($data, $encoding), 1);
     } elseif (isset($js_asset['attributes']['charset'])) {
         $data = Unicode::convertToUtf8($data, $js_asset['attributes']['charset']);
     }
     // No-op optimizer: no optimizations are applied to JavaScript assets.
     return $data;
 }
開發者ID:nstielau,項目名稱:drops-8,代碼行數:22,代碼來源:JsOptimizer.php

示例2: loadFile

 /**
  * Loads the stylesheet and resolves all @import commands.
  *
  * Loads a stylesheet and replaces @import commands with the contents of the
  * imported file. Use this instead of file_get_contents when processing
  * stylesheets.
  *
  * The returned contents are compressed removing white space and comments only
  * when CSS aggregation is enabled. This optimization will not apply for
  * color.module enabled themes with CSS aggregation turned off.
  *
  * Note: the only reason this method is public is so color.module can call it;
  * it is not on the AssetOptimizerInterface, so future refactorings can make
  * it protected.
  *
  * @param $file
  *   Name of the stylesheet to be processed.
  * @param $optimize
  *   Defines if CSS contents should be compressed or not.
  * @param $reset_basepath
  *   Used internally to facilitate recursive resolution of @import commands.
  *
  * @return
  *   Contents of the stylesheet, including any resolved @import commands.
  */
 public function loadFile($file, $optimize = NULL, $reset_basepath = TRUE)
 {
     // These statics are not cache variables, so we don't use drupal_static().
     static $_optimize, $basepath;
     if ($reset_basepath) {
         $basepath = '';
     }
     // Store the value of $optimize for preg_replace_callback with nested
     // @import loops.
     if (isset($optimize)) {
         $_optimize = $optimize;
     }
     // Stylesheets are relative one to each other. Start by adding a base path
     // prefix provided by the parent stylesheet (if necessary).
     if ($basepath && !file_uri_scheme($file)) {
         $file = $basepath . '/' . $file;
     }
     // Store the parent base path to restore it later.
     $parent_base_path = $basepath;
     // Set the current base path to process possible child imports.
     $basepath = dirname($file);
     // Load the CSS stylesheet. We suppress errors because themes may specify
     // stylesheets in their .info.yml file that don't exist in the theme's path,
     // but are merely there to disable certain module CSS files.
     $content = '';
     if ($contents = @file_get_contents($file)) {
         // If a BOM is found, convert the file to UTF-8, then use substr() to
         // remove the BOM from the result.
         if ($encoding = Unicode::encodingFromBOM($contents)) {
             $contents = Unicode::substr(Unicode::convertToUtf8($contents, $encoding), 1);
         } elseif (preg_match('/^@charset "([^"]+)";/', $contents, $matches)) {
             if ($matches[1] !== 'utf-8' && $matches[1] !== 'UTF-8') {
                 $contents = substr($contents, strlen($matches[0]));
                 $contents = Unicode::convertToUtf8($contents, $matches[1]);
             }
         }
         // Return the processed stylesheet.
         $content = $this->processCss($contents, $_optimize);
     }
     // Restore the parent base path as the file and its children are processed.
     $basepath = $parent_base_path;
     return $content;
 }
開發者ID:Wylbur,項目名稱:gj,代碼行數:68,代碼來源:CssOptimizer.php


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