<?xml version="1.0"?>
<rss version="2.0">
	<channel>
		<title>A5 compiled fine, but can&#39;t compile against the library</title>
		<link>http://www.allegro.cc/forums/view/616488</link>
		<description>Allegro.cc Forum Thread</description>
		<webMaster>matthew@allegro.cc (Matthew Leverton)</webMaster>
		<lastBuildDate>Wed, 21 Sep 2016 09:16:22 +0000</lastBuildDate>
	</channel>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>I compiled Allegro 5 using MinGW with no problems. I was even able to compile projects fine. Then today I updated stdlib.h and wchar.h in order to make MinGW compile without error when passing -std=c++11. Oddly enough, after updating those two files and recompiling the simple display code: 
</p><div class="source-code"><div class="toolbar"><span class="button numbers"><b>#</b></span><span class="button select">Select</span><span class="button expand">Expand</span></div><div class="inner"><span class="number">  1</span><span class="p">#include &lt;stdio.h&gt;</span>
<span class="number">  2</span><span class="p">#include &lt;allegro5/allegro.h&gt;</span>
<span class="number">  3</span> 
<span class="number">  4</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">  5</span> 
<span class="number">  6</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">  7</span> 
<span class="number">  8</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">  9</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">"failed to initialize allegro!\n"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 10</span>      <span class="k1">return</span> <span class="k3">-</span><span class="n">1</span><span class="k2">;</span>
<span class="number"> 11</span>   <span class="k2">}</span>
<span class="number"> 12</span> 
<span class="number"> 13</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">640</span>, <span class="n">480</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>display<span class="k2">)</span> <span class="k2">{</span>
<span class="number"> 15</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">"failed to create display!\n"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 16</span>      <span class="k1">return</span> <span class="k3">-</span><span class="n">1</span><span class="k2">;</span>
<span class="number"> 17</span>   <span class="k2">}</span>
<span class="number"> 18</span> 
<span class="number"> 19</span>   <a href="http://www.allegro.cc/manual/al_clear_to_color"><span class="a">al_clear_to_color</span></a><span class="k2">(</span><a href="http://www.allegro.cc/manual/al_map_rgb"><span class="a">al_map_rgb</span></a><span class="k2">(</span><span class="n">0</span>,<span class="n">0</span>,<span class="n">0</span><span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 20</span> 
<span class="number"> 21</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"> 22</span> 
<span class="number"> 23</span>   <a href="http://www.allegro.cc/manual/al_rest"><span class="a">al_rest</span></a><span class="k2">(</span><span class="n">10</span>.<span class="n">0</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 24</span> 
<span class="number"> 25</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"> 26</span> 
<span class="number"> 27</span>   <span class="k1">return</span> <span class="n">0</span><span class="k2">;</span>
<span class="number"> 28</span><span class="k2">}</span>
</div></div><p>
I get 5 errors: 
</p><div class="quote_container"><div class="title">Quote:</div><div class="quote"><p>
c:\mingw\include\allegro5\file.h|34|error: expected identifier before &#39;*&#39; token|<br />c:\mingw\include\allegro5\file.h|34|error: &#39;off_t&#39; declared as function returning a function|<br />c:\mingw\include\allegro5\fshook.h|75|error: expected identifier before &#39;*&#39; token|<br />c:\mingw\include\allegro5\fshook.h|75|error: &#39;off_t&#39; declared as function returning a function|<br />c:\mingw\include\allegro5\fshook.h|101|error: &#39;off_t&#39; does not name a type|
</p></div></div><p>
The lines in question:<br />file.h line 34:
</p><div class="source-code snippet"><div class="inner"><pre>AL_METHOD<span class="k2">(</span>off_t,   fi_fsize, <span class="k2">(</span><a href="http://www.allegro.cc/manual/ALLEGRO_FILE"><span class="a">ALLEGRO_FILE</span></a> <span class="k3">*</span>f<span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
</pre></div></div><p>
fshook.h line 75
</p><div class="source-code snippet"><div class="inner"><pre>AL_METHOD<span class="k2">(</span>off_t,           fs_entry_size,       <span class="k2">(</span><a href="http://www.allegro.cc/manual/ALLEGRO_FS_ENTRY"><span class="a">ALLEGRO_FS_ENTRY</span></a> <span class="k3">*</span>e<span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
</pre></div></div><p>
fshook.h line 101
</p><div class="source-code snippet"><div class="inner"><pre>AL_FUNC<span class="k2">(</span>off_t,                <a href="http://www.allegro.cc/manual/al_get_fs_entry_size"><span class="a">al_get_fs_entry_size</span></a>,<span class="k2">(</span><a href="http://www.allegro.cc/manual/ALLEGRO_FS_ENTRY"><span class="a">ALLEGRO_FS_ENTRY</span></a> <span class="k3">*</span>e<span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
</pre></div></div><p>
Don&#39;t understand why it worked before and now I get these errors. The last one makes no sense since both files have <span class="source-code"><span class="k1">typedef</span> <span class="k1">unsigned</span> <span class="k1">int</span> off_t<span class="k2">;</span></span>.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Specter Phoenix)</author>
		<pubDate>Mon, 19 Sep 2016 10:00:06 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>This kind of reminds me when I tried to compile some C++11 code using a cross-compiler and produced a similar error. I fixed it by passing -std=gnu++11 instead.</p><p>Maybe I&#39;m kind of misunderstanding but, have you tried passing -std=gnu++11 instead of the other?
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (EliasYFGM)</author>
		<pubDate>Mon, 19 Sep 2016 15:32:56 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Yeah, it compiles fine with -std=gnu++11, but you have to be careful as it loads extensions that aren&#39;t part of the standard so if you use them your code may not compile under another compiler. Making it work with -std=c++11 gives me a side project to do though.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Specter Phoenix)</author>
		<pubDate>Tue, 20 Sep 2016 00:00:39 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>For reference I&#39;m looking at MinGW gcc and stdlib c++ 5.3.0 with mingwrt 3.21.1. I&#39;m also assuming you&#39;re talking about the stdlib.h and the wchar.h from the MinGW users mailing list.</p><p>Did you try recompiling Allegro? And see if it still worked after your updates?</p><p>Why don&#39;t you look at the updated stdlib.h and wchar.h and see what changed? The diff program will tell you exactly what is different.</p><p>wchar.h includes sys/types.h. Both versions. wchar.h is never included by Allegro.</p><p>stdio.h includes sys/types.h as well (which you included in your program)</p><p>sys/types.h defines _off_t and off_t on lines 54 and 57.
</p><div class="source-code"><div class="toolbar"><span class="name">sys/types.h</span><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"> 52</span><span class="p">#ifndef  _OFF_T_</span>
<span class="number"> 53</span><span class="p">#define  _OFF_T_</span>
<span class="number"> 54</span><span class="k1">typedef</span> <span class="k1">long</span> _off_t<span class="k2">;</span>
<span class="number"> 55</span>
<span class="number"> 56</span><span class="p">#ifndef  _NO_OLDNAMES</span>
<span class="number"> 57</span><span class="k1">typedef</span> _off_t  off_t<span class="k2">;</span>
<span class="number"> 58</span><span class="p">#endif</span>
<span class="number"> 59</span><span class="p">#endif  /* Not _OFF_T_ */</span>
</div></div><p>

_NO_OLDNAMES is probably defined when -std=c++11, but I couldn&#39;t say for sure. Which would mean that off_t is undefined.</p><p>And in allegro/include/allegro5/file.h we have :
</p><div class="source-code"><div class="toolbar"><span class="name">allegro/include/allegro5/file.h</span><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"> 4</span><span class="p">#include "allegro5/base.h"</span>
</div></div><p>

And in allegro/include/allegro5/base.h we have :
</p><div class="source-code"><div class="toolbar"><span class="name">allegro/include/allegro5/base.h</span><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"> 22</span><span class="p">#ifndef ALLEGRO_NO_STD_HEADERS</span>
<span class="number"> 23</span>   <span class="p">#include &lt;errno.h&gt;</span>
<span class="number"> 24</span>   <span class="p">#ifdef _MSC_VER</span>
<span class="number"> 25</span>      <span class="c">/* enable posix for limits.h and only limits.h</span>
<span class="number"> 26</span><span class="c">         enabling it for all msvc headers will potentially</span>
<span class="number"> 27</span><span class="c">       disable a lot of commonly used msvcrt functions */</span>
<span class="number"> 28</span>      <span class="p">#define _POSIX_</span>
<span class="number"> 29</span>      <span class="p">#include &lt;limits.h&gt;</span>
<span class="number"> 30</span>      <span class="p">#undef _POSIX_</span>
<span class="number"> 31</span>   <span class="p">#else</span>
<span class="number"> 32</span>      <span class="p">#include &lt;limits.h&gt;</span>
<span class="number"> 33</span>   <span class="p">#endif</span>
<span class="number"> 34</span>   <span class="p">#include &lt;stdarg.h&gt;</span>
<span class="number"> 35</span>   <span class="p">#include &lt;stddef.h&gt;</span>
<span class="number"> 36</span>   <span class="p">#include &lt;stdlib.h&gt;</span>
<span class="number"> 37</span>   <span class="p">#include &lt;time.h&gt;</span>
<span class="number"> 38</span>   <span class="p">#include &lt;string.h&gt;</span>
<span class="number"> 39</span>   <span class="p">#include &lt;sys/types.h&gt;</span>
<span class="number"> 40</span><span class="p">#endif</span>
</div></div><p>

So if standard headers are included (#ifndef ALLEGRO_NO_STD_HEADERS) we have sys/types.h included, but it doesn&#39;t define off_t in the case of _NO_OLDNAMES, so file.h won&#39;t compile.</p><p>In the case of fshook.h it&#39;s a little different :
</p><div class="source-code"><div class="toolbar"><span class="name">allegro/include/allegro5/fshook.h</span><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"> 19</span><span class="p">#include "allegro5/base.h"</span>
<span class="number"> 20</span><span class="p">#include "allegro5/file.h"</span>
<span class="number"> 21</span><span class="p">#include "allegro5/path.h"</span>
<span class="number"> 22</span>
<span class="number"> 23</span><span class="p">#ifdef ALLEGRO_HAVE_SYS_TYPES_H</span>
<span class="number"> 24</span>   <span class="p">#include &lt;sys/types.h&gt;</span>
<span class="number"> 25</span><span class="p">#else</span>
<span class="number"> 26</span><span class="c">/* 4 Gig max offsets if sys/types doesn't exist. */</span>
<span class="number"> 27</span><span class="k1">typedef</span> <span class="k1">unsigned</span> <span class="k1">int</span> off_t<span class="k2">;</span>
<span class="number"> 28</span><span class="p">#endif</span>
</div></div><p>

Considering that MinGW has sys/types.h, it would make sense to assume that ALLEGRO_HAVE_SYS_TYPES_H would be defined, and therefore sys/types.h would be included (which doesn&#39;t define off_t in the case of _NO_OLDNAMES), leaving off_t undefined.</p><p>That would explain both cases in your compile test, as long as _NO_OLDNAMES is undefined it will work, but when it is, it won&#39;t.</p><p>The real difference here is compiling with -std=c++11. It has nothing to do with any of the changes in the headers. Try compiling with and without the c++11 flag. It should work without it, and fail with it.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Edgar Reynaldo)</author>
		<pubDate>Tue, 20 Sep 2016 23:55:35 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>That was the problem.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Specter Phoenix)</author>
		<pubDate>Wed, 21 Sep 2016 09:16:22 +0000</pubDate>
	</item>
</rss>
