Differences Between: [Versions 310 and 402] [Versions 311 and 402] [Versions 39 and 402] [Versions 400 and 402]
1 <?php 2 /** 3 * Copyright 2008-2017 Horde LLC (http://www.horde.org/) 4 * 5 * See the enclosed file LICENSE for license information (LGPL). If you 6 * did not receive this file, see http://www.horde.org/licenses/lgpl21. 7 * 8 * @category Horde 9 * @copyright 2008-2017 Horde LLC 10 * @license http://www.horde.org/licenses/lgpl21 LGPL 2.1 11 * @package Imap_Client 12 */ 13 14 /** 15 * Object representing the threaded sort results from 16 * Horde_Imap_Client_Base#thread(). 17 * 18 * @author Michael Slusarz <slusarz@horde.org> 19 * @category Horde 20 * @copyright 2008-2017 Horde LLC 21 * @license http://www.horde.org/licenses/lgpl21 LGPL 2.1 22 * @package Imap_Client 23 */ 24 class Horde_Imap_Client_Data_Thread implements Countable, Serializable 25 { 26 /** 27 * Internal thread data structure. Keys are base values, values are arrays 28 * with keys as the ID and values as the level. 29 * 30 * @var array 31 */ 32 protected $_thread = array(); 33 34 /** 35 * The index type. 36 * 37 * @var string 38 */ 39 protected $_type; 40 41 /** 42 * Constructor. 43 * 44 * @param array $data See $_thread. 45 * @param string $type Either 'sequence' or 'uid'. 46 */ 47 public function __construct($data, $type) 48 { 49 $this->_thread = $data; 50 $this->_type = $type; 51 } 52 53 /** 54 * Return the ID type. 55 * 56 * @return string Either 'sequence' or 'uid'. 57 */ 58 public function getType() 59 { 60 return $this->_type; 61 } 62 63 /** 64 * Return the sorted list of messages indices. 65 * 66 * @return Horde_Imap_Client_Ids The sorted list of messages. 67 */ 68 public function messageList() 69 { 70 return new Horde_Imap_Client_Ids($this->_getAllIndices(), $this->getType() == 'sequence'); 71 } 72 73 /** 74 * Returns the list of messages in a thread. 75 * 76 * @param integer $index An index contained in the thread. 77 * 78 * @return array Keys are indices, values are objects with the following 79 * properties: 80 * - base: (integer) Base ID of the thread. If null, thread is a single 81 * message. 82 * - last: (boolean) If true, this is the last index in the sublevel. 83 * - level: (integer) The sublevel of the index. 84 */ 85 public function getThread($index) 86 { 87 foreach ($this->_thread as $v) { 88 if (isset($v[$index])) { 89 reset($v); 90 91 $ob = new stdClass; 92 $ob->base = (count($v) > 1) ? key($v) : null; 93 $ob->last = false; 94 95 $levels = $out = array(); 96 $last = 0; 97 98 while (($v2 = current($v)) !== false) { 99 $k2 = key($v); 100 $ob2 = clone $ob; 101 $ob2->level = $v2; 102 $out[$k2] = $ob2; 103 104 if (($last < $v2) && isset($levels[$v2])) { 105 $out[$levels[$v2]]->last = true; 106 } 107 $levels[$v2] = $k2; 108 $last = $v2; 109 next($v); 110 } 111 112 foreach ($levels as $v) { 113 $out[$v]->last = true; 114 } 115 116 return $out; 117 } 118 } 119 120 return array(); 121 } 122 123 /** 124 * Returns array of all threads. 125 * 126 * @return array Keys of thread arrays are indices, values are objects with the following 127 * properties: 128 * - base: (integer) Base ID of the thread. If null, thread is a single 129 * message. 130 * - last: (boolean) If true, this is the last index in the sublevel. 131 * - level: (integer) The sublevel of the index. 132 */ 133 public function getThreads() 134 { 135 $data = array(); 136 foreach ($this->_thread as $v) { 137 reset($v); 138 139 $ob = new stdClass; 140 $ob->base = (count($v) > 1) ? key($v) : null; 141 $ob->last = false; 142 143 $levels = $out = array(); 144 $last = 0; 145 146 while (($v2 = current($v)) !== false) { 147 $k2 = key($v); 148 $ob2 = clone $ob; 149 $ob2->level = $v2; 150 $out[$k2] = $ob2; 151 152 if (($last < $v2) && isset($levels[$v2])) { 153 $out[$levels[$v2]]->last = true; 154 } 155 $levels[$v2] = $k2; 156 $last = $v2; 157 next($v); 158 } 159 160 foreach ($levels as $v) { 161 $out[$v]->last = true; 162 } 163 164 $data[] = $out; 165 } 166 167 return $data; 168 } 169 170 /* Countable methods. */ 171 172 /** 173 */ 174 #[ReturnTypeWillChange] 175 public function count() 176 { 177 return count($this->_getAllIndices()); 178 } 179 180 /* Serializable methods. */ 181 182 /** 183 */ 184 public function serialize() 185 { 186 return serialize($this->__serialize()); 187 } 188 189 /** 190 */ 191 public function unserialize($data) 192 { 193 $data = @unserialize($data); 194 if (!is_array($data)) { 195 throw new Exception('Cache version changed.'); 196 } 197 $this->__unserialize($data); 198 } 199 200 /** 201 * @return array 202 */ 203 public function __serialize() 204 { 205 return [$this->_thread, $this->_type]; 206 } 207 208 public function __unserialize(array $data) 209 { 210 list($this->_thread, $this->_type) = $data; 211 } 212 213 /* Protected methods. */ 214 215 /** 216 * Return all indices. 217 * 218 * @return array An array of indices. 219 */ 220 protected function _getAllIndices() 221 { 222 $out = array(); 223 224 foreach ($this->_thread as $val) { 225 $out += $val; 226 } 227 228 return array_keys($out); 229 } 230 231 }
title
Description
Body
title
Description
Body
title
Description
Body
title
Body