1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980 |
- <?php
- class Debug_Bar_Queries extends Debug_Bar_Panel {
- function init() {
- $this->title( __('Queries', 'debug-bar') );
- }
- function prerender() {
- $this->set_visible( defined('SAVEQUERIES') && SAVEQUERIES || ! empty($GLOBALS['EZSQL_ERROR']) );
- }
- function debug_bar_classes( $classes ) {
- if ( ! empty($GLOBALS['EZSQL_ERROR']) )
- $classes[] = 'debug-bar-php-warning-summary';
- return $classes;
- }
- function render() {
- global $wpdb, $EZSQL_ERROR;
- $out = '';
- $total_time = 0;
- if ( !empty($wpdb->queries) ) {
- $show_many = isset($_GET['debug_queries']);
- if ( $wpdb->num_queries > 500 && !$show_many )
- $out .= "<p>" . sprintf( __('There are too many queries to show easily! <a href="%s">Show them anyway</a>', 'debug-bar'), esc_url( add_query_arg( 'debug_queries', 'true' ) ) ) . "</p>";
- $out .= '<ol class="wpd-queries">';
- $counter = 0;
- foreach ( $wpdb->queries as $q ) {
- list($query, $elapsed, $debug) = $q;
- $total_time += $elapsed;
- if ( ++$counter > 500 && ! $show_many )
- continue;
- $debug = explode( ', ', $debug );
- $debug = array_diff( $debug, array( 'require_once', 'require', 'include_once', 'include' ) );
- $debug = implode( ', ', $debug );
- $debug = str_replace( array( 'do_action, call_user_func_array' ), array( 'do_action' ), $debug );
- $query = nl2br(esc_html($query));
- $out .= "<li>$query<br/><div class='qdebug'>$debug <span>#{$counter} (" . number_format(sprintf('%0.1f', $elapsed * 1000), 1, '.', ',') . "ms)</span></div></li>\n";
- }
- $out .= '</ol>';
- } else {
- if ( $wpdb->num_queries == 0 )
- $out .= "<p><strong>" . __('There are no queries on this page.', 'debug-bar') . "</strong></p>";
- else
- $out .= "<p><strong>" . __('SAVEQUERIES must be defined to show the query log.', 'debug-bar') . "</strong></p>";
- }
- if ( ! empty($EZSQL_ERROR) ) {
- $out .= '<h3>' . __( 'Database Errors', 'debug-bar' ) . '</h3>';
- $out .= '<ol class="wpd-queries">';
- foreach ( $EZSQL_ERROR as $e ) {
- $query = nl2br(esc_html($e['query']));
- $out .= "<li>$query<br/><div class='qdebug'>{$e['error_str']}</div></li>\n";
- }
- $out .= '</ol>';
- }
- $heading = '';
- if ( $wpdb->num_queries )
- $heading .= '<h2><span>Total Queries:</span>' . number_format( $wpdb->num_queries ) . "</h2>\n";
- if ( $total_time )
- $heading .= '<h2><span>Total query time:</span>' . number_format(sprintf('%0.1f', $total_time * 1000), 1) . " ms</h2>\n";
- if ( ! empty($EZSQL_ERROR) )
- $heading .= '<h2><span>Total DB Errors:</span>' . number_format( count($EZSQL_ERROR) ) . "</h2>\n";
- $out = $heading . $out;
- echo $out;
- }
- }
|