in reply to Re: User Code
in thread User Code
A problem with your regex, as it stands : you need to escape some of those square brackets, as those have special meaning within regexes.
Monolith-O, the syntax you're using is so close to HTML as it is that it doesn't seem to simplify things much. If you can change it, consider doing so. you could do something like what perlmonks does, and let [www.foo.com|the Foo site] stand in for <a href="http://www.foo.com">the Foo site</a>. A regex to match that would be:
$text =~ s#(\[([^|])+\|([^\]]+)]#<a href="http://$1">$2</a>#g;
Update that's wrong, as $code_or_die points out.
Sticking with the current setup, the first regex should be something like this (untested):
$text =~ s#\[link=(["'])(\S+)\1]([^[])+\[/link]#<a href="$2">$3</a>#g;
This says "when you find "link=" followed by a single or double quote, grab 1 or more characters that aren't a single or double quote (whichever matched) -- store that in $2 -- followed by the single or double quote, then grab one or more characters that aren't [ and store them in $3, finished up by [/link]. Replace that whole sequence with <a href="$2">$3</a>
Philosophy can be made out of anything. Or less -- Jerry A. Fodor
|
|---|
| Replies are listed 'Best First'. | |
|---|---|
|
Re: Re: Re: User Code
by $code or die (Deacon) on Dec 10, 2000 at 00:00 UTC | |
by arturo (Vicar) on Dec 10, 2000 at 01:00 UTC | |
by $code or die (Deacon) on Dec 11, 2000 at 07:19 UTC | |
by chipmunk (Parson) on Dec 11, 2000 at 08:51 UTC | |
by $code or die (Deacon) on Dec 11, 2000 at 19:19 UTC | |
| |
|
Re: Re: Re: User Code
by Monolith-0 (Beadle) on Dec 09, 2000 at 08:43 UTC |