- $prevline = $read_part;
- if (eregi ("^to:(.*)$", $read_part, $regs)) {
- $to = $regs[1];
- } else if (eregi ("^from:(.*)$", $read_part, $regs)) {
- $from = $regs[1];
- } else if (eregi ("^x-priority:(.*)$", $read_part, $regs)) {
- $priority = trim($regs[1]);
- } else if (eregi ("^message-id:(.*)$", $read_part, $regs)) {
- $messageid = trim($regs[1]);
- } else if (eregi ("^cc:(.*)$", $read_part, $regs)) {
- $cc = $regs[1];
- } else if (eregi ("^date:(.*)$", $read_part, $regs)) {
- $date = $regs[1];
- } else if (eregi ("^subject:(.*)$", $read_part, $regs)) {
- $subject = htmlspecialchars(trim($regs[1]));
- if ($subject == "") {
- $subject = _("(no subject)");
- }
- } else if (eregi ("^content-type:(.*)$", $read_part, $regs)) {
- $type = strtolower(trim($regs[1]));
- if ($pos = strpos($type, ";")) {
- $type = substr($type, 0, $pos);
- }
- $type = explode("/", $type);
- if (!isset($type[1])) {
- $type[1] = '';
- }
- } else if (eregi ("^in-reply-to:(.*)$", $read_part, $regs)) {
- $inrepto = trim($regs[1]);
- }
- }
- $internaldate = getPref($data_dir, $username, 'internal_date_sort');
- if (trim($date) == "" || $internaldate) {
- fputs($imap_stream, "$sid FETCH $msg_list[$msgi] INTERNALDATE\r\n");
- $readdate = sqimap_read_data($imap_stream, $sid, true, $response, $message);
- if (eregi(".*INTERNALDATE \"(.*)\".*", $readdate[0], $regs)) {
- $date_list = explode(' ', trim($regs[1]));
- $date_list[0] = str_replace("-", ' ', $date_list[0]);
- $date = implode(' ', $date_list);
- }
- }
- eregi("([0-9]+)[^0-9]*$", $sizes_list[$msgi][0], $regs);
- $size = $regs[1];
+ $prev_line = $read_part;
+
+ if ($read_part{0} == '*') {
+ if ($internaldate) {
+ if (preg_match ("/^.+INTERNALDATE\s\"(.+)\"\s.+/iUA",$read_part, $reg)) {
+ $date = $reg[1];
+ }
+ }
+ if (preg_match ("/^.+RFC822.SIZE\s+(\d+).+/iA",$read_part, $reg)) {
+ $size = $reg[1];
+ }
+ if (preg_match("/^.+FLAGS\s+\((.*)\).+/iUA", $read_part, $regs)) {
+ $flags = explode(' ',trim($regs[1]));
+ foreach ($flags as $flag) {
+ $flag = strtolower($flag);
+ if ($flag == '\\seen') {
+ $flag_seen = true;
+ } else if ($flag == '\\answered') {
+ $flag_answered = true;
+ } else if ($flag == '\\deleted') {
+ $flag_deleted = true;
+ } else if ($flag == '\\flagged') {
+ $flag_flagged = true;
+ }
+ }
+ }
+ } else {
+
+ $firstchar = $read_part{0};
+ if ($firstchar == 'T') {
+ $regpattern = $patterns[0];
+ $id = 1;
+ } else if ($firstchar == 'F') {
+ $regpattern = $patterns[1];
+ $id = 2;
+ } else if ($firstchar == 'X') {
+ $regpattern = $patterns[2];
+ $id = 3;
+ } else if ($firstchar == 'C') {
+ if (strtolower($read_part{1}) == 'c') {
+ $regpattern = $patterns[3];
+ $id = 4;
+ } else if (strtolower($read_part{1}) == 'o') {
+ $regpattern = $patterns[6];
+ $id = 7;
+ }
+ } else if ($firstchar == 'D') {
+ $regpattern = $patterns[4];
+ $id = 5;
+ } else if ($firstchar == 'S') {
+ $regpattern = $patterns[5];
+ $id = 6;
+ } else $regpattern = '';
+
+ if ($regpattern) {
+ if (preg_match ($regpattern, $read_part, $regs)) {
+ switch ($id) {
+ case 1:
+ $to = $regs[1];
+ break;
+ case 2:
+ $from = $regs[1];
+ break;
+ case 3:
+ $priority = $regs[1];
+ break;
+ case 4:
+ $cc = $regs[1];
+ break;
+ case 5:
+ if (!$internaldate) {
+ $date = $regs[1];
+ }
+ break;
+ case 6:
+ $subject = htmlspecialchars(trim($regs[1]));
+ if ($subject == "") {
+ $subject = _("(no subject)");
+ }
+ break;
+ case 7:
+ $type = strtolower(trim($regs[1]));
+ if ($pos = strpos($type, ";")) {
+ $type = substr($type, 0, $pos);
+ }
+ $type = explode("/", $type);
+ if (!isset($type[1])) {
+ $type[1] = '';
+ }
+ break;
+ default:
+ break;
+ }
+ }
+ }
+ }