mirror of
git://gcc.gnu.org/git/gcc.git
synced 2025-01-13 01:54:40 +08:00
456c0b60ad
2001-03-12 Bryce McKinlay <bryce@albatross.co.nz> * java/lang/Runtime.java (_exit): Declare new package-private native. * java/lang/natRuntime.cc (_exit): Implemented. Same as exit() but without a security manager check. (exit): Call _exit after security check. * prims.cc (JvRunMain): Call Runtime._exit to shutdown the runtime "naturally". * java/lang/System.java (setSecurityManager): If a security manager is already in place, call checkPermission. * java/lang/ThreadGroup.java (uncaughtException): If printStackTrace() throws an exception, try to deal with it gracefully. * java/lang/ExceptionInInitializerError.java (printStackTrace): Only try to print the subordinate stack trace if "exception" is set. Print our class name first. From-SVN: r40401
148 lines
3.8 KiB
Java
148 lines
3.8 KiB
Java
// Runtime.java - Runtime class.
|
|
|
|
/* Copyright (C) 1998, 1999, 2000, 2001 Free Software Foundation
|
|
|
|
This file is part of libgcj.
|
|
|
|
This software is copyrighted work licensed under the terms of the
|
|
Libgcj License. Please consult the file "LIBGCJ_LICENSE" for
|
|
details. */
|
|
|
|
package java.lang;
|
|
|
|
import java.io.IOException;
|
|
import java.io.InputStream;
|
|
import java.io.OutputStream;
|
|
import java.util.StringTokenizer;
|
|
|
|
/**
|
|
* @author Tom Tromey <tromey@cygnus.com>
|
|
* @date August 27, 1998
|
|
*/
|
|
|
|
/* Written using "Java Class Libraries", 2nd edition, ISBN 0-201-31002-3
|
|
* "The Java Language Specification", ISBN 0-201-63451-1
|
|
* plus online API docs for JDK 1.2 beta from http://www.javasoft.com.
|
|
* Status: All 1.1 methods exist. exec() is not fully implemented.
|
|
*/
|
|
|
|
public class Runtime
|
|
{
|
|
public Process exec (String prog) throws IOException
|
|
{
|
|
return exec (prog, null);
|
|
}
|
|
|
|
public Process exec (String prog, String[] envp) throws IOException
|
|
{
|
|
StringTokenizer st = new StringTokenizer(prog);
|
|
String[] a = new String[st.countTokens ()];
|
|
for (int i = 0; i < a.length; i++)
|
|
a[i] = st.nextToken ();
|
|
return exec (a, envp);
|
|
}
|
|
|
|
public Process exec (String[] progarray) throws IOException
|
|
{
|
|
return exec (progarray, null);
|
|
}
|
|
|
|
public Process exec (String[] progarray, String[] envp) throws IOException
|
|
{
|
|
SecurityManager s = System.getSecurityManager();
|
|
if (s != null)
|
|
s.checkExec(progarray[0]);
|
|
return new ConcreteProcess (progarray, envp);
|
|
}
|
|
|
|
private final static void checkExit (int status)
|
|
{
|
|
SecurityManager s = System.getSecurityManager();
|
|
if (s != null)
|
|
s.checkExit(status);
|
|
}
|
|
|
|
public native void exit (int status);
|
|
|
|
// Shutdown the runtime without a SecurityManager check. libgcj uses this
|
|
// exit function internally.
|
|
final native void _exit (int status);
|
|
|
|
public native long freeMemory ();
|
|
public native void gc ();
|
|
|
|
// Deprecated in 1.1. We implement what the JCL book says.
|
|
public InputStream getLocalizedInputStream (InputStream in)
|
|
{
|
|
return in;
|
|
}
|
|
|
|
// Deprecated in 1.1. We implement what the JCL book says.
|
|
public OutputStream getLocalizedOutputStream (OutputStream out)
|
|
{
|
|
return out;
|
|
}
|
|
|
|
public static Runtime getRuntime ()
|
|
{
|
|
return self;
|
|
}
|
|
|
|
private final void checkLink (String lib)
|
|
{
|
|
if (lib == null)
|
|
throw new NullPointerException ();
|
|
SecurityManager s = System.getSecurityManager();
|
|
if (s != null)
|
|
s.checkLink(lib);
|
|
}
|
|
|
|
private native void _load (String pathname, boolean do_search);
|
|
|
|
public void load (String pathname)
|
|
{
|
|
_load (pathname, false);
|
|
}
|
|
|
|
public void loadLibrary (String libname)
|
|
{
|
|
_load (libname, true);
|
|
}
|
|
|
|
// This is a helper function for the ClassLoader which can load
|
|
// compiled libraries. Returns true if library (which is just the
|
|
// base name -- path searching is done by this function) was loaded,
|
|
// false otherwise.
|
|
native boolean loadLibraryInternal (String libname);
|
|
|
|
public native void runFinalization ();
|
|
|
|
// This method is static in JDK 1.1, but isn't listed as static in
|
|
// the books. It is marked as static in the 1.2 docs.
|
|
public static void runFinalizersOnExit (boolean run)
|
|
{
|
|
// The status we pass to the security check is unspecified.
|
|
checkExit (0);
|
|
self.finalize_on_exit = run;
|
|
}
|
|
|
|
public native long totalMemory ();
|
|
public native void traceInstructions (boolean on);
|
|
public native void traceMethodCalls (boolean on);
|
|
|
|
// A helper for the constructor.
|
|
private final native void init ();
|
|
|
|
// The sole constructor.
|
|
private Runtime ()
|
|
{
|
|
init ();
|
|
}
|
|
|
|
// Private data.
|
|
private static Runtime self = new Runtime ();
|
|
// FIXME: for now this can't be static. If it is, our compiler will
|
|
// mark it as local, and it will be inaccessible to natRuntime.cc.
|
|
private boolean finalize_on_exit;
|
|
}
|