Search moodle.org's
Developer Documentation

See Release Notes

  • Bug fixes for general core bugs in 4.0.x will end 8 May 2023 (12 months).
  • Bug fixes for security issues in 4.0.x will end 13 November 2023 (18 months).
  • PHP version: minimum PHP 7.3.0 Note: the minimum PHP version has increased since Moodle 3.10. PHP 7.4.x is also supported.

Differences Between: [Versions 310 and 400]

(no description)

File Size: 716 lines (24 kb)
Included or required:0 times
Referenced: 0 times
Includes or requires: 0 files

Defines 1 class

Mustache_Compiler:: (24 methods):
  compile()
  setPragmas()
  walk()
  renderInternal()
  renderInternal()
  writeCode()
  blockVar()
  blockArg()
  block()
  section()
  getSection()
  section()
  invertedSection()
  partial()
  parent()
  onlyBlockArgs()
  variable()
  getFilters()
  text()
  prepare()
  getEscape()
  getFindMethod()
  getCallable()
  flushIndent()


Class: Mustache_Compiler  - X-Ref

Mustache Compiler class.

This class is responsible for turning a Mustache token parse tree into normal PHP source code.
compile($source, array $tree, $name, $customEscape = false, $charset = 'UTF-8', $strictCallables = false, $entityFlags = ENT_COMPAT, $disableLambdaRendering = false)   X-Ref
Compile a Mustache token parse tree into PHP source code.

return: string Generated PHP source code
param: string $source                 Mustache Template source code
param: array  $tree                   Parse tree of Mustache tokens
param: string $name                   Mustache Template class name
param: bool   $customEscape           (default: false)
param: string $charset                (default: 'UTF-8')
param: bool   $strictCallables        (default: false)
param: int    $entityFlags            (default: ENT_COMPAT)
param: bool   $disableLambdaRendering (default: false)

setPragmas(array $pragmas)   X-Ref
Enable pragmas across all templates, regardless of the presence of pragma
tags in the individual templates.

param: string[] $pragmas

walk(array $tree, $level = 0)   X-Ref
Helper function for walking the Mustache token parse tree.

return: string Generated PHP source code
param: array $tree  Parse tree of Mustache tokens
param: int   $level (default: 0)

renderInternal(Mustache_Context $context, $indent = \'\')   X-Ref
No description

renderInternal(Mustache_Context $context, $indent = \'\')   X-Ref
No description

writeCode($tree, $name)   X-Ref
Generate Mustache Template class PHP source.

return: string Generated PHP source code
param: array  $tree Parse tree of Mustache tokens
param: string $name Mustache Template class name

blockVar($nodes, $id, $start, $end, $otag, $ctag, $level)   X-Ref
Generate Mustache Template inheritance block variable PHP source.

return: string Generated PHP source code
param: array  $nodes Array of child tokens
param: string $id    Section name
param: int    $start Section start offset
param: int    $end   Section end offset
param: string $otag  Current Mustache opening tag
param: string $ctag  Current Mustache closing tag
param: int    $level

blockArg($nodes, $id, $start, $end, $otag, $ctag, $level)   X-Ref
Generate Mustache Template inheritance block argument PHP source.

return: string Generated PHP source code
param: array  $nodes Array of child tokens
param: string $id    Section name
param: int    $start Section start offset
param: int    $end   Section end offset
param: string $otag  Current Mustache opening tag
param: string $ctag  Current Mustache closing tag
param: int    $level

block({$indent = $buffer = \'\';%sreturn $buffer;}';/*** Generate Mustache Template inheritance block function PHP source.** @param array $nodes Array of child tokens** @return string key of new block function*/private function block($nodes)   X-Ref
No description

section({$buffer = \'\';if (%s)   X-Ref
No description

getSection($key, $callable, $source, $helper, $delims, $content)   X-Ref
Helper function to compile section with and without lambda rendering.

return: string section code
param: string $key
param: string $callable
param: string $source
param: string $helper
param: string $delims
param: string $content

section($nodes, $id, $filters, $start, $end, $otag, $ctag, $level)   X-Ref
Generate Mustache Template section PHP source.

return: string Generated section PHP source code
param: array    $nodes   Array of child tokens
param: string   $id      Section name
param: string[] $filters Array of filters
param: int      $start   Section start offset
param: int      $end     Section end offset
param: string   $otag    Current Mustache opening tag
param: string   $ctag    Current Mustache closing tag
param: int      $level

invertedSection($nodes, $id, $filters, $level)   X-Ref
Generate Mustache Template inverted section PHP source.

return: string Generated inverted section PHP source code
param: array    $nodes   Array of child tokens
param: string   $id      Section name
param: string[] $filters Array of filters
param: int      $level

partial($id, $indent, $level)   X-Ref
Generate Mustache Template partial call PHP source.

return: string Generated partial call PHP source code
param: string $id     Partial name
param: string $indent Whitespace indent to apply to partial
param: int    $level

parent($id, $indent, array $children, $level)   X-Ref
Generate Mustache Template inheritance parent call PHP source.

return: string Generated PHP source code
param: string $id       Parent tag name
param: string $indent   Whitespace indent to apply to parent
param: array  $children Child nodes
param: int    $level

onlyBlockArgs(array $node)   X-Ref
Helper method for filtering out non-block-arg tokens.

return: bool True if $node is a block arg token
param: array $node

variable($id, $filters, $escape, $level)   X-Ref
Generate Mustache Template variable interpolation PHP source.

return: string Generated variable interpolation PHP source
param: string   $id      Variable name
param: string[] $filters Array of filters
param: bool     $escape  Escape the variable value for output?
param: int      $level

getFilters(array $filters, $level)   X-Ref
Generate Mustache Template variable filtering PHP source.

return: string Generated filter PHP source
param: string[] $filters Array of filters
param: int      $level

text($text, $level)   X-Ref
Generate Mustache Template output Buffer call PHP source.

return: string Generated output Buffer call PHP source
param: string $text
param: int    $level

prepare($text, $bonus = 0, $prependNewline = true, $appendNewline = false)   X-Ref
Prepare PHP source code snippet for output.

return: string PHP source code snippet
param: string $text
param: int    $bonus          Additional indent level (default: 0)
param: bool   $prependNewline Prepend a newline to the snippet? (default: true)
param: bool   $appendNewline  Append a newline to the snippet? (default: false)

getEscape($value = '$value')   X-Ref
Get the current escaper.

return: string Either a custom callback, or an inline call to `htmlspecialchars`
param: string $value (default: '$value')

getFindMethod($id)   X-Ref
Select the appropriate Context `find` method for a given $id.

The return value will be one of `find`, `findDot`, `findAnchoredDot` or `last`.

return: string `find` method name
param: string $id Variable name

getCallable($variable = '$value')   X-Ref
Helper function to compile strict vs lax "is callable" logic.

return: string "is callable" logic
param: string $variable (default: '$value')

flushIndent()   X-Ref
Get the current $indent prefix to write to the buffer.

return: string "$indent . " or ""