WP hooks navigation: Home/browse • Actions index • Filters index
To save our bandwidth, we show only a snippet of code around each occurence of the hook. View complete file in SVN (without highlighting).
The best way to understand what a hook does is to look at where it occurs in the source code.
do_action( "hook_name" )apply_filters( "hook_name", "what_to_filter" ).Remember, this hook may occur in more than one file. Moreover, the hook's context may change from version to version.
| Line | Code |
|---|---|
| 386 | function akismet_delete_old() { |
| 387 | global $wpdb; |
| 388 | $now_gmt = current_time('mysql', 1); |
| 389 | $comment_ids = $wpdb->get_col("SELECT comment_id FROM $wpdb->comments WHERE DATE_SUB('$now_gmt', INTERVAL 15 DAY) > comment_date_gmt AND comment_approved = 'spam'"); |
| 390 | if ( empty( $comment_ids ) ) |
| 391 | return; |
| 392 | |
| 393 | $comma_comment_ids = implode( ', ', array_map('intval', $comment_ids) ); |
| 394 | |
| 395 | do_action( 'delete_comment', $comment_ids ); |
| 396 | $wpdb->query("DELETE FROM $wpdb->comments WHERE comment_id IN ( $comma_comment_ids )"); |
| 397 | $wpdb->query("DELETE FROM $wpdb->commentmeta WHERE comment_id IN ( $comma_comment_ids )"); |
| 398 | clean_comment_cache( $comment_ids ); |
| 399 | $n = mt_rand(1, 5000); |
| 400 | if ( apply_filters('akismet_optimize_table', ($n == 11)) ) // lucky number |
| 401 | $wpdb->query("OPTIMIZE TABLE $wpdb->comments"); |
| 402 | |
| 403 | } |
| 404 | |