All Downloads are FREE. Search and download functionalities are using the official Maven repository.

ery.jvrpn.1.0.0.source-code.AuxiliaryLoggerRemote Maven / Gradle / Ivy

There is a newer version: 1.2.0
Show newest version
package vrpn;

import java.util.Date;
import java.util.Enumeration;
import java.util.Vector;


public class AuxiliaryLoggerRemote extends VRPNDevice implements Runnable 
{

	/////////////////////////////////
	// Public structures and interfaces

	public class LoggingReport
	{
		public Date msg_time = new Date();
		public String localInLogfileName = "";
		public String localOutLogfileName = "";
		public String remoteInLogfileName = "";
		public String remoteOutLogfileName = "";
	}
	
	public interface LoggingReportListener
	{
		public void loggingReport( LoggingReport u, AuxiliaryLoggerRemote logger );
	}
		
	// end of the public structures and interfaces
	//////////////////////////////////

	
	////////////////////////////////
	// Public methods
	//
	
	/**
	 * @param name The name of the tracker to connect to (e.g., [email protected])
	 * @exception java.lang.InstantiationException
	 *		If the tracker could not be created because of problems with
	 *      its native code and linking.
	 */
	public AuxiliaryLoggerRemote( String name ) 
		throws InstantiationException
	{
		super( name, null, null, null, null );
	}
	
	
	public synchronized native boolean 
		sendLoggingRequest( String localInLogfileName, String localOutLogfileName,
							String remoteInLogfileName, String remoteOutLogfileName );
	
	
	public synchronized native boolean sendLoggingStatusRequest( );

	
	public synchronized void addLoggingReportListener( LoggingReportListener listener )
	{
		listeners.addElement( listener );
	}
	
	
	/**
	 * @return true on success; false on failure
	 */
	public synchronized boolean removeLoggingReportListener( LoggingReportListener listener )
	{
		return listeners.removeElement( listener );
	}
	
	
	// end public methods
	////////////////////////
	
	
	////////////////////////
	// Protected methods
	//
	
	/**
	 * Should be called only by mainloop(), a native method which is itself
	 * synchronized.  By extension, this method is synchronized (in that, for
	 * a given LoggerRemote object, this method can only be called from one
	 * thread at a time).
	 */
	protected void handleLoggingReport( long tv_sec, long tv_usec, 
										String localIn, String localOut, 
										String remoteIn, String remoteOut )
	{
		synchronized( notifyingListenersLock )
		{
			LoggingReport r = new LoggingReport();
			r.msg_time.setTime( tv_sec * 1000 + (int) (tv_usec/1000.0) );
			r.localInLogfileName = localIn;
			r.localOutLogfileName = localOut;
			r.remoteInLogfileName = remoteIn;
			r.remoteOutLogfileName = remoteOut;
			
			// notify all listeners
			Enumeration e = listeners.elements( );
			while( e.hasMoreElements( ) )
			{
				LoggingReportListener l = (LoggingReportListener) e.nextElement( );
				l.loggingReport( r, this );
			}
		} // end synchronized block
	} // end handleLoggerReport
	
	
	protected void stoppedRunning() 
	{
		listeners.removeAllElements();
		synchronized( downInVrpnLock )
		{
			this.shutdownAuxiliaryLogger();
		}
	}
	
	
	protected native void shutdownAuxiliaryLogger();
	
	
	/**
	 * This should only be called from the method run()
	 */
	protected native void mainloop();

	
	/**
	 * Initialize the native tracker object
	 * @param name The name of the tracker and host (e.g., "[email protected]").
	 * @param localInLogfileName This will be ignored (as will all the *LogfileName params).
	 * @return true if the tracker was connected successfully, 
	 *			false otherwise.
	 */
	protected native boolean init( String name, String localInLogfileName,
									String localOutLogfileName, String remoteInLogfileName,
									String remoteOutLogfileName );
	// end protected methods
	///////////////////////
		
	///////////////////
	// data members
	
	protected Vector listeners = new Vector( );

	/**
	 * these notifying*ListenersLock variables are used to ensure that multiple
	 * TrackerRemote objects running in multiple threads don't call the 
	 * trackerChangeUpdate, et al, method of some single object concurrently.
	 * For example, the handleTrackerChange(...) method, which is invoked from native 
	 * code, gets a lock on the notifyingChangeListenersLock object.  Since that object
	 * is static, all other instances of TrackerRemote must wait before notifying 
	 * their listeners and completing their handleTrackerChange(...) methods.
	 * They are necessary, in part, because methods in an interface can't be declared
	 * synchronized (and the semantics of the keyword 'synchronized' aren't what's
	 * wanted here, anyway -- we want synchronization across all instances, not just a 
	 * single object).
	 */
	protected final static Object notifyingListenersLock = new Object( );
		

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy