Here is my attempt at a unified diff against the current CVS.  Let me
know if I need to do anything differently.

-Brad

----------------------  diff for php_imap.c -----------------------

--- php_imap.c
+++ php_imap.c  Tue Feb 26 23:00:58 2002
@@ -91,6 +91,7 @@

PHP_FE(imap_bodystruct,
NULL)

PHP_FE(imap_fetchbody,
NULL)

PHP_FE(imap_fetchheader,
NULL)
+
PHP_FE(imap_fetch_header,
NULL)

PHP_FE(imap_fetchstructure,
NULL)

PHP_FE(imap_expunge,
NULL)

PHP_FE(imap_delete,
NULL)
@@ -2582,6 +2583,99 @@
        RETVAL_STRING(mail_fetchheader_full(imap_le_struct->imap_stream,
Z_LVAL_PP(msgno), NIL, NIL, (myargc == 3 ? Z_LVAL_PP(flags) : NIL)), 1);

 }
 /* }}} */
+
+
+
+/* {{{ proto string imap_fetch_header(int stream_id, int msg_no [,
string section [, array lines [, int options]]])
+   Get the (optionally filtered) header for a given section of a
message */
+PHP_FUNCTION(imap_fetch_header)
+{
+/*
+   NOTE: You need to explicitly set FT_PEEK to not mark message as READ
when calling this function.
+   Empty strings are ignored in the lines array.
+*/
+        zval **streamind, **msgno, **sec = NIL, **lines = NIL, **flags,
**tmp;
+        int i, ind, ind_type, msgindex;
+        pils *imap_le_struct;
+        int myargc = ZEND_NUM_ARGS();
+        HashPosition pos;
+        STRINGLIST *cur_lines = NIL, *cur;
+
+        if (myargc < 2 ||
+            myargc > 5 ||
+            zend_get_parameters_ex(myargc, &streamind, &msgno, &sec,
&lines, &flags) == FAILURE)
+        {
+                ZEND_WRONG_PARAM_COUNT();
+        } //if
+
+        convert_to_long_ex(streamind);
+        convert_to_long_ex(msgno);
+
+        if (myargc > 2) {
+                convert_to_string_ex(sec);
+        } //if
+
+        /* Convert the <lines> array to a STRINGLIST */
+        if (myargc > 3) {
+                convert_to_array_ex(lines);
+
+                zend_hash_internal_pointer_reset_ex((*lines)->value.ht,
&pos);
+                while
(zend_hash_get_current_data_ex((*lines)->value.ht, (void **) &tmp, &pos)
== SUCCESS) {
+                        convert_to_string_ex(tmp);
+
+                        // Only add to the filter list if not an empty
string
+                        if (*Z_STRVAL_PP(tmp)) {
+                                if (cur_lines) {
+                                        cur->next =
mail_newstringlist();
+                                        cur = cur->next;
+                                } else {
+                                        cur_lines =
mail_newstringlist();
+                                        cur = cur_lines;
+                                } //if
+
+                                cur->LSIZE = (*tmp)->value.str.len;
+                                cur->LTEXT = (char*)
cpystr((*tmp)->value.str.val);
+                        } //if
+
+                        zend_hash_move_forward_ex((*lines)->value.ht,
&pos);
+                } //while
+        } //if
+
+        if (myargc == 5) {
+                convert_to_long_ex(flags);
+        } //if
+        ind = Z_LVAL_PP(streamind);
+
+        imap_le_struct = (pils *) zend_list_find(ind, &ind_type);
+//      if (!imap_le_struct || !IS_STREAM(ind_type)) {
+        if (!imap_le_struct) {
+                php_error(E_WARNING, "Unable to find stream pointer");
+                RETURN_FALSE;
+        } //if
+
+        if ((myargc == 5) && (Z_LVAL_PP(flags) & FT_UID)) {
+        /* This should be cached; if it causes an extra RTT to the
+           IMAP server, then that's the price we pay for making sure
+           we don't crash. */
+                msgindex = mail_msgno(imap_le_struct->imap_stream,
Z_LVAL_PP(msgno));
+        } else {
+                msgindex = Z_LVAL_PP(msgno);
+        } //if
+        if ((msgindex < 1) || ((unsigned) msgindex >
imap_le_struct->imap_stream->nmsgs)) {
+                php_error(E_WARNING, "Bad message number");
+                RETURN_FALSE;
+        } //if
+
+        /* Perform the header fetch */
+        RETVAL_STRING(mail_fetch_header(imap_le_struct->imap_stream,
Z_LVAL_PP(msgno), Z_STRVAL_PP(sec),
+                                        cur_lines, NIL, myargc==5 ?
Z_LVAL_PP(flags) : NIL), 1);
+
+        /* Free the temporary string list */
+        mail_free_stringlist(&cur_lines);
+} // PHP_FUNCTION(imap_fetch_header)
+/* }}} */
+
+

 /* {{{ proto int imap_uid(int stream_id, int msg_no)
    Get the unique message id associated with a standard sequential
message number */


----------------------  diff for php_imap.h -----------------------

--- php_imap.h
+++ php_imap.h  Tue Feb 26 23:01:17 2002
@@ -149,6 +149,7 @@
 PHP_FUNCTION(imap_setflag_full);
 PHP_FUNCTION(imap_clearflag_full);
 PHP_FUNCTION(imap_sort);
+PHP_FUNCTION(imap_fetch_header);
 PHP_FUNCTION(imap_fetchheader);
 PHP_FUNCTION(imap_fetchtext);
 PHP_FUNCTION(imap_uid);
