<?xml version="1.0"?>
<rss version="2.0">
	<channel>
		<title>Problem in Allegro 5.2.4 Timer!</title>
		<link>http://www.allegro.cc/forums/view/617548</link>
		<description>Allegro.cc Forum Thread</description>
		<webMaster>matthew@allegro.cc (Matthew Leverton)</webMaster>
		<lastBuildDate>Mon, 27 Aug 2018 10:47:57 +0000</lastBuildDate>
	</channel>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Hello</p><p>After switching from Allegro 5.1 to Allegro 5.2.4<br />And using binaries in this distribution for Visual C/C++<br /><a href="https://www.nuget.org/packages/Allegro/">https://www.nuget.org/packages/Allegro/</a></p><p>I discovered a problem in the (Timer) !<br />Where the timer event is always fired without waiting for the time to pass.</p><p>I&#39;m using the timer to control the drawing at (60 FPS)<br />With Allegro 5.1 (No Problem) - I get the expected behavior (60 FPS)<br />While with Allegro 5.2.4 - I get over 350 FPS !</p><p>The code looks like this (In Ring programming language - Just normal calls to Allegro)</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>  func setup
<span class="number">  2</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="number">  3</span>    <a href="http://www.allegro.cc/manual/al_init_font_addon"><span class="a">al_init_font_addon</span></a><span class="k2">(</span><span class="k2">)</span>
<span class="number">  4</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="number">  5</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="number">  6</span>    <a href="http://www.allegro.cc/manual/al_install_audio"><span class="a">al_install_audio</span></a><span class="k2">(</span><span class="k2">)</span>
<span class="number">  7</span>    <a href="http://www.allegro.cc/manual/al_init_acodec_addon"><span class="a">al_init_acodec_addon</span></a><span class="k2">(</span><span class="k2">)</span>
<span class="number">  8</span>    <a href="http://www.allegro.cc/manual/al_reserve_samples"><span class="a">al_reserve_samples</span></a><span class="k2">(</span><span class="n">1</span><span class="k2">)</span>
<span class="number">  9</span>    <a href="http://www.allegro.cc/manual/al_set_new_display_flags"><span class="a">al_set_new_display_flags</span></a><span class="k2">(</span>ALLEGRO_OPENGL<span class="k2">)</span> 
<span class="number"> 10</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><a href="http://www.allegro.cc/manual/SCREEN_W"><span class="a">SCREEN_W</span></a>,<a href="http://www.allegro.cc/manual/SCREEN_H"><span class="a">SCREEN_H</span></a><span class="k2">)</span>
<span class="number"> 11</span>    <a href="http://www.allegro.cc/manual/al_set_window_title"><span class="a">al_set_window_title</span></a><span class="k2">(</span>display,TITLE<span class="k2">)</span>
<span class="number"> 12</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="number"> 13</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="number"> 14</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, 
<span class="number"> 15</span>      <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="number"> 16</span>    ev <span class="k3">=</span> al_new_allegro_event<span class="k2">(</span><span class="k2">)</span>
<span class="number"> 17</span>    timeout <span class="k3">=</span> al_new_allegro_timeout<span class="k2">(</span><span class="k2">)</span>
<span class="number"> 18</span>    <a href="http://www.allegro.cc/manual/al_init_timeout"><span class="a">al_init_timeout</span></a><span class="k2">(</span>timeout, <span class="n">0</span>.<span class="n">06</span><span class="k2">)</span>
<span class="number"> 19</span>    timer <span class="k3">=</span> <a href="http://www.allegro.cc/manual/al_create_timer"><span class="a">al_create_timer</span></a><span class="k2">(</span><span class="n">1</span>.<span class="n">0</span> <span class="k3">/</span> FPS<span class="k2">)</span>
<span class="number"> 20</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, 
<span class="number"> 21</span>      <a href="http://www.allegro.cc/manual/al_get_timer_event_source"><span class="a">al_get_timer_event_source</span></a><span class="k2">(</span>timer<span class="k2">)</span><span class="k2">)</span>
<span class="number"> 22</span>    <a href="http://www.allegro.cc/manual/al_start_timer"><span class="a">al_start_timer</span></a><span class="k2">(</span>timer<span class="k2">)</span>
<span class="number"> 23</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="number"> 24</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, 
<span class="number"> 25</span>      <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="number"> 26</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="number"> 27</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, 
<span class="number"> 28</span>      <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="number"> 29</span>
<span class="number"> 30</span>  func eventsLoop
<span class="number"> 31</span>    <span class="k1">while</span> <span class="k1">true</span>
<span class="number"> 32</span>      <a href="http://www.allegro.cc/manual/al_wait_for_event_until"><span class="a">al_wait_for_event_until</span></a><span class="k2">(</span>event_queue, ev, timeout<span class="k2">)</span>
<span class="number"> 33</span>      <span class="k1">switch</span> al_get_allegro_event_type<span class="k2">(</span>ev<span class="k2">)</span>
<span class="number"> 34</span>      on ALLEGRO_EVENT_DISPLAY_CLOSE
<span class="number"> 35</span>        CloseEvent<span class="k2">(</span><span class="k2">)</span>
<span class="number"> 36</span>      on ALLEGRO_EVENT_TIMER
<span class="number"> 37</span>        redraw <span class="k3">=</span> <span class="k1">true</span>
<span class="number"> 38</span>                        off
<span class="number"> 39</span>      <span class="k1">if</span> redraw <span class="k1">and</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="number"> 40</span>        redraw <span class="k3">=</span> <span class="k1">false</span>
<span class="number"> 41</span>        drawScene<span class="k2">(</span><span class="k2">)</span>
<span class="number"> 42</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="number"> 43</span>      ok
<span class="number"> 44</span>    end
</div></div><p>

