Newsgroups: php.internals Path: news.php.net Xref: news.php.net php.internals:51691 Return-Path: Mailing-List: contact internals-help@lists.php.net; run by ezmlm Delivered-To: mailing list internals@lists.php.net Received: (qmail 93687 invoked from network); 15 Mar 2011 10:02:59 -0000 Received: from unknown (HELO lists.php.net) (127.0.0.1) by localhost with SMTP; 15 Mar 2011 10:02:59 -0000 Authentication-Results: pb1.pair.com smtp.mail=proofek@gmail.com; spf=pass; sender-id=pass Authentication-Results: pb1.pair.com header.from=proofek@gmail.com; sender-id=pass; domainkeys=bad Received-SPF: pass (pb1.pair.com: domain gmail.com designates 209.85.216.42 as permitted sender) DomainKey-Status: bad X-DomainKeys: Ecelerity dk_validate implementing draft-delany-domainkeys-base-01 X-PHP-List-Original-Sender: proofek@gmail.com X-Host-Fingerprint: 209.85.216.42 mail-qw0-f42.google.com Received: from [209.85.216.42] ([209.85.216.42:37837] helo=mail-qw0-f42.google.com) by pb1.pair.com (ecelerity 2.1.1.9-wez r(12769M)) with ESMTP id BD/8C-10215-0593F7D4 for ; Tue, 15 Mar 2011 05:02:56 -0500 Received: by qwi4 with SMTP id 4so274987qwi.29 for ; Tue, 15 Mar 2011 03:02:09 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=gamma; h=domainkey-signature:mime-version:in-reply-to:references:date :message-id:subject:from:to:cc:content-type; bh=DihRnGt6u2oPuIxwvKIywQB5WqcM4flxOXh6R81dRuQ=; b=wONHUR+UbEfOhzuKMZiJxoONjd9u1bnAfurhiKbpNqD53CQHSk4bkuz2lkptK3Je9u agsNqj+oXCKHVq9rEnzB7LB8QttjeXB14LM90ulXn8R7oeLZmKTVYiekqr2wVO12mzu3 rRrOHLjqGAA13MppCkgDAPmxNIMvya6ZyHESs= DomainKey-Signature: a=rsa-sha1; c=nofws; d=gmail.com; s=gamma; h=mime-version:in-reply-to:references:date:message-id:subject:from:to :cc:content-type; b=sTDS+tQuoabi0q6ueMMQJvKMB+dq65MFHic7iW/R93QJ7Axq4XJDZiba6qHWn7ZdaL I6wU6CXfb1NH5BdXi7wPUDLZW4+RdFKjRx+BV+QEw5JkroR60fdYYCk95QYQVX7GiY1Z lzA20Q2toESZ368J45EE/GdXjiyA9kFgau4yM= MIME-Version: 1.0 Received: by 10.229.46.129 with SMTP id j1mr9220021qcf.95.1300183328774; Tue, 15 Mar 2011 03:02:08 -0700 (PDT) Received: by 10.229.239.203 with HTTP; Tue, 15 Mar 2011 03:02:08 -0700 (PDT) In-Reply-To: <54.6B.10215.BC23F7D4@pb1.pair.com> References: <20110313213928.GD4446@crousti> <54.6B.10215.BC23F7D4@pb1.pair.com> Date: Tue, 15 Mar 2011 10:02:08 +0000 Message-ID: To: Nick Pope Cc: internals@lists.php.net Content-Type: multipart/alternative; boundary=0016364eebb2745c8d049e828532 Subject: Re: [PHP-DEV] SplFileObject Countable From: proofek@gmail.com (Sebastian Marek) --0016364eebb2745c8d049e828532 Content-Type: text/plain; charset=UTF-8 Hello Nick, Might be fun, I'll have a look at it. Is the stuff I have done so far any good? I've got only a little C experience, so any feedback is good! cheers On Tue, Mar 15, 2011 at 9:35 AM, Nick Pope wrote: > Hi Sebastian, > > Since Etienne brought it up, would it not also make sense for you to > implement countWords() and countBytes()? > > Also, unicode issues aside, it might still be nice to implement > countChars(). > > And finally, so that it provides all most of the functionality of the GNU > wc program, there could also be getMaxLineLength(). This would need a > different name however as this method would be to count the longest line of > the file rather than indicate the maximum length of a line to read as the > current SplFileObject::getMaxLineLen() method does. > > Just my thoughts, > > Nick > > > > On 14/03/11 22:24, Sebastian Marek wrote: > >> Hello, >> >> That makes perfect sense. I have raised a feature request and have >> attached >> a patch containing both countLines() method implementation and phpt tests. >> >> thx >> >> On Sun, Mar 13, 2011 at 9:39 PM, Etienne Kneuss wrote: >> >> On Mar 11 23:22:04, Sebastian Marek wrote: >>> >>>> Hi, >>>> >>>> I have recently used SplFileObject to work with files. I was lacking a >>>> >>> bit >>> >>>> of functionality in there regarding counting number of lines in a given >>>> file. Although I could just load contents of the file to an array and >>>> >>> check >>> >>>> it size, I thought it would be nice to have SplFileObject Countable. >>>> >>>> Here is an example implementation I made tonight that seems to work well >>>> >>> - >>> >>>> https://gist.github.com/866767 . Is it something you think would be >>>> >>> worth >>> >>>> adding to the existing SplFileObject? Is the implementation any good? I >>>> reused some of the existing logic to avoid breaking >>>> >>> 'spl_filesystem_object' >>> >>>> internal integrity, but maybe it would make sense to make it work with >>>> >>> the >>> >>>> stream itself. >>>> >>> >>> In my oppinion, it does not make sense to implement countable for this >>> use. Countable should be implemented on classes where calling count() on >>> them is not ambiguous, i.e. the size of a collection. >>> >>> There is no reason why count() on a file should be the number of lines, >>> why not words, or bytes? >>> >>> I'd however be happy with a new countLines() method. >>> >>> Best, >>> >>> >>>> If it's fine I can write some unit tests to cover this and then submit a >>>> complete patch. >>>> >>>> Regards >>>> -- >>>> Sebastian Marek >>>> proofek@gmail.com >>>> >>>> Follow me online at: >>>> Blog: http://criticallog.thornet.net/ >>>> Twitter: http://twitter.com/proofek >>>> Linkedin: http://uk.linkedin.com/in/sebastianmarek >>>> Ohloh: http://www.ohloh.net/accounts/proofek >>>> >>>> >>> >>> >> >> >> > > -- > PHP Internals - PHP Runtime Development Mailing List > To unsubscribe, visit: http://www.php.net/unsub.php > > -- Sebastian Marek proofek@gmail.com Follow me online at: Blog: http://criticallog.thornet.net/ Twitter: http://twitter.com/proofek Linkedin: http://uk.linkedin.com/in/sebastianmarek Ohloh: http://www.ohloh.net/accounts/proofek --0016364eebb2745c8d049e828532--