<?xml version="1.0"?>
<rss version="2.0">
	<channel>
		<title>Possible bug in allegro utf8 function</title>
		<link>http://www.allegro.cc/forums/view/618392</link>
		<description>Allegro.cc Forum Thread</description>
		<webMaster>matthew@allegro.cc (Matthew Leverton)</webMaster>
		<lastBuildDate>Wed, 07 Apr 2021 18:04:29 +0000</lastBuildDate>
	</channel>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Hi, I was just looking to Allegro source code and foundsome strange situation. Or it&#39;s also possible that I just do not understand the code:</p><div class="source-code"><div class="toolbar"><span class="button numbers"><b>#</b></span><span class="button select">Select</span><span class="button expand">Expand</span></div><div class="inner"><span class="number">  1</span><span class="c">/* Function: al_ustr_find_set</span>
<span class="number">  2</span><span class="c"> */</span>
<span class="number">  3</span><span class="k1">int</span> <a href="http://www.allegro.cc/manual/al_ustr_find_set"><span class="a">al_ustr_find_set</span></a><span class="k2">(</span><span class="k1">const</span> <a href="http://www.allegro.cc/manual/ALLEGRO_USTR"><span class="a">ALLEGRO_USTR</span></a> <span class="k3">*</span>us, <span class="k1">int</span> start_pos,
<span class="number">  4</span>   <span class="k1">const</span> <a href="http://www.allegro.cc/manual/ALLEGRO_USTR"><span class="a">ALLEGRO_USTR</span></a> <span class="k3">*</span>accept<span class="k2">)</span>
<span class="number">  5</span><span class="k2">{</span>
<span class="number">  6</span>   <span class="k1">int</span> rc<span class="k2">;</span>
<span class="number">  7</span>   <span class="k1">int32_t</span> c, d<span class="k2">;</span>
<span class="number">  8</span>   <span class="k1">int</span> pos<span class="k2">;</span>
<span class="number">  9</span>   <span class="k1">int</span> set_pos<span class="k2">;</span>
<span class="number"> 10</span>
<span class="number"> 11</span>   <span class="c">/* Fast path for ASCII characters. */</span>
<span class="number"> 12</span>   <span class="k1">if</span> <span class="k2">(</span>all_ascii<span class="k2">(</span>accept<span class="k2">)</span><span class="k2">)</span> <span class="k2">{</span>
<span class="number"> 13</span>      rc <span class="k3">=</span> _al_binchr<span class="k2">(</span>us, start_pos, accept<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 14</span>      <span class="k1">return</span> <span class="k2">(</span>rc <span class="k3">=</span><span class="k3">=</span> _AL_BSTR_ERR<span class="k2">)</span> ? <span class="k3">-</span><span class="n">1</span> <span class="k2">:</span> rc<span class="k2">;</span>
<span class="number"> 15</span>   <span class="k2">}</span>
<span class="number"> 16</span>
<span class="number"> 17</span>   <span class="c">/* Non-ASCII. */</span>
<span class="number"> 18</span>   pos <span class="k3">=</span> <span class="n">0</span><span class="k2">;</span>
<span class="number"> 19</span>   <span class="k1">while</span> <span class="k2">(</span><span class="k2">(</span>c <span class="k3">=</span> <a href="http://www.allegro.cc/manual/al_ustr_get"><span class="a">al_ustr_get</span></a><span class="k2">(</span>us, pos<span class="k2">)</span><span class="k2">)</span> <span class="k3">!</span><span class="k3">=</span> <span class="k3">-</span><span class="n">1</span><span class="k2">)</span> <span class="k2">{</span>
<span class="number"> 20</span>      <span class="k1">if</span> <span class="k2">(</span>c <span class="k3">=</span><span class="k3">=</span> <span class="k3">-</span><span class="n">2</span><span class="k2">)</span> <span class="k2">{</span>
<span class="number"> 21</span>         <span class="c">/* Invalid byte sequence. */</span>
<span class="number"> 22</span>         pos<span class="k3">+</span><span class="k3">+</span><span class="k2">;</span>
<span class="number"> 23</span>         <span class="k1">continue</span><span class="k2">;</span>
<span class="number"> 24</span>      <span class="k2">}</span>
<span class="number"> 25</span>
<span class="number"> 26</span>      set_pos <span class="k3">=</span> <span class="n">0</span><span class="k2">;</span>
<span class="number"> 27</span>      <span class="k1">while</span> <span class="k2">(</span><span class="k2">(</span>d <span class="k3">=</span> <a href="http://www.allegro.cc/manual/al_ustr_get_next"><span class="a">al_ustr_get_next</span></a><span class="k2">(</span>accept, <span class="k3">&amp;</span>set_pos<span class="k2">)</span><span class="k2">)</span> <span class="k3">!</span><span class="k3">=</span> <span class="k3">-</span><span class="n">1</span><span class="k2">)</span> <span class="k2">{</span>
<span class="number"> 28</span>         <span class="k1">if</span> <span class="k2">(</span>c <span class="k3">=</span><span class="k3">=</span> d<span class="k2">)</span>
<span class="number"> 29</span>            <span class="k1">return</span> pos<span class="k2">;</span>
<span class="number"> 30</span>      <span class="k2">}</span>
<span class="number"> 31</span>
<span class="number"> 32</span>      pos <span class="k3">+</span><span class="k3">=</span> <a href="http://www.allegro.cc/manual/al_utf8_width"><span class="a">al_utf8_width</span></a><span class="k2">(</span>c<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 33</span>   <span class="k2">}</span>
<span class="number"> 34</span>
<span class="number"> 35</span>   <span class="k1">return</span> <span class="k3">-</span><span class="n">1</span><span class="k2">;</span>
<span class="number"> 36</span><span class="k2">}</span>
</div></div><p>

It should find first occurrence of code point starting at pos <b>start_pos</b>. The thing I do not understand is that the argument <b>start_pos</b> is used only in one place in the function and that&#39;s the ASCII only branch. But not in the non ASCII. Is it bug or just there is something I do not see?
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (archlinka)</author>
		<pubDate>Wed, 07 Apr 2021 12:51:53 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>I think you&#39;re right, this looks like a bug.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (amarillion)</author>
		<pubDate>Wed, 07 Apr 2021 16:27:02 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>I agree, if you&#39;ve got time please could you create an issue on the github?<br /><a href="https://github.com/liballeg/allegro5/issues">https://github.com/liballeg/allegro5/issues</a></p><p>Thanks.<br />(p.s. looks like it would be easily fixed, too!)
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Peter Hull)</author>
		<pubDate>Wed, 07 Apr 2021 18:04:29 +0000</pubDate>
	</item>
</rss>
