Sophie

Sophie

distrib > Mandriva > 2010.0 > i586 > media > contrib-release > by-pkgid > b818b6f4a71f6d777a55341c7d17486c > files > 82

libgpsim-devel-0.22.0-1mdv2008.0.i586.rpm

/*
   Copyright (C) 2004 T. Scott Dattalo

This file is part of gpsim.

gpsim is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2, or (at your option)
any later version.

gpsim is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
GNU General Public License for more details.

You should have received a copy of the GNU General Public License
along with gpsim; see the file COPYING.  If not, write to
the Free Software Foundation, 59 Temple Place - Suite 330,
Boston, MA 02111-1307, USA.  */

#if !defined(__TTOKEN_H__)
#define __TTOKEN_H__

namespace gpsim {

  /// Token - a class used to synchronize two threads.
  /// Token will spawn a new thread and keep it synchronized
  /// with the thread that called it. In gpsim, the simulation
  /// engine is a single thread application. However, it's 
  /// sometimes quite difficult to implement modules within the
  /// context of this thread. So modules that are instantiated
  /// from within the context of the simulator can use the Token
  /// class to spawn a new thread.
  /// 
  /// Note - the underlying implementation depends on pthreads.
  /// However, that implementation is completely hidden with an
  /// opaque pointer to the PThreadWrapper object. This way,
  /// if it turns out that pthreads are not installed or there's
  /// another implementation preferred for the synchronization
  /// then it's easy to change with impacting the whole system.

  struct ThreadWrapper;

  class Token
  {
  public:
    Token();

    /// Initialize - a wrapper for pthread create.

    void Initialize(void *(*child) (void *), void *data);

    /// 
    void waitForChild();
    void passToChild();
    void passToParent();
    void grab();

  private:

    ThreadWrapper *thread;
  };

} // end of namespace gpsim

#endif // !defined(__TTOKEN_H__)