From 96ea52894aea85b86d75f59fee35f90676735060 Mon Sep 17 00:00:00 2001 From: Andrey Andreev Date: Thu, 8 Nov 2012 11:34:00 +0200 Subject: Change route type checks priorities --- system/core/Router.php | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) (limited to 'system/core') diff --git a/system/core/Router.php b/system/core/Router.php index 30bf39657..3ef55cee2 100644 --- a/system/core/Router.php +++ b/system/core/Router.php @@ -341,8 +341,13 @@ class CI_Router { // Does the RegEx match? if (preg_match('#^'.$key.'$#', $uri, $matches)) { + // Are we using the default routing method for back-references? + if (strpos($val, '$') !== FALSE && strpos($key, '(') !== FALSE) + { + $val = preg_replace('#^'.$key.'$#', $val, $uri); + } // Are we using callbacks to process back-references? - if ( ! is_string($val) && is_callable($val)) + elseif ( ! is_string($val) && is_callable($val)) { // Remove the original string from the matches array. array_shift($matches); @@ -379,11 +384,6 @@ class CI_Router { // Execute the callback using the values in matches as its parameters. $val = call_user_func_array($val, $matches); } - // Are we using the default routing method for back-references? - elseif (strpos($val, '$') !== FALSE && strpos($key, '(') !== FALSE) - { - $val = preg_replace('#^'.$key.'$#', $val, $uri); - } return $this->_set_request(explode('/', $val)); } -- cgit v1.2.3-24-g4f1b