--- php_imap.c
+++ php_imap.c  Tue Feb 26 23:00:58 2002
@@ -91,6 +91,7 @@
        PHP_FE(imap_bodystruct,                                                 NULL)
        PHP_FE(imap_fetchbody,                                                  NULL)
        PHP_FE(imap_fetchheader,                                                NULL)
+       PHP_FE(imap_fetch_header,                                               NULL) 
        PHP_FE(imap_fetchstructure,                                             NULL)
        PHP_FE(imap_expunge,                                                    NULL)
        PHP_FE(imap_delete,                                                            
 NULL)
@@ -2582,6 +2583,99 @@
        RETVAL_STRING(mail_fetchheader_full(imap_le_struct->imap_stream, 
Z_LVAL_PP(msgno), NIL, NIL, (myargc == 3 ? Z_LVAL_PP(flags) : NIL)), 1);
 }
 /* }}} */
+
+
+
+/* {{{ proto string imap_fetch_header(int stream_id, int msg_no [, string section [, 
+array lines [, int options]]])
+   Get the (optionally filtered) header for a given section of a message */
+PHP_FUNCTION(imap_fetch_header)
+{
+/*
+   NOTE: You need to explicitly set FT_PEEK to not mark message as READ when calling 
+this function.
+   Empty strings are ignored in the lines array.
+*/
+        zval **streamind, **msgno, **sec = NIL, **lines = NIL, **flags, **tmp;
+        int i, ind, ind_type, msgindex;
+        pils *imap_le_struct;
+        int myargc = ZEND_NUM_ARGS();
+        HashPosition pos;
+        STRINGLIST *cur_lines = NIL, *cur;
+
+        if (myargc < 2 ||
+            myargc > 5 ||
+            zend_get_parameters_ex(myargc, &streamind, &msgno, &sec, &lines, &flags) 
+== FAILURE)
+        {
+                ZEND_WRONG_PARAM_COUNT();
+        } //if
+
+        convert_to_long_ex(streamind);
+        convert_to_long_ex(msgno);
+
+        if (myargc > 2) {
+                convert_to_string_ex(sec);
+        } //if
+
+        /* Convert the <lines> array to a STRINGLIST */
+        if (myargc > 3) {
+                convert_to_array_ex(lines);
+
+                zend_hash_internal_pointer_reset_ex((*lines)->value.ht, &pos);
+                while (zend_hash_get_current_data_ex((*lines)->value.ht, (void **) 
+&tmp, &pos) == SUCCESS) {
+                        convert_to_string_ex(tmp);
+
+                        // Only add to the filter list if not an empty string
+                        if (*Z_STRVAL_PP(tmp)) {
+                                if (cur_lines) {
+                                        cur->next = mail_newstringlist();
+                                        cur = cur->next;
+                                } else {
+                                        cur_lines = mail_newstringlist();
+                                        cur = cur_lines;
+                                } //if
+
+                                cur->LSIZE = (*tmp)->value.str.len;
+                                cur->LTEXT = (char*) cpystr((*tmp)->value.str.val);
+                        } //if
+
+                        zend_hash_move_forward_ex((*lines)->value.ht, &pos);
+                } //while
+        } //if
+
+        if (myargc == 5) {
+                convert_to_long_ex(flags);
+        } //if
+        ind = Z_LVAL_PP(streamind);
+
+        imap_le_struct = (pils *) zend_list_find(ind, &ind_type);
+//      if (!imap_le_struct || !IS_STREAM(ind_type)) {
+        if (!imap_le_struct) {
+                php_error(E_WARNING, "Unable to find stream pointer");
+                RETURN_FALSE;
+        } //if
+
+        if ((myargc == 5) && (Z_LVAL_PP(flags) & FT_UID)) {
+        /* This should be cached; if it causes an extra RTT to the
+           IMAP server, then that's the price we pay for making sure
+           we don't crash. */
+                msgindex = mail_msgno(imap_le_struct->imap_stream, Z_LVAL_PP(msgno));
+        } else {
+                msgindex = Z_LVAL_PP(msgno);
+        } //if
+        if ((msgindex < 1) || ((unsigned) msgindex > 
+imap_le_struct->imap_stream->nmsgs)) {
+                php_error(E_WARNING, "Bad message number");
+                RETURN_FALSE;
+        } //if
+
+        /* Perform the header fetch */
+        RETVAL_STRING(mail_fetch_header(imap_le_struct->imap_stream, 
+Z_LVAL_PP(msgno), Z_STRVAL_PP(sec),
+                                        cur_lines, NIL, myargc==5 ?  Z_LVAL_PP(flags) 
+: NIL), 1);
+
+        /* Free the temporary string list */
+        mail_free_stringlist(&cur_lines);
+} // PHP_FUNCTION(imap_fetch_header)
+/* }}} */
+
+
 
 /* {{{ proto int imap_uid(int stream_id, int msg_no)
    Get the unique message id associated with a standard sequential message number */
--- php_imap.h
+++ php_imap.h  Tue Feb 26 23:01:17 2002
@@ -149,6 +149,7 @@
 PHP_FUNCTION(imap_setflag_full);
 PHP_FUNCTION(imap_clearflag_full);
 PHP_FUNCTION(imap_sort);
+PHP_FUNCTION(imap_fetch_header);
 PHP_FUNCTION(imap_fetchheader);
 PHP_FUNCTION(imap_fetchtext);
 PHP_FUNCTION(imap_uid);

-- 
PHP Development Mailing List <http://www.php.net/>
To unsubscribe, visit: http://www.php.net/unsub.php

Reply via email to