diff --git a/benchmark/mixin.php b/benchmark/mixin.php new file mode 100644 index 000000000..a5a0b3664 --- /dev/null +++ b/benchmark/mixin.php @@ -0,0 +1,69 @@ +getFileName()); + + $start = $refl->getStartLine(); + $end = $refl->getEndLine(); + + $ret = array_slice($lines, $start, ($end - $start)); + + $code = trim(trim(implode(' ', $ret)), '{}'); + + $_map[$tpl . $method] = $code; + } else { + $code = $_map[$tpl . $method]; + } + eval($code); +} +function someCode() { + $a = 10; +} +class Template +{ + public function exec() + { + $a = 10; + } +} +print "
MIXIN BENCHMARK \n"; + +$timepoint = microtime(true); + +$i = 500; + +while ($i--) { + mixin('someCode'); +} + +print 'EXECUTED 500 CODE BLOCKS : ' . (microtime(true) - $timepoint) . "\n"; + + +$timepoint = microtime(true); + +$i = 500; + +while ($i--) { + someCode(); +} + +print 'EXECUTED 500 DIRECT FUNCTION CALLS : ' . (microtime(true) - $timepoint) . "\n"; + +$timepoint = microtime(true); + +$i = 500; + +while ($i--) { + eval('$a = 10;'); +} + +print 'EXECUTED 500 DIRECT EVAL CALLS : ' . (microtime(true) - $timepoint) . "\n";