[lnkForumImage]
TotalShareware - Download Free Software

Confronta i prezzi di migliaia di prodotti.
Asp Forum
 Home | Login | Register | Search 


 

Forums >

comp.lang.ruby

MatchData matchset and matchtree

Trans

4/15/2007 6:02:00 PM

I think someone asked about/suggested something like this recently. I
think these two methods would make a pretty good addition to the core
library.


class MatchData

# Returns [ pre_match, matchtree, post_match ]. (see matchtree)
#
# md = /(bb)(cc(dd))(ee)/.match "XXaabbccddeeffXX"
# md.to_a #=> ["XXaabbccddeeffXX", "bb", "ccdd", "dd", "ee"]
# md.matchset #=> ["XXaa", [["bb"], ["cc", ["dd"]], "ee"],
"ffXX"]
#
def matchset
[pre_match, matchtree, post_match]
end

# An alternate to #to_a which returns the matches in
# order corresponding with the regular expression.
#
# md = /(bb)(cc(dd))(ee)/.match "XXaabbccddeeffXX"
# md.to_a #=> ["XXaabbccddeeffXX", "bb", "ccdd", "dd", "ee"]
# md.matchtree #=> [["bb"], ["cc", ["dd"]], "ee"]
#
def matchtree(index=0)
ret=[]
b, e=self.begin(index), self.end(index)
while (index+=1)<=length
if index==length || (bi=self.begin(index))>=e
# we are finished, if something is left, then add it
ret << string[b, e-b] if e>b
break
else
if bi>=b
ret << string[b, bi-b] if bi>b
ret << matchtree(index)
b=self.end(index)
end
end
end
return ret
end

end