summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorshadlaws <shad@shadlaws.com>2013-02-18 19:12:45 +0100
committershadlaws <shad@shadlaws.com>2013-02-18 19:12:45 +0100
commitab920ae360d5cca446784675bb0401349c50d9fb (patch)
treec194587bf930831397ab602e116dfea94c6c9d23
parentafa61f9d0d551bc2a0c4fa903eb3f55742720c8d (diff)
#1749, 1754, 1901 - Eliminate incompatibility with Zend Guard Loader.
- added MY_Kohana to provide wrapper for auto_load(), which loads dummy class when none found. - revised Bootstrap to load MY_Kohana. This is based on the patch described here: http://blog.teatime.com.tw/1/post/403
-rw-r--r--application/Bootstrap.php2
-rw-r--r--modules/gallery/libraries/MY_Kohana.php45
2 files changed, 46 insertions, 1 deletions
diff --git a/application/Bootstrap.php b/application/Bootstrap.php
index 93353b47..a79ccba4 100644
--- a/application/Bootstrap.php
+++ b/application/Bootstrap.php
@@ -35,7 +35,7 @@ require SYSPATH.'core/Event'.EXT;
final class Event extends Event_Core {}
require SYSPATH.'core/Kohana'.EXT;
-final class Kohana extends Kohana_Core {}
+require MODPATH.'gallery/libraries/MY_Kohana'.EXT;
require SYSPATH.'core/Kohana_Exception'.EXT;
require MODPATH.'gallery/libraries/MY_Kohana_Exception'.EXT;
diff --git a/modules/gallery/libraries/MY_Kohana.php b/modules/gallery/libraries/MY_Kohana.php
new file mode 100644
index 00000000..d344c8ed
--- /dev/null
+++ b/modules/gallery/libraries/MY_Kohana.php
@@ -0,0 +1,45 @@
+<?php defined("SYSPATH") or die("No direct script access.");
+/**
+ * Gallery - a web based photo album viewer and editor
+ * Copyright (C) 2000-2013 Bharat Mediratta
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or (at
+ * your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA.
+ */
+final class Kohana extends Kohana_Core {
+ /**
+ * Wrapper function for Kohana::auto_load that provides compatibility with Zend Guard Loader's
+ * code obfuscation. Zend Guard is enabled by default on many PHP 5.3+ installations and can
+ * cause problems with Kohana 2.4. When a class is not found, Zend Guard Loader may continue to
+ * try and load the class, eventually leading to a seg fault.
+ *
+ * Instead, if we can't find the class and we can see that code obfuscation is at level 3+, let's
+ * load a dummy class. This does not change the return value, so Kohana still knows that
+ * there is no class.
+ *
+ * This is based on the patch described here: http://blog.teatime.com.tw/1/post/403
+ */
+ public static function auto_load($class) {
+ $found = parent::auto_load($class);
+
+ if (!$found && function_exists("zend_current_obfuscation_level") &&
+ (zend_current_obfuscation_level() >= 3)) {
+ // Load a dummy class instead.
+ eval("class $class {}");
+ }
+
+ // Return the same result.
+ return $found;
+ }
+} \ No newline at end of file