X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/7dea4b5d3be5500b5a2ffd92e09f767000549e19..67d66b0cf79b9fc02c0450f254584693dbf21d3b:/src/bindings/java/JavaContext.cpp diff --git a/src/bindings/java/JavaContext.cpp b/src/bindings/java/JavaContext.cpp index 7adaaaace8..48e1da96e2 100644 --- a/src/bindings/java/JavaContext.cpp +++ b/src/bindings/java/JavaContext.cpp @@ -1,6 +1,6 @@ /* Context switching within the JVM. */ -/* Copyright (c) 2009-2019. The SimGrid Team. All rights reserved. */ +/* Copyright (c) 2009-2021. The SimGrid Team. All rights reserved. */ /* This program is free software; you can redistribute it and/or modify it * under the terms of the license (GNU LGPL) which comes with this package. */ @@ -8,7 +8,6 @@ #include "JavaContext.hpp" #include "jxbt_utilities.hpp" #include "simgrid/Exception.hpp" -#include "src/simix/smx_private.hpp" #include #include @@ -29,15 +28,14 @@ ContextFactory* java_factory() JavaContextFactory::JavaContextFactory() : ContextFactory() { - xbt_binary_name = xbt_strdup("java"); // Used by the backtrace displayer + xbt_assert(xbt::binary_name == "java"); } JavaContextFactory::~JavaContextFactory()=default; -JavaContext* JavaContextFactory::create_context(std::function code, void_pfn_smxprocess_t cleanup_fun, - smx_actor_t actor) +Context* JavaContextFactory::create_context(std::function&& code, actor::ActorImpl* actor) { - return this->new_context(std::move(code), cleanup_fun, actor); + return this->new_context(std::move(code), actor); } void JavaContextFactory::run_all() @@ -45,8 +43,8 @@ void JavaContextFactory::run_all() SerialThreadContext::run_all(); } -JavaContext::JavaContext(std::function code, void_pfn_smxprocess_t cleanup_func, smx_actor_t process) - : SerialThreadContext(std::move(code), cleanup_func, process, false /* not maestro */) +JavaContext::JavaContext(std::function&& code, smx_actor_t actor) + : SerialThreadContext(std::move(code), actor, false /* not maestro */) { /* ThreadContext already does all we need */ } @@ -57,8 +55,8 @@ void JavaContext::start_hook() //Attach the thread to the JVM JNIEnv *env; - XBT_ATTRIB_UNUSED jint error = __java_vm->AttachCurrentThread((void**)&env, nullptr); - xbt_assert((error == JNI_OK), "The thread could not be attached to the JVM"); + xbt_assert(__java_vm->AttachCurrentThread((void**)&env, nullptr) == JNI_OK, + "The thread could not be attached to the JVM"); this->jenv_ = env; } @@ -66,7 +64,7 @@ void JavaContext::stop_hook() { JNIEnv* env = this->jenv_; env->DeleteGlobalRef(this->jprocess_); - XBT_ATTRIB_UNUSED jint error = __java_vm->DetachCurrentThread(); + jint error = __java_vm->DetachCurrentThread(); if (error != JNI_OK) { /* This is probably a Java thread, ie an actor not created from the XML (and thus from the C++), * but from Java with something like new Process().start(). @@ -75,8 +73,7 @@ void JavaContext::stop_hook() * until run_jprocess(), IIUC. */ jxbt_throw_by_name(env, "org/simgrid/msg/ProcessKilledError", "Process killed"); - // XBT_ERROR("Cannot detach the current thread"); - // simgrid::xbt::Backtrace().display(); + XBT_DEBUG("Cannot detach the current thread"); } }