<?xml version="1.0"?>
<rss version="2.0">
	<channel>
		<title>[A5] Memory Leak - al_fopen_interface</title>
		<link>http://www.allegro.cc/forums/view/611133</link>
		<description>Allegro.cc Forum Thread</description>
		<webMaster>matthew@allegro.cc (Matthew Leverton)</webMaster>
		<lastBuildDate>Wed, 26 Sep 2012 04:52:08 +0000</lastBuildDate>
	</channel>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>I&#39;m doing some memory leak analysis on my iOS device and so far so good, with the exception of a leak reported from al_fopen_interface (3 times during an 8 minute test run of my app.)</p><p>Seems like a pretty simple routine. Not sure whats leaking here?<br />Very confused.  </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"> 16</span><a href="http://www.allegro.cc/manual/ALLEGRO_FILE"><span class="a">ALLEGRO_FILE</span></a> <span class="k3">*</span><a href="http://www.allegro.cc/manual/al_fopen_interface"><span class="a">al_fopen_interface</span></a><span class="k2">(</span><span class="k1">const</span> <a href="http://www.allegro.cc/manual/ALLEGRO_FILE_INTERFACE"><span class="a">ALLEGRO_FILE_INTERFACE</span></a> <span class="k3">*</span>drv,
<span class="number"> 17</span>   <span class="k1">const</span> <span class="k1">char</span> <span class="k3">*</span>path, <span class="k1">const</span> <span class="k1">char</span> <span class="k3">*</span>mode<span class="k2">)</span>
<span class="number"> 18</span><span class="k2">{</span> 
<span class="number"> 19</span>   <a href="http://www.allegro.cc/manual/ALLEGRO_FILE"><span class="a">ALLEGRO_FILE</span></a> <span class="k3">*</span>f <span class="k3">=</span> NULL<span class="k2">;</span>
<span class="number"> 20</span>   
<span class="number"> 21</span>   <a href="http://www.allegro.cc/manual/ASSERT"><span class="a">ASSERT</span></a><span class="k2">(</span>drv<span class="k2">)</span><span class="k2">;</span>  
<span class="number"> 22</span>   <a href="http://www.allegro.cc/manual/ASSERT"><span class="a">ASSERT</span></a><span class="k2">(</span>path<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 23</span>   <a href="http://www.allegro.cc/manual/ASSERT"><span class="a">ASSERT</span></a><span class="k2">(</span>mode<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 24</span>   
<span class="number"> 25</span>   <span class="k1">if</span> <span class="k2">(</span>drv-&gt;fi_fopen<span class="k2">)</span> <span class="k2">{</span>
<span class="number"> 26</span>      f <span class="k3">=</span> <a href="http://www.allegro.cc/manual/al_malloc"><span class="a">al_malloc</span></a><span class="k2">(</span><span class="k1">sizeof</span><span class="k2">(</span><span class="k3">*</span>f<span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 27</span>      <span class="k1">if</span> <span class="k2">(</span><span class="k3">!</span>f<span class="k2">)</span> <span class="k2">{</span>
<span class="number"> 28</span>         <a href="http://www.allegro.cc/manual/al_set_errno"><span class="a">al_set_errno</span></a><span class="k2">(</span>ENOMEM<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 29</span>      <span class="k2">}</span>
<span class="number"> 30</span>      <span class="k1">else</span> <span class="k2">{</span>
<span class="number"> 31</span>         f-&gt;vtable <span class="k3">=</span> drv<span class="k2">;</span>
<span class="number"> 32</span>         f-&gt;userdata <span class="k3">=</span> drv-&gt;fi_fopen<span class="k2">(</span>path, mode<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 33</span>         f-&gt;ungetc_len <span class="k3">=</span> <span class="n">0</span><span class="k2">;</span>
<span class="number"> 34</span>         <span class="k1">if</span> <span class="k2">(</span><span class="k3">!</span>f-&gt;userdata<span class="k2">)</span> <span class="k2">{</span>
<span class="number"> 35</span>            <a href="http://www.allegro.cc/manual/al_free"><span class="a">al_free</span></a><span class="k2">(</span>f<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 36</span>            f <span class="k3">=</span> NULL<span class="k2">;</span>
<span class="number"> 37</span>         <span class="k2">}</span>
<span class="number"> 38</span>      <span class="k2">}</span>
<span class="number"> 39</span>   <span class="k2">}</span>
<span class="number"> 40</span>   
<span class="number"> 41</span>   <span class="k1">return</span> f<span class="k2">;</span>
<span class="number"> 42</span><span class="k2">}</span>
</div></div><p>


Am I not cleaning up the returned ALLEGRO_FILE object afterwards?  Does al_fclose() not cleanup the object?</p><p>Would rather not have any leaks if submitting to AppStore... I&#39;ve heard they can be pretty particular...
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (thebignic)</author>
		<pubDate>Wed, 26 Sep 2012 04:14:57 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Memory leaks reported by the &quot;Leaks&quot; tool in instruments (and anything else really, like valgrind) report the source of the allocated memory, not where the &quot;leak occurred&quot; which would probably when the last reference to allocated memory is lost. The routine looks ok to me. If you&#39;re sure you&#39;re calling al_fclose on ALL handles returned from this then the leak may be in drv-&gt;fi_fopen in your implementation.</p><p>EDIT: it could also be your fclose implementation or somewhere else in your interface.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Trent Gamblin)</author>
		<pubDate>Wed, 26 Sep 2012 04:52:08 +0000</pubDate>
	</item>
</rss>
