<?xml version="1.0" encoding="UTF-8"?><rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
		>
<channel>
	<title>Comments on: Class for profiling time of code execution</title>
	<atom:link href="http://zfsite.andreinikolov.com/2008/07/class-for-profiling-time-of-code-execution/feed/" rel="self" type="application/rss+xml" />
	<link>http://zfsite.andreinikolov.com/2008/07/class-for-profiling-time-of-code-execution/</link>
	<description>Series of articles describing step by step building of example php application (web site) based on Zend Framework.</description>
	<lastBuildDate>Mon, 05 Jul 2010 08:23:16 +0000</lastBuildDate>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.0</generator>
	<item>
		<title>By: BaнXeлcинк</title>
		<link>http://zfsite.andreinikolov.com/2008/07/class-for-profiling-time-of-code-execution/comment-page-1/#comment-617</link>
		<dc:creator>BaнXeлcинк</dc:creator>
		<pubDate>Sat, 27 Dec 2008 14:54:21 +0000</pubDate>
		<guid isPermaLink="false">http://zfsite.andreinikolov.com/?p=13#comment-617</guid>
		<description>А кому от этого легче станет?</description>
		<content:encoded><![CDATA[<p>А кому от этого легче станет?</p>
]]></content:encoded>
	</item>
	<item>
		<title>By: viperx</title>
		<link>http://zfsite.andreinikolov.com/2008/07/class-for-profiling-time-of-code-execution/comment-page-1/#comment-42</link>
		<dc:creator>viperx</dc:creator>
		<pubDate>Thu, 31 Jul 2008 10:33:24 +0000</pubDate>
		<guid isPermaLink="false">http://zfsite.andreinikolov.com/?p=13#comment-42</guid>
		<description>added ability for printTime to print transitional time (before stop() is invoked):

