/*-------------------------------------------------------------------------
| RXTX License v 2.1 - LGPL v 2.1 + Linking Over Controlled Interface.
| RXTX is a native interface to serial ports in java.
| Copyright 2002-2007 by Trent Jarvi tjarvi@qbang.org and others who
| actually wrote it. See individual source files for more information.
|
| A copy of the LGPL v 2.1 may be found at
| http://www.gnu.org/licenses/lgpl.txt on March 4th 2007. A copy is
| here for your convenience.
|
| This library is free software; you can redistribute it and/or
| modify it under the terms of the GNU Lesser General Public
| License as published by the Free Software Foundation; either
| version 2.1 of the License, or (at your option) any later version.
|
| This library 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
| Lesser General Public License for more details.
|
| An executable that contains no derivative of any portion of RXTX, but
| is designed to work with RXTX by being dynamically linked with it,
| is considered a "work that uses the Library" subject to the terms and
| conditions of the GNU Lesser General Public License.
|
| The following has been added to the RXTX License to remove
| any confusion about linking to RXTX. We want to allow in part what
| section 5, paragraph 2 of the LGPL does not permit in the special
| case of linking over a controlled interface. The intent is to add a
| Java Specification Request or standards body defined interface in the
| future as another exception but one is not currently available.
|
| http://www.fsf.org/licenses/gpl-faq.html#LinkingOverControlledInterface
|
| As a special exception, the copyright holders of RXTX give you
| permission to link RXTX with independent modules that communicate with
| RXTX solely through the Sun Microsytems CommAPI interface version 2,
| regardless of the license terms of these independent modules, and to copy
| and distribute the resulting combined work under terms of your choice,
| provided that every copy of the combined work is accompanied by a complete
| copy of the source code of RXTX (the version of RXTX used to produce the
| combined work), being distributed under the terms of the GNU Lesser General
| Public License plus this exception. An independent module is a
| module which is not derived from or based on RXTX.
|
| Note that people who make modified versions of RXTX are not obligated
| to grant this special exception for their modified versions; it is
| their choice whether to do so. The GNU Lesser General Public License
| gives permission to release a modified version without this exception; this
| exception also makes it possible to release a modified version which
| carries forward this exception.
|
| You should have received a copy of the GNU Lesser General Public
| License along with this library; if not, write to the Free
| Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
| All trademarks belong to their respective owners.
--------------------------------------------------------------------------*/
package gnu.io;
import java.io.RandomAccessFile;
public class Zystem
{
public static final int SILENT_MODE = 0;
public static final int FILE_MODE = 1;
public static final int NET_MODE = 2;
public static final int MEX_MODE = 3;
public static final int PRINT_MODE = 4;
public static final int J2EE_MSG_MODE = 5;
public static final int J2SE_LOG_MODE = 6;
static int mode;
static
{
/*
The rxtxZystem library uses Python code and is not
included with RXTX. A seperate library will be released
to avoid potential license conflicts.
Trent Jarvi taj@www.linux.org.uk
*/
//System.loadLibrary( "rxtxZystem" );
mode = SILENT_MODE;
}
private static String target;
public Zystem( int m ) throws UnSupportedLoggerException
{
mode = m;
startLogger( "rxtx-debug.log" );
}
/**
* Constructor.
* Mode is taken from the java system property "gnu.io.log.mode". The available values are :<ul>
* <li> SILENT_MODE No logging
* <li> FILE_MODE log to file
* <li> NET_MODE
* <li> MEX_MODE
* <li> PRINT_MODE
* <li> J2EE_MSG_MODE
* <li> J2SE_LOG_MODE log to java.util.logging
* </ul>
*/
public Zystem () throws UnSupportedLoggerException
{
String s = System.getProperty ("gnu.io.log.mode");
if (s != null)
{
if ("SILENT_MODE".equals (s))
{
mode = SILENT_MODE;
}
else if ("FILE_MODE".equals (s))
{
mode = FILE_MODE;
}
else if ("NET_MODE".equals (s))
{
mode = NET_MODE;
}
else if ("MEX_MODE".equals (s))
{
mode = MEX_MODE;
}
else if ("PRINT_MODE".equals (s))
{
mode = PRINT_MODE;
}
else if ("J2EE_MSG_MODE".equals (s))
{
mode = J2EE_MSG_MODE;
}
else if ("J2SE_LOG_MODE".equals (s))
{
mode = J2SE_LOG_MODE;
}
else
{
try
{
mode = Integer.parseInt (s);
}
catch (NumberFormatException e)
{
mode = SILENT_MODE;
}
}
}
else
{
mode = SILENT_MODE;
}
startLogger ("rxtx-debug.log");
}
public void startLogger( ) throws UnSupportedLoggerException
{
if ( mode == SILENT_MODE || mode == PRINT_MODE )
{
//nativeNetInit( );
return;
}
throw new UnSupportedLoggerException( "Target Not Allowed" );
}
/* accept the host or file to log to. */
public void startLogger( String t ) throws UnSupportedLoggerException
{
target = t;
/*
if ( mode == NET_MODE )
{
nativeNetInit( );
}
if ( nativeInit( ) )
{
throw new UnSupportedLoggerException(
"Port initializion failed" );
}
*/
return;
}
public void finalize()
{
/*
if ( mode == NET_MODE )
{
nativeNetFinalize( );
}
nativeFinalize();
*/
mode = SILENT_MODE;
target = null;
}
/*
public void filewrite( String s )
{
try {
RandomAccessFile w =
new RandomAccessFile( target, "rw" );
w.seek( w.length() );
w.writeBytes( s );
w.close();
} catch ( Exception e ) {
System.out.println("Debug output file write failed");
}
}
public boolean report( String s)
{
if ( mode == NET_MODE )
{
// return( nativeNetReportln( s ) );
}
else if ( mode == PRINT_MODE )
{
System.out.println( s );
return( true );
}
else if ( mode == MEX_MODE )
{
// return( nativeMexReport( s ) );
}
else if ( mode == SILENT_MODE )
{
return( true );
}
else if ( mode == FILE_MODE )
{
filewrite( s );
}
else if ( mode == J2EE_MSG_MODE )
{
return( false );
}
else if (mode == J2SE_LOG_MODE)
{
java.util.logging.Logger.getLogger ("gnu.io").fine (s);
return (true);
}
return( false );
}
public boolean reportln( )
{
boolean b;
if ( mode == NET_MODE )
{
// b= nativeNetReportln( "\n" );
// return(b);
}
else if ( mode == PRINT_MODE )
{
System.out.println( );
return( true );
}
else if ( mode == MEX_MODE )
{
// b = nativeMexReportln( "\n" );
// return(b);
}
else if ( mode == SILENT_MODE )
{
return( true );
}
else if ( mode == FILE_MODE )
{
filewrite( "\n" );
}
else if ( mode == J2EE_MSG_MODE )
{
return( false );
}
return( false );
}
public boolean reportln( String s)
{
boolean b;
if ( mode == NET_MODE )
{
// b= nativeNetReportln( s + "\n" );
// return(b);
}
else if ( mode == PRINT_MODE )
{
System.out.println( s );
return( true );
}
else if ( mode == MEX_MODE )
{
// b = nativeMexReportln( s + "\n" );
// return(b);
}
else if ( mode == SILENT_MODE )
{
return( true );
}
else if ( mode == FILE_MODE )
{
filewrite( s + "\n" );
}
else if ( mode == J2EE_MSG_MODE )
{
return( false );
}
else if (mode == J2SE_LOG_MODE)
{
return (true);
}
return( false );
}
*/
/*
private native boolean nativeInit( );
private native void nativeFinalize();
*/
/* open and close the socket */
/*
private native boolean nativeNetInit( );
private native void nativeNetFinalize();
*/
/* dumping to a remote machine */
/*
public native boolean nativeNetReport( String s );
public native boolean nativeNetReportln( String s );
*/
/* specific to Matlab */
/*
public native boolean nativeMexReport( String s );
public native boolean nativeMexReportln( String s );
*/
}