}
sub names {
- map {
- tr/\r\n\t/ /;
- s/\s*<([^<]+)\z//;
- my $e = $1;
- s/\A['"\s]*//;
- s/['"\s]*\z//;
- $e = $_ =~ /\S/ ? $_ : $e;
- $e =~ s/\@\S+\z//;
- $e;
- } split(/\@+[\w\.\-]+>?\s*(?:\(.*?\))?(?:,\s*|\z)/, $_[0]);
+ my @p = split(/<?([^@<>]+)\@[\w\.\-]+>?\s*(\(.*?\))?(?:,\s*|\z)/,
+ $_[0]);
+ my @ret;
+ for (my $i = 0; $i <= $#p;) {
+ my $phrase = $p[$i++];
+ $phrase =~ tr/\r\n\t / /s;
+ $phrase =~ s/\A['"\s]*//;
+ $phrase =~ s/['"\s]*\z//;
+ my $user = $p[$i++] // '';
+ my $comment = $p[$i++] // '';
+ if ($phrase =~ /\S/) {
+ $phrase =~ s/\@\S+\z//;
+ push @ret, $phrase;
+ } elsif ($comment =~ /\A\((.*?)\)\z/) {
+ push @ret, $1;
+ } else {
+ push @ret, $user;
+ }
+ }
+ @ret;
}
1;
'comment after domain accepted before >');
my @names = PublicInbox::Address::names(
- 'User <e@e>, e@e, "John A. Doe" <j@d>, <x@x>');
-is_deeply(['User', 'e', 'John A. Doe', 'x'], \@names,
+ 'User <e@e>, e@e, "John A. Doe" <j@d>, <x@x>, <y@x> (xyz), '.
+ 'U Ser <u@x> (do not use)');
+is_deeply(\@names, ['User', 'e', 'John A. Doe', 'x', 'xyz', 'U Ser'],
'name extraction works as expected');
@names = PublicInbox::Address::names('"user@example.com" <user@example.com>');
{
my $backwards = 'u@example.com (John Q. Public)';
@names = PublicInbox::Address::names($backwards);
- is_deeply(\@names, ['u'], 'backwards name OK');
+ is_deeply(\@names, ['John Q. Public'], 'backwards name OK');
my @emails = PublicInbox::Address::emails($backwards);
is_deeply(\@emails, ['u@example.com'], 'backwards emails OK');
}