Greetings,<br />Mahmoud
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Mahmoud Fayed)</author>
		<pubDate>Sat, 25 Aug 2018 16:14:58 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>You mean you set FPS to 60, and measured the actual frames per second, and it was 350? Please create a simple test in C that demonstrates your problem. We need a Minimal, Complete, Verifiable Example.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Edgar Reynaldo)</author>
		<pubDate>Sun, 26 Aug 2018 20:21:10 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>I haven&#39;t compiled the code but my guess is: ALLEGRO_TIMEOUT is an absolute time so the first call to <span class="source-code"><a href="http://www.allegro.cc/manual/al_wait_for_event_until"><span class="a">al_wait_for_event_until</span></a></span> will wait 60ms but the ones after will be zero. Probably <span class="source-code"><a href="http://www.allegro.cc/manual/al_wait_for_event_timed"><span class="a">al_wait_for_event_timed</span></a></span> is what you want<br />Hope that helps<br />Pete
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Peter Hull)</author>
		<pubDate>Sun, 26 Aug 2018 22:11:46 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Hello Edgar </p><p>Yes, This is what I mean, and I will attach a C program</p><p>Hello Peter </p><p>Yes, the problem is related to ALLEGRO_TIMEOUT </p><p>(1) The Ring code uses a pointer for the ALLEGRO_TIMEOUT and doing the initialize operation just one time! ---&gt; (I fixed that to avoid the problem, Thanks <img src="http://www.allegro.cc/forums/smileys/cheesy.gif" alt=":D" /> )</p><p>(2) It was also a change in behavior between Allegro 5.1.11 and Allegro 5.2.4 where the problem doesn&#39;t exist in Allegro 5.1.11</p><p>Attached the C source code, written just for testing to demonstrate the change.</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 "stdlib.h"</span>
