<?xml version="1.0"?>
<rss version="2.0">
	<channel>
		<title>DAllegro and D confusing output...</title>
		<link>http://www.allegro.cc/forums/view/617113</link>
		<description>Allegro.cc Forum Thread</description>
		<webMaster>matthew@allegro.cc (Matthew Leverton)</webMaster>
		<lastBuildDate>Tue, 31 Oct 2017 04:14:41 +0000</lastBuildDate>
	</channel>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>[edit 1] DOOOOH. I accidentally placed my color code above allegro_init. UHGGGHHH.</p><p>[edit 2] WAIT. Now THIS is still really confusing. If I printf with floats, they display correctly:</p><div class="source-code snippet"><div class="inner"><pre><span class="k2">(</span>RGBA<span class="k2">)</span>
<span class="n">0</span>.<span class="n">501961</span> <span class="n">0</span>.<span class="n">250980</span> <span class="n">0</span>.<span class="n">501961</span> <span class="n">1</span>.<span class="n">000000</span>
<span class="n">0</span>.<span class="n">501961</span> <span class="n">0</span>.<span class="n">250980</span> <span class="n">0</span>.<span class="n">501961</span> <span class="n">1</span>.<span class="n">000000</span>
<span class="n">0</span>.<span class="n">501961</span> <span class="n">0</span>.<span class="n">250980</span> <span class="n">0</span>.<span class="n">501961</span> <span class="n">1</span>.<span class="n">000000</span>
</pre></div></div><p>

Now watch what happens when I use printf unsigned int:
</p><div class="source-code snippet"><div class="inner"><pre><span class="n">1056997505</span> <span class="n">1056997505</span> <span class="n">255</span>        <span class="n">2011460928</span>
<span class="n">0</span>          <span class="n">0</span>          <span class="n">2013416856</span> <span class="n">0</span>
<span class="n">1056997505</span> <span class="n">1056997505</span> <span class="n">2013416888</span> <span class="n">2011460928</span>
</pre></div></div><p>

What the heck is going on? Are there multiple &quot;float&quot; values for the same thing? Why would they change going from one variable to another, and why ONLY when using printf with integer output?</p><p>Here&#39;s both output, at the same time, so you can be sure there&#39;s no other data changes:
</p><div class="source-code snippet"><div class="inner"><pre><a href="http://www.delorie.com/djgpp/doc/libc/libc_624.html" target="_blank">printf</a><span class="k2">(</span><span class="s">"%12u %12u %12u %12u - %12f %12f %12f %12f \n"</span>, c.r, c.g, c.b, c.a, c.r, c.g, c.b, c.a<span class="k2">)</span><span class="k2">;</span>
</pre></div></div><p>
</p><div class="source-code snippet"><div class="inner"><pre>
  <span class="n">1056997505</span>   <span class="n">1056997505</span>          <span class="n">255</span>    <span class="n">991089984</span> <span class="k3">-</span>     <span class="n">0</span>.<span class="n">501961</span>     <span class="n">0</span>.<span class="n">250980</span>     <span class="n">0</span>.<span class="n">501961</span>     <span class="n">1</span>.<span class="n">000000</span> 
           <span class="n">0</span>            <span class="n">0</span>    <span class="n">993045912</span>            <span class="n">0</span> <span class="k3">-</span>     <span class="n">0</span>.<span class="n">501961</span>     <span class="n">0</span>.<span class="n">250980</span>     <span class="n">0</span>.<span class="n">501961</span>     <span class="n">1</span>.<span class="n">000000</span> 
  <span class="n">1056997505</span>   <span class="n">1056997505</span>    <span class="n">993045944</span>    <span class="n">991089984</span> <span class="k3">-</span>     <span class="n">0</span>.<span class="n">501961</span>     <span class="n">0</span>.<span class="n">250980</span>     <span class="n">0</span>.<span class="n">501961</span>     <span class="n">1</span>.<span class="n">000000</span>
