/* Copyright (C) 2011 Jeroen Frijters This software is provided 'as-is', without any express or implied warranty. In no event will the authors be held liable for any damages arising from the use of this software. Permission is granted to anyone to use this software for any purpose, including commercial applications, and to alter it and redistribute it freely, subject to the following restrictions: 1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. 2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. 3. This notice may not be removed or altered from any source distribution. Jeroen Frijters jeroen@frijters.net */ #if !FIRST_PASS using java.lang.management; #endif static class Java_sun_management_ClassLoadingImpl { public static void setVerboseClass(bool value) { } } static class Java_sun_management_MemoryImpl { public static object getMemoryPools0() { #if FIRST_PASS return null; #else return new MemoryPoolMXBean[0]; #endif } public static object getMemoryManagers0() { #if FIRST_PASS return null; #else return new MemoryManagerMXBean[0]; #endif } public static object getMemoryUsage0(object impl, bool heap) { #if FIRST_PASS return null; #else long mem = System.GC.GetTotalMemory(false); return new MemoryUsage(-1, mem, mem, -1); #endif } public static void setVerboseGC(object impl, bool value) { } } static class Java_sun_management_ThreadImpl { public static object getThreads() { return IKVM.NativeCode.java.lang.Thread.getThreads(); } private const int JVMTI_THREAD_STATE_ALIVE = 0x0001; private const int JVMTI_THREAD_STATE_TERMINATED = 0x0002; private const int JVMTI_THREAD_STATE_RUNNABLE = 0x0004; private const int JVMTI_THREAD_STATE_BLOCKED_ON_MONITOR_ENTER = 0x0400; private const int JVMTI_THREAD_STATE_WAITING_INDEFINITELY = 0x0010; private const int JVMTI_THREAD_STATE_WAITING_WITH_TIMEOUT = 0x0020; private const int JMM_THREAD_STATE_FLAG_SUSPENDED = 0x00100000; private const int JMM_THREAD_STATE_FLAG_NATIVE = 0x00400000; public static void getThreadInfo1(long[] ids, int maxDepth, object result) { #if !FIRST_PASS System.Reflection.ConstructorInfo[] constructors = typeof(java.lang.management.ThreadInfo).GetConstructors( System.Reflection.BindingFlags.Instance | System.Reflection.BindingFlags.NonPublic); foreach (System.Reflection.ConstructorInfo constructor in constructors) { if (constructor.GetParameters().Length == 9) { java.lang.Thread[] threads = (java.lang.Thread[])getThreads(); java.lang.management.ThreadInfo[] threadInfos = (java.lang.management.ThreadInfo[])result; for (int i = 0; i < ids.Length; i++) { long id = ids[i]; for (int t = 0; t < threads.Length; t++) { if (threads[t].getId() == id) { java.lang.Thread thread = threads[t]; int state; // invers to sun.misc.VM.toThreadState switch(thread.getState().ordinal()) { case (int)java.lang.Thread.State.__Enum.RUNNABLE: state = JVMTI_THREAD_STATE_RUNNABLE; break; case (int)java.lang.Thread.State.__Enum.BLOCKED: state = JVMTI_THREAD_STATE_BLOCKED_ON_MONITOR_ENTER; break; case (int)java.lang.Thread.State.__Enum.WAITING: state = JVMTI_THREAD_STATE_WAITING_INDEFINITELY; break; case (int)java.lang.Thread.State.__Enum.TIMED_WAITING: state = JVMTI_THREAD_STATE_WAITING_WITH_TIMEOUT; break; case (int)java.lang.Thread.State.__Enum.TERMINATED: state = JVMTI_THREAD_STATE_TERMINATED; break; case (int)java.lang.Thread.State.__Enum.NEW: state = JVMTI_THREAD_STATE_ALIVE; break; default: state = 0; break; } //TODO set in state JMM_THREAD_STATE_FLAG_SUSPENDED if the thread is suspended java.lang.StackTraceElement[] stacktrace = thread.getStackTrace(); if (maxDepth >= 0 && maxDepth < stacktrace.Length) { java.lang.StackTraceElement[] temp = new java.lang.StackTraceElement[maxDepth]; System.Array.Copy(stacktrace, temp, temp.Length); stacktrace = temp; } object[] parameters = new object[9]; parameters[0] = thread; // thread parameters[1] = state; // state // lockObj // lockOwner parameters[4] = 0; // blockedCount parameters[5] = 0; // blockedTime parameters[6] = -1; // waitedCount parameters[7] = 0; // waitedTime parameters[8] = stacktrace; // stackTrace threadInfos[i] = (java.lang.management.ThreadInfo)constructor.Invoke(parameters); break; } } } return; } } throw new java.lang.InternalError("Constructor for java.lang.management.ThreadInfo not find."); #endif } public static long getThreadTotalCpuTime0(long id) { throw new System.NotImplementedException(); } public static void getThreadTotalCpuTime1(long[] ids, long[] result) { throw new System.NotImplementedException(); } public static long getThreadUserCpuTime0(long id) { throw new System.NotImplementedException(); } public static void getThreadUserCpuTime1(long[] ids, long[] result) { throw new System.NotImplementedException(); } public static void getThreadAllocatedMemory1(long[] ids, long[] result) { throw new System.NotImplementedException(); } public static void setThreadCpuTimeEnabled0(bool enable) { throw new System.NotImplementedException(); } public static void setThreadAllocatedMemoryEnabled0(bool enable) { throw new System.NotImplementedException(); } public static void setThreadContentionMonitoringEnabled0(bool enable) { throw new System.NotImplementedException(); } public static object findMonitorDeadlockedThreads0() { throw new System.NotImplementedException(); } public static object findDeadlockedThreads0() { throw new System.NotImplementedException(); } public static void resetPeakThreadCount0() { throw new System.NotImplementedException(); } public static object dumpThreads0(long[] ids, bool lockedMonitors, bool lockedSynchronizers) { throw new System.NotImplementedException(); } public static void resetContentionTimes0(long tid) { throw new System.NotImplementedException(); } }