-
-
Save westonruter/6647252 to your computer and use it in GitHub Desktop.
| <?php // Common way to do it: | |
| remove_filter( 'the_title', 'wptexturize' ); | |
| $title = get_the_title(); | |
| add_filter( 'the_title', 'wptexturize' ); |
| <?php // More robust way to do it, but oh so verbose: | |
| $filter_priority = has_filter( 'the_title', 'wptexturize' ); | |
| if ( false !== $filter_priority ) { | |
| remove_filter( 'the_title', 'wptexturize', $filter_priority ); | |
| } | |
| $title = get_the_title( $post_ID ); | |
| if ( false !== $filter_priority ) { | |
| add_filter( 'the_title', 'wptexturize', $filter_priority ); | |
| } |
| <?php // What if we could do this: | |
| $title = with_filter_disabled( 'the_title', 'wptexturize', function () { | |
| return get_the_title(); | |
| } ); |
| <?php | |
| /** | |
| * Run $callback with the $handler disabled for the $hook action/filter | |
| * @param string $hook filter name | |
| * @param callable $handler function | |
| * @param callable $callback function execited while filter disabled | |
| * @return mixed value returned by $callback | |
| */ | |
| function with_filter_disabled( $hook, $handler, $callback ) { | |
| $priority = has_filter( $hook, $handler ); | |
| if ( false !== $priority ) { | |
| remove_filter( $hook, $handler, $priority ); | |
| } | |
| $retval = call_user_func( $callback ); | |
| if ( false !== $priority ) { | |
| $accepted_args = PHP_INT_MAX; // for array_slice, can't use null since cast to int | |
| add_filter( $hook, $handler, $priority, $accepted_args ); | |
| } | |
| return $retval; | |
| } |
Guys, what do you think about this:
$title = without_filters( 'the_title', function () {
return get_the_title();
} );
/**
* Run $callback with the $handler disabled for the $hook action/filter
* @param string $hook filter name
* @param callable $callback function execited while filter disabled
* @return mixed value returned by $callback
*/
function without_filters( $hook, $callback ) {
global $wp_filter;
$wp_hook = null;
// Remove and cache the filter
if ( isset( $wp_filter[ $hook ] ) && $wp_filter[ $hook ] instanceof WP_Hook ) {
$wp_hook = $wp_filter[ $hook ];
unset( $wp_filter[ $hook ] );
}
$retval = call_user_func( $callback );
// Add back the filter
if ( $wp_hook instanceof WP_Hook ) {
$wp_filter[ $hook ] = $wp_hook;
}
return $retval;
}Very helpful, thanks. Gonna use a version of this to run AMP_Content with wpautop() and other the_content filters disabled.
@rodruiz thanks for the code
i think there's a typo at line
if ( count( $hook_callbacks ) ) {
that must be like
if ( count( $wp_hook ) ) {
btw, thanks again
Pp.
Hi @duepi,
I updated the function and added some comments.
Thanks.
Thanks for this! Your code still ranks highly in search results for this particular use case.
I made one amendment to support callback functions which accept an array of arguments ($callback_args):
function with_filter_disabled( $hook, $handler, $callback, $callback_args ) {...which are just passed along to call_user_func:
$retval = call_user_func( $callback, $callback_args );Any Ideas how to get around WordPress.WP.GlobalVariablesOverride.Prohibited,
which pops up at $wp_filter[ $hook ] = $wp_hook; ?
Lovin' it. Thank you.