From 6f398dcfc6bb0c58902266c9117c0e1d03f5bb47 Mon Sep 17 00:00:00 2001 From: Andrew Dolgov Date: Mon, 5 Jun 2017 12:53:06 +0300 Subject: af_comics updates: 1. move preferences to Feeds tab 2. update CAD comic with support for sillies 3. add support for loading updated/third-party filters from filters.local (would override bundled filters) --- plugins/af_comics/init.php | 24 +++++++++++++++++------- 1 file changed, 17 insertions(+), 7 deletions(-) (limited to 'plugins/af_comics/init.php') diff --git a/plugins/af_comics/init.php b/plugins/af_comics/init.php index 15af1d1a6..09e903379 100644 --- a/plugins/af_comics/init.php +++ b/plugins/af_comics/init.php @@ -19,23 +19,31 @@ class Af_Comics extends Plugin { require_once __DIR__ . "/filter_base.php"; - $filters = glob(__DIR__ . "/filters/*.php"); + $filters = array_merge(glob(__DIR__ . "/filters.local/*.php"), glob(__DIR__ . "/filters/*.php")); + $names = []; foreach ($filters as $file) { - require_once $file; $filter_name = preg_replace("/\..*$/", "", basename($file)); - $filter = new $filter_name(); + if (array_search($filter_name, $names) === FALSE) { + if (!class_exists($filter_name)) { + require_once $file; + } + + array_push($names, $filter_name); + + $filter = new $filter_name(); - if (is_subclass_of($filter, "Af_ComicFilter")) { - array_push($this->filters, $filter); + if (is_subclass_of($filter, "Af_ComicFilter")) { + array_push($this->filters, $filter); + array_push($names, $filter_name); + } } } - } function hook_prefs_tab($args) { - if ($args != "prefPrefs") return; + if ($args != "prefFeeds") return; print "
"; @@ -59,6 +67,8 @@ class Af_Comics extends Plugin { print "

".__('GoComics requires a specific URL to workaround their lack of feed support: http://feeds.feedburner.com/uclick/comic_name (e.g. http://www.gocomics.com/garfield uses http://feeds.feedburner.com/uclick/garfield).')."

"; + print "

".__('Drop any updated filters into filters.local in plugin directory.')."

"; + print "
"; } -- cgit v1.2.3-54-g00ecf