Here's a code snippet from a site I wrote that parses a twitter feed. It parses links, hash tags, and twitter usernames. So far it's worked fine. I know it's not Ruby, but the regex should be helpful.
if(tweetStream[i] != null)
{
var str = tweetStream[i].Text;
var re = new Regex(@"http(s)?:\/\/\S+");
MatchCollection mc = re.Matches(tweetStream[i].Text);
foreach (Match m in mc)
{
str = str.Replace(m.Value, "<a href='" + m.Value + "' target='_blank'>" + m.Value + "</a>");
}
re = new Regex(@"(@)(\w+)");
mc = re.Matches(tweetStream[i].Text);
foreach (Match m in mc)
{
str = str.Replace(m.Value, "<a href='http://twitter.com/" + m.Value.Replace("@",string.Empty) + "' target='_blank'>" + m.Value + "</a>");
}
re = new Regex(@"(#)(\w+)");
mc = re.Matches(tweetStream[i].Text);
foreach (Match m in mc)
{
str = str.Replace(m.Value, "<a href='http://twitter.com/#search?q=" + m.Value.Replace("#", "%23") + "' target='_blank'>" + m.Value + "</a>");
}
tweets += string1 + "<div>" + str + "</div>" + string2;
}