On Mon, 2008-02-11 at 13:42 +0900, Michael Moyle wrote:
> Rob,
>
>
> > $reps = array
> > (
> > array
> > (
> > 'match' => '#<a.*</a>#Uims',
>
> Can you explain what the 'U' from #Uims does? Does it have to do with
> Unicode? I can't find it anywhere (preg_match doc, man perlre, man
> perlop).
It makes the match "Ungreedy". Look at the following example:
$text = "<a href="">blah</a> ... <a href="">bleh</a>";
If we match with the following:
preg_match_all( '#<a.*</a>#Uims', $html, $matches )
Then $matches will contain 2 matches...
1. <a href="">blah</a>
2. <a href="">bleh</a>
However if we match with the following:
preg_match_all( '#<a.*</a>#ims', $html, $matches )
Then $matches will only get 1 match...
1. <a href="">blah</a> ... <a href="">bleh</a>
This is because the default behaviour is greedy, it will match as much
as possible even if a shorter match exists.
Cheers,
Rob.
--
.------------------------------------------------------------.
| InterJinn Application Framework - http://www.interjinn.com |
:------------------------------------------------------------:
| An application and templating framework for PHP. Boasting |
| a powerful, scalable system for accessing system services |
| such as forms, properties, sessions, and caches. InterJinn |
| also provides an extremely flexible architecture for |
| creating re-usable components quickly and easily. |
`------------------------------------------------------------'
--
PHP General Mailing List (http://www.php.net/)
To unsubscribe, visit: http://www.php.net/unsub.php