On Wed, Oct 22, 2008 at 1:28 PM, John Mertic <[EMAIL PROTECTED]> wrote:
> On Wed, Oct 22, 2008 at 1:16 PM, Ilia Alshanetsky <[EMAIL PROTECTED]> wrote:
>> You cannot use smart_str_appendc() in this case, since the EOL could be a 2
>> byte string "\r\n".
>>
>> smart_str_appendl(&csvline, PHP_EOL, sizeof(PHP_EOL)-1); should be used
>> here.
>>
>> On 22-Oct-08, at 2:35 PM, John Mertic wrote:
>>
>>> Hi Lars,
>>>
>>> Thanks for the pointers, updated the patch and added a test.
>>>
>>> Index: file.c
>>> ===================================================================
>>> RCS file: /repository/php-src/ext/standard/file.c,v
>>> retrieving revision 1.530
>>> diff -u -r1.530 file.c
>>> --- file.c      21 Oct 2008 22:06:48 -0000      1.530
>>> +++ file.c      22 Oct 2008 18:21:10 -0000
>>> @@ -2104,7 +2104,7 @@
>>>                }
>>>        }
>>>
>>> -       smart_str_appendc(&csvline, '\n');
>>> +       smart_str_appendc(&csvline, PHP_EOL);
>>>        smart_str_0(&csvline);
>>>
>>>        ret = php_stream_write(stream, csvline.c, csvline.len);
>>>
>>>
>>> John Mertic
>>> [EMAIL PROTECTED]
>>> http://jmertic.wordpress.com
>>>
>>> "Explaining a joke is like dissecting a frog: you understand it
>>> better, but the frog dies
>>> in the process." --Mark Twain
>>>
>>>
>>>
>>> On Wed, Oct 22, 2008 at 10:36 AM, Lars Strojny <[EMAIL PROTECTED]> wrote:
>>>>
>>>> Hi John,
>>>>
>>>>
>>>> Am Mittwoch, den 22.10.2008, 10:03 -0700 schrieb John Mertic:
>>>> [...]
>>>>>
>>>>> Below is a patch to fix this issue; it uses the constant PHP_EOL to
>>>>> get the correct newline to use on the current platform:
>>>>
>>>> Thanks for your patch. A few things to mention, as it is your first
>>>> patch: please use "diff -ru" to create unified diffs. Also we try to
>>>> always add tests for the things we fix or create. Would you mind
>>>> creating a test for the fix you sent to make sure no regression happens
>>>> in the next n years?
>>>>
>>>> Thanks, Lars
>>>> --
>>>>  Jabber: [EMAIL PROTECTED]
>>>>  Weblog: http://usrportage.de
>>>>
>>>
>>> --
>>> PHP Internals - PHP Runtime Development Mailing List
>>> To unsubscribe, visit: http://www.php.net/unsub.php
>>
>> Ilia Alshanetsky
>>
>>
>>
>>
>>
>
> Hi Ilia,
>
> I can see your point about scanner's having trouble with different EOL
> characters, but I know in our use case the problem is that the CSV
> files created will come out the lines all mashed together, which is a
> problem for readability of the file. And since most CSV scanners know
> how to deal with Windows, I would think we are pretty safe ;-)
>
> Attached is an updated patch that uses this function instead.
>
> --
> John Mertic
> [EMAIL PROTECTED] | http://jmertic.wordpress.com
>

Hi All,

I haven't seen any further comments on this bug; does it seem safe to
commit or should it wait? I've re-attached the patch and test again
for everyone's reference.

Thanks!

John Mertic
[EMAIL PROTECTED] | http://jmertic.wordpress.com

Attachment: file.c.patch
Description: application/force-download

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

Reply via email to