<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    <meta content="text/html; charset=ISO-8859-1"
      http-equiv="Content-Type">
  </head>
  <body text="#000000" bgcolor="#ffffff">
    Hi,<br>
    <br>
    On 05/03/2011 10:20 AM, Kaarlo Räihä wrote:
    <blockquote
      cite="mid:BANLkTik7mByvjAx=8b_c8cXm87_kj122iQ@mail.gmail.com"
      type="cite"><br>
      <br>
      <div class="gmail_quote">2011/5/2 Rémi Denis-Courmont <span
          dir="ltr"><<a moz-do-not-send="true"
            href="mailto:remi@remlab.net">remi@remlab.net</a>></span><br>
        <blockquote class="gmail_quote" style="margin: 0pt 0pt 0pt
          0.8ex; border-left: 1px solid rgb(204, 204, 204);
          padding-left: 1ex;">
          ----- Message d'origine -----<br>
          <div class="im">> It isn't perfect code wise, since I have
            NO clue how to create thread<br>
            > without parameters using vlc thread functions.<br>
            <br>
          </div>
          That is impossible. If you do not need any parameter, the
          convention is to pass NULL. That being said, there is almost
          always need to pass a parameter, some kind of context.<br>
          <br>
          > kill_thread(id)<br>
          <br>
          Killing a thread makes no sense. Every thread has to be
          joined, before the plugin is unloaded and before its context
          data gets invalidated.<br>
        </blockquote>
        <div><br>
        </div>
        <div>Problem with join is that 50 seconds long sleep function I
          have since AFAIK join needs selfterminating threads. But in
          Win32 (according to MSDN) you are allowed to use ExitThread or
          similar function to terminate threads since VLC is C code. <br>
        </div>
      </div>
    </blockquote>
    <br>
    Suggestion:<br>
    <br>
    - Have an instance data struct for the thread, containing only an
    exit flag (initialized to false in the main thread, just before it
    starts the new thread). Malloc it, and pass a pointer as the thread
    argument. The flag will be used for signaling.<br>
    - When the main thread wants to shut down the screensaver prevention
    thread, it sets the exit flag to true.<br>
    - When the thread notices that its exit flag has been set to true,
    it joins.<br>
    - Finally, we need to take care of the 50-second sleep. How about,
    instead of<br>
    <br>
    for( ; ; )<br>
    {<br>
        PreventScreensaver();<br>
       
    sleep(50);<br>
    }<br>
    <br>
    having<br>
    <br>
    for( ; ; )<br>
    {<br>
        PreventScreensaver();<br>
    <br>
        for(int i = 0; i < 100; ++i)<br>
        {<br>
            sleep(0.5); /* this is what I meant by pseudocode ;) */<br>
            if( p_data->b_exited )<br>
                goto _terminated; /* "doublebreak;" :) */<br>
        }<br>
    }<br>
    <br>
    _terminated:<br>
    /* ...clean up, join... */<br>
    <br>
    <br>
    This is not ideal, as it relies on polling, but it should get the
    job done without a need to kill the thread from the outside.<br>
    <br>
     -J<br>
    <br>
  </body>
</html>