sub new {
my $invocant = shift;
my $class = ref $invocant || $invocant;
- return $class->SUPER::new(tab_width => MARKDOWN_TAB_WIDTH,
+ my $obj = $class->SUPER::new(tab_width => MARKDOWN_TAB_WIDTH,
# Bugzilla uses HTML not XHTML
empty_element_suffix => '>');
+ $obj->{tab_width} = MARKDOWN_TAB_WIDTH;
+ $obj->{empty_element_suffix} = '>';
+ return $obj;
}
sub markdown {
- my $self = shift;
- my $text = shift;
+ my ($self, $text, $bug, $comment) = @_;
my $user = Bugzilla->user;
if ($user->settings->{use_markdown}->{is_enabled}
&& $user->setting('use_markdown') eq 'on')
{
- return $self->SUPER::markdown($text, @_);
+ $text = $self->_removeFencedCodeBlocks($text);
+ $text = Bugzilla::Template::quoteUrls($text, $bug, $comment, $user, 1);
+ return $self->SUPER::markdown($text);
}
- return Bugzilla::Template::quoteUrls($text);
-}
-
-sub _Markdown {
- my $self = shift;
- my $text = shift;
-
- $text = $self->_removeFencedCodeBlocks($text);
- $text = Bugzilla::Template::quoteUrls($text, undef, undef, undef, 1);
-
- return $self->SUPER::_Markdown($text, @_);
+ return Bugzilla::Template::quoteUrls($text, $bug, $comment, $user);
}
sub _code_blocks {
# If the comment is already wrapped, we should ignore newlines when
# looking for matching regexps. Else we should take them into account.
- my $s = ($comment && $comment->already_wrapped) ? qr/\s/ : qr/\h/;
+ # And confirm comment is an object, it could be a hash from WebService::Bug::render_comment
+ my $s = ($comment && ref($comment) eq 'Bugzilla::Comment' && $comment->already_wrapped) ? qr/\s/ : qr/\h/;
# However, note that adding the title (for buglinks) can affect things
# In particular, attachment matches go before bug titles, so that titles
&& ((ref($comment) eq 'HASH' && $comment->{is_markdown})
|| (ref($comment) eq 'Bugzilla::Comment' && $comment->is_markdown)))
{
- return Bugzilla->markdown->markdown($text);
+ return Bugzilla->markdown->markdown($text, $bug, $comment);
}
return quoteUrls($text, $bug, $comment, $user);
};