Small change to wc

Julian Elischer julian at elischer.org
Fri Dec 5 15:20:02 PST 2008


Garrett Cooper wrote:
> On Fri, Dec 5, 2008 at 2:14 PM, Sheldon Givens <sheldon at sigsegv.ca> wrote:
>> Hello everyone,
>> In the process of migrating the last of a few Linux servers to FreeBSD, we
>> ran in to a bit of a snag with one of our scripts when BSD wc didn't have an
>> equivalent to the Linux -L. This flag tells wc to keep track of the longest
>> line in the input.
>>
>> Here's a little diff to add this functionality to BSD wc.
>>
>> With this patch, an additional parameter is added to output that shows the
>> length of the longest line
>>
>> My apologies if this is in the wrong format. I don't often post here.
>>
>> Happy Holidays,
>>
>> Sheldon Givens
>>
>>
>> ---snip---
>> 65,66c65,66
>> < uintmax_t tlinect, twordct, tcharct;
>> < int doline, doword, dochar, domulti;
>> ---
>>> uintmax_t tlinect, twordct, tcharct, tlongline;
>>> int doline, doword, dochar, domulti, dolongline;
>> 78c78
>> <       while ((ch = getopt(argc, argv, "clmw")) != -1)
>> ---
>>>       while ((ch = getopt(argc, argv, "clmwL")) != -1)
>> 93a94,96
>>>               case 'L':
>>>                       dolongline = 1;
>>>                       break;
>> 127a131,132
>>>               if (dolongline)
>>>                       (void)printf(" %7ju", tlongline);
>> 137c142
>> <       uintmax_t linect, wordct, charct;
>> ---
>>>       uintmax_t linect, wordct, charct, llcnt, tmpll;
>> 146c151
>> <       linect = wordct = charct = 0;
>> ---
>>>       linect = wordct = charct = llcnt = tmpll = 0;
>> 171c176,179
>> <                                       if (*p == '\n')
>> ---
>>>                                       if (*p == '\n') {
>>>                                               if (tmpll > llcnt)
>>>                                                       llcnt = tmpll;
>>>                                               tmpll = 0;
>> 172a181
>>>                                       } else { tmpll++; }
>> 179a189,192
>>>                       if (dolongline) {
>>>                               tlongline = llcnt;
>>>                               (void)printf(" %7ju", tlongline);
>>>                       }
>> 197c210
>> <                               return (0);
>> ---
>>>                       return (0);
>> 231a245
>>>                       tmpll++;
>> 234c248,251
>> <                       if (wch == L'\n')
>> ---
>>>                       if (wch == L'\n') {
>>>                               if (tmpll > llcnt)
>>>                                       llcnt = tmpll;
>>>                               tmpll = 0;
>> 235a253
>>>                       }
>> 258a277,280
>>>       if (dolongline) {
>>>               tlongline = llcnt;
>>>               (void)printf(" %7ju", llcnt - 1);
>>>       }
>> 266c288
>> <       (void)fprintf(stderr, "usage: wc [-clmw] [file ...]\n");
>> ---
>>>       (void)fprintf(stderr, "usage: wc [-clmwL] [file ...]\n");
>> ---unsnip---
> 
> What's the plus side of having this? I can accomplish the same with
> something like awk without the additional overhead, which would be
> guaranteed to be portable.

true, but this is a well known extension that people use and to tell 
the truth, I have no idea how I would do it in awk without reading a 
lot where in wc it's obvious from the synopsis.

> -Garrett
> _______________________________________________
> freebsd-hackers at freebsd.org mailing list
> http://lists.freebsd.org/mailman/listinfo/freebsd-hackers
> To unsubscribe, send any mail to "freebsd-hackers-unsubscribe at freebsd.org"



More information about the freebsd-hackers mailing list