From 6ee5ed253b92593ac5784300ac425f34f7fd1728 Mon Sep 17 00:00:00 2001
From: alecpl <alec@alec.pl>
Date: Tue, 29 Apr 2008 04:13:26 -0400
Subject: [PATCH] #1485021: update dutch localization

---
 program/lib/imap.inc |  635 ++++++++++++++++++++++++++++++++-------------------------
 1 files changed, 359 insertions(+), 276 deletions(-)

diff --git a/program/lib/imap.inc b/program/lib/imap.inc
index fa2fe2a..918e71a 100644
--- a/program/lib/imap.inc
+++ b/program/lib/imap.inc
@@ -49,17 +49,25 @@
 		- Sanity check of $message_set in iil_C_FetchHeaders(), iil_C_FetchHeaderIndex(), iil_C_FetchThreadHeaders()
 		- Implemented UID FETCH in iil_C_FetchHeaders()
 		- Abort do-loop on socket errors (fgets returns false)
+		- $ICL_SSL is not boolean anymore but contains the connection schema (ssl or tls)
 		- Removed some debuggers (echo ...)
 
 ********************************************************/
 
+/**
+ * @todo Possibly clean up more CS.
+ * @todo Try to replace most double-quotes with single-quotes.
+ * @todo Split this file into smaller files.
+ * @todo Refactor code.
+ * @todo Replace echo-debugging (make it adhere to config setting and log)
+ */
 
 // changed path to work within roundcube webmail
