From eabd44876c67239b1f27afc4acadf1d7e2001219 Mon Sep 17 00:00:00 2001 From: alecpl Date: Tue, 4 Jan 2011 10:48:27 +0000 Subject: - Extend getCapability() to return caps values or true/false --- program/include/rcube_imap_generic.php | 41 +++++++++++++++++++++++++++++----- 1 file changed, 35 insertions(+), 6 deletions(-) diff --git a/program/include/rcube_imap_generic.php b/program/include/rcube_imap_generic.php index 9eeb028bf..b5fd96871 100644 --- a/program/include/rcube_imap_generic.php +++ b/program/include/rcube_imap_generic.php @@ -371,11 +371,44 @@ class rcube_imap_generic return false; } - function getCapability($name) + private function hasCapability($name) { + if (empty($this->capability) || $name == '') { + return false; + } + if (in_array($name, $this->capability)) { return true; } + else if (strpos($name, '=')) { + return false; + } + + $result = array(); + foreach ($this->capability as $cap) { + $entry = explode('=', $cap); + if ($entry[0] == $name) { + $result[] = $entry[1]; + } + } + + return !empty($result) ? $result : false; + } + + /** + * Capabilities checker + * + * @param string $name Capability name + * + * @return mixed Capability values array for key=value pairs, true/false for others + */ + function getCapability($name) + { + $result = $this->hasCapability($name); + + if (!empty($result)) { + return $result; + } else if ($this->capability_readed) { return false; } @@ -390,11 +423,7 @@ class rcube_imap_generic $this->capability_readed = true; - if (in_array($name, $this->capability)) { - return true; - } - - return false; + return $this->hasCapability($name); } function clearCapability() -- cgit v1.2.3