<span class="number">  2</span><span class="p">#include "stdio.h"</span>
<span class="number">  3</span>
<span class="number">  4</span><span class="p">#define ALLEGRO_NO_MAGIC_MAIN</span>
<span class="number">  5</span>
<span class="number">  6</span><span class="p">#include &lt;allegro5/allegro.h&gt;</span>
<span class="number">  7</span><span class="p">#include &lt;allegro5/allegro_color.h&gt;</span>
<span class="number">  8</span>
<span class="number">  9</span><span class="k1">int</span> <a href="http://www.allegro.cc/manual/SCREEN_W"><span class="a">SCREEN_W</span></a>   <span class="k3">=</span> <span class="n">800</span><span class="k2">;</span>
<span class="number"> 10</span><span class="k1">int</span> <a href="http://www.allegro.cc/manual/SCREEN_H"><span class="a">SCREEN_H</span></a>   <span class="k3">=</span> <span class="n">600</span><span class="k2">;</span>
<span class="number"> 11</span><span class="k1">int</span> FPS         <span class="k3">=</span> <span class="n">60</span><span class="k2">;</span>
<span class="number"> 12</span><span class="k1">int</span> Counter    <span class="k3">=</span> <span class="n">0</span><span class="k2">;</span>
<span class="number"> 13</span><span class="k1">int</span> RunProgram <span class="k3">=</span> <span class="n">1</span><span class="k2">;</span>
<span class="number"> 14</span><span class="k1">int</span> Wait      <span class="k3">=</span> <span class="n">7</span><span class="k2">;</span>
<span class="number"> 15</span>
<span class="number"> 16</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"> 17</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"> 18</span><a href="http://www.allegro.cc/manual/ALLEGRO_TIMER"><span class="a">ALLEGRO_TIMER</span></a> <span class="k3">*</span>timer       <span class="k3">=</span> NULL<span class="k2">;</span>
<span class="number"> 19</span>
<span class="number"> 20</span><span class="k1">void</span> Setup<span class="k2">(</span><span class="k1">void</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 21</span><span class="k1">void</span> EventsLoop<span class="k2">(</span><span class="k1">void</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 22</span><span class="k1">void</span> DrawScene<span class="k2">(</span><span class="k1">void</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 23</span><span class="k1">void</span> FreeResources<span class="k2">(</span><span class="k1">void</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 24</span>
<span class="number"> 25</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>argv<span class="k2">)</span> <span class="k2">{</span>
<span class="number"> 26</span>  <a href="http://www.delorie.com/djgpp/doc/libc/libc_624.html" target="_blank">printf</a><span class="k2">(</span><span class="s">"Welcome to the Timer test program!\n"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 27</span>  <a href="http://www.delorie.com/djgpp/doc/libc/libc_624.html" target="_blank">printf</a><span class="k2">(</span><span class="s">"The program must wait for around 7 seconds then exit!\n"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 28</span>  Setup<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 29</span>  EventsLoop<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 30</span>  FreeResources<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 31</span>  <span class="k1">return</span> <span class="n">0</span><span class="k2">;</span>
<span class="number"> 32</span><span class="k2">}</span>
<span class="number"> 33</span>
<span class="number"> 34</span><span class="k1">void</span> Setup<span class="k2">(</span><span class="k1">void</span><span class="k2">)</span> <span class="k2">{</span>
<span class="number"> 35</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="number"> 36</span>  <a href="http://www.allegro.cc/manual/al_set_new_display_flags"><span class="a">al_set_new_display_flags</span></a><span class="k2">(</span>ALLEGRO_OPENGL<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 37</span>  <a href="http://www.allegro.cc/manual/al_set_new_display_option"><span class="a">al_set_new_display_option</span></a><span class="k2">(</span>ALLEGRO_DEPTH_SIZE, <span class="n">16</span>, ALLEGRO_SUGGEST<span class="k2">)</span><span class="k2">;</span> 
<span class="number"> 38</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><a href="http://www.allegro.cc/manual/SCREEN_W"><span class="a">SCREEN_W</span></a>,<a href="http://www.allegro.cc/manual/SCREEN_H"><span class="a">SCREEN_H</span></a><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 39</span>  <a href="http://www.allegro.cc/manual/al_set_window_title"><span class="a">al_set_window_title</span></a><span class="k2">(</span>display,<span class="s">"Test Timer"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 40</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"> 41</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"> 42</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"> 43</span>  timer <span class="k3">=</span> <a href="http://www.allegro.cc/manual/al_create_timer"><span class="a">al_create_timer</span></a><span class="k2">(</span><span class="n">1</span>.<span class="n">0</span> <span class="k3">/</span> FPS<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 44</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_timer_event_source"><span class="a">al_get_timer_event_source</span></a><span class="k2">(</span>timer<span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 45</span>  <a href="http://www.allegro.cc/manual/al_start_timer"><span class="a">al_start_timer</span></a><span class="k2">(</span>timer<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 46</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="number"> 47</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"> 48</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="number"> 49</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"> 50</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"> 51</span><span class="k2">}</span>
<span class="number"> 52</span>
<span class="number"> 53</span><span class="k1">void</span> EventsLoop<span class="k2">(</span><span class="k1">void</span><span class="k2">)</span> <span class="k2">{</span>
<span class="number"> 54</span>  <span class="k1">int</span> redraw <span class="k3">=</span> <span class="n">0</span> <span class="k2">;</span>
<span class="number"> 55</span>  <span class="k1">while</span> <span class="k2">(</span>RunProgram<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> ev   <span class="k2">;</span>
<span class="number"> 57</span>    <a href="http://www.allegro.cc/manual/ALLEGRO_TIMEOUT"><span class="a">ALLEGRO_TIMEOUT</span></a> timeout <span class="k2">;</span>
<span class="number"> 58</span>    <span class="c">// We can ignore the next line in Allegro 5.1.11 (But we can't do that for Allegro 5.2.4)</span>
<span class="number"> 59</span>    <span class="c">// al_init_timeout(&amp;timeout, 0.06);</span>
<span class="number"> 60</span>    <a href="http://www.allegro.cc/manual/al_wait_for_event_until"><span class="a">al_wait_for_event_until</span></a><span class="k2">(</span>event_queue, <span class="k3">&amp;</span>ev, <span class="k3">&amp;</span>timeout<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 61</span>    <span class="k1">switch</span><span class="k2">(</span> ev.type <span class="k2">)</span> <span class="k2">{</span>
<span class="number"> 62</span>    <span class="k1">case</span> ALLEGRO_EVENT_DISPLAY_CLOSE <span class="k2">:</span>
<span class="number"> 63</span>      RunProgram <span class="k3">=</span> <span class="n">0</span><span class="k2">;</span>
<span class="number"> 64</span>      <span class="k1">break</span><span class="k2">;</span>
<span class="number"> 65</span>    <span class="k1">case</span> ALLEGRO_EVENT_TIMER <span class="k2">:</span>
<span class="number"> 66</span>      redraw <span class="k3">=</span> <span class="n">1</span><span class="k2">;</span>
<span class="number"> 67</span>      <span class="k1">break</span><span class="k2">;</span>
<span class="number"> 68</span>    <span class="k2">}</span>
<span class="number"> 69</span>    <span class="k1">if</span> <span class="k2">(</span>redraw <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="k2">)</span> <span class="k2">{</span>
<span class="number"> 70</span>      redraw <span class="k3">=</span> <span class="n">0</span> <span class="k2">;</span>
<span class="number"> 71</span>      DrawScene<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 72</span>    <span class="k2">}</span>
<span class="number"> 73</span>  <span class="k2">}</span>
<span class="number"> 74</span><span class="k2">}</span>
<span class="number"> 75</span>
<span class="number"> 76</span><span class="k1">void</span> DrawScene<span class="k2">(</span><span class="k1">void</span><span class="k2">)</span> <span class="k2">{</span>
<span class="number"> 77</span>  Counter<span class="k3">+</span><span class="k3">+</span><span class="k2">;</span>
<span class="number"> 78</span>  <span class="k1">if</span> <span class="k2">(</span>Counter <span class="k3">=</span><span class="k3">=</span> FPS <span class="k3">*</span> Wait <span class="k2">)</span> RunProgram <span class="k3">=</span> <span class="n">0</span> <span class="k2">;</span>
<span class="number"> 79</span><span class="k2">}</span>
<span class="number"> 80</span>
<span class="number"> 81</span><span class="k1">void</span> FreeResources<span class="k2">(</span><span class="k1">void</span><span class="k2">)</span> <span class="k2">{</span>
<span class="number"> 82</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"> 83</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"> 84</span>  <a href="http://www.allegro.cc/manual/al_destroy_timer"><span class="a">al_destroy_timer</span></a><span class="k2">(</span>timer<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 85</span><span class="k2">}</span>
</div></div><p>

Greetings,<br />Mahmoud
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Mahmoud Fayed)</author>
		<pubDate>Sun, 26 Aug 2018 23:21:25 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><div class="quote_container"><div class="title">Mahmoud said:</div><div class="quote"><p>
</p><div class="source-code snippet"><div class="inner"><pre><a href="http://www.allegro.cc/manual/ALLEGRO_TIMEOUT"><span class="a">ALLEGRO_TIMEOUT</span></a> timeout <span class="k2">;</span>
<span class="c">// We can ignore the next line in Allegro 5.1.11 (But we can't do that for Allegro 5.2.4)</span>
<span class="c">// al_init_timeout(&amp;timeout, 0.06);</span>
<a href="http://www.allegro.cc/manual/al_wait_for_event_until"><span class="a">al_wait_for_event_until</span></a><span class="k2">(</span>event_queue, <span class="k3">&amp;</span>ev, <span class="k3">&amp;</span>timeout<span class="k2">)</span><span class="k2">;</span>
</pre></div></div><p>
</p></div></div><p>

Take notice that &#39;timeout&#39; is UNINITIALIZED if you don&#39;t call al_init_timeout.</p><p>Now if you call al_init_timeout, and wait until the timeout returns, it SHOULD remain the same as far as timeout value goes. If it changes before the next call to al_wait_for_event_until, that&#39;s a bug in Allegro, or at the least its undocumented behavior.</p><p>The fact that it works in 5.1.11 makes no difference. 5.1 is VERY old as far as versions go. You should be using 5.2.4 if you can.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Edgar Reynaldo)</author>
		<pubDate>Mon, 27 Aug 2018 04:17:32 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>This is probably due to this bug being fixed:</p><p><a href="https://github.com/liballeg/allegro5/issues/593">https://github.com/liballeg/allegro5/issues/593</a></p><p>Before it was fixed, even though your timeout was effectively 0 (being set in the past), <span class="source-code"><a href="http://www.allegro.cc/manual/al_wait_for_event_until"><span class="a">al_wait_for_event_until</span></a></span> would still wait for an event to show up.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (SiegeLord)</author>
		<pubDate>Mon, 27 Aug 2018 06:00:41 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>But, if you&#39;ve got a timer firing every 60ms, you don&#39;t need a timeout at all because the timer event do the same thing (or am I missing something?)</p><p>And, if you do want to use <span class="source-code"><a href="http://www.allegro.cc/manual/al_wait_for_event_until"><span class="a">al_wait_for_event_until</span></a></span> you should check the return value; if it returns due to the timeout, the event will be invalid.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Peter Hull)</author>
		<pubDate>Mon, 27 Aug 2018 10:47:57 +0000</pubDate>
	</item>
</rss>