-include_once("lib/icl_commons.inc");
+include_once 'lib/icl_commons.inc';
 
 
-if (!$IMAP_USE_HEADER_DATE) {
-	$IMAP_USE_INTERNAL_DATE = true;
+if (!isset($IMAP_USE_HEADER_DATE) || !$IMAP_USE_HEADER_DATE) {
+    $IMAP_USE_INTERNAL_DATE = true;
 }
 
 /**
@@ -120,6 +128,7 @@
 	var $f;
 	var $internaldate;
 	var $references;
+	var $priority;
 	var $mdn_to;
 	var $mdn_sent = false;
 	var $is_reply = false;
@@ -152,41 +161,48 @@
 }
 
 function iil_ReadLine($fp, $size) {
-	$line = '';
-	if ($fp) {
-		do {
-			$buffer = fgets($fp, 2048);
-			if ($buffer === false) {
-				break;
-            }
-			$line.=$buffer;
-		} while ($buffer[strlen($buffer)-1]!="\n");
-	}
-	return $line;
+    $line = '';
+    if (!$fp) {
+        return $line;
+    }
+    do {
+	// FIXME: hardcode size?
+        $buffer = fgets($fp, 2048);
+        if ($buffer === false) {
+            break;
+        }
+        $line .= $buffer;
+    } while ($buffer[strlen($buffer)-1] != "\n");
+    return $line;
 }
 
 function iil_MultLine($fp, $line) {
 	$line = chop($line);
 	if (ereg('\{[0-9]+\}$', $line)) {
 		$out = '';
+        
 		preg_match_all('/(.*)\{([0-9]+)\}$/', $line, $a);
 		$bytes = $a[2][0];
-		while (strlen($out)<$bytes) {
-			$out.=chop(iil_ReadLine($fp, 1024));
+		while (strlen($out) < $bytes) {
+		    $line = iil_ReadLine($fp, 1024); 
+			$out .= chop($line);
 		}
-		$line = $a[1][0]."\"$out\"";
+		$line = $a[1][0] . "\"$out\"";
 	}
 	return $line;
 }
 
 function iil_ReadBytes($fp, $bytes) {
-	$data = '';
-	$len  = 0;
-	do {
-		$data.=fread($fp, $bytes-$len);
-		$len = strlen($data);
-	} while ($len<$bytes);
-	return $data;
+    $data = '';
+    $len  = 0;
+    do {
+        $data .= fread($fp, $bytes-$len);
+        if ($len == strlen($data)) {
+            break; //nothing was read -> exit to avoid apache lockups
+        }
+        $len = strlen($data);
+    } while ($len < $bytes);
+    return $data;
 }
 
 function iil_ReadReply($fp) {
@@ -242,8 +258,8 @@
     
     // initialize ipad, opad
     for ($i=0;$i<64;$i++) {
-        $ipad .=chr(0x36);
-        $opad .=chr(0x5C);
+        $ipad .= chr(0x36);
+        $opad .= chr(0x5C);
     }
     // pad $pass so it's 64 bytes
     $padLen = 64 - strlen($pass);
@@ -252,13 +268,15 @@
     }
     
     // generate hash
-    $hash = md5(iil_xor($pass,$opad) . pack("H*",md5(iil_xor($pass, $ipad) . base64_decode($encChallenge))));
+    $hash  = iil_xor($pass,$opad);
+    $hash .= pack("H*", md5(iil_xor($pass, $ipad) . base64_decode($encChallenge)));
+    $hash  = md5($hash);
     
     // generate reply
-    $reply = base64_encode($user . ' ' . $hash);
+    $reply = base64_encode('"' . $user . '" "' . $hash . '"');
     
     // send result, get reply
-    fputs($conn->fp, $reply."\r\n");
+    fputs($conn->fp, $reply . "\r\n");
     $line = iil_ReadLine($conn->fp, 1024);
     
     // process result
@@ -267,7 +285,7 @@
         $conn->errorNum  = 0;
         return $conn->fp;
     }
-    $conn->error    .= 'Authentication for '.$user.' failed (AUTH): "';
+    $conn->error    .= 'Authentication for ' . $user . ' failed (AUTH): "';
     $conn->error    .= htmlspecialchars($line) . '"';
     $conn->errorNum  = -2;
     return false;
@@ -443,7 +461,7 @@
     
 	//check for SSL
 	if ($ICL_SSL) {
-		$host = "ssl://".$host;
+		$host = $ICL_SSL . '://' . $host;
 	}
 	
 	//open socket connection
@@ -461,17 +479,19 @@
 		//check for supported auth methods
 		
 		//default to plain text auth
-		$auth_method = "plain";
+		$auth_method = 'plain';
 			
 		//check for CRAM-MD5
 		fputs($conn->fp, "cp01 CAPABILITY\r\n");
 		do {
 		    $line = trim(chop(iil_ReadLine($conn->fp, 100)));
-		    $conn->message.="$line\n";
+
+		    $conn->message .= "$line\n";
+
 			$a = explode(' ', $line);
-			if ($line[0]=="*") {
-				while ( list($k, $w) = each($a) ) {
-				    if ($w!='*' && $w!='CAPABILITY') {
+			if ($line[0] == '*') {
+				while (list($k, $w) = each($a)) {
+				    if ($w != '*' && $w != 'CAPABILITY') {
     					$conn->capability[] = $w;
                     }
 					if ((strcasecmp($w, "AUTH=CRAM_MD5") == 0)||
@@ -480,25 +500,29 @@
 					}
 				}
 			}
-		} while ($a[0]!="cp01");
+		} while ($a[0] != 'cp01');
 	}
 
-	if (strcasecmp($auth_method, "auth") == 0) {
+	if (strcasecmp($auth_method, 'auth') == 0) {
 		$conn->message .= "Trying CRAM-MD5\n";
+
 		//do CRAM-MD5 authentication
 		fputs($conn->fp, "a000 AUTHENTICATE CRAM-MD5\r\n");
 		$line = trim(chop(iil_ReadLine($conn->fp, 1024)));
         
-		$conn->message.="$line\n";
+		$conn->message .= "$line\n";
         
-		if ($line[0] == "+") {
-			$conn->message.='Got challenge: '.htmlspecialchars($line)."\n";
+		if ($line[0] == '+') {
+			$conn->message .= 'Got challenge: ' . htmlspecialchars($line) . "\n";
+
 			//got a challenge string, try CRAM-5
 			$result = iil_C_Authenticate($conn, $user, $password, substr($line,2));
-			$conn->message.= "Tried CRAM-MD5: $result \n";
+            
+			$conn->message .= "Tried CRAM-MD5: $result \n";
 		} else {
-			$conn->message.='No challenge ('.htmlspecialchars($line)."), try plain\n";
-			$auth = "plain";
+			$conn->message .='No challenge ('.htmlspecialchars($line)."), try plain\n";
+			
+            $auth = 'plain';            
 		}
 	}
 		
@@ -557,22 +581,30 @@
 }
 
 function iil_C_LoadCache(&$conn, $folder) {
-	if (!$conn->do_cache) return false;
-	
-	$key = $folder.".imap";
+	if (!$conn->do_cache) {
+	    return false;
+	}
+    
+	$key = $folder.'.imap';
 	if (!is_array($conn->cache[$folder])) {
-		$conn->cache[$folder] = cache_read($conn->user, $conn->host, $key);
+		$conn->cache[$folder]       = cache_read($conn->user, $conn->host, $key);
 		$conn->cache_dirty[$folder] = false;
 	}
 }
 
 function iil_C_ExpireCachedItems(&$conn, $folder, $message_set) {
 	
-	if (!$conn->do_cache) return;	//caching disabled
-	if (!is_array($conn->cache[$folder])) return;	//cache not initialized|empty
-	if (count($conn->cache[$folder]) == 0) return;	//cache not initialized|empty
-		
-	$uids = iil_C_FetchHeaderIndex($conn, $folder, $message_set, "UID");
+	if (!$conn->do_cache) {
+	    return;	//caching disabled
+	}
+    if (!is_array($conn->cache[$folder])) {
+        return;	//cache not initialized|empty
+	}
+    if (count($conn->cache[$folder]) == 0) {
+        return;	//cache not initialized|empty
+    }
+    
+	$uids = iil_C_FetchHeaderIndex($conn, $folder, $message_set, 'UID');
 	$num_removed = 0;
 	if (is_array($uids)) {
 		//echo "<!-- unsetting: ".implode(",",$uids)." //-->\n";
@@ -603,16 +635,19 @@
 }
 
 function iil_ExplodeQuotedString($delimiter, $string) {
-	$quotes=explode("\"", $string);
-	while ( list($key, $val) = each($quotes))
-		if (($key % 2) == 1) 
+	$quotes=explode('"', $string);
+	while ( list($key, $val) = each($quotes)) {
+		if (($key % 2) == 1) {
 			$quotes[$key] = str_replace($delimiter, "_!@!_", $quotes[$key]);
-	$string=implode("\"", $quotes);
+        }
+    }
+	$string=implode('"', $quotes);
 	
 	$result=explode($delimiter, $string);
-	while ( list($key, $val) = each($result) )
-		$result[$key] = str_replace("_!@!_", $delimiter, $result[$key]);
-	
+	while ( list($key, $val) = each($result) ) {
+		$result[$key] = str_replace('_!@!_', $delimiter, $result[$key]);
+	}
+    
 	return $result;
 }
 
@@ -628,10 +663,10 @@
 		do {
 			$line=chop(iil_ReadLine($fp, 300));
 			$a=explode(' ', $line);
-			if (($a[0] == '*') && (strcasecmp($a[2], "RECENT") == 0)) {
+			if (($a[0] == '*') && (strcasecmp($a[2], 'RECENT') == 0)) {
 			    $result = (int) $a[1];
             }
-		} while (!iil_StartsWith($a[0],"a002"));
+		} while (!iil_StartsWith($a[0], 'a002'));
 
 		fputs($fp, "a003 LOGOUT\r\n");
 		fclose($fp);
@@ -659,14 +694,18 @@
 			$line=chop(iil_ReadLine($fp, 300));
 			$a=explode(' ', $line);
 			if (count($a) == 3) {
-				if (strcasecmp($a[2], "EXISTS") == 0) $conn->exists=(int)$a[1];
-				if (strcasecmp($a[2], "RECENT") == 0) $conn->recent=(int)$a[1];
+				if (strcasecmp($a[2], 'EXISTS') == 0) {
+				    $conn->exists = (int) $a[1];
+				}
+                if (strcasecmp($a[2], 'RECENT') == 0) {
+                    $conn->recent = (int) $a[1];
+                }
 			}
-		} while (!iil_StartsWith($line, "sel1"));
+		} while (!iil_StartsWith($line, 'sel1'));
 
 		$a=explode(' ', $line);
 
-		if (strcasecmp($a[1],"OK") == 0) {
+		if (strcasecmp($a[1], 'OK') == 0) {
 			$conn->selected = $mailbox;
 			return true;
 		}
@@ -721,15 +760,15 @@
 	
 	//replace double spaces with single space
 	$str = trim($str);
-	$str = str_replace("  ", " ", $str);
+	$str = str_replace('  ', ' ', $str);
 	
 	//strip off day of week
-	$pos=strpos($str, " ");
+	$pos = strpos($str, ' ');
 	if (!is_numeric(substr($str, 0, $pos))) {
 	    $str = substr($str, $pos+1);
     }
 	//explode, take good parts
-	$a=explode(' ',$str);
+	$a = explode(' ', $str);
 
 	$month_str = $a[1];
 	$month     = $IMAP_MONTHS[$month_str];
@@ -738,7 +777,7 @@
 	$time      = $a[3];
 	$tz_str    = $a[4];
 	$tz        = substr($tz_str, 0, 3);
-	$ta        = explode(":",$time);
+	$ta        = explode(':', $time);
 	$hour      = (int)$ta[0]-(int)$tz;
 	$minute    = (int)$ta[1];
 	$second    = (int)$ta[2];
@@ -750,7 +789,7 @@
 }
 
 function iil_C_Sort(&$conn, $mailbox, $field, $add='', $is_uid=FALSE,
-    $encoding='US-ASCII') {
+    $encoding = 'US-ASCII') {
 	/*  Do "SELECT" command */
 	if (!iil_C_Select($conn, $mailbox)) {
 	    return false;
@@ -759,8 +798,8 @@
 	if ($field == 'INTERNALDATE') {
 	    $field = 'ARRIVAL';
     }
-	$fields = array('ARRIVAL'=>1,'CC'=>1,'DATE'=>1,'FROM'=>1,'SIZE'=>1,
-        'SUBJECT'=>1,'TO'=>1);
+	$fields = array('ARRIVAL' => 1,'CC' => 1,'DATE' => 1,
+        'FROM' => 1, 'SIZE' => 1, 'SUBJECT' => 1, 'TO' => 1);
 	
 	if (!$fields[$field]) {
 	    return false;
@@ -772,16 +811,19 @@
 	    $add = " $add";
     }
 
-	$fp      = $conn->fp;
-	$command = 's '. $is_uid .'SORT ('.$field.') '.$encoding.' ALL'."$add\r\n";
-	$line    = $data = '';
+	$fp       = $conn->fp;
+	$command  = 's ' . $is_uid . 'SORT (' . $field . ') ';
+    $command .= $encoding . ' ALL' . "$add\r\n";
+	$line     = $data = '';
 	
 	if (!fputs($fp, $command)) {
 	    return false;
     }
 	do {
 		$line = chop(iil_ReadLine($fp, 1024));
-		if (iil_StartsWith($line, '* SORT')) $data.=($data?' ':'').substr($line,7);
+		if (iil_StartsWith($line, '* SORT')) {
+		    $data .= ($data?' ':'') . substr($line, 7);
+        }
 	} while ($line[0]!='s');
 	
 	if (empty($data)) {
@@ -882,45 +924,54 @@
 				$bytes = (int)substr($line, $pos, $end_pos-$pos);
 				$received = 0;
 				do {
-					$line = iil_ReadLine($fp, 0);
-					$received+=strlen($line);
-					$line = chop($line);
+					$line      = iil_ReadLine($fp, 0);
+					$received += strlen($line);
+					$line      = chop($line);
 					
-					if ($received>$bytes) break;
-					else if (!$line) continue;
+					if ($received>$bytes) {
+                        break;
+					} else if (!$line) {
+                        continue;
+					}
+
+					list($field, $string) = explode(': ', $line);
 					
-					list($field,$string)=explode(": ", $line);
-					
-					if (strcasecmp($field, "date") == 0)
+					if (strcasecmp($field, 'date') == 0) {
 						$result[$id] = iil_StrToTime($string);
-					else if ($index_field!="DATE")
+					} else if ($index_field != 'DATE') {
 						$result[$id]=strtoupper(str_replace('"', '', $string));
-				} while ($line[0]!=")");
+                    }
+				} while ($line[0] != ')');
 			} else {
 				//one line response, not expected so ignore				
 			}
 			*/
 		} while (!iil_StartsWith($line, $key));
