View Single Post
  #28  
Old 03-08-2006, 09:06 PM
bairy bairy is offline
 
Join Date: Oct 2005
Posts: 184
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

Not exactly related to the first post but some things I find very very useful when coding.

At the bottom of includes/functions.php I have the following:

PHP Code:
function pre($var) {
    if (
$_SERVER['REMOTE_ADDR'] == 'xxx.xxx.xxx.xxx' or $_SERVER['REMOTE_ADDR'] == '127.0.0.1') {
        echo 
"<pre>";
        
print_r($var);
        echo 
"</pre><br />";
    }
}

function 
echoa($var) {
    if (
$_SERVER['REMOTE_ADDR'] == 'xxx.xxx.xxx.xxx' or $_SERVER['REMOTE_ADDR'] == '127.0.0.1') echo $var;
}

class 
microtimer {
// Starts, Ends and Displays Page Creation Time
   
function getmicrotime() {
       list(
$usec$sec) = explode(" "microtime());
       return ((float)
$usec + (float)$sec);
   }
   
   function 
s() {
   
$this->st $this->getmicrotime();
   }
       
   function 
e() {
       
$this->et $this->getmicrotime();
       if (
$_SERVER['REMOTE_ADDR'] == 'xxx.xxx.xxx.xxx' or $_SERVER['REMOTE_ADDR'] == 'xxx.xxx.xxx.xxx') echo round(($this->et $this->st), 6);
   }
}
$tm = new microtimer
where xxx.xxx.xxx.xxx is your internet IP and 127.0.0.1 is if you have an installation on your pc.

All of the above were taken off user comments at php.net


Usages:
PHP Code:
pre($var);

e.gpre($vbulletin->userinfo); 
This will print_r a variable in a formatted way (print_r is a php function that outputs the value of variables, good for arrays).
Extremely useful for seeing what vB knows at any point, especially if you need to call some of that data. A tip: don't pre($vbulletin), it's really messy.

PHP Code:
echoa $var
Does what echo $var does, but as you can see from the code, it only shows you so it doesn't disrupt the board.

PHP Code:
$tm->s(); 
and
PHP Code:
$tm->e(); 
This is a microtimer, put the s() just before the code you want to time, and the e() after, and it will echo the time it took in seconds. Change the 6 to control the number of decimal places. So:
PHP Code:
$tm->s();
for (
$i=0;$i 1000000$i++) {
  
$tmp 1;

That will tell you how long it takes the system to assign a value to a variable 1 million times (I got 0.35secs on a 2.4ghz P4, if anyone cares).


These are all bound to your IP or localhost to save unnecessary outputting to the board.
Reply With Quote
 
X vBulletin 3.8.12 by vBS Debug Information
  • Page Generation 0.01291 seconds
  • Memory Usage 1,793KB
  • Queries Executed 11 (?)
More Information
Template Usage:
  • (1)SHOWTHREAD_SHOWPOST
  • (1)ad_footer_end
  • (1)ad_footer_start
  • (1)ad_header_end
  • (1)ad_header_logo
  • (1)ad_navbar_below
  • (6)bbcode_php
  • (1)footer
  • (1)gobutton
  • (1)header
  • (1)headinclude
  • (6)option
  • (1)post_thanks_box
  • (1)post_thanks_button
  • (1)post_thanks_javascript
  • (1)post_thanks_navbar_search
  • (1)post_thanks_postbit_info
  • (1)postbit
  • (1)postbit_onlinestatus
  • (1)postbit_wrapper
  • (1)spacer_close
  • (1)spacer_open 

Phrase Groups Available:
  • global
  • postbit
  • reputationlevel
  • showthread
Included Files:
  • ./showpost.php
  • ./global.php
  • ./includes/init.php
  • ./includes/class_core.php
  • ./includes/config.php
  • ./includes/functions.php
  • ./includes/class_hook.php
  • ./includes/modsystem_functions.php
  • ./includes/functions_bigthree.php
  • ./includes/class_postbit.php
  • ./includes/class_bbcode.php
  • ./includes/functions_reputation.php
  • ./includes/functions_post_thanks.php 

Hooks Called:
  • init_startup
  • init_startup_session_setup_start
  • init_startup_session_setup_complete
  • cache_permissions
  • fetch_postinfo_query
  • fetch_postinfo
  • fetch_threadinfo_query
  • fetch_threadinfo
  • fetch_foruminfo
  • style_fetch
  • cache_templates
  • global_start
  • parse_templates
  • global_setup_complete
  • showpost_start
  • bbcode_fetch_tags
  • bbcode_create
  • postbit_factory
  • showpost_post
  • postbit_display_start
  • post_thanks_function_post_thanks_off_start
  • post_thanks_function_post_thanks_off_end
  • post_thanks_function_fetch_thanks_start
  • post_thanks_function_fetch_thanks_end
  • post_thanks_function_thanked_already_start
  • post_thanks_function_thanked_already_end
  • fetch_musername
  • postbit_imicons
  • bbcode_parse_start
  • bbcode_parse_complete_precache
  • bbcode_parse_complete
  • postbit_display_complete
  • post_thanks_function_can_thank_this_post_start
  • showpost_complete