OMKPvmSvmLink.h

Go to the documentation of this file.
00001 /*
00002  * This file is part of openMask © INRIA, CNRS, Universite de Rennes 1 1993-2002, thereinafter the Software
00003  * 
00004  * The Software has been developped within the Siames Project. 
00005  * INRIA, the University of Rennes 1 and CNRS jointly hold intellectual property rights
00006  * 
00007  * The Software has been registered with the Agence pour la Protection des
00008  * Programmes (APP) under registration number IDDN.FR.001.510008.00.S.P.2001.000.41200
00009  *
00010  * This file may be distributed under the terms of the Q Public License
00011  * version 1.0 as defined by Trolltech AS of Norway and appearing in the file
00012  * LICENSE.QPL included in the packaging of this file.
00013  *
00014  * Licensees holding valid specific licenses issued by INRIA, CNRS or Université de Rennes 1 
00015  * for the software may use this file in accordance with that specific license 
00016  *
00017  */
00018 #ifndef OMKPvmSvmLinkHEADER
00019 #define OMKPvmSvmLinkHEADER
00020 
00021 #include <OMKSvmLink.h>
00022 #include "OMKPvmUnicastMessage.h"
00023 
00024 namespace OMK
00025 {
00030 class OMKPVM_API PvmSvmLink : public SvmLink
00031 {
00032 public:
00034    PvmSvmLink(int td);
00035 
00036    
00038    virtual ~PvmSvmLink ();
00039    
00040  
00045    virtual void send(PvmOutgoingMessage & m, PvmMessage::MessageTag tag);
00046 
00047 
00051    virtual PvmIncomingMessage & waitForMessage(PvmMessage::MessageTag tag);
00052    
00053 
00058    virtual PvmIncomingMessage * testForMessage(PvmMessage::MessageTag tag);
00059    
00061    // chadi added method testIfRequestUpdateProcessTable
00062    virtual PvmIncomingMessage*  
00063      testIfRequestUpdateProcessTable (PvmMessage::MessageTag tag);
00070    virtual PvmMessage::MessageTag testForAnyMessage (PvmIncomingMessage & receiveBuffer ) ;
00071 
00072 
00074    virtual void unpack (IncomingSynchronisationMessage &) ;
00075    
00076    
00078    virtual void pack (OutgoingSynchronisationMessage &) const ;
00079 
00080    
00082    virtual PvmOutgoingMessage & getOutgoingBuffer() ;
00083 
00084 
00088    void sendOutgoingBuffer( PvmMessage::MessageTag tag );
00089    
00090  
00092    virtual int getTID();
00093 
00094   virtual void printDebuggingInformation();
00095 
00096 protected:
00097 
00099   PvmUnicastMessage _outgoingBuffer ;
00100 
00102   PvmIncomingMessage _incomingBuffer ;
00103 
00105   int _distantSiteId ; 
00106 
00107 };    // PvmSvmLink
00108 } // namespace OMK
00109 #endif

logo OpenMask

Documentation generated on Mon Jun 9 11:45:57 2008

Generated with doxygen by Dimitri van Heesch ,   1997-2007