ILIAS  release_5-3 Revision v5.3.23-19-g915713cf615
Twig_Profiler_NodeVisitor_Profiler Class Reference
+ Inheritance diagram for Twig_Profiler_NodeVisitor_Profiler:
+ Collaboration diagram for Twig_Profiler_NodeVisitor_Profiler:

Public Member Functions

 __construct ($extensionName)
 
 getPriority ()
 Returns the priority for this visitor. More...
 
- Public Member Functions inherited from Twig_BaseNodeVisitor
 enterNode (Twig_NodeInterface $node, Twig_Environment $env)
 Called before child nodes are visited. More...
 
 leaveNode (Twig_NodeInterface $node, Twig_Environment $env)
 Called after child nodes are visited. More...
 
 enterNode (Twig_NodeInterface $node, Twig_Environment $env)
 Called before child nodes are visited. More...
 
 leaveNode (Twig_NodeInterface $node, Twig_Environment $env)
 Called after child nodes are visited. More...
 
 getPriority ()
 Returns the priority for this visitor. More...
 

Protected Member Functions

 doEnterNode (Twig_Node $node, Twig_Environment $env)
 Called before child nodes are visited. More...
 
 doLeaveNode (Twig_Node $node, Twig_Environment $env)
 Called after child nodes are visited. More...
 
 doEnterNode (Twig_Node $node, Twig_Environment $env)
 Called before child nodes are visited. More...
 
 doLeaveNode (Twig_Node $node, Twig_Environment $env)
 Called after child nodes are visited. More...
 

Private Member Functions

 getVarName ()
 

Private Attributes

 $extensionName
 

Detailed Description

Author
Fabien Potencier fabie.nosp@m.n@sy.nosp@m.mfony.nosp@m..com

@final

Definition at line 17 of file Profiler.php.

Constructor & Destructor Documentation

◆ __construct()

Twig_Profiler_NodeVisitor_Profiler::__construct (   $extensionName)

Definition at line 21 of file Profiler.php.

22 {
23 $this->extensionName = $extensionName;
24 }

References $extensionName.

Member Function Documentation

◆ doEnterNode()

Twig_Profiler_NodeVisitor_Profiler::doEnterNode ( Twig_Node  $node,
Twig_Environment  $env 
)
protected

Called before child nodes are visited.

Returns
Twig_Node The modified node

Reimplemented from Twig_BaseNodeVisitor.

Definition at line 26 of file Profiler.php.

27 {
28 return $node;
29 }

◆ doLeaveNode()

Twig_Profiler_NodeVisitor_Profiler::doLeaveNode ( Twig_Node  $node,
Twig_Environment  $env 
)
protected

Called after child nodes are visited.

Returns
Twig_Node|false The modified node or false if the node must be removed

Reimplemented from Twig_BaseNodeVisitor.

Definition at line 31 of file Profiler.php.

32 {
33 if ($node instanceof Twig_Node_Module) {
34 $varName = $this->getVarName();
35 $node->setNode('display_start', new Twig_Node(array(new Twig_Profiler_Node_EnterProfile($this->extensionName, Twig_Profiler_Profile::TEMPLATE, $node->getTemplateName(), $varName), $node->getNode('display_start'))));
36 $node->setNode('display_end', new Twig_Node(array(new Twig_Profiler_Node_LeaveProfile($varName), $node->getNode('display_end'))));
37 } elseif ($node instanceof Twig_Node_Block) {
38 $varName = $this->getVarName();
39 $node->setNode('body', new Twig_Node_Body(array(
40 new Twig_Profiler_Node_EnterProfile($this->extensionName, Twig_Profiler_Profile::BLOCK, $node->getAttribute('name'), $varName),
41 $node->getNode('body'),
43 )));
44 } elseif ($node instanceof Twig_Node_Macro) {
45 $varName = $this->getVarName();
46 $node->setNode('body', new Twig_Node_Body(array(
47 new Twig_Profiler_Node_EnterProfile($this->extensionName, Twig_Profiler_Profile::MACRO, $node->getAttribute('name'), $varName),
48 $node->getNode('body'),
50 )));
51 }
52
53 return $node;
54 }
Represents a block node.
Definition: Block.php:19
Represents a body node.
Definition: Body.php:18
Represents a macro node.
Definition: Macro.php:18
Represents a module node.
Definition: Module.php:23
Represents a node in the AST.
Definition: Node.php:19
setNode($name, $node=null)
Definition: Node.php:195
getAttribute($name)
Definition: Node.php:152
getTemplateName()
Definition: Node.php:229
getNode($name)
Definition: Node.php:186
Represents a profile enter node.
Represents a profile leave node.

References Twig_Profiler_Profile\BLOCK, Twig_Node\getAttribute(), Twig_Node\getNode(), Twig_Node\getTemplateName(), getVarName(), Twig_Profiler_Profile\MACRO, Twig_Node\setNode(), and Twig_Profiler_Profile\TEMPLATE.

+ Here is the call graph for this function:

◆ getPriority()

Twig_Profiler_NodeVisitor_Profiler::getPriority ( )

Returns the priority for this visitor.

Priority should be between -10 and 10 (0 is the default).

Returns
int The priority level

Implements Twig_NodeVisitorInterface.

Definition at line 61 of file Profiler.php.

62 {
63 return 0;
64 }

◆ getVarName()

Twig_Profiler_NodeVisitor_Profiler::getVarName ( )
private

Definition at line 56 of file Profiler.php.

57 {
58 return sprintf('__internal_%s', hash('sha256', $this->extensionName));
59 }
sprintf('%.4f', $callTime)
hash(StreamInterface $stream, $algo, $rawOutput=false)
Calculate a hash of a Stream.
Definition: functions.php:406

References GuzzleHttp\Psr7\hash(), and sprintf.

Referenced by doLeaveNode().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

Field Documentation

◆ $extensionName

Twig_Profiler_NodeVisitor_Profiler::$extensionName
private

Definition at line 19 of file Profiler.php.

Referenced by __construct().


The documentation for this class was generated from the following file: