]> granicus.if.org Git - libass/commit
Simplify word wrapping and fix possible endless loop
authorGrigori Goronzy <greg@blackbox>
Wed, 9 Feb 2011 00:27:22 +0000 (01:27 +0100)
committerGrigori Goronzy <greg@blackbox>
Wed, 9 Feb 2011 00:27:22 +0000 (01:27 +0100)
commited62c02763237146517e8d7a8e0cbc01b717cb41
tree8eda5c701814ba75337d096d159d9ca400482353
parent8113989290ed507efcfa98d30f89945150f32acb
Simplify word wrapping and fix possible endless loop

wrap_lines_smart() got stuck if there was a long line without spaces
followed by a hard linebreak. When the loop got to the '\n' character
the hard linebreak was not handled because the line was already over
wrap length and soft linebreak handling had precedence. Then at the
end of the loop body the code noted that the hard linebreak hadn't yet
been handled, and the same glyph needed to be reprocessed for that.
However, the soft linebreak code hadn't actually done anything because
there was no space to break at, and thus the loop repeated from the
exact same state forever.

Handle this by removing the check for an additional hard linebreak
after a soft linebreak, which stepped back by one char. This is a
very marginal case and shouldn't really matter in practice.

Original patch and parts of this message by uau.
libass/ass_render.c