hi,

Can you send patches as attachment please?

Also I like to think again about a nicer approach. As your proposal
works, it sounds like multiple calls could be avoided.

Cheers,

On Wed, Feb 3, 2010 at 8:37 PM, Dominik Gehl <domi...@dokdok.com> wrote:
> Attached is a patch which would allow the usage of most of the IMAP4 search 
> criteria.
>
> Please let me know if I should contact someone else (IMAP extension 
> maintainer(s) ?) regarding this ...
>
> Dominik
>
>
> On 2010-02-02, at 4:14 PM, Dominik Gehl wrote:
>
>> I continued thinking about this and came up with the idea of adding a new 
>> resource 'imap_searchpgm' to the imap extension, which would then have quite 
>> a good number of new functions: imap_searchprogram_new, 
>> imap_searchprogram_sentsince, imap_searchprogram_since, 
>> imap_searchprogram_before, imap_searchprogram_on etc. etc.
>>
>> The functions could then be defined along the following lines (untested code 
>> ...):
>>
>> PHP_FUNCTION(imap_searchprogram_new)
>> {
>>       int myargc = ZEND_NUM_ARGS();
>>
>>       if (myargc != 0) {
>>               ZEND_WRONG_PARAM_COUNT();
>>       }
>>
>>       pgm = mail_newsearchpgm();
>>       searchpgm = emalloc(sizeof(php_imap_searchpgm));
>>       searchpgm->searchpgm = pgm;
>>       ZEND_REGISTER_RESOURCE(return_value, searchpgm, le_imap_searchpgm);
>> }
>>
>> PHP_FUNCTION(imap_searchprogram_sentsince)
>> {
>>       zval *zpgm;
>>       php_imap_searchpgm *pgm;
>>       char *criterion = "";
>>
>>       if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "rs", &zpgm, 
>> &criterion) == FAILURE) {
>>               RETURN_FALSE;
>>       }
>>
>>       ZEND_FETCH_RESOURCE(pgm, php_imap_search_pgm*, &zpgm, -1, 
>> "imapsearch", le_imap_searchpgm);
>>
>>       mail_criteria_date(&pgm->searchpgm->sentsince, &criterion);
>>
>>       RETURN_TRUE;
>> }
>>
>> etc. etc.
>>
>>
>> And finally, the imap_search function could then accept either the criteria 
>> string OR an imap_searchpgm resource.
>>
>> Ideas, comments ?
>>
>> Thanks,
>> Dominik
>>
>>
>> On 2010-02-01, at 10:06 AM, Dominik Gehl wrote:
>>
>>> Thanks a lot for your reply. I also found a second bug report related to 
>>> this: http://bugs.php.net/bug.php?id=21168
>>>
>>> Now, how about adding an imap_newsearchpgm function to the PHP imap 
>>> extension which would do a call to mail_nsewsearchpgm inside c-client and 
>>> return a structure allowing to contruct IMAP4 search programs (SEARCHPGM 
>>> inside c-client) ?
>>>
>>> Anyone interested in this ?
>>>
>>> Dominik
>>>
>>> On 2010-01-30, at 6:22 PM, Joey Smith wrote:
>>>
>>>> There's an open bug on this, #15238 
>>>> (http://bugs.php.net/bug.php?id=15238&;). I'm
>>>> sure patches would be welcomed.
>>>>
>>>> On Fri, Jan 29, 2010 at 03:49:18PM -0500, Dominik Gehl wrote:
>>>>> Hi,
>>>>>
>>>>> I noticed that the imap extension seems to support only IMAP2 search 
>>>>> criteria.
>>>>>
>>>>> This is caused by the fact that in ext/imap/php_imap.c, the imap_search 
>>>>> function uses a call to mail_criteria. And
>>>>> the University of Washington IMAP toolkit mentions in docs/internal.txt:
>>>>>
>>>>> SEARCHPGM *mail_criteria (char *criteria);
>>>>>     criteria IMAP2-format search criteria string
>>>>>
>>>>>  This function accepts an IMAP2-format search criteria string and
>>>>> parses it.  If the parse is successful, it returns a search program
>>>>> suitable for use in mail_search_full().
>>>>>     WARNING: This function does not accept IMAP4 search criteria.
>>>>>
>>>>>
>>>>> Is there any specific reason why PHP uses this mail_criteria call ? It 
>>>>> really would be nice to be able to use IMAP4 search criteria !
>>>>>
>>>>> Thanks,
>>>>> Dominik
>>>>>
>>>>> --
>>>>> PHP Internals - PHP Runtime Development Mailing List
>>>>> To unsubscribe, visit: http://www.php.net/unsub.php
>>>>>
>>>
>>
>
>
>
> --
> PHP Internals - PHP Runtime Development Mailing List
> To unsubscribe, visit: http://www.php.net/unsub.php
>



-- 
Pierre

@pierrejoye | http://blog.thepimp.net | http://www.libgd.org

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

Reply via email to