+
 	}else if ($mode == 6) {
+
 		$key     = 'fhi' . ($c++);
-		$request = $key." FETCH $message_set (INTERNALDATE)\r\n";
+		$request = $key . " FETCH $message_set (INTERNALDATE)\r\n";
 		if (!fputs($fp, $request)) {
 		    return false;
         }
 		do {
 			$line=chop(iil_ReadLine($fp, 200));
-			if ($line[0]=="*") {
-				//original: "* 10 FETCH (INTERNALDATE "31-Jul-2002 09:18:02 -0500")"
-				$paren_pos = strpos($line, "(");
-				$foo = substr($line, 0, $paren_pos);
-				$a = explode(' ', $foo);
-				$id = $a[1];
+			if ($line[0] == '*') {
+				/*
+				 * original:
+				 * "* 10 FETCH (INTERNALDATE "31-Jul-2002 09:18:02 -0500")"
+				 */
+				$paren_pos = strpos($line, '(');
+				$foo       = substr($line, 0, $paren_pos);
+				$a         = explode(' ', $foo);
+				$id        = $a[1];
 				
-				$open_pos = strpos($line, "\"") + 1;
-				$close_pos = strrpos($line, "\"");
+				$open_pos  = strpos($line, '"') + 1;
+				$close_pos = strrpos($line, '"');
 				if ($open_pos && $close_pos) {
-					$len = $close_pos - $open_pos;
-					$time_str = substr($line, $open_pos, $len);
+					$len         = $close_pos - $open_pos;
+					$time_str    = substr($line, $open_pos, $len);
 					$result[$id] = strtotime($time_str);
 				}
 			} else {
@@ -972,23 +1023,21 @@
 	}
 
 	//check number of elements...
-	list($start_mid,$end_mid) = explode(':', $message_set);
+	list($start_mid, $end_mid) = explode(':', $message_set);
 	if (is_numeric($start_mid) && is_numeric($end_mid)) {
 		//count how many we should have
 		$should_have = $end_mid - $start_mid +1;
 		
 		//if we have less, try and fill in the "gaps"
-		if (count($result)<$should_have) {
-			for ($i=$start_mid;$i<=$end_mid;$i++) {
+		if (count($result) < $should_have) {
+			for ($i=$start_mid; $i<=$end_mid; $i++) {
 			    if (!isset($result[$i])) {
 			        $result[$i] = '';
                 }
             }
 		}
 	}
-	
 	return $result;	
-
 }
 
 function iil_CompressMessageSet($message_set) {
@@ -1006,17 +1055,21 @@
 	}
     
 	//separate, then sort
-	$ids = explode(',',$message_set);
+	$ids = explode(',', $message_set);
 	sort($ids);
 	
 	$result = array();
-	$start = $prev = $ids[0];
+	$start  = $prev = $ids[0];
+
 	foreach ($ids as $id) {
 		$incr = $id - $prev;
-		if ($incr>1) {			//found a gap
-			if ($start==$prev) $result[] = $prev;	//push single id
-			else $result[] = $start.':'.$prev;		//push sequence as start_id:end_id
-			$start = $id;							//start of new sequence
+		if ($incr > 1) {			//found a gap
+			if ($start == $prev) {
+			    $result[] = $prev;	//push single id
+			} else {
+			    $result[] = $start . ':' . $prev;   //push sequence as start_id:end_id
+			}
+            $start = $id;							//start of new sequence
 		}
 		$prev = $id;
 	}
@@ -1035,12 +1088,12 @@
 	if (!is_array($uids) || count($uids) == 0) {
 	    return array();
     }
-	return iil_C_Search($conn, $mailbox, "UID ".implode(",", $uids));
+	return iil_C_Search($conn, $mailbox, 'UID ' . implode(',', $uids));
 }
 
 function iil_C_UIDToMID(&$conn, $mailbox, $uid) {
 	$result = iil_C_UIDsToMIDs($conn, $mailbox, array($uid));
-	if (count($result)==1) {
+	if (count($result) == 1) {
 	    return $result[0];
 	}
     return false;
@@ -1053,7 +1106,7 @@
 	if ($num == 0) {
 	    return array();
     }
-	$message_set = '1'.($num>1?':'.$num:'');
+	$message_set = '1' . ($num>1?':' . $num:'');
 	
 	//if cache not enabled, just call iil_C_FetchHeaderIndex on 'UID' field
 	if (!$conn->do_cache)
@@ -1069,17 +1122,17 @@
 	}
     
 	//was anything cached at all?
-	if ($data===false) {
+	if ($data === false) {
 	    $cache_good = -1;
 	}
     
 	//make sure number of messages were the same
-	if ($cache_good>0 && $data['n']!=$num) {
+	if ($cache_good > 0 && $data['n'] != $num) {
 	    $cache_good = -2;
 	}
     
 	//if everything's okay so far...
-	if ($cache_good>0) {
+	if ($cache_good > 0) {
 		//check UIDs of highest mid with current and cached
 		$temp = iil_C_Search($conn, $mailbox, 'UID ' . $data['d'][$num]);
 		if (!$temp || !is_array($temp) || $temp[0] != $num) {
@@ -1088,12 +1141,12 @@
 	}
 
 	//if cached data's good, return it
-	if ($cache_good>0) {
+	if ($cache_good > 0) {
 		return $data['d'];
 	}
 
 	//otherwise, we need to fetch it
-	$data      = array('n'=>$num,'d'=>array());
+	$data      = array('n' => $num, 'd' => array());
 	$data['d'] = iil_C_FetchHeaderIndex($conn, $mailbox, $message_set, 'UID');
     
 	cache_write($conn->user, $conn->host, $key, $data);
@@ -1173,16 +1226,19 @@
 				$new_thhd = new iilThreadHeader;
 				$new_thhd->id = $a[1];
 				do {
-					$line=chop(iil_ReadLine($fp, 1024),"\r\n");
+					$line = chop(iil_ReadLine($fp, 1024), "\r\n");
 					if (iil_StartsWithI($line, 'Message-ID:')
                         || (iil_StartsWithI($line,'In-Reply-To:'))
                         || (iil_StartsWithI($line,'SUBJECT:'))) {
-						$pos = strpos($line, ":");
+
+						$pos        = strpos($line, ':');
 						$field_name = substr($line, 0, $pos);
-						$field_val = substr($line, $pos+1);
+						$field_val  = substr($line, $pos+1);
+
 						$new[strtoupper($field_name)] = trim($field_val);
+
 					} else if (ereg('^[[:space:]]', $line)) {
-						$new[strtoupper($field_name)].= trim($line);
+						$new[strtoupper($field_name)] .= trim($line);
 					}
 				} while ($line[0] != ')');
                 
@@ -1256,8 +1312,8 @@
 		//$new = array('id'=>$id, 'MESSAGE-ID'=>$header['m'], 
 		//			'IN-REPLY-TO'=>$header['r'], 'SUBJECT'=>$header['s']);
 		$id  = $header->id;
-		$new = array('id'=>$id, 'MESSAGE-ID'=>$header->mid, 
-            'IN-REPLY-TO'=>$header->irt, 'SUBJECT'=>$header->sbj);
+		$new = array('id' => $id, 'MESSAGE-ID' => $header->mid, 
+            'IN-REPLY-TO' => $header->irt, 'SUBJECT' => $header->sbj);
 
 		/* add to message-id -> mid lookup table */
 		$mid_to_id[$new['MESSAGE-ID']] = $id;
@@ -1298,7 +1354,7 @@
 			}
             $sub_mids[$new['MESSAGE-ID']] = $root_id;
 			$result[$root_id][]           = $id;
-		}else if (!isset($roots[$sbj])||(!$has_re&&$root_in_root[$root_id])) {
+		}else if (!isset($roots[$sbj]) || (!$has_re && $root_in_root[$root_id])) {
 			/* try to use In-Reply-To header to find root 
 				unless subject contains 'Re:' */
 			if ($has_re&&$new['IN-REPLY-TO']) {
@@ -1341,7 +1397,7 @@
 	
 	//now that we've gone through all the messages,
 	//go back and try and link up the stray threads
-	if (count($strays)>0) {
+	if (count($strays) > 0) {
 		foreach ($strays as $id=>$irt) {
 			$root_id = $sub_mids[$irt];
 			if (!$root_id || $root_id==$id) {
@@ -1407,8 +1463,8 @@
 	
 	//sort by key, this basically sorts all threads
 	ksort($itree);
-	$i=0;
-	$out=array();
+	$i   = 0;
+	$out = array();
 	foreach ($itree as $k=>$node) {
 		$out[$i] = $itree[$k];
 		$i++;
@@ -1433,7 +1489,8 @@
 	return $t_index;
 }
 
-function iil_C_FetchHeaders(&$conn, $mailbox, $message_set, $uidfetch=false) {
+function iil_C_FetchHeaders(&$conn, $mailbox, $message_set, $uidfetch=false)
+{
 	global $IMAP_USE_INTERNAL_DATE;
 	
 	$c      = 0;
@@ -1442,9 +1499,9 @@
 	
 	list($from_idx, $to_idx) = explode(':', $message_set);
 	if (empty($message_set) || (isset($to_idx)
-        && (int)$from_idx > (int)$to_idx)) {
+		&& (int)$from_idx > (int)$to_idx)) {
 		return false;
-    }
+	}
 		
 	/*  Do "SELECT" command */
 	if (!iil_C_Select($conn, $mailbox)) {
@@ -1463,29 +1520,29 @@
 					$result[$id]->id = $id;
 				} else {
 				    $needed_set.=($needed_set ? ',': '') . $id;
-                }
+				}
 			}
 			//echo "<!-- iil_C_FetchHeader\nMessage Set: $message_set\nNeeded Set:$needed_set\n//-->\n";
 			if ($needed_set) {
-			    $message_set = iil_CompressMessageSet($needed_set);
-            } else {
-                return $result;
-            }
+				$message_set = iil_CompressMessageSet($needed_set);
+			} else {
+				return $result;
+			}
 		}
 	}
 
 	/* FETCH date,from,subject headers */
-	$key      = 'fh' . ($c++);
-	$prefix   = $uidfetch?' UID':'';
+	$key	  = 'fh' . ($c++);
+	$prefix	  = $uidfetch?' UID':'';
 	$request  = $key . $prefix;
-    $request .= " FETCH $message_set (BODY.PEEK[HEADER.FIELDS ";
-    $request .= "(DATE FROM TO SUBJECT REPLY-TO IN-REPLY-TO CC BCC ";
-    $request .= "CONTENT-TRANSFER-ENCODING CONTENT-TYPE MESSAGE-ID ";
-    $request .= "REFERENCES DISPOSITION-NOTIFICATION-TO)])\r\n";
+	$request .= " FETCH $message_set (BODY.PEEK[HEADER.FIELDS ";
+	$request .= "(DATE FROM TO SUBJECT REPLY-TO IN-REPLY-TO CC BCC ";
+	$request .= "CONTENT-TRANSFER-ENCODING CONTENT-TYPE MESSAGE-ID ";
+	$request .= "REFERENCES DISPOSITION-NOTIFICATION-TO X-PRIORITY)])\r\n";
 
 	if (!fputs($fp, $request)) {
-	    return false;
-    }
+		return false;
+	}
 	do {
 		$line = chop(iil_ReadLine($fp, 200));
 		$a    = explode(' ', $line);
@@ -1496,6 +1553,7 @@
 			$result[$id]->id        = $id;
 			$result[$id]->subject   = '';
 			$result[$id]->messageID = 'mid:' . $id;
+
 			/*
 				Start parsing headers.  The problem is, some header "lines" take up multiple lines.
 				So, we'll read ahead, and if the one we're reading now is a valid header, we'll
@@ -1508,7 +1566,7 @@
 				$line = chop(iil_ReadLine($fp, 300), "\r\n");
 				if (ord($line[0])<=32) {
 				    $lines[$i] .= (empty($lines[$i])?'':"\n").trim(chop($line));
-				} else{
+				} else {
 					$i++;
 					$lines[$i] = trim(chop($line));
 				}
@@ -1522,98 +1580,107 @@
 					if (!preg_match("/:/",$line) && preg_match("/\)$/",$line)) break;
 					however, unsure how well this would work with all imap clients.
 				*/
-				if (preg_match("/^\s*UID [0-9]+\)$/",$line)) {
+				if (preg_match("/^\s*UID [0-9]+\)$/", $line)) {
 				    break;
-                }
-			} while (trim($line[0]) != ')' && strncmp($line, $key, strlen($key)));  // patch from "Maksim Rubis" <siburny@hotmail.com>
+				}
+			// patch from "Maksim Rubis" <siburny@hotmail.com>
+			} while (trim($line[0]) != ')' && strncmp($line, $key, strlen($key)));
 			
-            if (strncmp($line, $key, strlen($key))) { 
-    			//process header, fill iilBasicHeader obj.
-    			//	initialize
-    			if (is_array($headers)) {
-    				reset($headers);
-    				while ( list($k, $bar) = each($headers) ) $headers[$k] = '';
-    			}
-    
-    			//	create array with header field:data
-    			while ( list($lines_key, $str) = each($lines) ) {
-    				list($field, $string) = iil_SplitHeaderLine($str);
-                    
-    				$field = strtolower($field);
-    				
-    				switch ($field) {
+			if (strncmp($line, $key, strlen($key))) { 
+				//process header, fill iilBasicHeader obj.
+				//	initialize
+				if (is_array($headers)) {
+					reset($headers);
+					while (list($k, $bar) = each($headers)) {
+						$headers[$k] = '';
+					}
+				}
+	
+				//	create array with header field:data
+				while ( list($lines_key, $str) = each($lines) ) {
+					list($field, $string) = iil_SplitHeaderLine($str);
+					
+					$field  = strtolower($field);
+                                        $string = ereg_replace("\n[[:space:]]*"," ",$string); 
+					
+					switch ($field) {
 					case 'date';
-						$result[$id]->date      = $string;
+						$result[$id]->date = $string;
 						$result[$id]->timestamp = iil_StrToTime($string);
 						break;
 					case 'from':
 						$result[$id]->from = $string;
 						break;
 					case 'to':
-						$result[$id]->to = str_replace("\n", " ", $string);
+						$result[$id]->to = $string;
 						break;
 					case 'subject':
-						$result[$id]->subject = str_replace("\n", '', $string);
+						$result[$id]->subject = $string;
 						break;
 					case 'reply-to':
-						$result[$id]->replyto = str_replace("\n", " ", $string);
+						$result[$id]->replyto = $string;
 						break;
 					case 'cc':
-						$result[$id]->cc = str_replace("\n", " ", $string);
+						$result[$id]->cc = $string;
 						break;
 					case 'bcc':
-						$result[$id]->bcc = str_replace("\n", " ", $string);
+						$result[$id]->bcc = $string;
 						break;
 					case 'content-transfer-encoding':
-						$result[$id]->encoding = str_replace("\n", " ", $string);
+						$result[$id]->encoding = $string;
 						break;
 					case 'content-type':
-					 	$ctype_parts = explode(";", $string);
+						$ctype_parts = explode(";", $string);
 						$result[$id]->ctype = array_shift($ctype_parts);
-						foreach ($ctype_parts as $ctype_add)
-                            if (preg_match('/charset="?([a-z0-9\-\.\_]+)"?/i',
-                                $ctype_add, $regs)) {
-                                $result[$id]->charset = $regs[1];
+						foreach ($ctype_parts as $ctype_add) {
+							if (preg_match('/charset="?([a-z0-9\-\.\_]+)"?/i',
+								$ctype_add, $regs)) {
+								$result[$id]->charset = $regs[1];
 							}
-                            break;
+						}
+						break;
 					case 'in-reply-to':
 						$result[$id]->in_reply_to = ereg_replace("[\n<>]", '', $string);
 						break;
 					case 'references':
 						$result[$id]->references = $string;
 						break;
-						case 'return-receipt-to':
-						case 'disposition-notification-to':
-						case 'x-confirm-reading-to':
-							$result[$id]->mdn_to = str_replace("\n", " ", $string);
-							break;
+					case 'return-receipt-to':
+					case 'disposition-notification-to':
+					case 'x-confirm-reading-to':
+						$result[$id]->mdn_to = $string;
+						break;
 					case 'message-id':
 						$result[$id]->messageID = $string;
 						break;
-    				} // end switch ()
-    			} // end while ()
-		    } else {
-			    $a=explode(' ', $line);
-		    }
+					case 'x-priority':
+						if (preg_match('/^(\d+)/', $string, $matches))
+							$result[$id]->priority = intval($matches[1]);
+						break;
+					} // end switch ()
+				} // end while ()
+			} else {
+				$a = explode(' ', $line);
+			}
 		}
-	} while (strcmp($a[0], $key)!=0);
-		
+	} while (strcmp($a[0], $key) != 0);
+
 	/* 
 		FETCH uid, size, flags
 		Sample reply line: "* 3 FETCH (UID 2417 RFC822.SIZE 2730 FLAGS (\Seen \Deleted))"
 	*/
 	$command_key = 'fh' . ($c++);
-    
-	$request  = $command_key . $prefix;
-    $request .= " FETCH $message_set (UID RFC822.SIZE FLAGS INTERNALDATE)\r\n";
+	$request     = $command_key . $prefix;
+	$request    .= " FETCH $message_set (UID RFC822.SIZE FLAGS INTERNALDATE)\r\n";
+	
 	if (!fputs($fp, $request)) {
 	    return false;
 	}
     do {
-		$line=chop(iil_ReadLine($fp, 200));
+		$line = chop(iil_ReadLine($fp, 200));
 		//$a = explode(' ', $line);
 		//if (($line[0]=="*") && ($a[2]=="FETCH")) {
-		if ($line[0]=="*") {
+		if ($line[0] == '*') {
 			//echo "<!-- $line //-->\n";
 			//get outter most parens
 			$open_pos = strpos($line, "(") + 1;
@@ -1644,8 +1711,12 @@
 
 					// process flags
 					$flags_str = eregi_replace('[\\\"]', '', $flags_str);
-					$flags_a = explode(' ', $flags_str);
-					//echo "<!-- ID: $id FLAGS: ".implode(",", $flags_a)." //-->\n";
+					$flags_a   = explode(' ', $flags_str);
+
+                    /*
+                    trigger_error("<!-- ID: $id FLAGS: ".implode(",", $flags_a)." //-->\n",
+                        E_USER_WARNING);
+                    */
 					
 					if (is_array($flags_a)) {
 						reset($flags_a);
@@ -1676,18 +1747,19 @@
 					if ($time_zone_str[3] != '0') {
 					    $time_zone += 0.5;  //handle half hour offset
 					}
-                    if ($time_zone_str[0] == '-') {
-                        $time_zone = $time_zone * -1.0; //minus?
+					if ($time_zone_str[0] == '-') {
+						$time_zone = $time_zone * -1.0; //minus?
 					}
-                    $result[$id]->internaldate = $time_str;
+					$result[$id]->internaldate = $time_str;
 					
-					if ($IMAP_USE_INTERNAL_DATE) {
+					if ($IMAP_USE_INTERNAL_DATE || empty($result[$id]->date)) {
 						//calculate timestamp
 						$timestamp     = strtotime($time_str); //return's server's time
 						$na_timestamp  = $timestamp;
 						$timestamp    -= $time_zone * 3600; //compensate for tz, get GMT
 						
 						$result[$id]->timestamp = $timestamp;
+						$result[$id]->date = $time_str;
 					}
 						
 					if ($conn->do_cache) {
@@ -1706,13 +1778,12 @@
 	return $result;
 }
 
-
 function iil_C_FetchHeader(&$conn, $mailbox, $id, $uidfetch=false) {
 	$fp = $conn->fp;
 	$a  = iil_C_FetchHeaders($conn, $mailbox, $id, $uidfetch);
 	if (is_array($a)) {
-	    return array_shift($a);
-    }
+		return array_shift($a);
+	}
 	return false;
 }
 
@@ -1733,7 +1804,7 @@
 	$stripArr = ($field=='subject') ? array('Re: ','Fwd: ','Fw: ','"') : array('"');
 
 	$c=count($a);
-	if ($c>0) {
+	if ($c > 0) {
 		/*
 			Strategy:
 			First, we'll create an "index" array.
@@ -1761,7 +1832,7 @@
 		}
 		
 		// sort index
-		$i=0;
+		$i = 0;
 		if ($flag == 'ASC') {
 		    asort($index);
         } else {
@@ -1783,11 +1854,13 @@
 function iil_C_Expunge(&$conn, $mailbox) {
 	$fp = $conn->fp;
 	if (iil_C_Select($conn, $mailbox)) {
-		$c=0;
+		$c = 0;
 		fputs($fp, "exp1 EXPUNGE\r\n");
 		do {
 			$line=chop(iil_ReadLine($fp, 100));
-			if ($line[0]=="*") $c++;
+			if ($line[0] == '*') {
+                $c++;
+            }
 		} while (!iil_StartsWith($line, 'exp1'));
 		
 		if (iil_ParseResult($line) == 0) {
@@ -1820,7 +1893,7 @@
 	$flag = $flags[$flag];
     
 	if (iil_C_Select($conn, $mailbox)) {
-		$c=0;
+		$c = 0;
 		fputs($fp, "flg STORE $messages " . $mod . "FLAGS (" . $flag . ")\r\n");
 		do {
 			$line=chop(iil_ReadLine($fp, 100));
@@ -1883,12 +1956,6 @@
 function iil_FormatSearchDate($month, $day, $year) {
 	$month  = (int) $month;
     $months = $GLOBALS['IMAP_MONTHS'];
-	/* $months=array(
-			1=>"Jan", 2=>"Feb", 3=>"Mar", 4=>"Apr", 
-			5=>"May", 6=>"Jun", 7=>"Jul", 8=>"Aug", 
-			9=>"Sep", 10=>"Oct", 11=>"Nov", 12=>"Dec"
-			);
-    */
 	return $day . '-' . $months[$month] . '-' . $year;
 }
 
@@ -1941,7 +2008,7 @@
 function iil_C_Search(&$conn, $folder, $criteria) {
 	$fp = $conn->fp;
 	if (iil_C_Select($conn, $folder)) {
-		$c=0;
+		$c = 0;
 		
 		$query = 'srch1 SEARCH ' . chop($criteria) . "\r\n";
 		fputs($fp, $query);
@@ -1951,10 +2018,10 @@
 				$str = trim(substr($line, 8));
 				$messages = explode(' ', $str);
 			}
-		} while (!iil_StartsWith($line, "srch1"));
+		} while (!iil_StartsWith($line, 'srch1'));
 		
-		$result_code=iil_ParseResult($line);
-		if ($result_code==0) {
+		$result_code = iil_ParseResult($line);
+		if ($result_code == 0) {
 		    return $messages;
 		}
 		$conn->error = 'iil_C_Search: ' . $line . "\n";
@@ -1972,13 +2039,23 @@
 	    return -1;
 	}
     
-	$r=iil_C_Copy($conn, $messages, $from,$to);
+	$r = iil_C_Copy($conn, $messages, $from,$to);
 	if ($r==0) {
 		return iil_C_Delete($conn, $from, $messages);
 	}
     return $r;
 }
 
+/**
+ * Gets the delimiter, for example:
+ * INBOX.foo -> .
+ * INBOX/foo -> /
+ * INBOX\foo -> \
+ * 
+ * @return mixed A delimiter (string), or false. 
+ * @param object $conn The current connection.
+ * @see iil_Connect()
+ */
 function iil_C_GetHierarchyDelimiter(&$conn) {
 	if ($conn->delimiter) {
         return $conn->delimiter;
@@ -1988,16 +2065,16 @@
 	$delimiter = false;
 	
 	//try (LIST "" ""), should return delimiter (RFC2060 Sec 6.3.8)
-	if (!fputs($fp, "ghd LIST \"\" \"\"\r\n")) {
+	if (!fputs($fp, 'ghd LIST "" ""' . "\r\n")) {
 	    return false;
     }
     
 	do {
 		$line=iil_ReadLine($fp, 500);
-		if ($line[0]=="*") {
+		if ($line[0] == '*') {
 			$line = rtrim($line);
 			$a=iil_ExplodeQuotedString(' ', $line);
-			if ($a[0]=="*") {
+			if ($a[0] == '*') {
 			    $delimiter = str_replace('"', '', $a[count($a)-2]);
             }
 		}
@@ -2012,11 +2089,11 @@
 	fputs($conn->fp, "ns1 NAMESPACE\r\n");
 	do {
 		$line = iil_ReadLine($conn->fp, 1024);
-		if (iil_StartsWith($line, "* NAMESPACE")) {
+		if (iil_StartsWith($line, '* NAMESPACE')) {
 			$i = 0;
 			$data = iil_ParseNamespace2(substr($line,11), $i, 0, 0);
 		}
-	} while (!iil_StartsWith($line, "ns1"));
+	} while (!iil_StartsWith($line, 'ns1'));
 		
 	if (!is_array($data)) {
 	    return false;
@@ -2083,7 +2160,7 @@
             // is it a container?
             $i++;
 		}
-	} while (!iil_StartsWith($line, "lmb"));
+	} while (!iil_StartsWith($line, 'lmb'));
 
 	if (is_array($folders)) {
         if (!empty($ref)) {
@@ -2151,7 +2228,7 @@
             // is it a container?
             $i++;
 		}
-	} while (!iil_StartsWith($line, "lsb"));
+	} while (!iil_StartsWith($line, 'lsb'));
 
 	if (is_array($folders)) {
         if (!empty($ref)) {
@@ -2176,6 +2253,7 @@
 
 	$query = 'sub1 SUBSCRIBE "' . $folder. '"' . "\r\n";
 	fputs($fp, $query);
+
 	$line = trim(chop(iil_ReadLine($fp, 10000)));
 	return iil_ParseResult($line);
 }
@@ -2206,17 +2284,17 @@
 		$request = $key . " FETCH $id (BODY.PEEK[$part])\r\n";
 		if (!fputs($fp, $request)) return false;
 		do {
-			$line=chop(iil_ReadLine($fp, 200));
-			$a=explode(' ', $line);
+			$line = chop(iil_ReadLine($fp, 200));
+			$a    = explode(' ', $line);
 			if (($line[0] == '*') && ($a[2] == 'FETCH')
                 && ($line[strlen($line)-1] != ')')) {
 				$line=iil_ReadLine($fp, 300);
-				while (chop($line)!=")") {
-					$result.=$line;
+				while (chop($line) != ')') {
+					$result .= $line;
 					$line=iil_ReadLine($fp, 300);
 				}
 			}
-		} while (strcmp($a[0], $key)!=0);
+		} while (strcmp($a[0], $key) != 0);
 	}
 	
 	return $result;
@@ -2231,12 +2309,12 @@
     */
 	$fp     = $conn->fp;
 	$result = false;
-	if (($part==0) || (empty($part))) {
+	if (($part == 0) || empty($part)) {
 	    $part = 'TEXT';
 	}
     
 	if (iil_C_Select($conn, $mailbox)) {
-        $reply_key='* ' . $id;
+        $reply_key = '* ' . $id;
         
         // format request
 		$key     = 'ftch' . ($c++) . ' ';
@@ -2250,21 +2328,26 @@
         do {
             $line = chop(iil_ReadLine($fp, 1000));
             $a    = explode(' ', $line);
-        } while ($a[2]!="FETCH");
+        } while ($a[2] != 'FETCH');
         $len = strlen($line);
         if ($line[$len-1] == ')') {
             //one line response, get everything between first and last quotes
-            $from = strpos($line, '"') + 1;
-            $to   = strrpos($line, '"');
-            $len  = $to - $from;
-            if ($mode == 1) {
-                $result = substr($line, $from, $len);
-            } else if ($mode == 2) {
-                echo substr($line, $from, $len);
+	    if (substr($line, -4, 3) == 'NIL') {
+		// NIL response
+		$result = '';
+	    } else {
+	        $from = strpos($line, '"') + 1;
+        	$to   = strrpos($line, '"');
+        	$len  = $to - $from;
+		$result = substr($line, $from, $len);
+	    }
+	    
+            if ($mode == 2) {
+                echo $result;
             } else if ($mode == 3) {
-                echo base64_decode(substr($line, $from, $len));
+                echo base64_decode($result);
             }
-        }else if ($line[$len-1] == '}') {
+        } else if ($line[$len-1] == '}') {
             //multi-line request, find sizes of content and receive that many bytes
             $from     = strpos($line, '{') + 1;
             $to       = strrpos($line, '}');
@@ -2281,11 +2364,11 @@
                     $line = substr($line, 0, $remaining);
                 }
                 $received += strlen($line);
-                if ($mode==1) {
-                    $result .= chop($line)."\n";
-                } else if ($mode==2) {
-                    echo chop($line)."\n"; flush();
-                } else if ($mode==3) {
+                if ($mode == 1) {
+                    $result .= rtrim($line, "\t\r\n\0\x0B") . "\n";
+                } else if ($mode == 2) {
+                    echo rtrim($line, "\t\r\n\0\x0B") . "\n"; flush();
+                } else if ($mode == 3) {
                     echo base64_decode($line); flush();
                 }
             }
@@ -2296,12 +2379,12 @@
 		} while (!iil_StartsWith($line, $key));
         
         if ($result) {
-			$result = chop($result);
+	    $result = rtrim($result, "\t\r\n\0\x0B");
             return $result; // substr($result, 0, strlen($result)-1);
         }
         return false;
 	} else {
-		echo "Select failed.";
+		echo 'Select failed.';
 	}
     
     if ($mode==1) {
@@ -2324,10 +2407,10 @@
 
 function iil_C_CreateFolder(&$conn, $folder) {
 	$fp = $conn->fp;
-	if (fputs($fp, "c CREATE \"".$folder."\"\r\n")) {
+	if (fputs($fp, 'c CREATE "' . $folder . '"' . "\r\n")) {
 		do {
 			$line=iil_ReadLine($fp, 300);
-		} while ($line[0]!="c");
+		} while ($line[0] != 'c');
         $conn->error = $line;
 		return (iil_ParseResult($line) == 0);
 	}
@@ -2336,21 +2419,21 @@
 
 function iil_C_RenameFolder(&$conn, $from, $to) {
 	$fp = $conn->fp;
-	if (fputs($fp, "r RENAME \"".$from."\" \"".$to."\"\r\n")) {
+	if (fputs($fp, 'r RENAME "' . $from . '" "' . $to . '"' . "\r\n")) {
 		do {
-			$line=iil_ReadLine($fp, 300);
-		} while ($line[0]!="r");
+			$line = iil_ReadLine($fp, 300);
+		} while ($line[0] != 'r');
 		return (iil_ParseResult($line) == 0);
 	}
-    return false;	
+    return false;
 }
 
 function iil_C_DeleteFolder(&$conn, $folder) {
 	$fp = $conn->fp;
-	if (fputs($fp, "d DELETE \"".$folder."\"\r\n")) {
+	if (fputs($fp, 'd DELETE "' . $folder. '"' . "\r\n")) {
 		do {
 			$line=iil_ReadLine($fp, 300);
-		} while ($line[0]!="d");
+		} while ($line[0] != 'd');
 		return (iil_ParseResult($line) == 0);
 	}
     $conn->error = "Couldn't send command\n";
@@ -2358,28 +2441,30 @@
 }
 
 function iil_C_Append(&$conn, $folder, &$message) {
-	if (!$folder) return false;
+	if (!$folder) {
+        return false;
+    }
 	$fp = $conn->fp;
 
 	$message = str_replace("\r", '', $message);
 	$message = str_replace("\n", "\r\n", $message);		
 
 	$len = strlen($message);
-	if (!$len) return false;
-	
+	if (!$len) {
+        return false;
+	}
 	$request = 'A APPEND "' . $folder .'" (\\Seen) {' . $len . "}\r\n";
     
 	if (fputs($fp, $request)) {
 		$line=iil_ReadLine($fp, 100);		
 		$sent = fwrite($fp, $message."\r\n");
-		flush();
 		do {
 			$line=iil_ReadLine($fp, 1000);
 		} while ($line[0] != 'A');
 	
 		$result = (iil_ParseResult($line) == 0);
 		if (!$result) {
-		    $conn->error .= $line."\n";
+		    $conn->error .= $line . "\n";
         }
 		return $result;
 	
@@ -2397,7 +2482,7 @@
 	//open message file
 	$in_fp = false;				
 	if (file_exists(realpath($path))) {
-	    $in_fp = fopen($path, "r");
+	    $in_fp = fopen($path, 'r');
     }
 	if (!$in_fp) { 
 		$conn->error .= "Couldn't open $path for reading\n";
@@ -2414,11 +2499,11 @@
 	$request    = 'A APPEND "' . $folder . '" (\\Seen) {' . $len . "}\r\n";
 	$bytes_sent = 0;
 	if (fputs($fp, $request)) {
-		$line=iil_ReadLine($fp, 100);
+		$line = iil_ReadLine($fp, 100);
 				
 		//send file
 		while (!feof($in_fp)) {
-			$buffer = fgets($in_fp, 4096);
+			$buffer      = fgets($in_fp, 4096);
 			$bytes_sent += strlen($buffer);
 			fputs($fp, $buffer);
 		}
@@ -2428,12 +2513,12 @@
 
 		//read response
 		do {
-			$line=iil_ReadLine($fp, 1000);
+			$line = iil_ReadLine($fp, 1000);
 		} while ($line[0] != 'A');
 			
 		$result = (iil_ParseResult($line) == 0);
 		if (!$result) {
-		    $conn->error .= $line."\n";
+		    $conn->error .= $line . "\n";
 		}
         return $result;
 	
@@ -2472,7 +2557,7 @@
 					//truncate last ')' and return
 					$result = substr($post, 0, strlen($post)-1);
 				}
-			} while (!preg_match("/^$key/",$line));
+			} while (!preg_match("/^$key/", $line));
 		}
 	}
 	return $result;
@@ -2497,21 +2582,21 @@
 	$quota_line = '';
 	
 	//get line containing quota info
-	if (fputs($fp, "QUOT1 GETQUOTAROOT \"INBOX\"\r\n")) {
+	if (fputs($fp, 'QUOT1 GETQUOTAROOT "INBOX"' . "\r\n")) {
 		do {
 			$line=chop(iil_ReadLine($fp, 5000));
-			if (iil_StartsWith($line, "* QUOTA ")) {
+			if (iil_StartsWith($line, '* QUOTA ')) {
 			    $quota_line = $line;
             }
-		} while (!iil_StartsWith($line, "QUOT1"));
+		} while (!iil_StartsWith($line, 'QUOT1'));
 	}
 	
 	//return false if not found, parse if found
 	if (!empty($quota_line)) {
-		$quota_line = eregi_replace("[()]", '', $quota_line);
-		$parts = explode(' ', $quota_line);
-		$storage_part = array_search("STORAGE", $parts);
-		if ($storage_part>0) {
+		$quota_line   = eregi_replace('[()]', '', $quota_line);
+		$parts        = explode(' ', $quota_line);
+		$storage_part = array_search('STORAGE', $parts);
+		if ($storage_part > 0) {
 			$result = array();
 			$used   = $parts[$storage_part+1];
 			$total  = $parts[$storage_part+2];
@@ -2522,7 +2607,6 @@
 			$result['free']    = 100 - $result['percent'];
 		}
 	}
-	
 	return $result;
 }
 
@@ -2534,5 +2618,4 @@
     }
 	return (iil_C_Expunge($conn, $folder) >= 0);
 }
-
 ?>

--
Gitblit v1.9.1