xandeadx.ru Блог музицирующего веб-девелопера

Drupal → Выводим в html время затраченное на создание блока

Опубликовано в

В продолжении прошлого поста — выводим время создания контента блока, а точнее время выполнения hook_block_view() (это не время рендеринга):

/**
 * Implements hook_block_list_alter().
 */
function THEMENAME_block_list_alter(&$blocks) {
  $GLOBALS['block_build_microtime'] = microtime(TRUE);
}
 
/**
 * Implements hook_block_view_alter().
 */
function THEMENAME_block_view_alter(&$data, $block) {
  $block->build_time = microtime(TRUE) - $GLOBALS['block_build_microtime'];
  $GLOBALS['block_build_microtime'] = microtime(TRUE);
}
 
/**
 * Preprocess function for block.tpl.php.
 */
function THEMENAME_preprocess_block(&$vars) {
  if (isset($vars['block']->build_time)) {
    $build_time = intval($vars['block']->build_time * 100000) / 100;
    $vars['content'] .= "\n<!-- Block build time: $build_time ms -->\n";
  }
}

Результат:

Написанное актуально для Drupal 7
Похожие записи

Комментарии RSS

Думал, эти данные уже собираются каким-нибудь модулем типа devel.

Оставить комментарий

Содержимое этого поля является приватным и не будет отображаться публично. Если у вас есть аккаунт в Gravatar, привязанный к этому e-mail адресу, то он будет использован для отображения аватара.
  • Адреса страниц и электронной почты автоматически преобразуются в ссылки.
  • Доступные HTML теги: <a> <i> <b> <strong> <code> <ul> <ol> <li> <blockquote> <em> <s>
  • Строки и параграфы переносятся автоматически.
  • Подсветка кода осуществляется с помощью тегов: <code>, <css>, <html>, <ini>, <javascript>, <sql>, <php>. Поддерживаемые стили выделения кода: <foo>, [foo].

Подробнее о форматировании