vercmp with "-" [SOLVED]
Bradley Giesbrecht
pixilla at macports.org
Sun Dec 18 11:50:44 PST 2011
On Dec 18, 2011, at 10:55 AM, Bradley Giesbrecht wrote:
>
> On Dec 18, 2011, at 9:47 AM, Bradley Giesbrecht wrote:
>
>> On Dec 18, 2011, at 7:41 AM, Rainer Müller wrote:
>>
>>>> The code that before worked did this:
>>>>
>>>> - if {[regexp $the_re $line matched upver]} {
>>>>
>>>> "matched" is the entire string matched, and "upver" is the first
>>>> parenthesized expression. Any additional parenthesized expressions
>>>> are ignored.
>>>
>>> Okay, that's the problem. I did not think of a regex with multiple
>>> groups. Thanks for chasing this one down.
>>
>> ...
>>> So, if
>>> we find out how many parentheses the regex will produce, we can remove
>>> this many items from the returned list in each loop iteration but only
>>> use the first one as the matched version. This would be easier than
>>> algorithmically modifying the regex.
>>>
>>> An alternative would be to use the -indices option of regexp which
>>> returns the position of the match in the string. Then the regex could be
>>> applied multiple times using -start to begin matching where the previous
>>> match ended.
>>
>> With the -indices option, would the intent of the code be more obvious?
>
> portlivecheck.tcl:172
> set lastoff 0
> while {[regexp -start $lastoff -indices $the_re $line offsets]} {
> regexp -start $lastoff $the_re $line matched upver
> set foundmatch 1
> if {$updated_version == 0 || [vercmp $upver $updated_version] > 0} {
> set updated_version $upver
> }
> ui_debug "The regex matched \"$matched\", extracted \"$upver\""
> lassign $offsets firstoff lastoff
> }
>
> Works with my original multiple version on single line string and with the three examples Joshua reported broke after r88031.
>
> Should I commit this?
I opened a ticket.
http://trac.macports.org/ticket/32589
http://trac.macports.org/attachment/ticket/32589/patch-base-src-port1.0-portlivecheck.tcl.diff
Regards,
Bradley Giesbrecht (pixilla)
More information about the macports-dev
mailing list