&lt;pre lang=&quot;php&quot;&gt;
    public static function printTime($counter = &quot;def&quot;)
    {
        $counter = self::filterCounterName($counter);
        if ($counter === &quot;&quot;) throw new Exception(&#039;Not valid counter name&#039;);
        
        if (!isset(self::$durations[$counter])) 
        {
            //print transitional time:
            $currentTime = microtime();
            $aA = explode(&#039; &#039;,self::$startTimes[$counter].&#039; &#039;.$currentTime); //seperate values and put parts in array
            
            $transitionalTime = (($aA[2]+$aA[3])-($aA[0]+$aA[1])) + 
                                (isset(self::$durations[$counter]) ? self::$durations[$counter] : 0);
                                
          if($counter != &quot;def&quot;)
            return sprintf(&#039;Transitional time for Counter &#039;.$counter.&#039;: %03.4f Seconds&#039;, $transitionalTime);
          else
            return sprintf(&#039;Transitional time: %03.4f Seconds&#039;, $transitionalTime);            
        }
        
        if($counter != &quot;def&quot;)
          return sprintf(&#039;Counter &#039;.$counter.&#039;: %03.4f Seconds&#039;, self::$durations[$counter]);
        else
          return sprintf(&#039;%03.4f Seconds&#039;, self::$durations[$counter]);        
    }
&lt;/pre&gt;</description>
		<content:encoded><![CDATA[<p>added ability for printTime to print transitional time (before stop() is invoked):</p>

<div class="wp_syntax"><div class="code"><pre class="php php" style="font-family:monospace;">    <span style="color: #000000; font-weight: bold;">public</span> <span style="color: #990000;">static</span> <span style="color: #000000; font-weight: bold;">function</span> printTime<span style="color: #009900;">&#40;</span><span style="color: #000088;">$counter</span> <span style="color: #339933;">=</span> <span style="color: #0000ff;">&quot;def&quot;</span><span style="color: #009900;">&#41;</span>
    <span style="color: #009900;">&#123;</span>
        <span style="color: #000088;">$counter</span> <span style="color: #339933;">=</span> <span style="color: #000000; font-weight: bold;">self</span><span style="color: #339933;">::</span><span style="color: #004000;">filterCounterName</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$counter</span><span style="color: #009900;">&#41;</span>;
        <span style="color: #b1b100;">if</span> <span style="color: #009900;">&#40;</span><span style="color: #000088;">$counter</span> <span style="color: #339933;">===</span> <span style="color: #0000ff;">&quot;&quot;</span><span style="color: #009900;">&#41;</span> throw <span style="color: #000000; font-weight: bold;">new</span> Exception<span style="color: #009900;">&#40;</span><span style="">'Not valid counter name'</span><span style="color: #009900;">&#41;</span>;
&nbsp;
        <span style="color: #b1b100;">if</span> <span style="color: #009900;">&#40;</span><span style="color: #339933;">!</span><span style="color: #990000;">isset</span><span style="color: #009900;">&#40;</span><span style="color: #000000; font-weight: bold;">self</span><span style="color: #339933;">::</span><span style="color: #000088;">$durations</span><span style="color: #009900;">&#91;</span><span style="color: #000088;">$counter</span><span style="color: #009900;">&#93;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span> 
        <span style="color: #009900;">&#123;</span>
            <span style="color: #666666; font-style: italic;">//print transitional time:</span>
            <span style="color: #000088;">$currentTime</span> <span style="color: #339933;">=</span> <span style="color: #990000;">microtime</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span>;
            <span style="color: #000088;">$aA</span> <span style="color: #339933;">=</span> <span style="color: #990000;">explode</span><span style="color: #009900;">&#40;</span><span style="">' '</span><span style="color: #339933;">,</span><span style="color: #000000; font-weight: bold;">self</span><span style="color: #339933;">::</span><span style="color: #000088;">$startTimes</span><span style="color: #009900;">&#91;</span><span style="color: #000088;">$counter</span><span style="color: #009900;">&#93;</span><span style="color: #339933;">.</span><span style="">' '</span><span style="color: #339933;">.</span><span style="color: #000088;">$currentTime</span><span style="color: #009900;">&#41;</span>; <span style="color: #666666; font-style: italic;">//seperate values and put parts in array</span>
&nbsp;
            <span style="color: #000088;">$transitionalTime</span> <span style="color: #339933;">=</span> <span style="color: #009900;">&#40;</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$aA</span><span style="color: #009900;">&#91;</span><span style="color: #cc66cc;">2</span><span style="color: #009900;">&#93;</span><span style="color: #339933;">+</span><span style="color: #000088;">$aA</span><span style="color: #009900;">&#91;</span><span style="color: #cc66cc;">3</span><span style="color: #009900;">&#93;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">-</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$aA</span><span style="color: #009900;">&#91;</span><span style="color:#800080;">0</span><span style="color: #009900;">&#93;</span><span style="color: #339933;">+</span><span style="color: #000088;">$aA</span><span style="color: #009900;">&#91;</span><span style="color: #cc66cc;">1</span><span style="color: #009900;">&#93;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span> <span style="color: #339933;">+</span> 
                                <span style="color: #009900;">&#40;</span><span style="color: #990000;">isset</span><span style="color: #009900;">&#40;</span><span style="color: #000000; font-weight: bold;">self</span><span style="color: #339933;">::</span><span style="color: #000088;">$durations</span><span style="color: #009900;">&#91;</span><span style="color: #000088;">$counter</span><span style="color: #009900;">&#93;</span><span style="color: #009900;">&#41;</span> ? <span style="color: #000000; font-weight: bold;">self</span><span style="color: #339933;">::</span><span style="color: #000088;">$durations</span><span style="color: #009900;">&#91;</span><span style="color: #000088;">$counter</span><span style="color: #009900;">&#93;</span> <span style="color: #339933;">:</span> <span style="color:#800080;">0</span><span style="color: #009900;">&#41;</span>;
&nbsp;
          <span style="color: #b1b100;">if</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$counter</span> <span style="color: #339933;">!=</span> <span style="color: #0000ff;">&quot;def&quot;</span><span style="color: #009900;">&#41;</span>
            <span style="color: #b1b100;">return</span> <span style="color: #990000;">sprintf</span><span style="color: #009900;">&#40;</span><span style="">'Transitional time for Counter '</span><span style="color: #339933;">.</span><span style="color: #000088;">$counter</span><span style="color: #339933;">.</span><span style="">': %03.4f Seconds'</span><span style="color: #339933;">,</span> <span style="color: #000088;">$transitionalTime</span><span style="color: #009900;">&#41;</span>;
          <span style="color: #b1b100;">else</span>
            <span style="color: #b1b100;">return</span> <span style="color: #990000;">sprintf</span><span style="color: #009900;">&#40;</span><span style="">'Transitional time: %03.4f Seconds'</span><span style="color: #339933;">,</span> <span style="color: #000088;">$transitionalTime</span><span style="color: #009900;">&#41;</span>;            
        <span style="color: #009900;">&#125;</span>
&nbsp;
        <span style="color: #b1b100;">if</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$counter</span> <span style="color: #339933;">!=</span> <span style="color: #0000ff;">&quot;def&quot;</span><span style="color: #009900;">&#41;</span>
          <span style="color: #b1b100;">return</span> <span style="color: #990000;">sprintf</span><span style="color: #009900;">&#40;</span><span style="">'Counter '</span><span style="color: #339933;">.</span><span style="color: #000088;">$counter</span><span style="color: #339933;">.</span><span style="">': %03.4f Seconds'</span><span style="color: #339933;">,</span> <span style="color: #000000; font-weight: bold;">self</span><span style="color: #339933;">::</span><span style="color: #000088;">$durations</span><span style="color: #009900;">&#91;</span><span style="color: #000088;">$counter</span><span style="color: #009900;">&#93;</span><span style="color: #009900;">&#41;</span>;
        <span style="color: #b1b100;">else</span>
          <span style="color: #b1b100;">return</span> <span style="color: #990000;">sprintf</span><span style="color: #009900;">&#40;</span><span style="">'%03.4f Seconds'</span><span style="color: #339933;">,</span> <span style="color: #000000; font-weight: bold;">self</span><span style="color: #339933;">::</span><span style="color: #000088;">$durations</span><span style="color: #009900;">&#91;</span><span style="color: #000088;">$counter</span><span style="color: #009900;">&#93;</span><span style="color: #009900;">&#41;</span>;        
    <span style="color: #009900;">&#125;</span></pre></div></div>

]]></content:encoded>
	</item>
</channel>
</rss>

<!-- Dynamic Page Served (once) in 0.350 seconds -->
