<?xml version="1.0"?>
<rss version="2.0">
	<channel>
		<title>Drawing a level</title>
		<link>http://www.allegro.cc/forums/view/607045</link>
		<description>Allegro.cc Forum Thread</description>
		<webMaster>matthew@allegro.cc (Matthew Leverton)</webMaster>
		<lastBuildDate>Fri, 22 Apr 2011 05:08:18 +0000</lastBuildDate>
	</channel>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Hello everybody. For my game I&#39;m trying to create a load_level function which loads a config file from disk to get all of the parameters for drawing the level. The problem is I have is in the level struct, where I have a int **, in order to hold the order of tiles to be drawn. The level struct looks like this:</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="p">#include &lt;stdio.h&gt;</span>
<span class="number">  2</span><span class="p">#include &lt;stdlib.h&gt;</span>
<span class="number">  3</span><span class="p">#include &lt;string.h&gt;</span>
<span class="number">  4</span><span class="p">#include &lt;allegro5/allegro.h&gt;</span>
<span class="number">  5</span>
<span class="number">  6</span><span class="p">#include "player.h"</span>
<span class="number">  7</span>
<span class="number">  8</span><span class="k1">typedef</span> <span class="k1">struct</span> level
<span class="number">  9</span><span class="k2">{</span>
<span class="number"> 10</span>  <span class="k1">int</span> size_x<span class="k2">;</span>
<span class="number"> 11</span>  <span class="k1">int</span> size_y<span class="k2">;</span>
<span class="number"> 12</span>  <span class="k1">float</span> start_x<span class="k2">;</span>
<span class="number"> 13</span>  <span class="k1">float</span> start_y<span class="k2">;</span>
<span class="number"> 14</span>  <span class="k1">int</span> tilesize<span class="k2">;</span>
<span class="number"> 15</span>  <span class="k1">int</span> <span class="k3">*</span><span class="k3">*</span>tilemap<span class="k2">;</span>
<span class="number"> 16</span>  <a href="http://www.allegro.cc/manual/ALLEGRO_BITMAP"><span class="a">ALLEGRO_BITMAP</span></a> <span class="k3">*</span>tile_file<span class="k2">;</span>
<span class="number"> 17</span><span class="k2">}</span> level<span class="k2">;</span>
<span class="number"> 18</span>
<span class="number"> 19</span><span class="k1">extern</span> level <span class="k3">*</span>load_level<span class="k2">(</span><span class="k1">int</span> world_num, <span class="k1">int</span> level_num<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 20</span><span class="k1">extern</span> <span class="k1">void</span> destroy_level<span class="k2">(</span>level <span class="k3">*</span>my_level<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 21</span><span class="k1">extern</span> <span class="k1">void</span> setup_level<span class="k2">(</span>level <span class="k3">*</span>my_level, player <span class="k3">*</span>my_player<span class="k2">)</span><span class="k2">;</span>
</div></div><p>

The problem is in the load level function, where I try to assign the values from the config file to int **tilemap</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>level <span class="k3">*</span>load_level<span class="k2">(</span><span class="k1">int</span> world_num, <span class="k1">int</span> level_num<span class="k2">)</span>
<span class="number">  2</span><span class="k2">{</span>
<span class="number">  3</span>  <a href="http://www.allegro.cc/manual/ALLEGRO_CONFIG"><span class="a">ALLEGRO_CONFIG</span></a> <span class="k3">*</span>level_file<span class="k2">;</span>
<span class="number">  4</span>  level hard_level<span class="k2">;</span>
<span class="number">  5</span>  level <span class="k3">*</span>tmp_level<span class="k2">;</span>
<span class="number">  6</span>  tmp_level <span class="k3">=</span> <span class="k3">&amp;</span>hard_level<span class="k2">;</span>
<span class="number">  7</span>  <span class="k1">const</span> <span class="k1">char</span> <span class="k3">*</span>tile_file_name<span class="k2">;</span>    <span class="c">// for the tiles.bmp level.tile_file 31</span>
<span class="number">  8</span>  <span class="k1">char</span> level_file_name<span class="k2">[</span><span class="n">27</span><span class="k2">]</span><span class="k2">;</span>    <span class="c">// worldxx-levelyy.cfg 27</span>
<span class="number">  9</span>  
<span class="number"> 10</span>  <span class="c">// Get all of the data from the level cfg file</span>
<span class="number"> 11</span>  <a href="http://www.delorie.com/djgpp/doc/libc/libc_737.html" target="_blank">sprintf</a><span class="k2">(</span>level_file_name, <span class="s">"levels/world%02d-level%02d.cfg"</span>, world_num, level_num<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 12</span>  level_file <span class="k3">=</span> <a href="http://www.allegro.cc/manual/al_load_config_file"><span class="a">al_load_config_file</span></a><span class="k2">(</span>level_file_name<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 13</span>  tmp_level-&gt;size_x <span class="k3">=</span> <a href="http://www.delorie.com/djgpp/doc/libc/libc_54.html" target="_blank">atoi</a><span class="k2">(</span><a href="http://www.allegro.cc/manual/al_get_config_value"><span class="a">al_get_config_value</span></a><span class="k2">(</span>level_file, NULL, <span class="s">"size_x"</span><span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 14</span>  tmp_level-&gt;size_y <span class="k3">=</span> <a href="http://www.delorie.com/djgpp/doc/libc/libc_54.html" target="_blank">atoi</a><span class="k2">(</span><a href="http://www.allegro.cc/manual/al_get_config_value"><span class="a">al_get_config_value</span></a><span class="k2">(</span>level_file, NULL, <span class="s">"size_y"</span><span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 15</span>  tmp_level-&gt;start_x <span class="k3">=</span> <span class="k2">(</span><span class="k1">float</span><span class="k2">)</span> <a href="http://www.delorie.com/djgpp/doc/libc/libc_53.html" target="_blank">atof</a><span class="k2">(</span><a href="http://www.allegro.cc/manual/al_get_config_value"><span class="a">al_get_config_value</span></a><span class="k2">(</span>level_file, NULL, <span class="s">"start_x"</span><span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 16</span>  tmp_level-&gt;start_y <span class="k3">=</span> <span class="k2">(</span><span class="k1">float</span><span class="k2">)</span> <a href="http://www.delorie.com/djgpp/doc/libc/libc_53.html" target="_blank">atof</a><span class="k2">(</span><a href="http://www.allegro.cc/manual/al_get_config_value"><span class="a">al_get_config_value</span></a><span class="k2">(</span>level_file, NULL, <span class="s">"start_y"</span><span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 17</span>  tmp_level-&gt;tilesize <span class="k3">=</span> <a href="http://www.delorie.com/djgpp/doc/libc/libc_54.html" target="_blank">atoi</a><span class="k2">(</span><a href="http://www.allegro.cc/manual/al_get_config_value"><span class="a">al_get_config_value</span></a><span class="k2">(</span>level_file, NULL, <span class="s">"tilesize"</span><span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 18</span>  
<span class="number"> 19</span>  <span class="c">// Get the tile file loaded into the level struct</span>
<span class="number"> 20</span>  tile_file_name <span class="k3">=</span> <a href="http://www.allegro.cc/manual/al_get_config_value"><span class="a">al_get_config_value</span></a><span class="k2">(</span>level_file, NULL, <span class="s">"tile_file"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 21</span>  tmp_level-&gt;tile_file <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>tile_file_name<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 22</span>
<span class="number"> 23</span>  
<span class="number"> 24</span>  <span class="c">// Create the tilemap array</span>
<span class="number"> 25</span>  tmp_level-&gt;tilemap <span class="k3">=</span> <a href="http://www.delorie.com/djgpp/doc/libc/libc_551.html" target="_blank">malloc</a><span class="k2">(</span>tmp_level-&gt;size_y <span class="k3">*</span> <span class="k1">sizeof</span><span class="k2">(</span><span class="k1">int</span> <span class="k3">*</span><span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 26</span>  <span class="k1">if</span><span class="k2">(</span>tmp_level-&gt;tilemap <span class="k3">=</span><span class="k3">=</span> NULL<span class="k2">)</span>
<span class="number"> 27</span>  <span class="k2">{</span>
<span class="number"> 28</span>    <a href="http://www.delorie.com/djgpp/doc/libc/libc_345.html" target="_blank">fprintf</a><span class="k2">(</span>stderr, <span class="s">"Out of memory for the pointer-pointer-int in the level struct!\n"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 29</span>    <span class="k1">return</span> NULL<span class="k2">;</span>
<span class="number"> 30</span>  <span class="k2">}</span>
<span class="number"> 31</span>  <span class="k1">int</span> i<span class="k2">;</span>
<span class="number"> 32</span>  <span class="k1">for</span><span class="k2">(</span>i <span class="k3">=</span> <span class="n">0</span><span class="k2">;</span> i <span class="k3">&lt;</span> tmp_level-&gt;size_y<span class="k2">;</span> i<span class="k3">+</span><span class="k3">+</span><span class="k2">)</span>
<span class="number"> 33</span>  <span class="k2">{</span>
<span class="number"> 34</span>    tmp_level-&gt;tilemap<span class="k2">[</span>i<span class="k2">]</span> <span class="k3">=</span> <a href="http://www.delorie.com/djgpp/doc/libc/libc_551.html" target="_blank">malloc</a><span class="k2">(</span>tmp_level-&gt;size_x <span class="k3">*</span> <span class="k1">sizeof</span><span class="k2">(</span><span class="k1">int</span><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>tmp_level-&gt;tilemap<span class="k2">[</span>i<span class="k2">]</span> <span class="k3">=</span><span class="k3">=</span> NULL<span class="k2">)</span>
<span class="number"> 36</span>    <span class="k2">{</span>
<span class="number"> 37</span>      <a href="http://www.delorie.com/djgpp/doc/libc/libc_345.html" target="_blank">fprintf</a><span class="k2">(</span>stderr, <span class="s">"Out of memory for the **intergers in the level struct!\n"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 38</span>      <span class="k1">return</span> NULL<span class="k2">;</span>
<span class="number"> 39</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="c">// Get the tilemap data from the cfg file</span>
<span class="number"> 43</span>  <span class="k1">char</span> <span class="k3">*</span>result <span class="k3">=</span> NULL<span class="k2">;</span>
<span class="number"> 44</span>  <span class="k1">const</span> <span class="k1">char</span> <span class="k3">*</span>tilemap_data<span class="k2">;</span>
<span class="number"> 45</span>  tilemap_data <span class="k3">=</span> <a href="http://www.allegro.cc/manual/al_get_config_value"><span class="a">al_get_config_value</span></a><span class="k2">(</span>level_file, NULL, <span class="s">"map_data"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 46</span>  result <span class="k3">=</span> <a href="http://www.delorie.com/djgpp/doc/libc/libc_779.html" target="_blank">strtok</a><span class="k2">(</span><span class="k2">(</span><span class="k1">char</span> <span class="k3">*</span><span class="k2">)</span>tilemap_data, <span class="s">","</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 47</span>  <span class="k1">int</span> x <span class="k3">=</span> <span class="n">0</span><span class="k2">;</span>
<span class="number"> 48</span>  <span class="k1">int</span> y <span class="k3">=</span> <span class="n">0</span><span class="k2">;</span>
<span class="number"> 49</span>
<span class="number"> 50</span>  <span class="k1">while</span> <span class="k2">(</span>result <span class="k3">!</span><span class="k3">=</span> NULL<span class="k2">)</span>
<span class="number"> 51</span>  <span class="k2">{</span>
<span class="number"> 52</span>    hard_level.tilemap<span class="k2">[</span>y<span class="k2">]</span><span class="k2">[</span>x<span class="k2">]</span> <span class="k3">=</span> <a href="http://www.delorie.com/djgpp/doc/libc/libc_54.html" target="_blank">atoi</a><span class="k2">(</span>result<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 53</span>    <span class="k1">while</span><span class="k2">(</span>x <span class="k3">&lt;</span> tmp_level-&gt;size_x<span class="k2">)</span>
<span class="number"> 54</span>    <span class="k2">{</span>
<span class="number"> 55</span>      hard_level.tilemap<span class="k2">[</span>y<span class="k2">]</span><span class="k2">[</span>x<span class="k2">]</span> <span class="k3">=</span> <a href="http://www.delorie.com/djgpp/doc/libc/libc_54.html" target="_blank">atoi</a><span class="k2">(</span>result<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 56</span>      result <span class="k3">=</span> <a href="http://www.delorie.com/djgpp/doc/libc/libc_779.html" target="_blank">strtok</a><span class="k2">(</span>NULL, <span class="s">","</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 57</span>      x<span class="k3">+</span><span class="k3">+</span><span class="k2">;</span>
<span class="number"> 58</span>    <span class="k2">}</span>
<span class="number"> 59</span>    x <span class="k3">=</span> <span class="n">0</span><span class="k2">;</span>
<span class="number"> 60</span>    result <span class="k3">=</span> <a href="http://www.delorie.com/djgpp/doc/libc/libc_779.html" target="_blank">strtok</a><span class="k2">(</span>NULL, <span class="s">","</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 61</span>    y<span class="k3">+</span><span class="k3">+</span><span class="k2">;</span>
<span class="number"> 62</span>  <span class="k2">}</span>
<span class="number"> 63</span>  <a href="http://www.delorie.com/djgpp/doc/libc/libc_345.html" target="_blank">fprintf</a><span class="k2">(</span>stderr, <span class="s">"done the strtok loop\n"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 64</span>  
<span class="number"> 65</span>  <span class="c">// See if the pointer was filled correctly</span>
<span class="number"> 66</span>        <span class="k1">int</span> b, c<span class="k2">;</span>
<span class="number"> 67</span>  <span class="k1">for</span><span class="k2">(</span>b <span class="k3">=</span> <span class="n">0</span><span class="k2">;</span> b <span class="k3">&lt;</span> tmp_level-&gt;size_y<span class="k2">;</span> b<span class="k3">+</span><span class="k3">+</span><span class="k2">)</span>
<span class="number"> 68</span>  <span class="k2">{</span>
<span class="number"> 69</span>    <span class="k1">for</span><span class="k2">(</span>c <span class="k3">=</span> <span class="n">0</span><span class="k2">;</span> c <span class="k3">&lt;</span> tmp_level-&gt;size_x<span class="k2">;</span> c<span class="k3">+</span><span class="k3">+</span><span class="k2">)</span>
<span class="number"> 70</span>      <a href="http://www.delorie.com/djgpp/doc/libc/libc_345.html" target="_blank">fprintf</a><span class="k2">(</span>stderr, <span class="s">"%i,"</span>, tmp_level-&gt;tilemap<span class="k2">[</span>b<span class="k2">]</span><span class="k2">[</span>c<span class="k2">]</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 71</span>  <span class="k2">}</span>
<span class="number"> 72</span>  
<span class="number"> 73</span>  <a href="http://www.allegro.cc/manual/al_destroy_config"><span class="a">al_destroy_config</span></a><span class="k2">(</span>level_file<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 74</span>  <a href="http://www.delorie.com/djgpp/doc/libc/libc_345.html" target="_blank">fprintf</a><span class="k2">(</span>stderr, <span class="s">"~~CREATE LEVEL - DONE~~\n"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 75</span>  <span class="k1">return</span> tmp_level<span class="k2">;</span>
<span class="number"> 76</span><span class="k2">}</span>
</div></div><p>

Inside the function, getting the values from a_level-&gt;tilemap[y][x] returns the expected values. Outside the function, a_level-&gt;tilemap[y][x] returns garbage values and crashes the program.</p><p>The config file that I am using looks like this:
</p><div class="source-code snippet"><div class="inner"><pre>size_x <span class="k3">=</span> <span class="n">20</span>
size_y <span class="k3">=</span> <span class="n">15</span>
start_x <span class="k3">=</span> <span class="n">32</span>.<span class="n">0</span>
start_y <span class="k3">=</span> <span class="n">416</span>.<span class="n">0</span>
tilesize <span class="k3">=</span> <span class="n">32</span>
tile_file <span class="k3">=</span> tiles<span class="k3">/</span>tiles.bmp
map_data <span class="k3">=</span> <span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">3</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">3</span>,<span class="n">1</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">3</span>,<span class="n">3</span>,<span class="n">3</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">2</span>,<span class="n">3</span>,<span class="n">1</span>,<span class="n">0</span>,<span class="n">3</span>,<span class="n">3</span>,<span class="n">3</span>,<span class="n">3</span>,<span class="n">3</span>,<span class="n">3</span>,<span class="n">1</span>,<span class="n">1</span>,<span class="n">1</span>,<span class="n">3</span>,<span class="n">3</span>,<span class="n">3</span>,<span class="n">3</span>,<span class="n">3</span>,<span class="n">3</span>,<span class="n">3</span>,<span class="n">3</span>,<span class="n">1</span>,<span class="n">0</span>,<span class="n">0</span>,<span class="n">1</span>,<span class="n">1</span>,<span class="n">1</span>,<span class="n">1</span>,<span class="n">1</span>,<span class="n">1</span>,<span class="n">0</span>,<span class="n">0</span>,<span class="n">0</span>,<span class="n">1</span>,<span class="n">1</span>,<span class="n">1</span>,<span class="n">1</span>,<span class="n">1</span>,<span class="n">1</span>,<span class="n">1</span>,<span class="n">1</span>,<span class="n">0</span>,<span class="n">0</span>,<span class="n">0</span>
</pre></div></div><p>

How would I need to change my code in order to access the **tilemap pointer and get correct values?
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (octotep)</author>
		<pubDate>Mon, 18 Apr 2011 06:27:42 +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/607045/913587#target">octotep</a> said:</div><div class="quote"><p>
</p><div class="source-code snippet"><div class="inner"><pre>  level hard_level<span class="k2">;</span>
  level <span class="k3">*</span>tmp_level<span class="k2">;</span>
<div class="highlight">  tmp_level <span class="k3">=</span> <span class="k3">&amp;</span>hard_level<span class="k2">;</span></div>
<span class="c">//...</span>
  <span class="k1">return</span> tmp_level<span class="k2">;</span>
</pre></div></div><p>
</p></div></div><p>

You are returning the address of a temporary level object. As soon as load_level returns &#39;hard_level&#39; is no longer a valid object. You have to create a new &#39;level&#39; using malloc. It crashes because the area in memory where &#39;hard_level&#39; was has most likely been overwritten or else it causes a segfault.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Edgar Reynaldo)</author>
		<pubDate>Mon, 18 Apr 2011 08:23:31 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Ok, I think I see what the problem is now, but I have one more question. <br />I now have:<br /><span class="source-code">level <span class="k3">*</span>tmp_level <span class="k3">=</span> <a href="http://www.delorie.com/djgpp/doc/libc/libc_551.html" target="_blank">malloc</a><span class="k2">(</span><span class="k1">sizeof</span><span class="k2">(</span>level<span class="k2">)</span><span class="k2">)</span><span class="k2">;</span></span><br />instead of<br /><span class="source-code">level <span class="k3">*</span>tmp_level<span class="k2">;</span></span><br />but the program gives the error:<br />&quot;request for member &#39;tilemap&#39; in something not a structure or a union&quot;, so I don&#39;t think what I did was right. </p><p>Could you point me in the right direction as to what I need to do to malloc() the level?</p><p>Thanks
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (octotep)</author>
		<pubDate>Tue, 19 Apr 2011 04:50:47 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Since you&#39;re now dealing with a pointer to a struct instead of a struct itself, you&#39;re using the wrong member access operator - &quot;<span class="source-code">.</span>&quot; instead of &quot;<span class="source-code"><span class="k3">-</span><span class="k3">&gt;</span></span>&quot;.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (gnolam)</author>
		<pubDate>Tue, 19 Apr 2011 05:23:01 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Hrm... I fixed that, but now my main loop always crashes when I try to access the tilemap (even though I allocate memory for that and the level struct pointer), while I can access the other values of the level struct just fine.</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">// In main, before the loop checking for events and after initializing</span>
<span class="number">  2</span>        <span class="c">// everything</span>
<span class="number">  3</span>        level <span class="k3">*</span>first_level<span class="k2">;</span>
<span class="number">  4</span>  first_level <span class="k3">=</span> load_level<span class="k2">(</span>current_world, current_level<span class="k2">)</span><span class="k2">;</span>
<span class="number">  5</span>  <span class="k1">if</span><span class="k2">(</span><span class="k3">!</span>first_level<span class="k2">)</span>
<span class="number">  6</span>  <span class="k2">{</span>
<span class="number">  7</span>    <a href="http://www.delorie.com/djgpp/doc/libc/libc_345.html" target="_blank">fprintf</a><span class="k2">(</span>stderr, <span class="s">"Couldnt create the level!\n"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  8</span>                <span class="c">// shutdown everything</span>
<span class="number">  9</span>    <span class="k1">return</span> <span class="k3">-</span><span class="n">1</span><span class="k2">;</span>
<span class="number"> 10</span>  <span class="k2">}</span>
<span class="number"> 11</span>  <a href="http://www.delorie.com/djgpp/doc/libc/libc_345.html" target="_blank">fprintf</a><span class="k2">(</span>stderr, <span class="s">"Back to main\n"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 12</span>  player <span class="k3">*</span>player<span class="k2">;</span>
<span class="number"> 13</span>  player <span class="k3">=</span> create_player<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 14</span>  <span class="k1">if</span><span class="k2">(</span><span class="k3">!</span>player<span class="k2">)</span>
<span class="number"> 15</span>  <span class="k2">{</span>
<span class="number"> 16</span>    <a href="http://www.delorie.com/djgpp/doc/libc/libc_345.html" target="_blank">fprintf</a><span class="k2">(</span>stderr, <span class="s">"Couldnt create the player!\n"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 17</span>                <span class="c">// shutdown everything</span>
<span class="number"> 18</span>    <span class="k1">return</span> <span class="k3">-</span><span class="n">1</span><span class="k2">;</span>
<span class="number"> 19</span>  <span class="k2">}</span>
<span class="number"> 20</span>  <a href="http://www.delorie.com/djgpp/doc/libc/libc_345.html" target="_blank">fprintf</a><span class="k2">(</span>stderr, <span class="s">"Back to main2\n"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 21</span>  <a href="http://www.allegro.cc/manual/al_set_new_bitmap_flags"><span class="a">al_set_new_bitmap_flags</span></a><span class="k2">(</span><span class="n">0</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 22</span>  <a href="http://www.delorie.com/djgpp/doc/libc/libc_624.html" target="_blank">printf</a><span class="k2">(</span><span class="s">"Set the flag"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 23</span>  <span class="k1">int</span> level_x <span class="k3">=</span> <a href="http://www.allegro.cc/manual/SCREEN_W"><span class="a">SCREEN_W</span></a> <span class="k3">+</span> <span class="k2">(</span><span class="n">2</span> <span class="k3">*</span> first_level-&gt;tilesize<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 24</span>  <span class="k1">int</span> level_y <span class="k3">=</span> <a href="http://www.allegro.cc/manual/SCREEN_H"><span class="a">SCREEN_H</span></a> <span class="k3">+</span> <span class="k2">(</span><span class="n">2</span> <span class="k3">*</span> first_level-&gt;tilesize<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 25</span>  level_bitmap <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>level_x, level_y<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 26</span>  <span class="k1">if</span><span class="k2">(</span><span class="k3">!</span>level_bitmap<span class="k2">)</span>
<span class="number"> 27</span>  <span class="k2">{</span>
<span class="number"> 28</span>    <a href="http://www.delorie.com/djgpp/doc/libc/libc_345.html" target="_blank">fprintf</a><span class="k2">(</span>stderr, <span class="s">"Couldn't create the level bitmap!\n"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 29</span>                <span class="c">// shutdown everything</span>
<span class="number"> 30</span>    <span class="k1">return</span> <span class="k3">-</span><span class="n">1</span><span class="k2">;</span>
<span class="number"> 31</span>  <span class="k2">}</span>
<span class="number"> 32</span>  
<span class="number"> 33</span>  <span class="c">//crashes right here </span>
<span class="number"> 34</span>        <span class="k1">int</span> b, c<span class="k2">;</span>
<span class="number"> 35</span>  <span class="k1">for</span><span class="k2">(</span>b <span class="k3">=</span> <span class="n">0</span><span class="k2">;</span> b <span class="k3">&lt;</span> first_level-&gt;size_y<span class="k2">;</span> b<span class="k3">+</span><span class="k3">+</span><span class="k2">)</span>
<span class="number"> 36</span>  <span class="k2">{</span>
<span class="number"> 37</span>    <span class="k1">for</span><span class="k2">(</span>c <span class="k3">=</span> <span class="n">0</span><span class="k2">;</span> c <span class="k3">&lt;</span> first_level-&gt;size_x<span class="k2">;</span> c<span class="k3">+</span><span class="k3">+</span><span class="k2">)</span>
<span class="number"> 38</span>                        <a href="http://www.delorie.com/djgpp/doc/libc/libc_345.html" target="_blank">fprintf</a><span class="k2">(</span>stderr, <span class="s">"%i,"</span>, first_level-&gt;tilemap<span class="k2">[</span>b<span class="k2">]</span><span class="k2">[</span>c<span class="k2">]</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 39</span>  <span class="k2">}</span>
</div></div><p>

I feel bad for asking so many questions, because I feel that there&#39;s just one really stupid thing I&#39;m missing... <img src="http://www.allegro.cc/forums/smileys/huh.gif" alt="???" />
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (octotep)</author>
		<pubDate>Wed, 20 Apr 2011 03:41:44 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Post your latest load_level function. Either level-&gt;size_y or level-&gt;size_x is wrong, or you are not allocating level-&gt;tilemap correctly.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Edgar Reynaldo)</author>
		<pubDate>Wed, 20 Apr 2011 06:47:15 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Here it is:
</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>level <span class="k3">*</span>load_level<span class="k2">(</span><span class="k1">int</span> world_num, <span class="k1">int</span> level_num<span class="k2">)</span>
<span class="number">  2</span><span class="k2">{</span>
<span class="number">  3</span>  <a href="http://www.allegro.cc/manual/ALLEGRO_CONFIG"><span class="a">ALLEGRO_CONFIG</span></a> <span class="k3">*</span>level_file<span class="k2">;</span>
<span class="number">  4</span>  level <span class="k3">*</span>tmp_level <span class="k3">=</span> <a href="http://www.delorie.com/djgpp/doc/libc/libc_551.html" target="_blank">malloc</a><span class="k2">(</span><span class="k1">sizeof</span><span class="k2">(</span>level <span class="k3">*</span><span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  5</span>  <span class="k1">if</span><span class="k2">(</span>tmp_level <span class="k3">=</span><span class="k3">=</span> NULL<span class="k2">)</span>
<span class="number">  6</span>  <span class="k2">{</span>
<span class="number">  7</span>    <a href="http://www.delorie.com/djgpp/doc/libc/libc_345.html" target="_blank">fprintf</a><span class="k2">(</span>stderr, <span class="s">"Out of memory for the level struct!\n"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  8</span>    <span class="k1">return</span> NULL<span class="k2">;</span>
<span class="number">  9</span>  <span class="k2">}</span>
<span class="number"> 10</span>  <a href="http://www.delorie.com/djgpp/doc/libc/libc_624.html" target="_blank">printf</a><span class="k2">(</span><span class="s">"Break here!\n"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 11</span>  
<span class="number"> 12</span>  <span class="k1">const</span> <span class="k1">char</span> <span class="k3">*</span>tile_file_name<span class="k2">;</span>    <span class="c">// for the tiles.bmp level.tile_file 31</span>
<span class="number"> 13</span>  <span class="k1">char</span> level_file_name<span class="k2">[</span><span class="n">27</span><span class="k2">]</span><span class="k2">;</span>    <span class="c">// worldxx-levelyy.cfg 27</span>
<span class="number"> 14</span>  
<span class="number"> 15</span>  <span class="c">// Get all of the data from the level cfg file</span>
<span class="number"> 16</span>  <a href="http://www.delorie.com/djgpp/doc/libc/libc_737.html" target="_blank">sprintf</a><span class="k2">(</span>level_file_name, <span class="s">"levels/world%02d-level%02d.cfg"</span>, world_num, level_num<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 17</span>  level_file <span class="k3">=</span> <a href="http://www.allegro.cc/manual/al_load_config_file"><span class="a">al_load_config_file</span></a><span class="k2">(</span>level_file_name<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 18</span>  tmp_level-&gt;size_x <span class="k3">=</span> <a href="http://www.delorie.com/djgpp/doc/libc/libc_54.html" target="_blank">atoi</a><span class="k2">(</span><a href="http://www.allegro.cc/manual/al_get_config_value"><span class="a">al_get_config_value</span></a><span class="k2">(</span>level_file, NULL, <span class="s">"size_x"</span><span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 19</span>  tmp_level-&gt;size_y <span class="k3">=</span> <a href="http://www.delorie.com/djgpp/doc/libc/libc_54.html" target="_blank">atoi</a><span class="k2">(</span><a href="http://www.allegro.cc/manual/al_get_config_value"><span class="a">al_get_config_value</span></a><span class="k2">(</span>level_file, NULL, <span class="s">"size_y"</span><span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 20</span>  tmp_level-&gt;start_x <span class="k3">=</span> <span class="k2">(</span><span class="k1">float</span><span class="k2">)</span> <a href="http://www.delorie.com/djgpp/doc/libc/libc_53.html" target="_blank">atof</a><span class="k2">(</span><a href="http://www.allegro.cc/manual/al_get_config_value"><span class="a">al_get_config_value</span></a><span class="k2">(</span>level_file, NULL, <span class="s">"start_x"</span><span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 21</span>  tmp_level-&gt;start_y <span class="k3">=</span> <span class="k2">(</span><span class="k1">float</span><span class="k2">)</span> <a href="http://www.delorie.com/djgpp/doc/libc/libc_53.html" target="_blank">atof</a><span class="k2">(</span><a href="http://www.allegro.cc/manual/al_get_config_value"><span class="a">al_get_config_value</span></a><span class="k2">(</span>level_file, NULL, <span class="s">"start_y"</span><span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 22</span>  <span class="c">//without this, I can't access tilesize from outside this function...</span>
<span class="number"> 23</span>  tmp_level-&gt;tilesize <span class="k3">=</span> <span class="k2">(</span><span class="k1">int</span><span class="k2">)</span> <a href="http://www.delorie.com/djgpp/doc/libc/libc_551.html" target="_blank">malloc</a><span class="k2">(</span><span class="k1">sizeof</span><span class="k2">(</span><span class="k1">int</span><span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 24</span>  tmp_level-&gt;tilesize <span class="k3">=</span> <span class="k2">(</span><span class="k1">int</span><span class="k2">)</span> <a href="http://www.delorie.com/djgpp/doc/libc/libc_54.html" target="_blank">atoi</a><span class="k2">(</span><a href="http://www.allegro.cc/manual/al_get_config_value"><span class="a">al_get_config_value</span></a><span class="k2">(</span>level_file, NULL, <span class="s">"tile_size"</span><span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 25</span>  
<span class="number"> 26</span>  <span class="c">// Get the tile file loaded into the level struct</span>
<span class="number"> 27</span>  tile_file_name <span class="k3">=</span> <a href="http://www.allegro.cc/manual/al_get_config_value"><span class="a">al_get_config_value</span></a><span class="k2">(</span>level_file, NULL, <span class="s">"tile_file"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 28</span>  tmp_level-&gt;tile_file <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>tile_file_name<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 29</span>  <span class="k1">if</span><span class="k2">(</span><span class="k3">!</span>tmp_level-&gt;tile_file<span class="k2">)</span>
<span class="number"> 30</span>  <span class="k2">{</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">"TILE FILE NOT LOADED!\n"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 32</span>    <span class="k1">return</span> NULL<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="number"> 36</span>  <span class="c">// Create the tilemap array</span>
<span class="number"> 37</span>  tmp_level-&gt;tilemap <span class="k3">=</span> <a href="http://www.delorie.com/djgpp/doc/libc/libc_551.html" target="_blank">malloc</a><span class="k2">(</span>tmp_level-&gt;size_y <span class="k3">*</span> <span class="k1">sizeof</span><span class="k2">(</span><span class="k1">int</span> <span class="k3">*</span><span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 38</span>  <span class="k1">if</span><span class="k2">(</span>tmp_level-&gt;tilemap <span class="k3">=</span><span class="k3">=</span> NULL<span class="k2">)</span>
<span class="number"> 39</span>  <span class="k2">{</span>
<span class="number"> 40</span>    <a href="http://www.delorie.com/djgpp/doc/libc/libc_345.html" target="_blank">fprintf</a><span class="k2">(</span>stderr, <span class="s">"Out of memory for the pointer-pointer-int in the level struct!\n"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 41</span>    <span class="k1">return</span> NULL<span class="k2">;</span>
<span class="number"> 42</span>  <span class="k2">}</span>
<span class="number"> 43</span>  <span class="k1">int</span> i<span class="k2">;</span>
<span class="number"> 44</span>  <span class="k1">for</span><span class="k2">(</span>i <span class="k3">=</span> <span class="n">0</span><span class="k2">;</span> i <span class="k3">&lt;</span> tmp_level-&gt;size_y<span class="k2">;</span> i<span class="k3">+</span><span class="k3">+</span><span class="k2">)</span>
<span class="number"> 45</span>  <span class="k2">{</span>
<span class="number"> 46</span>    tmp_level-&gt;tilemap<span class="k2">[</span>i<span class="k2">]</span> <span class="k3">=</span> <a href="http://www.delorie.com/djgpp/doc/libc/libc_551.html" target="_blank">malloc</a><span class="k2">(</span>tmp_level-&gt;size_x <span class="k3">*</span> <span class="k1">sizeof</span><span class="k2">(</span><span class="k1">int</span><span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 47</span>    <span class="k1">if</span><span class="k2">(</span>tmp_level-&gt;tilemap<span class="k2">[</span>i<span class="k2">]</span> <span class="k3">=</span><span class="k3">=</span> NULL<span class="k2">)</span>
<span class="number"> 48</span>    <span class="k2">{</span>
<span class="number"> 49</span>      <a href="http://www.delorie.com/djgpp/doc/libc/libc_345.html" target="_blank">fprintf</a><span class="k2">(</span>stderr, <span class="s">"Out of memory for the **intergers in the level struct!\n"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 50</span>      <span class="k1">return</span> NULL<span class="k2">;</span>
<span class="number"> 51</span>    <span class="k2">}</span>
<span class="number"> 52</span>  <span class="k2">}</span>
<span class="number"> 53</span>
<span class="number"> 54</span>  
<span class="number"> 55</span>  <span class="c">// Get the tilemap data from the cfg file</span>
<span class="number"> 56</span>  <span class="k1">char</span> <span class="k3">*</span>result <span class="k3">=</span> NULL<span class="k2">;</span>
<span class="number"> 57</span>  <span class="k1">const</span> <span class="k1">char</span> <span class="k3">*</span>tilemap_data<span class="k2">;</span>
<span class="number"> 58</span>  tilemap_data <span class="k3">=</span> <a href="http://www.allegro.cc/manual/al_get_config_value"><span class="a">al_get_config_value</span></a><span class="k2">(</span>level_file, NULL, <span class="s">"map_data"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 59</span>  result <span class="k3">=</span> <a href="http://www.delorie.com/djgpp/doc/libc/libc_779.html" target="_blank">strtok</a><span class="k2">(</span><span class="k2">(</span><span class="k1">char</span> <span class="k3">*</span><span class="k2">)</span>tilemap_data, <span class="s">","</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 60</span>  <span class="k1">int</span> x <span class="k3">=</span> <span class="n">0</span><span class="k2">;</span>
<span class="number"> 61</span>  <span class="k1">int</span> y <span class="k3">=</span> <span class="n">0</span><span class="k2">;</span>
<span class="number"> 62</span>
<span class="number"> 63</span>  <span class="k1">while</span> <span class="k2">(</span>result <span class="k3">!</span><span class="k3">=</span> NULL<span class="k2">)</span>
<span class="number"> 64</span>  <span class="k2">{</span>
<span class="number"> 65</span>    tmp_level-&gt;tilemap<span class="k2">[</span>y<span class="k2">]</span><span class="k2">[</span>x<span class="k2">]</span> <span class="k3">=</span> <a href="http://www.delorie.com/djgpp/doc/libc/libc_54.html" target="_blank">atoi</a><span class="k2">(</span>result<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 66</span>    <span class="k1">while</span><span class="k2">(</span>x <span class="k3">&lt;</span> tmp_level-&gt;size_x<span class="k2">)</span>
<span class="number"> 67</span>    <span class="k2">{</span>
<span class="number"> 68</span>      tmp_level-&gt;tilemap<span class="k2">[</span>y<span class="k2">]</span><span class="k2">[</span>x<span class="k2">]</span> <span class="k3">=</span> <a href="http://www.delorie.com/djgpp/doc/libc/libc_54.html" target="_blank">atoi</a><span class="k2">(</span>result<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 69</span>      result <span class="k3">=</span> <a href="http://www.delorie.com/djgpp/doc/libc/libc_779.html" target="_blank">strtok</a><span class="k2">(</span>NULL, <span class="s">","</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 70</span>      x<span class="k3">+</span><span class="k3">+</span><span class="k2">;</span>
<span class="number"> 71</span>    <span class="k2">}</span>
<span class="number"> 72</span>    x <span class="k3">=</span> <span class="n">0</span><span class="k2">;</span>
<span class="number"> 73</span>    result <span class="k3">=</span> <a href="http://www.delorie.com/djgpp/doc/libc/libc_779.html" target="_blank">strtok</a><span class="k2">(</span>NULL, <span class="s">","</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 74</span>    y<span class="k3">+</span><span class="k3">+</span><span class="k2">;</span>
<span class="number"> 75</span>  <span class="k2">}</span>
<span class="number"> 76</span>  
<span class="number"> 77</span>  <span class="k1">int</span> b, c<span class="k2">;</span>
<span class="number"> 78</span>  <span class="k1">for</span><span class="k2">(</span>b <span class="k3">=</span> <span class="n">0</span><span class="k2">;</span> b <span class="k3">&lt;</span> tmp_level-&gt;size_y<span class="k2">;</span> b<span class="k3">+</span><span class="k3">+</span><span class="k2">)</span>
<span class="number"> 79</span>  <span class="k2">{</span>
<span class="number"> 80</span>    <span class="k1">for</span><span class="k2">(</span>c <span class="k3">=</span> <span class="n">0</span><span class="k2">;</span> c <span class="k3">&lt;</span> tmp_level-&gt;size_x<span class="k2">;</span> c<span class="k3">+</span><span class="k3">+</span><span class="k2">)</span>
<span class="number"> 81</span>      <a href="http://www.delorie.com/djgpp/doc/libc/libc_345.html" target="_blank">fprintf</a><span class="k2">(</span>stderr, <span class="s">"%i,"</span>, tmp_level-&gt;tilemap<span class="k2">[</span>b<span class="k2">]</span><span class="k2">[</span>c<span class="k2">]</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 82</span>  <span class="k2">}</span>
<span class="number"> 83</span>  
<span class="number"> 84</span>  <a href="http://www.allegro.cc/manual/al_destroy_config"><span class="a">al_destroy_config</span></a><span class="k2">(</span>level_file<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 85</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\n"</span>, tmp_level-&gt;tilesize<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 86</span>  <a href="http://www.delorie.com/djgpp/doc/libc/libc_345.html" target="_blank">fprintf</a><span class="k2">(</span>stderr, <span class="s">"~~CREATE LEVEL - DONE~~\n"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 87</span>  <span class="k1">return</span> tmp_level<span class="k2">;</span>
<span class="number"> 88</span><span class="k2">}</span>
</div></div><p>
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (octotep)</author>
		<pubDate>Wed, 20 Apr 2011 07:22:17 +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/607045/913693#target">octotep</a> said:</div><div class="quote"><p>
</p><div class="source-code snippet"><div class="inner"><pre><div class="highlight">  level <span class="k3">*</span>tmp_level <span class="k3">=</span> <a href="http://www.delorie.com/djgpp/doc/libc/libc_551.html" target="_blank">malloc</a><span class="k2">(</span><span class="k1">sizeof</span><span class="k2">(</span>level <span class="k3">*</span><span class="k2">)</span><span class="k2">)</span><span class="k2">;</span></div>
</pre></div></div><p>
</p></div></div><p>
That should be <span class="source-code">level<span class="k3">*</span> tmp_level <span class="k3">=</span> <a href="http://www.delorie.com/djgpp/doc/libc/libc_551.html" target="_blank">malloc</a><span class="k2">(</span><span class="k1">sizeof</span><span class="k2">(</span>level<span class="k2">)</span><span class="k2">)</span><span class="k2">;</span></span>, like you had it before. You&#39;re only allocating enough memory to hold a pointer.</p><div class="quote_container"><div class="title"><a href="http://www.allegro.cc/forums/thread/607045/913804#target">octotep</a> said:</div><div class="quote"><p>
</p><div class="source-code snippet"><div class="inner"><pre>  <span class="c">//without this, I can't access tilesize from outside this function...</span>
<span class="c">//  tmp_level-&gt;tilesize = (int) malloc(sizeof(int));</span>
  tmp_level-&gt;tilesize <span class="k3">=</span> <a href="http://www.delorie.com/djgpp/doc/libc/libc_54.html" target="_blank">atoi</a><span class="k2">(</span><a href="http://www.allegro.cc/manual/al_get_config_value"><span class="a">al_get_config_value</span></a><span class="k2">(</span>level_file, NULL, <span class="s">"tile_size"</span><span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
</pre></div></div><p>
</p></div></div><p>
The line I commented out (the second one) is not good C. You allocate an integer&#39;s worth of memory and then cast that address to an integer - it&#39;s value would likely be huge, and totally incorrect. The third line there is correct.</p><div class="quote_container"><div class="title">octotep said:</div><div class="quote"><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>  tilemap_data <span class="k3">=</span> <a href="http://www.allegro.cc/manual/al_get_config_value"><span class="a">al_get_config_value</span></a><span class="k2">(</span>level_file, NULL, <span class="s">"map_data"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  2</span>  result <span class="k3">=</span> <a href="http://www.delorie.com/djgpp/doc/libc/libc_779.html" target="_blank">strtok</a><span class="k2">(</span><span class="k2">(</span><span class="k1">char</span> <span class="k3">*</span><span class="k2">)</span>tilemap_data, <span class="s">","</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  3</span>  <span class="k1">int</span> x <span class="k3">=</span> <span class="n">0</span><span class="k2">;</span>
<span class="number">  4</span>  <span class="k1">int</span> y <span class="k3">=</span> <span class="n">0</span><span class="k2">;</span>
<span class="number">  5</span>
<span class="number">  6</span>  <span class="k1">while</span> <span class="k2">(</span>result <span class="k3">!</span><span class="k3">=</span> NULL<span class="k2">)</span>
<span class="number">  7</span>  <span class="k2">{</span>
<span class="number">  8</span><span class="c">//    tmp_level-&gt;tilemap[y][x] = atoi(result);// this is not necessary</span>
<span class="number">  9</span>    <span class="k1">while</span><span class="k2">(</span>x <span class="k3">&lt;</span> tmp_level-&gt;size_x<span class="k2">)</span>
<span class="number"> 10</span>    <span class="k2">{</span>
<span class="number"> 11</span>      tmp_level-&gt;tilemap<span class="k2">[</span>y<span class="k2">]</span><span class="k2">[</span>x<span class="k2">]</span> <span class="k3">=</span> <a href="http://www.delorie.com/djgpp/doc/libc/libc_54.html" target="_blank">atoi</a><span class="k2">(</span>result<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 12</span>      result <span class="k3">=</span> <a href="http://www.delorie.com/djgpp/doc/libc/libc_779.html" target="_blank">strtok</a><span class="k2">(</span>NULL, <span class="s">","</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 13</span>      x<span class="k3">+</span><span class="k3">+</span><span class="k2">;</span>
<span class="number"> 14</span>    <span class="k2">}</span>
<span class="number"> 15</span>    x <span class="k3">=</span> <span class="n">0</span><span class="k2">;</span>
<span class="number"> 16</span><span class="c">//    result = strtok(NULL, ",");// You're skipping a token here</span>
<span class="number"> 17</span>    y<span class="k3">+</span><span class="k3">+</span><span class="k2">;</span>
<span class="number"> 18</span>  <span class="k2">}</span>
</div></div><p>
</p></div></div><p>
I commented out two lines - the first commented line is unnecessary and is overwritten by your second assignment, and the second commented line is a mistake, because it would skip one of your values.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Edgar Reynaldo)</author>
		<pubDate>Wed, 20 Apr 2011 08:44:19 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Thank you, it works perfectly! <img src="http://www.allegro.cc/forums/smileys/cheesy.gif" alt=":D" />
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (octotep)</author>
		<pubDate>Thu, 21 Apr 2011 07:02:32 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Glad to hear it. Got a screenshot you could show us?
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Edgar Reynaldo)</author>
		<pubDate>Thu, 21 Apr 2011 08:08:51 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Here&#39;s one. Unfortunately I&#39;m not the best artist, so all I have right now is a stick figure for testing purposes. <img src="http://www.allegro.cc/forums/smileys/grin.gif" alt=";D" /><br /><span class="remote-thumbnail"><span class="json">{"name":"screenshot.jpg","src":"\/\/djungxnpq2nug.cloudfront.net\/image\/cache\/0\/6\/069bfb2e47ac9abeeb5ce934152edd50.jpg","w":646,"h":512,"tn":"\/\/djungxnpq2nug.cloudfront.net\/image\/cache\/0\/6\/069bfb2e47ac9abeeb5ce934152edd50"}</span><img src="http://www.allegro.cc//djungxnpq2nug.cloudfront.net/image/cache/0/6/069bfb2e47ac9abeeb5ce934152edd50-240.jpg" alt="screenshot.jpg" width="240" height="190" /></span>
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (octotep)</author>
		<pubDate>Thu, 21 Apr 2011 20:30:20 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Well, your basic ground tile looks good. It blends perfectly with the tiles next to it.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Edgar Reynaldo)</author>
		<pubDate>Fri, 22 Apr 2011 05:08:18 +0000</pubDate>
	</item>
</rss>
