<?xml version="1.0"?>
<rss version="2.0">
	<channel>
		<title>Allegro 5 crashes when using al_draw_bitmap inside a list container</title>
		<link>http://www.allegro.cc/forums/view/618193</link>
		<description>Allegro.cc Forum Thread</description>
		<webMaster>matthew@allegro.cc (Matthew Leverton)</webMaster>
		<lastBuildDate>Wed, 22 Jul 2020 02:28:19 +0000</lastBuildDate>
	</channel>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Hi, I was trying to use the bitmap functions. But the program crashes when trying to use the &quot;al_draw_bitmap&quot; function. So I tried to reproduce the error, I created a simple program with a class, and in its constructor I used the lines to create the bitmap, and to load it:</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>grass <span class="k3">=</span> <a href="http://www.allegro.cc/manual/al_create_bitmap"><span class="a">al_create_bitmap</span></a><span class="k2">(</span><span class="n">50</span>, <span class="n">50</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 2</span>grass <span class="k3">=</span> <a href="http://www.allegro.cc/manual/al_load_bitmap"><span class="a">al_load_bitmap</span></a><span class="k2">(</span><span class="s">"D:/Documents/SimpleApp/bin/Debug/grass.bmp"</span><span class="k2">)</span><span class="k2">;</span>
</div></div><p>

Another function of that class called &quot;print()&quot; has the drawing function:</p><p><span class="source-code"><a href="http://www.allegro.cc/manual/al_draw_bitmap"><span class="a">al_draw_bitmap</span></a><span class="k2">(</span>grass, <span class="n">100</span>, <span class="n">100</span>, <span class="n">0</span><span class="k2">)</span><span class="k2">;</span></span></p><p>Then I created an instance of that class, and inside the main loop of the code, I used the print() function of my class. It worked fine, as expected.</p><p>But then, when instead of creating a single instance of that class, I create a list container with an element of that class, it doesn&#39;t work properly:</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>std::list<span class="k3">&lt;</span>THING&gt; thing<span class="k2">;</span>
<span class="number"> 2</span>std::list<span class="k3">&lt;</span>THING&gt;::iterator itt<span class="k2">;</span>
<span class="number"> 3</span>thing.push_back<span class="k2">(</span>THING<span class="k2">(</span><span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
</div></div><p>

Then in the main loop of the code, I call the print() function this way:</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>itt <span class="k3">=</span> thing.begin<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 2</span><span class="k2">(</span><span class="k3">*</span>itt<span class="k2">)</span>.print<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
</div></div><p>

And then the program crashes. It doesn&#39;t crash when I create and load the bitmap in the constructor, it crashes when I try to use the &quot;al_draw_bitmap&quot; function. I&#39;m on codeblocks, and when debugging, in the moment I step into the &quot;al_draw_bitmap(grass, 100, 100, 0);&quot; line, the debugger gives me this message:</p><p>Cannot open file: C:/dev/allegro_winpkg/universal/allegro/src/bitmap_draw.c</p><p>Any idea of why is this happening to me? Everything works fine when I&#39;m not using the list container, it&#39;s when I use it that it crashes. I include the &quot;#include &lt;allegro5/allegro_image.h&gt;&quot; line, and also call for the &quot;al_init_image_addon()&quot; after &quot;al_init()&quot; so I have no idea what it could be. Maybe al_draw_bitmap() isn&#39;t supposed to work with a list containers? That&#39;d be unfortunate because my main program is based on list and vector containers <img src="http://www.allegro.cc/forums/smileys/cry.gif" alt=":&#39;(" />
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Xinomorph)</author>
		<pubDate>Tue, 21 Jul 2020 20:44:30 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Without more code, I can only offer suggestions.</p><p>Loading a bitmap already creates it. Your creating it twice without freeing the first creation.
</p><div class="source-code snippet"><div class="inner"><pre>
<span class="c">// allocates memory, grass not points to that memory</span>
grass <span class="k3">=</span> <a href="http://www.allegro.cc/manual/al_create_bitmap"><span class="a">al_create_bitmap</span></a><span class="k2">(</span><span class="n">50</span>, <span class="n">50</span><span class="k2">)</span><span class="k2">;</span>

<span class="c">// allocates memory, grass not points to that memory</span>
<span class="c">// previous memory allocated now has nothing pointing to it and it wasn't freed</span>
grass <span class="k3">=</span> <a href="http://www.allegro.cc/manual/al_load_bitmap"><span class="a">al_load_bitmap</span></a><span class="k2">(</span><span class="s">"D:/Documents/SimpleApp/bin/Debug/grass.bmp"</span><span class="k2">)</span><span class="k2">;</span>
</pre></div></div><p>

also where is the verification that the bitmap was actually loaded?</p><p>At what point was the THING constructor called? Was it after display initialization?
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (DanielH)</author>
		<pubDate>Tue, 21 Jul 2020 21:02:13 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Shouldn&#39;t that be:</p><div class="source-code snippet"><div class="inner"><pre>thing.push_back<span class="k2">(</span><span class="k1">new</span> THING<span class="k2">(</span><span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
</pre></div></div><p>
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Dizzy Egg)</author>
		<pubDate>Tue, 21 Jul 2020 21:02:58 +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/618193/1046780#target">DanielH</a> said:</div><div class="quote"><p> Loading a bitmap already creates it. Your creating it twice without freeing the first creation.</p></div></div><p>

Thanks, I removed that line as it was unnecessary. The same problem still persists though.</p><div class="quote_container"><div class="title">DanielH said:</div><div class="quote"><p> also where is the verification that the bitmap was actually loaded?</p></div></div><p>

I added one, but I&#39;m not sure if the way I did it is the correct way.</p><p>Now, I tried to put all the code of this test program in a single file so I can paste the entire program here. I tried to keep it as simple as I could. It behaves the same way I said above: without the list container, it works fine, but with the list container it crashes. First, this is the code without the list container:</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="p">#include &lt;allegro5/allegro.h&gt;</span>
<span class="number">   3</span><span class="p">#include &lt;allegro5/allegro_native_dialog.h&gt;</span>
<span class="number">   4</span><span class="p">#include &lt;allegro5/allegro_ttf.h&gt;</span>
<span class="number">   5</span><span class="p">#include &lt;allegro5/allegro_image.h&gt;</span>
<span class="number">   6</span><span class="p">#include &lt;list&gt;</span>
<span class="number">   7</span>
<span class="number">   8</span><a href="http://www.allegro.cc/manual/ALLEGRO_DISPLAY"><span class="a">ALLEGRO_DISPLAY</span></a> <span class="k3">*</span>display <span class="k3">=</span> NULL<span class="k2">;</span>
<span class="number">   9</span><a href="http://www.allegro.cc/manual/ALLEGRO_EVENT_QUEUE"><span class="a">ALLEGRO_EVENT_QUEUE</span></a> <span class="k3">*</span>event_queue <span class="k3">=</span> NULL<span class="k2">;</span>
<span class="number">  10</span>
<span class="number">  11</span><span class="k1">int</span> initiate_allegro<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  12</span><span class="k1">void</span> destroy_pointers<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  13</span><span class="k1">void</span> exit_allegro<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  14</span>
<span class="number">  15</span><span class="k1">void</span> events<span class="k2">(</span><a href="http://www.allegro.cc/manual/ALLEGRO_EVENT"><span class="a">ALLEGRO_EVENT</span></a> <span class="k3">&amp;</span>event, <span class="k1">bool</span> <span class="k3">&amp;</span>cycle, <span class="k1">bool</span> <span class="k3">&amp;</span>doexit<span class="k2">)</span><span class="k2">;</span>
<span class="number">  16</span>
<span class="number">  17</span><span class="k1">class</span> THING<span class="k2">{</span>
<span class="number">  18</span>private:
<span class="number">  19</span>    <a href="http://www.allegro.cc/manual/ALLEGRO_BITMAP"><span class="a">ALLEGRO_BITMAP</span></a> <span class="k3">*</span>grass<span class="k2">;</span>
<span class="number">  20</span>public:
<span class="number">  21</span>    THING<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  22</span>    ~THING<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  23</span>    <span class="k1">void</span> print<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  24</span><span class="k2">}</span><span class="k2">;</span>
<span class="number">  25</span>
<span class="number">  26</span>THING::THING<span class="k2">(</span><span class="k2">)</span><span class="k2">{</span>
<span class="number">  27</span>    grass <span class="k3">=</span> NULL<span class="k2">;</span>
<span class="number">  28</span>    grass <span class="k3">=</span> <a href="http://www.allegro.cc/manual/al_load_bitmap"><span class="a">al_load_bitmap</span></a><span class="k2">(</span><span class="s">"D:/Documents/TestBitmaps/bin/Debug/grass.bmp"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  29</span>    <span class="k1">if</span> <span class="k2">(</span>grass <span class="k3">=</span><span class="k3">=</span> NULL<span class="k2">)</span><span class="k2">{</span>
<span class="number">  30</span>        <a href="http://www.allegro.cc/manual/al_show_native_message_box"><span class="a">al_show_native_message_box</span></a><span class="k2">(</span><a href="http://www.allegro.cc/manual/al_get_current_display"><span class="a">al_get_current_display</span></a><span class="k2">(</span><span class="k2">)</span>, <span class="s">"Allegro 5 Error"</span>, <span class="s">"Error"</span>, <span class="s">"Couldn't load bitmap."</span>, NULL, ALLEGRO_MESSAGEBOX_ERROR<span class="k2">)</span><span class="k2">;</span>
<span class="number">  31</span>    <span class="k2">}</span>
<span class="number">  32</span><span class="k2">}</span>
<span class="number">  33</span>
<span class="number">  34</span>THING::~THING<span class="k2">(</span><span class="k2">)</span><span class="k2">{</span>
<span class="number">  35</span>    <span class="k1">if</span> <span class="k2">(</span>grass <span class="k3">!</span><span class="k3">=</span> NULL<span class="k2">)</span> <a href="http://www.allegro.cc/manual/al_destroy_bitmap"><span class="a">al_destroy_bitmap</span></a><span class="k2">(</span>grass<span class="k2">)</span><span class="k2">;</span>
<span class="number">  36</span><span class="k2">}</span>
<span class="number">  37</span>
<span class="number">  38</span><span class="k1">void</span> THING::print<span class="k2">(</span><span class="k2">)</span><span class="k2">{</span>
<span class="number">  39</span>    <a href="http://www.allegro.cc/manual/al_draw_bitmap"><span class="a">al_draw_bitmap</span></a><span class="k2">(</span>grass, <span class="n">100</span>, <span class="n">100</span>, <span class="n">0</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  40</span><span class="k2">}</span>
<span class="number">  41</span>
<span class="number">  42</span>
<span class="number">  43</span><span class="k1">int</span> main<span class="k2">(</span><span class="k1">int</span> argc, <span class="k1">char</span> <span class="k3">*</span><span class="k3">*</span>argv<span class="k2">)</span><span class="k2">{</span>
<span class="number">  44</span>    <span class="k1">bool</span> doexit <span class="k3">=</span> <span class="k1">false</span>, cycle <span class="k3">=</span> <span class="k1">true</span><span class="k2">;</span>
<span class="number">  45</span>
<span class="number">  46</span>    <span class="k1">if</span> <span class="k2">(</span>initiate_allegro<span class="k2">(</span><span class="k2">)</span> <span class="k3">!</span><span class="k3">=</span> <span class="n">0</span><span class="k2">)</span><span class="k2">{</span>
<span class="number">  47</span>        <a href="http://www.allegro.cc/manual/al_show_native_message_box"><span class="a">al_show_native_message_box</span></a><span class="k2">(</span><a href="http://www.allegro.cc/manual/al_get_current_display"><span class="a">al_get_current_display</span></a><span class="k2">(</span><span class="k2">)</span>, <span class="s">"Allegro 5 Error"</span>, <span class="s">"Error"</span>, <span class="s">"An error has ocurred."</span>, NULL, ALLEGRO_MESSAGEBOX_ERROR<span class="k2">)</span><span class="k2">;</span>
<span class="number">  48</span>        <span class="k1">return</span> <span class="k3">-</span><span class="n">1</span><span class="k2">;</span>
<span class="number">  49</span>    <span class="k2">}</span>
<span class="number">  50</span>
<span class="number">  51</span>    THING thing<span class="k2">;</span>
<span class="number">  52</span>
<span class="number">  53</span>    <span class="k1">while</span><span class="k2">(</span>doexit <span class="k3">=</span><span class="k3">=</span> <span class="k1">false</span><span class="k2">)</span><span class="k2">{</span>
<span class="number">  54</span>        <a href="http://www.allegro.cc/manual/ALLEGRO_EVENT"><span class="a">ALLEGRO_EVENT</span></a> event<span class="k2">;</span>
<span class="number">  55</span>        events<span class="k2">(</span>event, cycle, doexit<span class="k2">)</span><span class="k2">;</span>
<span class="number">  56</span>
<span class="number">  57</span>        <span class="k1">if</span> <span class="k2">(</span>cycle <span class="k3">=</span><span class="k3">=</span> <span class="k1">true</span> <span class="k3">&amp;</span><span class="k3">&amp;</span> <a href="http://www.allegro.cc/manual/al_is_event_queue_empty"><span class="a">al_is_event_queue_empty</span></a><span class="k2">(</span>event_queue<span class="k2">)</span> <span class="k3">=</span><span class="k3">=</span> <span class="k1">true</span><span class="k2">)</span><span class="k2">{</span>
<span class="number">  58</span>            cycle <span class="k3">=</span> <span class="k1">false</span><span class="k2">;</span>
<span class="number">  59</span>
<span class="number">  60</span>            thing.print<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  61</span>
<span class="number">  62</span>            <a href="http://www.allegro.cc/manual/al_flip_display"><span class="a">al_flip_display</span></a><span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  63</span>        <span class="k2">}</span>
<span class="number">  64</span>    <span class="k2">}</span>
<span class="number">  65</span>
<span class="number">  66</span>    exit_allegro<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  67</span>    <span class="k1">return</span> <span class="n">0</span><span class="k2">;</span>
<span class="number">  68</span><span class="k2">}</span>
<span class="number">  69</span>
<span class="number">  70</span>
<span class="number">  71</span><span class="k1">int</span> initiate_allegro<span class="k2">(</span><span class="k2">)</span><span class="k2">{</span>
<span class="number">  72</span>    <span class="k1">if</span> <span class="k2">(</span><span class="k3">!</span><a href="http://www.allegro.cc/manual/al_init"><span class="a">al_init</span></a><span class="k2">(</span><span class="k2">)</span><span class="k2">)</span><span class="k2">{</span>
<span class="number">  73</span>        <a href="http://www.allegro.cc/manual/al_show_native_message_box"><span class="a">al_show_native_message_box</span></a><span class="k2">(</span><a href="http://www.allegro.cc/manual/al_get_current_display"><span class="a">al_get_current_display</span></a><span class="k2">(</span><span class="k2">)</span>, <span class="s">"Allegro 5 Error"</span>, <span class="s">"Error"</span>, <span class="s">"Failed to initialize Allegro 5."</span>, NULL, ALLEGRO_MESSAGEBOX_ERROR<span class="k2">)</span><span class="k2">;</span>
<span class="number">  74</span>        destroy_pointers<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  75</span>        <span class="k1">return</span> <span class="k3">-</span><span class="n">1</span><span class="k2">;</span>
<span class="number">  76</span>    <span class="k2">}</span>
<span class="number">  77</span>
<span class="number">  78</span>    <a href="http://www.allegro.cc/manual/al_init_ttf_addon"><span class="a">al_init_ttf_addon</span></a><span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  79</span>    <a href="http://www.allegro.cc/manual/al_init_image_addon"><span class="a">al_init_image_addon</span></a><span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  80</span>
<span class="number">  81</span>    display <span class="k3">=</span> <a href="http://www.allegro.cc/manual/al_create_display"><span class="a">al_create_display</span></a><span class="k2">(</span><span class="n">1280</span>, <span class="n">720</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  82</span>    <span class="k1">if</span> <span class="k2">(</span>display <span class="k3">=</span><span class="k3">=</span> NULL<span class="k2">)</span><span class="k2">{</span>
<span class="number">  83</span>        <a href="http://www.allegro.cc/manual/al_show_native_message_box"><span class="a">al_show_native_message_box</span></a><span class="k2">(</span><a href="http://www.allegro.cc/manual/al_get_current_display"><span class="a">al_get_current_display</span></a><span class="k2">(</span><span class="k2">)</span>, <span class="s">"Allegro 5 Error"</span>, <span class="s">"Error"</span>, <span class="s">"Failed to create a display."</span>, NULL, ALLEGRO_MESSAGEBOX_ERROR<span class="k2">)</span><span class="k2">;</span>
<span class="number">  84</span>        destroy_pointers<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  85</span>        <span class="k1">return</span> <span class="k3">-</span><span class="n">1</span><span class="k2">;</span>
<span class="number">  86</span>    <span class="k2">}</span>
<span class="number">  87</span>
<span class="number">  88</span>    <span class="k1">if</span> <span class="k2">(</span><span class="k3">!</span><a href="http://www.allegro.cc/manual/al_install_mouse"><span class="a">al_install_mouse</span></a><span class="k2">(</span><span class="k2">)</span><span class="k2">)</span><span class="k2">{</span>
<span class="number">  89</span>        <a href="http://www.allegro.cc/manual/al_show_native_message_box"><span class="a">al_show_native_message_box</span></a><span class="k2">(</span><a href="http://www.allegro.cc/manual/al_get_current_display"><span class="a">al_get_current_display</span></a><span class="k2">(</span><span class="k2">)</span>, <span class="s">"Allegro 5 Error"</span>, <span class="s">"Error"</span>, <span class="s">"Failed to install mouse."</span>, NULL, ALLEGRO_MESSAGEBOX_ERROR<span class="k2">)</span><span class="k2">;</span>
<span class="number">  90</span>        destroy_pointers<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  91</span>        <span class="k1">return</span> <span class="k3">-</span><span class="n">1</span><span class="k2">;</span>
<span class="number">  92</span>    <span class="k2">}</span>
<span class="number">  93</span>
<span class="number">  94</span>    <span class="k1">if</span> <span class="k2">(</span><span class="k3">!</span><a href="http://www.allegro.cc/manual/al_install_keyboard"><span class="a">al_install_keyboard</span></a><span class="k2">(</span><span class="k2">)</span><span class="k2">)</span><span class="k2">{</span>
<span class="number">  95</span>        <a href="http://www.allegro.cc/manual/al_show_native_message_box"><span class="a">al_show_native_message_box</span></a><span class="k2">(</span><a href="http://www.allegro.cc/manual/al_get_current_display"><span class="a">al_get_current_display</span></a><span class="k2">(</span><span class="k2">)</span>, <span class="s">"Allegro 5 Error"</span>, <span class="s">"Error"</span>, <span class="s">"Failed to install keyboard."</span>, NULL, ALLEGRO_MESSAGEBOX_ERROR<span class="k2">)</span><span class="k2">;</span>
<span class="number">  96</span>        destroy_pointers<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  97</span>        <span class="k1">return</span> <span class="k3">-</span><span class="n">1</span><span class="k2">;</span>
<span class="number">  98</span>    <span class="k2">}</span>
<span class="number">  99</span>
<span class="number"> 100</span>    event_queue <span class="k3">=</span> <a href="http://www.allegro.cc/manual/al_create_event_queue"><span class="a">al_create_event_queue</span></a><span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 101</span>    <span class="k1">if</span> <span class="k2">(</span>event_queue <span class="k3">=</span><span class="k3">=</span> NULL<span class="k2">)</span><span class="k2">{</span>
<span class="number"> 102</span>        <a href="http://www.allegro.cc/manual/al_show_native_message_box"><span class="a">al_show_native_message_box</span></a><span class="k2">(</span><a href="http://www.allegro.cc/manual/al_get_current_display"><span class="a">al_get_current_display</span></a><span class="k2">(</span><span class="k2">)</span>, <span class="s">"Allegro 5 Error"</span>, <span class="s">"Error"</span>, <span class="s">"Failed to create event queue."</span>, NULL, ALLEGRO_MESSAGEBOX_ERROR<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 103</span>        destroy_pointers<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 104</span>        <span class="k1">return</span> <span class="k3">-</span><span class="n">1</span><span class="k2">;</span>
<span class="number"> 105</span>    <span class="k2">}</span>
<span class="number"> 106</span>
<span class="number"> 107</span>    <a href="http://www.allegro.cc/manual/al_register_event_source"><span class="a">al_register_event_source</span></a><span class="k2">(</span>event_queue, <a href="http://www.allegro.cc/manual/al_get_display_event_source"><span class="a">al_get_display_event_source</span></a><span class="k2">(</span>display<span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 108</span>    <a href="http://www.allegro.cc/manual/al_register_event_source"><span class="a">al_register_event_source</span></a><span class="k2">(</span>event_queue, <a href="http://www.allegro.cc/manual/al_get_mouse_event_source"><span class="a">al_get_mouse_event_source</span></a><span class="k2">(</span><span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 109</span>    <a href="http://www.allegro.cc/manual/al_register_event_source"><span class="a">al_register_event_source</span></a><span class="k2">(</span>event_queue, <a href="http://www.allegro.cc/manual/al_get_keyboard_event_source"><span class="a">al_get_keyboard_event_source</span></a><span class="k2">(</span><span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 110</span>
<span class="number"> 111</span>    <span class="k1">return</span> <span class="n">0</span><span class="k2">;</span>
<span class="number"> 112</span><span class="k2">}</span>
<span class="number"> 113</span>
<span class="number"> 114</span><span class="k1">void</span> destroy_pointers<span class="k2">(</span><span class="k2">)</span><span class="k2">{</span>
<span class="number"> 115</span>    <span class="k1">if</span> <span class="k2">(</span>display <span class="k3">!</span><span class="k3">=</span> NULL<span class="k2">)</span> <a href="http://www.allegro.cc/manual/al_destroy_display"><span class="a">al_destroy_display</span></a><span class="k2">(</span>display<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 116</span>    <span class="k1">if</span> <span class="k2">(</span>event_queue <span class="k3">!</span><span class="k3">=</span> NULL<span class="k2">)</span> <a href="http://www.allegro.cc/manual/al_destroy_event_queue"><span class="a">al_destroy_event_queue</span></a><span class="k2">(</span>event_queue<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 117</span><span class="k2">}</span>
<span class="number"> 118</span>
<span class="number"> 119</span><span class="k1">void</span> exit_allegro<span class="k2">(</span><span class="k2">)</span><span class="k2">{</span>
<span class="number"> 120</span>    destroy_pointers<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 121</span><span class="k2">}</span>
<span class="number"> 122</span>
<span class="number"> 123</span>
<span class="number"> 124</span><span class="k1">void</span> events<span class="k2">(</span><a href="http://www.allegro.cc/manual/ALLEGRO_EVENT"><span class="a">ALLEGRO_EVENT</span></a> <span class="k3">&amp;</span>event, <span class="k1">bool</span> <span class="k3">&amp;</span>cycle, <span class="k1">bool</span> <span class="k3">&amp;</span>doexit<span class="k2">)</span><span class="k2">{</span>
<span class="number"> 125</span>    <a href="http://www.allegro.cc/manual/al_wait_for_event"><span class="a">al_wait_for_event</span></a><span class="k2">(</span>event_queue, <span class="k3">&amp;</span>event<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 126</span>
<span class="number"> 127</span>    <span class="k1">if</span> <span class="k2">(</span>event.type <span class="k3">=</span><span class="k3">=</span> ALLEGRO_EVENT_DISPLAY_CLOSE<span class="k2">)</span><span class="k2">{</span>
<span class="number"> 128</span>        doexit <span class="k3">=</span> <span class="k1">true</span><span class="k2">;</span>
<span class="number"> 129</span>    <span class="k2">}</span>
<span class="number"> 130</span><span class="k2">}</span>
</div></div><p>

Now, with the list container, instead of a single normal instance of the class, here it crashes:</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="p">#include &lt;allegro5/allegro.h&gt;</span>
<span class="number">   3</span><span class="p">#include &lt;allegro5/allegro_native_dialog.h&gt;</span>
<span class="number">   4</span><span class="p">#include &lt;allegro5/allegro_ttf.h&gt;</span>
<span class="number">   5</span><span class="p">#include &lt;allegro5/allegro_image.h&gt;</span>
<span class="number">   6</span><span class="p">#include &lt;list&gt;</span>
<span class="number">   7</span>
<span class="number">   8</span><a href="http://www.allegro.cc/manual/ALLEGRO_DISPLAY"><span class="a">ALLEGRO_DISPLAY</span></a> <span class="k3">*</span>display <span class="k3">=</span> NULL<span class="k2">;</span>
<span class="number">   9</span><a href="http://www.allegro.cc/manual/ALLEGRO_EVENT_QUEUE"><span class="a">ALLEGRO_EVENT_QUEUE</span></a> <span class="k3">*</span>event_queue <span class="k3">=</span> NULL<span class="k2">;</span>
<span class="number">  10</span>
<span class="number">  11</span><span class="k1">int</span> initiate_allegro<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  12</span><span class="k1">void</span> destroy_pointers<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  13</span><span class="k1">void</span> exit_allegro<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  14</span>
<span class="number">  15</span><span class="k1">void</span> events<span class="k2">(</span><a href="http://www.allegro.cc/manual/ALLEGRO_EVENT"><span class="a">ALLEGRO_EVENT</span></a> <span class="k3">&amp;</span>event, <span class="k1">bool</span> <span class="k3">&amp;</span>cycle, <span class="k1">bool</span> <span class="k3">&amp;</span>doexit<span class="k2">)</span><span class="k2">;</span>
<span class="number">  16</span>
<span class="number">  17</span><span class="k1">class</span> THING<span class="k2">{</span>
<span class="number">  18</span>private:
<span class="number">  19</span>    <a href="http://www.allegro.cc/manual/ALLEGRO_BITMAP"><span class="a">ALLEGRO_BITMAP</span></a> <span class="k3">*</span>grass<span class="k2">;</span>
<span class="number">  20</span>public:
<span class="number">  21</span>    THING<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  22</span>    ~THING<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  23</span>    <span class="k1">void</span> print<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  24</span><span class="k2">}</span><span class="k2">;</span>
<span class="number">  25</span>
<span class="number">  26</span>THING::THING<span class="k2">(</span><span class="k2">)</span><span class="k2">{</span>
<span class="number">  27</span>    grass <span class="k3">=</span> NULL<span class="k2">;</span>
<span class="number">  28</span>    grass <span class="k3">=</span> <a href="http://www.allegro.cc/manual/al_load_bitmap"><span class="a">al_load_bitmap</span></a><span class="k2">(</span><span class="s">"D:/Documents/TestBitmaps/bin/Debug/grass.bmp"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  29</span>    <span class="k1">if</span> <span class="k2">(</span>grass <span class="k3">=</span><span class="k3">=</span> NULL<span class="k2">)</span><span class="k2">{</span>
<span class="number">  30</span>        <a href="http://www.allegro.cc/manual/al_show_native_message_box"><span class="a">al_show_native_message_box</span></a><span class="k2">(</span><a href="http://www.allegro.cc/manual/al_get_current_display"><span class="a">al_get_current_display</span></a><span class="k2">(</span><span class="k2">)</span>, <span class="s">"Allegro 5 Error"</span>, <span class="s">"Error"</span>, <span class="s">"Couldn't load bitmap."</span>, NULL, ALLEGRO_MESSAGEBOX_ERROR<span class="k2">)</span><span class="k2">;</span>
<span class="number">  31</span>    <span class="k2">}</span>
<span class="number">  32</span><span class="k2">}</span>
<span class="number">  33</span>
<span class="number">  34</span>THING::~THING<span class="k2">(</span><span class="k2">)</span><span class="k2">{</span>
<span class="number">  35</span>    <span class="k1">if</span> <span class="k2">(</span>grass <span class="k3">!</span><span class="k3">=</span> NULL<span class="k2">)</span> <a href="http://www.allegro.cc/manual/al_destroy_bitmap"><span class="a">al_destroy_bitmap</span></a><span class="k2">(</span>grass<span class="k2">)</span><span class="k2">;</span>
<span class="number">  36</span><span class="k2">}</span>
<span class="number">  37</span>
<span class="number">  38</span><span class="k1">void</span> THING::print<span class="k2">(</span><span class="k2">)</span><span class="k2">{</span>
<span class="number">  39</span>    <a href="http://www.allegro.cc/manual/al_draw_bitmap"><span class="a">al_draw_bitmap</span></a><span class="k2">(</span>grass, <span class="n">100</span>, <span class="n">100</span>, <span class="n">0</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  40</span><span class="k2">}</span>
<span class="number">  41</span>
<span class="number">  42</span>
<span class="number">  43</span><span class="k1">int</span> main<span class="k2">(</span><span class="k1">int</span> argc, <span class="k1">char</span> <span class="k3">*</span><span class="k3">*</span>argv<span class="k2">)</span><span class="k2">{</span>
<span class="number">  44</span>    <span class="k1">bool</span> doexit <span class="k3">=</span> <span class="k1">false</span>, cycle <span class="k3">=</span> <span class="k1">true</span><span class="k2">;</span>
<span class="number">  45</span>
<span class="number">  46</span>    <span class="k1">if</span> <span class="k2">(</span>initiate_allegro<span class="k2">(</span><span class="k2">)</span> <span class="k3">!</span><span class="k3">=</span> <span class="n">0</span><span class="k2">)</span><span class="k2">{</span>
<span class="number">  47</span>        <a href="http://www.allegro.cc/manual/al_show_native_message_box"><span class="a">al_show_native_message_box</span></a><span class="k2">(</span><a href="http://www.allegro.cc/manual/al_get_current_display"><span class="a">al_get_current_display</span></a><span class="k2">(</span><span class="k2">)</span>, <span class="s">"Allegro 5 Error"</span>, <span class="s">"Error"</span>, <span class="s">"An error has ocurred."</span>, NULL, ALLEGRO_MESSAGEBOX_ERROR<span class="k2">)</span><span class="k2">;</span>
<span class="number">  48</span>        <span class="k1">return</span> <span class="k3">-</span><span class="n">1</span><span class="k2">;</span>
<span class="number">  49</span>    <span class="k2">}</span>
<span class="number">  50</span>
<span class="number">  51</span>    std::list<span class="k3">&lt;</span>THING&gt; thing<span class="k2">;</span>
<span class="number">  52</span>    std::list<span class="k3">&lt;</span>THING&gt;::iterator itt<span class="k2">;</span>
<span class="number">  53</span>    thing.push_back<span class="k2">(</span>THING<span class="k2">(</span><span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  54</span>
<span class="number">  55</span>    <span class="k1">while</span><span class="k2">(</span>doexit <span class="k3">=</span><span class="k3">=</span> <span class="k1">false</span><span class="k2">)</span><span class="k2">{</span>
<span class="number">  56</span>        <a href="http://www.allegro.cc/manual/ALLEGRO_EVENT"><span class="a">ALLEGRO_EVENT</span></a> event<span class="k2">;</span>
<span class="number">  57</span>        events<span class="k2">(</span>event, cycle, doexit<span class="k2">)</span><span class="k2">;</span>
<span class="number">  58</span>
<span class="number">  59</span>        <span class="k1">if</span> <span class="k2">(</span>cycle <span class="k3">=</span><span class="k3">=</span> <span class="k1">true</span> <span class="k3">&amp;</span><span class="k3">&amp;</span> <a href="http://www.allegro.cc/manual/al_is_event_queue_empty"><span class="a">al_is_event_queue_empty</span></a><span class="k2">(</span>event_queue<span class="k2">)</span> <span class="k3">=</span><span class="k3">=</span> <span class="k1">true</span><span class="k2">)</span><span class="k2">{</span>
<span class="number">  60</span>            cycle <span class="k3">=</span> <span class="k1">false</span><span class="k2">;</span>
<span class="number">  61</span>
<span class="number">  62</span>            itt <span class="k3">=</span> thing.begin<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  63</span>            <span class="k2">(</span><span class="k3">*</span>itt<span class="k2">)</span>.print<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  64</span>
<span class="number">  65</span>            <a href="http://www.allegro.cc/manual/al_flip_display"><span class="a">al_flip_display</span></a><span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  66</span>        <span class="k2">}</span>
<span class="number">  67</span>    <span class="k2">}</span>
<span class="number">  68</span>
<span class="number">  69</span>    exit_allegro<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  70</span>    <span class="k1">return</span> <span class="n">0</span><span class="k2">;</span>
<span class="number">  71</span><span class="k2">}</span>
<span class="number">  72</span>
<span class="number">  73</span>
<span class="number">  74</span><span class="k1">int</span> initiate_allegro<span class="k2">(</span><span class="k2">)</span><span class="k2">{</span>
<span class="number">  75</span>    <span class="k1">if</span> <span class="k2">(</span><span class="k3">!</span><a href="http://www.allegro.cc/manual/al_init"><span class="a">al_init</span></a><span class="k2">(</span><span class="k2">)</span><span class="k2">)</span><span class="k2">{</span>
<span class="number">  76</span>        <a href="http://www.allegro.cc/manual/al_show_native_message_box"><span class="a">al_show_native_message_box</span></a><span class="k2">(</span><a href="http://www.allegro.cc/manual/al_get_current_display"><span class="a">al_get_current_display</span></a><span class="k2">(</span><span class="k2">)</span>, <span class="s">"Allegro 5 Error"</span>, <span class="s">"Error"</span>, <span class="s">"Failed to initialize Allegro 5."</span>, NULL, ALLEGRO_MESSAGEBOX_ERROR<span class="k2">)</span><span class="k2">;</span>
<span class="number">  77</span>        destroy_pointers<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  78</span>        <span class="k1">return</span> <span class="k3">-</span><span class="n">1</span><span class="k2">;</span>
<span class="number">  79</span>    <span class="k2">}</span>
<span class="number">  80</span>
<span class="number">  81</span>    <a href="http://www.allegro.cc/manual/al_init_ttf_addon"><span class="a">al_init_ttf_addon</span></a><span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  82</span>    <a href="http://www.allegro.cc/manual/al_init_image_addon"><span class="a">al_init_image_addon</span></a><span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  83</span>
<span class="number">  84</span>    display <span class="k3">=</span> <a href="http://www.allegro.cc/manual/al_create_display"><span class="a">al_create_display</span></a><span class="k2">(</span><span class="n">1280</span>, <span class="n">720</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  85</span>    <span class="k1">if</span> <span class="k2">(</span>display <span class="k3">=</span><span class="k3">=</span> NULL<span class="k2">)</span><span class="k2">{</span>
<span class="number">  86</span>        <a href="http://www.allegro.cc/manual/al_show_native_message_box"><span class="a">al_show_native_message_box</span></a><span class="k2">(</span><a href="http://www.allegro.cc/manual/al_get_current_display"><span class="a">al_get_current_display</span></a><span class="k2">(</span><span class="k2">)</span>, <span class="s">"Allegro 5 Error"</span>, <span class="s">"Error"</span>, <span class="s">"Failed to create a display."</span>, NULL, ALLEGRO_MESSAGEBOX_ERROR<span class="k2">)</span><span class="k2">;</span>
<span class="number">  87</span>        destroy_pointers<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  88</span>        <span class="k1">return</span> <span class="k3">-</span><span class="n">1</span><span class="k2">;</span>
<span class="number">  89</span>    <span class="k2">}</span>
<span class="number">  90</span>
<span class="number">  91</span>    <span class="k1">if</span> <span class="k2">(</span><span class="k3">!</span><a href="http://www.allegro.cc/manual/al_install_mouse"><span class="a">al_install_mouse</span></a><span class="k2">(</span><span class="k2">)</span><span class="k2">)</span><span class="k2">{</span>
<span class="number">  92</span>        <a href="http://www.allegro.cc/manual/al_show_native_message_box"><span class="a">al_show_native_message_box</span></a><span class="k2">(</span><a href="http://www.allegro.cc/manual/al_get_current_display"><span class="a">al_get_current_display</span></a><span class="k2">(</span><span class="k2">)</span>, <span class="s">"Allegro 5 Error"</span>, <span class="s">"Error"</span>, <span class="s">"Failed to install mouse."</span>, NULL, ALLEGRO_MESSAGEBOX_ERROR<span class="k2">)</span><span class="k2">;</span>
<span class="number">  93</span>        destroy_pointers<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  94</span>        <span class="k1">return</span> <span class="k3">-</span><span class="n">1</span><span class="k2">;</span>
<span class="number">  95</span>    <span class="k2">}</span>
<span class="number">  96</span>
<span class="number">  97</span>    <span class="k1">if</span> <span class="k2">(</span><span class="k3">!</span><a href="http://www.allegro.cc/manual/al_install_keyboard"><span class="a">al_install_keyboard</span></a><span class="k2">(</span><span class="k2">)</span><span class="k2">)</span><span class="k2">{</span>
<span class="number">  98</span>        <a href="http://www.allegro.cc/manual/al_show_native_message_box"><span class="a">al_show_native_message_box</span></a><span class="k2">(</span><a href="http://www.allegro.cc/manual/al_get_current_display"><span class="a">al_get_current_display</span></a><span class="k2">(</span><span class="k2">)</span>, <span class="s">"Allegro 5 Error"</span>, <span class="s">"Error"</span>, <span class="s">"Failed to install keyboard."</span>, NULL, ALLEGRO_MESSAGEBOX_ERROR<span class="k2">)</span><span class="k2">;</span>
<span class="number">  99</span>        destroy_pointers<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 100</span>        <span class="k1">return</span> <span class="k3">-</span><span class="n">1</span><span class="k2">;</span>
<span class="number"> 101</span>    <span class="k2">}</span>
<span class="number"> 102</span>
<span class="number"> 103</span>    event_queue <span class="k3">=</span> <a href="http://www.allegro.cc/manual/al_create_event_queue"><span class="a">al_create_event_queue</span></a><span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 104</span>    <span class="k1">if</span> <span class="k2">(</span>event_queue <span class="k3">=</span><span class="k3">=</span> NULL<span class="k2">)</span><span class="k2">{</span>
<span class="number"> 105</span>        <a href="http://www.allegro.cc/manual/al_show_native_message_box"><span class="a">al_show_native_message_box</span></a><span class="k2">(</span><a href="http://www.allegro.cc/manual/al_get_current_display"><span class="a">al_get_current_display</span></a><span class="k2">(</span><span class="k2">)</span>, <span class="s">"Allegro 5 Error"</span>, <span class="s">"Error"</span>, <span class="s">"Failed to create event queue."</span>, NULL, ALLEGRO_MESSAGEBOX_ERROR<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 106</span>        destroy_pointers<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 107</span>        <span class="k1">return</span> <span class="k3">-</span><span class="n">1</span><span class="k2">;</span>
<span class="number"> 108</span>    <span class="k2">}</span>
<span class="number"> 109</span>
<span class="number"> 110</span>    <a href="http://www.allegro.cc/manual/al_register_event_source"><span class="a">al_register_event_source</span></a><span class="k2">(</span>event_queue, <a href="http://www.allegro.cc/manual/al_get_display_event_source"><span class="a">al_get_display_event_source</span></a><span class="k2">(</span>display<span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 111</span>    <a href="http://www.allegro.cc/manual/al_register_event_source"><span class="a">al_register_event_source</span></a><span class="k2">(</span>event_queue, <a href="http://www.allegro.cc/manual/al_get_mouse_event_source"><span class="a">al_get_mouse_event_source</span></a><span class="k2">(</span><span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 112</span>    <a href="http://www.allegro.cc/manual/al_register_event_source"><span class="a">al_register_event_source</span></a><span class="k2">(</span>event_queue, <a href="http://www.allegro.cc/manual/al_get_keyboard_event_source"><span class="a">al_get_keyboard_event_source</span></a><span class="k2">(</span><span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 113</span>
<span class="number"> 114</span>    <span class="k1">return</span> <span class="n">0</span><span class="k2">;</span>
<span class="number"> 115</span><span class="k2">}</span>
<span class="number"> 116</span>
<span class="number"> 117</span><span class="k1">void</span> destroy_pointers<span class="k2">(</span><span class="k2">)</span><span class="k2">{</span>
<span class="number"> 118</span>    <span class="k1">if</span> <span class="k2">(</span>display <span class="k3">!</span><span class="k3">=</span> NULL<span class="k2">)</span> <a href="http://www.allegro.cc/manual/al_destroy_display"><span class="a">al_destroy_display</span></a><span class="k2">(</span>display<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 119</span>    <span class="k1">if</span> <span class="k2">(</span>event_queue <span class="k3">!</span><span class="k3">=</span> NULL<span class="k2">)</span> <a href="http://www.allegro.cc/manual/al_destroy_event_queue"><span class="a">al_destroy_event_queue</span></a><span class="k2">(</span>event_queue<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 120</span><span class="k2">}</span>
<span class="number"> 121</span>
<span class="number"> 122</span><span class="k1">void</span> exit_allegro<span class="k2">(</span><span class="k2">)</span><span class="k2">{</span>
<span class="number"> 123</span>    destroy_pointers<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 124</span><span class="k2">}</span>
<span class="number"> 125</span>
<span class="number"> 126</span>
<span class="number"> 127</span><span class="k1">void</span> events<span class="k2">(</span><a href="http://www.allegro.cc/manual/ALLEGRO_EVENT"><span class="a">ALLEGRO_EVENT</span></a> <span class="k3">&amp;</span>event, <span class="k1">bool</span> <span class="k3">&amp;</span>cycle, <span class="k1">bool</span> <span class="k3">&amp;</span>doexit<span class="k2">)</span><span class="k2">{</span>
<span class="number"> 128</span>    <a href="http://www.allegro.cc/manual/al_wait_for_event"><span class="a">al_wait_for_event</span></a><span class="k2">(</span>event_queue, <span class="k3">&amp;</span>event<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 129</span>
<span class="number"> 130</span>    <span class="k1">if</span> <span class="k2">(</span>event.type <span class="k3">=</span><span class="k3">=</span> ALLEGRO_EVENT_DISPLAY_CLOSE<span class="k2">)</span><span class="k2">{</span>
<span class="number"> 131</span>        doexit <span class="k3">=</span> <span class="k1">true</span><span class="k2">;</span>
<span class="number"> 132</span>    <span class="k2">}</span>
<span class="number"> 133</span><span class="k2">}</span>
</div></div><p>

The first code gives me this result: <span class="remote-thumbnail"><span class="json">{"name":"NVos1jk.png","src":"\/\/djungxnpq2nug.cloudfront.net\/image\/cache\/d\/f\/dfe7e5f7a63eac38ec37b7080a00fcb9.png","w":1280,"h":747,"tn":"\/\/djungxnpq2nug.cloudfront.net\/image\/cache\/d\/f\/dfe7e5f7a63eac38ec37b7080a00fcb9"}</span><img src="http://www.allegro.cc//djungxnpq2nug.cloudfront.net/image/cache/d/f/dfe7e5f7a63eac38ec37b7080a00fcb9-240.jpg" alt="NVos1jk.png" width="240" height="140" /></span></p><p>But the second one just crashes almost every time. Although in one single occasion it didn&#39;t crash and the program did run, but instead of showing the grass bitmap, it showed a white square in the place it should be. I had added that line to check if it was loading:</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="k1">if</span> <span class="k2">(</span>grass <span class="k3">=</span><span class="k3">=</span> NULL<span class="k2">)</span><span class="k2">{</span>
<span class="number"> 2</span>    <a href="http://www.allegro.cc/manual/al_show_native_message_box"><span class="a">al_show_native_message_box</span></a><span class="k2">(</span><a href="http://www.allegro.cc/manual/al_get_current_display"><span class="a">al_get_current_display</span></a><span class="k2">(</span><span class="k2">)</span>, <span class="s">"Allegro 5 Error"</span>, <span class="s">"Error"</span>, <span class="s">"Couldn't load bitmap."</span>, NULL, ALLEGRO_MESSAGEBOX_ERROR<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 3</span><span class="k2">}</span>
</div></div><p>

But when the program crashes that error message doesn&#39;t show up. I can trigger that error message if I, for example, write the wrong file path in the &quot;al_load_bitmap&quot; line.</p><p>Sorry if the code is too long for the post, I tried to simplify the program to be able to include it here while still being able to reproduce the same bug.</p><p>EDIT:</p><div class="quote_container"><div class="title"><a href="http://www.allegro.cc/forums/thread/618193/1046781#target">Dizzy Egg</a> said:</div><div class="quote"><p> Shouldn&#39;t that be:</p><p><span class="source-code">thing.push_back<span class="k2">(</span><span class="k1">new</span> THING<span class="k2">(</span><span class="k2">)</span><span class="k2">)</span><span class="k2">;</span></span> </p></div></div><p>

Now... that worked, it didn&#39;t crash and it worked as it was supposed to. But I don&#39;t get it... I used to do the list containers that way before, but many people told me it was not ideal to create the elements as pointers. It shouldn&#39;t crash even if I create the elements as not-pointers, should it?</p><p>So changing these lines to this, solves it, but I don&#39;t undersand why:</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>std::list<span class="k3">&lt;</span>THING<span class="k3">*</span><span class="k3">&gt;</span> thing<span class="k2">;</span>
<span class="number"> 2</span>std::list<span class="k3">&lt;</span>THING<span class="k3">*</span><span class="k3">&gt;</span><span class="k2">:</span><span class="k2">:</span>iterator itt<span class="k2">;</span>
<span class="number"> 3</span>thing.push_back<span class="k2">(</span><span class="k1">new</span> THING<span class="k2">(</span><span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
</div></div><p>

</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>itt <span class="k3">=</span> thing.begin<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 2</span><span class="k2">(</span><span class="k3">*</span><span class="k3">*</span>itt<span class="k2">)</span>.print<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
</div></div><p>

But regardless of why it worked, thank you a lot!!
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Xinomorph)</author>
		<pubDate>Tue, 21 Jul 2020 22:30:33 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Thing is static. When you put in a list. You are adding a copy. </p><p>Now you have multiple copies with multiple pointers to one object. </p><p>Which one destroys the bitmap? When is the bitmap destroyed? </p><p>In the internals, the destructor might be called for anyone of them. Freeing the internal memory for the bitmap, but you still might have other thing objects with pointers to it.</p><p>When you create a list of thing pointers, you are only adding one object. The destructor will be called any number of times, but the internal memory is not freed.</p><p>EDIT ****************<br />In your original code, add a print statement (to file if needeD) to the constructor and another to the destructor. See how many times they are called.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (DanielH)</author>
		<pubDate>Tue, 21 Jul 2020 22:55:26 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>If you don&#39;t want to use pointers, or the new keyword, you still have to create the objects before adding them to the list. Saying:</p><div class="source-code snippet"><div class="inner"><pre>thing.push_back<span class="k2">(</span>THING<span class="k2">(</span><span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
</pre></div></div><p>

doesn&#39;t make much sense. That&#39;s like saying &quot;add a constructor call to my list&quot;.</p><p>So you could say:</p><div class="source-code snippet"><div class="inner"><pre>THING thing_1<span class="k2">;</span> <span class="c">//Calls THING() automatically</span>
THING thing_2<span class="k2">;</span>
THING thing_3<span class="k2">;</span>
</pre></div></div><p>

and then say:</p><div class="source-code snippet"><div class="inner"><pre>thing.push_back<span class="k2">(</span>thing_1<span class="k2">)</span><span class="k2">;</span>
thing.push_back<span class="k2">(</span>thing_2<span class="k2">)</span><span class="k2">;</span>
thing.push_back<span class="k2">(</span>thing_3<span class="k2">)</span><span class="k2">;</span>
</pre></div></div><p>

but IMHO that defeats the point of the list (very subjective I guess). Much neater to say:</p><div class="source-code snippet"><div class="inner"><pre><span class="k1">for</span><span class="k2">(</span>however many things I want<span class="k2">)</span>
<span class="k2">{</span>
    thing.push_back<span class="k2">(</span><span class="k1">new</span> thing<span class="k2">(</span><span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
<span class="k2">}</span>
</pre></div></div><p>

and then loop through the list to render the tiles or whatever.<br />That&#39;s my thoughts anyway.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Dizzy Egg)</author>
		<pubDate>Tue, 21 Jul 2020 23:16:29 +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/618193/1046783#target">DanielH</a> said:</div><div class="quote"><p>
Thing is static. When you put in a list. You are adding a copy.</p><p>Now you have multiple copies with multiple pointers to one object.</p><p>Which one destroys the bitmap? When is the bitmap destroyed?</p><p>In the internals, the destructor might be called for anyone of them. Freeing the internal memory for the bitmap, but you still might have other thing objects with pointers to it.</p><p>When you create a list of thing pointers, you are only adding one object. The destructor will be called any number of times, but the internal memory is not freed.</p><p>EDIT ****************<br />In your original code, add a print statement (to file if needeD) to the constructor and another to the destructor. See how many times they are called.
</p></div></div><p>

Thanks, I now understand. I was ignorant about the difference between declaring a list element as a pointer, and declaring it as a static element. I thought the list container already created the nodes for the objects as pointers, and that declaring it as a pointer myself would be redundant, like two pointers nested. I see I was wrong now.</p><p>BTW, I did what you suggested to check how many times the constructor and destructor were called in my original code (the second one I posted, the one with the list but without pointers); and you are right, the destructor was being called once, even before the main loop of the program started. The constructor I declared in my code was only called once, so I assume the copy constructor is being called, and then the destructor is also being called when the element created by the copy constructor disappears.</p><div class="quote_container"><div class="title"><a href="http://www.allegro.cc/forums/thread/618193/1046784#target">Dizzy Egg</a> said:</div><div class="quote"><p>

If you don&#39;t want to use pointers, or the new keyword, you still have to create the objects before adding them to the list. Saying:</p><div class="source-code snippet"><div class="inner"><pre>thing.push_back<span class="k2">(</span>THING<span class="k2">(</span><span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
</pre></div></div><p>
doesn&#39;t make much sense. That&#39;s like saying &quot;add a constructor call to my list&quot;.</p><p>So you could say:</p><div class="source-code snippet"><div class="inner"><pre>THING thing_1<span class="k2">;</span> <span class="c">//Calls THING() automatically</span>
THING thing_2<span class="k2">;</span>
THING thing_3<span class="k2">;</span>
</pre></div></div><p>
and then say:
</p><div class="source-code snippet"><div class="inner"><pre>thing.push_back<span class="k2">(</span>thing_1<span class="k2">)</span><span class="k2">;</span>
thing.push_back<span class="k2">(</span>thing_2<span class="k2">)</span><span class="k2">;</span>
thing.push_back<span class="k2">(</span>thing_3<span class="k2">)</span><span class="k2">;</span>
</pre></div></div><p>
but IMHO that defeats the point of the list (very subjective I guess). Much neater to say:
</p><div class="source-code snippet"><div class="inner"><pre><span class="k1">for</span><span class="k2">(</span>however many things I want<span class="k2">)</span>
<span class="k2">{</span>
    thing.push_back<span class="k2">(</span><span class="k1">new</span> thing<span class="k2">(</span><span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
<span class="k2">}</span>
</pre></div></div><p>
and then loop through the list to render the tiles or whatever.<br />That&#39;s my thoughts anyway.</p></div></div><p>

No, I think you are right, declaring a different list for every element kinda defeats the purpose of the list. I don&#39;t have any problem with declaring the list elements as pointers, in fact I&#39;ll do that now! It&#39;s just that I didn&#39;t know it was necessary, now I see the difference!</p><p>Thank you both!! I was trapped in this bug for 2 days!
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Xinomorph)</author>
		<pubDate>Tue, 21 Jul 2020 23:46:53 +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/618193/1046784#target">Dizzy Egg</a> said:</div><div class="quote"><p>
thing.push_back(THING());</p><p>doesn&#39;t make much sense. That&#39;s like saying &quot;add a constructor call to my list&quot;.
</p></div></div><p>

It does make sense. It is constructing a temporary <span class="source-code">THING</span>, adding a copy of it to the list, and then destroying the temporary.</p><p>As DanielH said above, the problem is that copying a <span class="source-code">THING</span> just makes a simple copy of the <span class="source-code">grass</span> member, so when the temporary is destroyed, the copy inside the list still has a pointer to a bitmap that has been destroyed.</p><p>Your choices are to use pointers: <span class="source-code">list<span class="k3">&lt;</span>THING<span class="k3">*</span><span class="k3">&gt;</span></span> and <span class="source-code">push_back<span class="k2">(</span><span class="k1">new</span> THING<span class="k2">)</span></span><br />or<br />implement the copy constructor for <span class="source-code">THING</span> so it makes a true copy (which would involve <span class="source-code"><a href="http://www.allegro.cc/manual/al_clone_bitmap"><span class="a">al_clone_bitmap</span></a></span> I suppose.)</p><p>The first one would be more straightforward.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Peter Hull)</author>
		<pubDate>Wed, 22 Jul 2020 00:35:09 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>You could also use <span class="source-code">emplace_back</span> to construct the object in-place, avoiding the pointless copy.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (torhu)</author>
		<pubDate>Wed, 22 Jul 2020 00:50:16 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>A somewhat better design is to offload the loading/managing/destroying of resources (in this case, a bitmap from a file on disk) to a special &quot;resource manager&quot; object or class. That way instead of your <span class="source-code">THING</span> knowing about files and loading bitmaps it just knows about the resource manager and can ask for a resource from it by path or name (and type?); either by passing a pointer or reference to the resource manager to the <span class="source-code">THING</span> constructor, or by the resource manager being a static class and therefore global.</p><p>You can also wrap the pointers to objects that Allegro gives you in smart pointers (e.g., <span class="source-code">std::shared_ptr<span class="k3">&lt;</span><span class="k3">&gt;</span></span> or <span class="source-code">boost::shared_ptr<span class="k3">&lt;</span><span class="k3">&gt;</span></span>) with the destructor function specified so that your copies of the pointers will all be tracked, and the resource won&#39;t actually be freed until it&#39;s no longer being referenced anyway.</p><div class="source-code snippet"><div class="inner"><pre>std::shared_ptr<span class="k3">&lt;</span>ALLEGRO_BITMAP&gt; grass<span class="k2">(</span><a href="http://www.allegro.cc/manual/al_load_bitmap"><span class="a">al_load_bitmap</span></a><span class="k2">(</span>...<span class="k2">)</span>, <a href="http://www.allegro.cc/manual/al_destroy_bitmap"><span class="a">al_destroy_bitmap</span></a><span class="k2">)</span><span class="k2">;</span>
</pre></div></div><p>
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (bamccaig)</author>
		<pubDate>Wed, 22 Jul 2020 01:02:44 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>For more information, google shallow and deep copies, pass by value, and pass by reference.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Edgar Reynaldo)</author>
		<pubDate>Wed, 22 Jul 2020 01:20:56 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Just remember that clearing a list will not delete the memory. You must delete each object. Then clear the list.</p><div class="source-code snippet"><div class="inner"><pre>std::list<span class="k3">&lt;</span>THING<span class="k3">*</span><span class="k3">&gt;</span> tlist<span class="k2">;</span>

tlist.push_back<span class="k2">(</span><span class="k1">new</span> THING<span class="k2">(</span><span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
tlist.push_back<span class="k2">(</span><span class="k1">new</span> THING<span class="k2">(</span><span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
tlist.push_back<span class="k2">(</span><span class="k1">new</span> THING<span class="k2">(</span><span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>

<span class="k1">for</span><span class="k2">(</span>std::list<span class="k3">&lt;</span>THING<span class="k3">*</span><span class="k3">&gt;</span><span class="k2">:</span><span class="k2">:</span>const_iterator it <span class="k3">=</span> tlist.begin<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span> it <span class="k3">!</span><span class="k3">=</span> tlist.end<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span> <span class="k3">+</span><span class="k3">+</span>it<span class="k2">)</span>
<span class="k2">{</span>
    <span class="k1">delete</span> <span class="k3">*</span>it<span class="k2">;</span>
<span class="k2">}</span> 
tlist.clear<span class="k2">(</span><span class="k2">)</span>
</pre></div></div><p>
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (DanielH)</author>
		<pubDate>Wed, 22 Jul 2020 02:22:03 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>...or use smart pointers and it <b>will</b> automatically delete the memory when it&#39;s no longer used. <img src="http://www.allegro.cc/forums/smileys/wink.gif" alt=";)" />
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (bamccaig)</author>
		<pubDate>Wed, 22 Jul 2020 02:25:25 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Yes, use smart pointers</p><p>You can use your original code if you used smart pointers</p><p>smart pointers keep a tally of how many copies point to an object and won&#39;t delete the object until the last destructor is called.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (DanielH)</author>
		<pubDate>Wed, 22 Jul 2020 02:28:19 +0000</pubDate>
	</item>
</rss>
