Stabilize how WordPress hooks into SimplePie to implement transient caching.

Since a plugin can load a previous (< 1.3) version of SimplePie before we do,
we need to be compatible with our old method of overriding SimplePie_Cache::create().

SimplePie_Cache::create() was converted to static in 1.3 (as it was called),
requiring that we create two different definitions of WP_Feed_Cache (extends
SimplePie_Cache). Instead, we can use 1.3's new object registry, and leave
the old WP_Feed_Cache to SimplePie 1.2 versions.

see #21183.



git-svn-id: http://core.svn.wordpress.org/trunk@21652 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
Andrew Nacin 2012-08-29 00:25:52 +00:00
parent 52b3f498e6
commit f1aaf6d359
2 changed files with 24 additions and 12 deletions

View File

@ -3,6 +3,9 @@
if ( !class_exists('SimplePie') )
require_once (ABSPATH . WPINC . '/class-simplepie.php');
if ( version_compare( SIMPLEPIE_VERSION, '1.3-dev', '>' ) ) :
SimplePie_Cache::register( 'wp-transient', 'WP_Feed_Cache_Transient' );
else :
class WP_Feed_Cache extends SimplePie_Cache {
/**
* Create a new SimplePie_Cache object
@ -10,10 +13,11 @@ class WP_Feed_Cache extends SimplePie_Cache {
* @static
* @access public
*/
public static function create($location, $filename, $extension) {
function create($location, $filename, $extension) {
return new WP_Feed_Cache_Transient($location, $filename, $extension);
}
}
endif;
class WP_Feed_Cache_Transient {
var $name;

View File

@ -532,9 +532,17 @@ function fetch_feed($url) {
require_once (ABSPATH . WPINC . '/class-feed.php');
$feed = new SimplePie();
$feed->set_feed_url($url);
if ( version_compare( SIMPLEPIE_VERSION, '1.3-dev', '>' ) ) {
$feed->set_cache_location( 'wp-transient' );
$feed->registry->register( 'Cache', 'WP_Feed_Cache_Transient' );
$feed->registry->register( 'File', 'WP_SimplePie_File' );
} else {
$feed->set_cache_class( 'WP_Feed_Cache' );
$feed->set_file_class( 'WP_SimplePie_File' );
}
$feed->set_feed_url($url);
$feed->set_cache_duration(apply_filters('wp_feed_cache_transient_lifetime', 43200, $url));
do_action_ref_array( 'wp_feed_options', array( &$feed, $url ) );
$feed->init();