</pre></div></div><p>
Using ul instead of u (unsigned long) doesn&#39;t help either.</p><p>[orignal post:]</p><p>I keep getting strange problems. One is, printf doesn&#39;t seem to always output. </p><p>But the DAllegro specific issue...
</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="number">  2</span><span class="k1">struct</span> player_t
<span class="number">  3</span><span class="k2">{</span>
<span class="number">  4</span><a href="http://www.allegro.cc/manual/ALLEGRO_COLOR"><span class="a">ALLEGRO_COLOR</span></a> c<span class="k2">;</span>
<span class="number">  5</span>
<span class="number">  6</span><span class="k1">void</span> setup<span class="k2">(</span><a href="http://www.allegro.cc/manual/ALLEGRO_COLOR"><span class="a">ALLEGRO_COLOR</span></a> c<span class="k2">)</span>
<span class="number">  7</span>  <span class="k2">{</span>
<span class="number">  8</span>  color <span class="k3">=</span> c<span class="k2">;</span>
<span class="number">  9</span>  <a href="http://www.delorie.com/djgpp/doc/libc/libc_624.html" target="_blank">printf</a><span class="k2">(</span><span class="s">"%i %i %i\n"</span>, c.r, c.g, c.b<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 10</span>  <span class="k2">}</span>
<span class="number"> 11</span>
<span class="number"> 12</span><span class="k1">void</span> draw<span class="k2">(</span><span class="k1">float</span> offset_x, <span class="k1">float</span> offset_y<span class="k2">)</span>
<span class="number"> 13</span>  <span class="k2">{</span>
<span class="number"> 14</span>  <a href="http://www.allegro.cc/manual/al_draw_circle"><span class="a">al_draw_circle</span></a><span class="k2">(</span>x <span class="k3">-</span> offset_x, y <span class="k3">-</span> offset_y, <span class="n">10</span>, <a href="http://www.allegro.cc/manual/al_map_rgb"><span class="a">al_map_rgb</span></a><span class="k2">(</span><span class="n">255</span>,<span class="n">0</span>,<span class="n">255</span><span class="k2">)</span>, <span class="n">2</span><span class="k2">)</span><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="k2">}</span>
<span class="number"> 18</span>
<span class="number"> 19</span>player_t <span class="k2">[</span><span class="n">2</span><span class="k2">]</span> players<span class="k2">;</span>
<span class="number"> 20</span>
<span class="number"> 21</span>
<span class="number"> 22</span><span class="k1">void</span> initialize<span class="k2">(</span><span class="k2">)</span>
<span class="number"> 23</span>  <span class="k2">{</span>    
<span class="number"> 24</span>  <a href="http://www.delorie.com/djgpp/doc/libc/libc_624.html" target="_blank">printf</a><span class="k2">(</span><span class="s">"---------------\n"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 25</span>  <a href="http://www.allegro.cc/manual/ALLEGRO_COLOR"><span class="a">ALLEGRO_COLOR</span></a> x <span class="k3">=</span> <a href="http://www.allegro.cc/manual/al_map_rgb"><span class="a">al_map_rgb</span></a><span class="k2">(</span><span class="n">128</span>, <span class="n">64</span>, <span class="n">128</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 26</span>  <a href="http://www.delorie.com/djgpp/doc/libc/libc_624.html" target="_blank">printf</a><span class="k2">(</span><span class="s">"%i %i %i\n"</span>, x.r, x.g, x.b<span class="k2">)</span><span class="k2">;</span> <span class="c">//first line output</span>
<span class="number"> 27</span>
<span class="number"> 28</span>  g.players<span class="k2">[</span><span class="n">0</span><span class="k2">]</span>.setup<span class="k2">(</span> x <span class="k2">)</span><span class="k2">;</span> <span class="c">//second line output</span>
<span class="number"> 29</span>  g.players<span class="k2">[</span><span class="n">1</span><span class="k2">]</span>.setup<span class="k2">(</span> <a href="http://www.allegro.cc/manual/al_map_rgb"><span class="a">al_map_rgb</span></a><span class="k2">(</span><span class="n">128</span>, <span class="n">64</span>, <span class="n">128</span><span class="k2">)</span> <span class="k2">)</span><span class="k2">;</span> <span class="c">//third line output</span>
<span class="number"> 30</span>
<span class="number"> 31</span>  <a href="http://www.delorie.com/djgpp/doc/libc/libc_624.html" target="_blank">printf</a><span class="k2">(</span><span class="s">"---------------\n"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 32</span>  
<span class="number"> 33</span>  <span class="c">//...</span>
<span class="number"> 34</span>  <span class="k2">}</span>
</div></div><p>


Output:</p><div class="source-code snippet"><div class="inner"><pre><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span>
<span class="n">0</span> <span class="n">0</span> <span class="n">255</span>
<span class="n">0</span> <span class="n">0</span> <span class="k3">-</span><span class="n">111424104</span>
<span class="n">0</span> <span class="n">0</span> <span class="k3">-</span><span class="n">111424072</span>
<span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span>
</pre></div></div><p>

First, why is R=0, G=0 in the first line?</p><p>Secondly, why does the color data explode when I store it in a struct?</p><p>I&#39;m looking into this problem because I&#39;m writing something super-simple and trying to draw my &quot;players&quot; with a set color. And whenever I pass the data, they go invisible.</p><p>I thought structs were value-types, so they should copy in just fine. And if they&#39;re going out of scope, shouldn&#39;t that be a segfault? </p><p>Hmm...
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Chris Katko)</author>
		<pubDate>Sat, 28 Oct 2017 13:10:00 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><div class="quote_container"><div class="title"><a href="http://www.allegro.cc/forums/thread/617113/1033226#target">Chris Katko</a> said:</div><div class="quote"><p> Why would they change going from one variable to another, and why ONLY when using printf with integer output?</p></div></div><p>You&#39;re running into the gnarly details of the calling convention (probably optlink, if you&#39;re on Windows). Floating point values and integer values are probably placed in different memory locations, and by asking it to decode integers when you&#39;re passing floats, you&#39;re likely reading garbage.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (SiegeLord)</author>
		<pubDate>Sat, 28 Oct 2017 23:36:59 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>I&#39;m running Linux, but the same may apply. It&#39;s certainly a head scratcher for me.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Chris Katko)</author>
		<pubDate>Sun, 29 Oct 2017 02:59:37 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>I&#39;ve never used D, but</p><p>Float: 0.501961</p><p>Actual float value stored in memory: 0.5019609928131103515625</p><p>Breakdown: <br />float = sign : exponent : mantissa</p><p>sign: 0<br />exp: 01111110<br />mantissa: 00000001000000010000100</p><p>Binary: 00111111000000001000000010000100<br />Hex: 0x3f008084<br />Integer: 1056997508
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (DanielH)</author>
		<pubDate>Tue, 31 Oct 2017 03:59:39 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Yes! But perhaps I didn&#39;t make it clearer. Why does the value change... once it&#39;s stored into a class method?</p><p>The only possibility (which I don&#39;t think exists on further exploration) was that there were multiple bitfield values that equal a float value and somehow it was &quot;converted&quot; to the second one in some kind of casting or something. But I think that&#39;s false.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Chris Katko)</author>
		<pubDate>Tue, 31 Oct 2017 04:14:41 +0000</pubDate>
	</item>
</rss>
