123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226 |
- /* System.c -- native code for java.lang.System
- Copyright (C) 1998, 1999, 2000, 2002, 2004 Free Software Foundation, Inc.
- This file is part of GNU Classpath.
- GNU Classpath 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.
-
- GNU Classpath 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 GNU Classpath; see the file COPYING. If not, write to the
- Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
- 02110-1301 USA.
- Linking this library statically or dynamically with other modules is
- making a combined work based on this library. Thus, the terms and
- conditions of the GNU General Public License cover the whole
- combination.
- As a special exception, the copyright holders of this library give you
- permission to link this library with independent modules to produce an
- executable, regardless of the license terms of these independent
- modules, and to copy and distribute the resulting executable under
- terms of your choice, provided that you also meet, for each linked
- independent module, the terms and conditions of the license of that
- module. An independent module is a module which is not derived from
- or based on this library. If you modify this library, you may extend
- this exception to your version of the library, but you are not
- obligated to do so. If you do not wish to do so, delete this
- exception statement from your version. */
- #include "java_lang_VMSystem.h"
- #include <jcl.h>
- #include <time.h>
- #include <sys/time.h>
- #include <stdlib.h>
- #include <errno.h>
- #include <unistd.h>
- #include <string.h>
- /*
- * Class: java_lang_VMSystem
- * Method: setIn0
- * Signature: (Ljava/io/InputStream;)V
- */
- JNIEXPORT void JNICALL
- Java_java_lang_VMSystem_setIn (JNIEnv * env,
- jclass thisClass __attribute__ ((__unused__)),
- jobject obj)
- {
- jclass cls;
- jfieldID field;
- cls = JCL_FindClass (env, "java/lang/System");
- if (!cls)
- return;
- field = (*env)->GetStaticFieldID (env, cls, "in", "Ljava/io/InputStream;");
- if (!field)
- return;
- (*env)->SetStaticObjectField (env, cls, field, obj);
- }
- /*
- * Class: java_lang_VMSystem
- * Method: setOut0
- * Signature: (Ljava/io/PrintStream;)V
- */
- JNIEXPORT void JNICALL
- Java_java_lang_VMSystem_setOut (JNIEnv * env,
- jclass thisClass __attribute__ ((__unused__)),
- jobject obj)
- {
- jclass cls;
- jfieldID field;
- cls = JCL_FindClass (env, "java/lang/System");
- if (!cls)
- return;
- field = (*env)->GetStaticFieldID (env, cls, "out", "Ljava/io/PrintStream;");
- if (!field)
- return;
- (*env)->SetStaticObjectField (env, cls, field, obj);
- }
- /*
- * Class: java_lang_VMSystem
- * Method: setErr0
- * Signature: (Ljava/io/PrintStream;)V
- */
- JNIEXPORT void JNICALL
- Java_java_lang_VMSystem_setErr (JNIEnv * env,
- jclass thisClass __attribute__ ((__unused__)),
- jobject obj)
- {
- jclass cls;
- jfieldID field;
- cls = JCL_FindClass (env, "java/lang/System");
- if (!cls)
- return;
- field = (*env)->GetStaticFieldID (env, cls, "err", "Ljava/io/PrintStream;");
- if (!field)
- return;
- (*env)->SetStaticObjectField (env, cls, field, obj);
- }
- static jlong currentTimeMicros(JNIEnv * env)
- {
- /* Note: this implementation copied directly from Japhar's, by Chris Toshok. */
- jlong result;
- struct timeval tp;
- if (gettimeofday (&tp, NULL) == -1)
- (*env)->FatalError (env, "gettimeofday call failed.");
- result = (jlong) tp.tv_sec;
- result *= (jlong)1000000L;
- result += (jlong)tp.tv_usec;
- return result;
- }
- /*
- * Class: java_lang_VMSystem
- * Method: nanoTime
- * Signature: ()J
- */
- JNIEXPORT jlong JNICALL
- Java_java_lang_VMSystem_nanoTime
- (JNIEnv * env,
- jclass thisClass __attribute__ ((__unused__)))
- {
- #if defined(HAVE_CLOCK_GETTIME) && defined(_POSIX_MONOTONIC_CLOCK)
- jlong result;
- struct timespec tp;
- if (clock_gettime (CLOCK_MONOTONIC, &tp) == -1) {
- return currentTimeMicros(env) * (jlong)1000;
- }
- result = (jlong) tp.tv_sec;
- result *= (jlong)1000000000L;
- result += (jlong)tp.tv_nsec;
- return result;
- #else
- return currentTimeMicros(env) * (jlong)1000;
- #endif
- }
- /*
- * Class: java_lang_VMSystem
- * Method: currentTimeMillis
- * Signature: ()J
- */
- JNIEXPORT jlong JNICALL
- Java_java_lang_VMSystem_currentTimeMillis
- (JNIEnv * env,
- jclass thisClass __attribute__ ((__unused__)))
- {
- return currentTimeMicros(env) / (jlong)1000L;
- }
- JNIEXPORT jstring JNICALL
- Java_java_lang_VMSystem_getenv (JNIEnv * env,
- jclass klass __attribute__ ((__unused__)),
- jstring jname)
- {
- const char *cname;
- const char *envname;
- cname = JCL_jstring_to_cstring (env, jname);
- if (cname == NULL)
- return NULL;
- envname = getenv (cname);
- if (envname == NULL)
- return NULL;
- JCL_free_cstring (env, jname, cname);
- return (*env)->NewStringUTF (env, envname);
- }
- JNIEXPORT jobject JNICALL
- Java_java_lang_VMSystem_environ (JNIEnv *env,
- jclass klass __attribute__((__unused__)))
- {
- char **env_pointer;
- jobject variables;
- jclass list_class;
- jmethodID list_constructor;
- jmethodID add;
- list_class = (*env)->FindClass(env, "java/util/LinkedList");
- if (list_class == NULL)
- return NULL;
- list_constructor = (*env)->GetMethodID(env, list_class, "<init>", "()V");
- if (list_constructor == NULL)
- return NULL;
- variables = (*env)->NewObject(env, list_class, list_constructor);
- if (variables == NULL)
- return NULL;
- add = (*env)->GetMethodID(env, list_class, "add", "(Ljava/lang/Object;)Z");
- if (add == NULL)
- return NULL;
- env_pointer = environ;
- while (*env_pointer != NULL)
- {
- jstring string = (*env)->NewStringUTF(env, *env_pointer);
- (*env)->CallBooleanMethod(env, variables, add, string);
- ++env_pointer;
- }
- return variables;
- }
|