|
@@ -1,6 +1,4 @@
|
|
|
|
|
|
|
|
-#include <ThirdParty/SDL/include/SDL.h>
|
|
|
|
|
-
|
|
|
|
|
#include <Atomic/Core/CoreEvents.h>
|
|
#include <Atomic/Core/CoreEvents.h>
|
|
|
#include <Atomic/IO/FileSystem.h>
|
|
#include <Atomic/IO/FileSystem.h>
|
|
|
#include <Atomic/IO/Log.h>
|
|
#include <Atomic/IO/Log.h>
|
|
@@ -15,63 +13,12 @@
|
|
|
#ifdef ATOMIC_PLATFORM_WINDOWS
|
|
#ifdef ATOMIC_PLATFORM_WINDOWS
|
|
|
#include "Platforms/Windows/NETHostWindows.h"
|
|
#include "Platforms/Windows/NETHostWindows.h"
|
|
|
#else
|
|
#else
|
|
|
|
|
+#include "Platforms/Unix/NETHostUnix.h"
|
|
|
#endif
|
|
#endif
|
|
|
|
|
|
|
|
namespace Atomic
|
|
namespace Atomic
|
|
|
{
|
|
{
|
|
|
|
|
|
|
|
-/*
|
|
|
|
|
-mcs /nostdlib /noconfig /r:System.Console.dll /r:System.Runtime.dll /r:System.IO.dll /r:System.IO.FileSystem.dll /r:mscorlib.dll HelloWorld.cs
|
|
|
|
|
-
|
|
|
|
|
-export PAL_DBG_CHANNELS="+all.all"
|
|
|
|
|
-*/
|
|
|
|
|
-
|
|
|
|
|
-
|
|
|
|
|
-#ifdef ATOMIC_PLATFORM_OSX
|
|
|
|
|
-static const char * const sCoreClrDll = "libcoreclr.dylib";
|
|
|
|
|
-#elif ATOMIC_PLATFORM_WINDOWS
|
|
|
|
|
-static const char * const sCoreClrDll = "coreclr.dll";
|
|
|
|
|
-#else
|
|
|
|
|
-static const char * const sCoreClrDll = "libcoreclr.so";
|
|
|
|
|
-#endif
|
|
|
|
|
-
|
|
|
|
|
-// Prototype of the coreclr_initialize function from the libcoreclr.so
|
|
|
|
|
-typedef int (*InitializeCoreCLRFunction)(
|
|
|
|
|
- const char* exePath,
|
|
|
|
|
- const char* appDomainFriendlyName,
|
|
|
|
|
- int propertyCount,
|
|
|
|
|
- const char** propertyKeys,
|
|
|
|
|
- const char** propertyValues,
|
|
|
|
|
- void** hostHandle,
|
|
|
|
|
- unsigned int* domainId);
|
|
|
|
|
-
|
|
|
|
|
-// Prototype of the coreclr_shutdown function from the libcoreclr.so
|
|
|
|
|
-typedef int (*ShutdownCoreCLRFunction)(
|
|
|
|
|
- void* hostHandle,
|
|
|
|
|
- unsigned int domainId);
|
|
|
|
|
-
|
|
|
|
|
-// Prototype of the coreclr_execute_assembly function from the libcoreclr.so
|
|
|
|
|
-typedef int (*ExecuteAssemblyFunction)(
|
|
|
|
|
- void* hostHandle,
|
|
|
|
|
- unsigned int domainId,
|
|
|
|
|
- int argc,
|
|
|
|
|
- const char** argv,
|
|
|
|
|
- const char* managedAssemblyPath,
|
|
|
|
|
- unsigned int* exitCode);
|
|
|
|
|
-
|
|
|
|
|
-typedef int (*CreateDelegateFunction)(
|
|
|
|
|
- void* hostHandle,
|
|
|
|
|
- unsigned int domainId,
|
|
|
|
|
- const char* entryPointAssemblyName,
|
|
|
|
|
- const char* entryPointTypeName,
|
|
|
|
|
- const char* entryPointMethodName,
|
|
|
|
|
- void** delegate);
|
|
|
|
|
-
|
|
|
|
|
-static InitializeCoreCLRFunction sInitializeCoreCLR = 0;
|
|
|
|
|
-static ExecuteAssemblyFunction sExecuteAssembly = 0;
|
|
|
|
|
-static CreateDelegateFunction sCreateDelegate = 0;
|
|
|
|
|
-static ShutdownCoreCLRFunction sShutdownCoreCLR = 0;
|
|
|
|
|
-
|
|
|
|
|
/// Register NETCore library objects.
|
|
/// Register NETCore library objects.
|
|
|
void ATOMIC_API RegisterNETCoreLibrary(Context* context);
|
|
void ATOMIC_API RegisterNETCoreLibrary(Context* context);
|
|
|
|
|
|
|
@@ -79,10 +26,7 @@ WeakPtr<Context> NETCore::csContext_;
|
|
|
WeakPtr<NETCore> NETCore::instance_;
|
|
WeakPtr<NETCore> NETCore::instance_;
|
|
|
|
|
|
|
|
NETCore::NETCore(Context* context) :
|
|
NETCore::NETCore(Context* context) :
|
|
|
- Object(context),
|
|
|
|
|
- coreCLRDLLHandle_(0),
|
|
|
|
|
- hostHandle_(0),
|
|
|
|
|
- domainId_(0)
|
|
|
|
|
|
|
+ Object(context)
|
|
|
{
|
|
{
|
|
|
RegisterNETCoreLibrary(context_);
|
|
RegisterNETCoreLibrary(context_);
|
|
|
|
|
|
|
@@ -93,6 +37,7 @@ NETCore::NETCore(Context* context) :
|
|
|
|
|
|
|
|
NETCore::~NETCore()
|
|
NETCore::~NETCore()
|
|
|
{
|
|
{
|
|
|
|
|
+ Shutdown();
|
|
|
context_->RemoveGlobalEventListener(context_->GetSubsystem<CSEventDispatcher>());
|
|
context_->RemoveGlobalEventListener(context_->GetSubsystem<CSEventDispatcher>());
|
|
|
context_->RemoveSubsystem(CSEventDispatcher::GetTypeStatic());
|
|
context_->RemoveSubsystem(CSEventDispatcher::GetTypeStatic());
|
|
|
context_->RemoveSubsystem(NETManaged::GetTypeStatic());
|
|
context_->RemoveSubsystem(NETManaged::GetTypeStatic());
|
|
@@ -100,110 +45,18 @@ NETCore::~NETCore()
|
|
|
instance_ = NULL;
|
|
instance_ = NULL;
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
-void NETCore::GenerateTPAList(String& tpaList)
|
|
|
|
|
-{
|
|
|
|
|
-#ifdef disabled
|
|
|
|
|
- tpaList = String::EMPTY;
|
|
|
|
|
-
|
|
|
|
|
- FileSystem* fs = GetSubsystem<FileSystem>();
|
|
|
|
|
- Vector<String> results;
|
|
|
|
|
- fs->ScanDir(results, coreCLRFilesAbsPath_, "*.dll", SCAN_FILES, true);
|
|
|
|
|
-
|
|
|
|
|
- Vector<String> trustedAssemblies;
|
|
|
|
|
-
|
|
|
|
|
- for (unsigned i = 0; i < results.Size(); i++)
|
|
|
|
|
- {
|
|
|
|
|
- const String& assembly = results[i];
|
|
|
|
|
-
|
|
|
|
|
- // TODO: apply filtering if necessary
|
|
|
|
|
- trustedAssemblies.Push(coreCLRFilesAbsPath_ + assembly);
|
|
|
|
|
- }
|
|
|
|
|
-
|
|
|
|
|
- // trustedAssemblies.Push(coreCLRFilesAbsPath_ + "HelloWorld.exe");
|
|
|
|
|
-
|
|
|
|
|
- tpaList.Join(trustedAssemblies, ":");
|
|
|
|
|
-
|
|
|
|
|
- // LOGINFOF("NetCore:: TPALIST - %s", tpaList.CString());
|
|
|
|
|
-#endif
|
|
|
|
|
-
|
|
|
|
|
-}
|
|
|
|
|
-
|
|
|
|
|
void NETCore::Shutdown()
|
|
void NETCore::Shutdown()
|
|
|
{
|
|
{
|
|
|
- RefCounted::SetRefCountedDeletedFunction(0);
|
|
|
|
|
-
|
|
|
|
|
- if (sShutdownCoreCLR && hostHandle_)
|
|
|
|
|
- {
|
|
|
|
|
- sShutdownCoreCLR(hostHandle_, domainId_);
|
|
|
|
|
- }
|
|
|
|
|
-
|
|
|
|
|
- if (coreCLRDLLHandle_)
|
|
|
|
|
- {
|
|
|
|
|
- SDL_UnloadObject(coreCLRDLLHandle_);
|
|
|
|
|
- }
|
|
|
|
|
-
|
|
|
|
|
- coreCLRDLLHandle_ = 0;
|
|
|
|
|
- hostHandle_ = 0;
|
|
|
|
|
- domainId_ = 0;
|
|
|
|
|
- sInitializeCoreCLR = 0;
|
|
|
|
|
- sExecuteAssembly = 0;
|
|
|
|
|
- sCreateDelegate = 0;
|
|
|
|
|
- sShutdownCoreCLR = 0;
|
|
|
|
|
-
|
|
|
|
|
-}
|
|
|
|
|
-
|
|
|
|
|
-bool NETCore::InitCoreCLRDLL(String& errorMsg)
|
|
|
|
|
-{
|
|
|
|
|
-#ifdef disabled
|
|
|
|
|
- String coreClrDllPath = AddTrailingSlash(coreCLRFilesAbsPath_) + sCoreClrDll;
|
|
|
|
|
-
|
|
|
|
|
- coreCLRDLLHandle_ = SDL_LoadObject(coreClrDllPath.CString());
|
|
|
|
|
-
|
|
|
|
|
- if (coreCLRDLLHandle_ == NULL)
|
|
|
|
|
- {
|
|
|
|
|
- errorMsg = ToString("NETCore: Unable to load %s with error %s",
|
|
|
|
|
- coreClrDllPath.CString(),
|
|
|
|
|
- SDL_GetError());
|
|
|
|
|
- return false;
|
|
|
|
|
- }
|
|
|
|
|
-
|
|
|
|
|
- sInitializeCoreCLR = (InitializeCoreCLRFunction) SDL_LoadFunction(coreCLRDLLHandle_, "coreclr_initialize");
|
|
|
|
|
-
|
|
|
|
|
- if (!sInitializeCoreCLR)
|
|
|
|
|
- {
|
|
|
|
|
- errorMsg = ToString("NETCore: Unable to get coreclr_initialize entry point in %s", coreClrDllPath.CString());
|
|
|
|
|
- return false;
|
|
|
|
|
- }
|
|
|
|
|
-
|
|
|
|
|
- sShutdownCoreCLR = (ShutdownCoreCLRFunction) SDL_LoadFunction(coreCLRDLLHandle_, "coreclr_shutdown");
|
|
|
|
|
|
|
|
|
|
- if (!sShutdownCoreCLR)
|
|
|
|
|
- {
|
|
|
|
|
- errorMsg = ToString("NETCore: Unable to get coreclr_shutdown entry point in %s", coreClrDllPath.CString());
|
|
|
|
|
- return false;
|
|
|
|
|
- }
|
|
|
|
|
-
|
|
|
|
|
- sCreateDelegate = (CreateDelegateFunction) SDL_LoadFunction(coreCLRDLLHandle_, "coreclr_create_delegate");
|
|
|
|
|
-
|
|
|
|
|
- if (!sCreateDelegate)
|
|
|
|
|
- {
|
|
|
|
|
- errorMsg = ToString("NETCore: Unable to get coreclr_create_delegate entry point in %s", coreClrDllPath.CString());
|
|
|
|
|
- return false;
|
|
|
|
|
- }
|
|
|
|
|
-
|
|
|
|
|
- sExecuteAssembly = (ExecuteAssemblyFunction) SDL_LoadFunction(coreCLRDLLHandle_, "coreclr_execute_assembly");
|
|
|
|
|
|
|
+ RefCounted::SetRefCountedDeletedFunction(0);
|
|
|
|
|
|
|
|
- if (!sExecuteAssembly)
|
|
|
|
|
|
|
+ if (netHost_.NotNull())
|
|
|
{
|
|
{
|
|
|
- errorMsg = ToString("NETCore: Unable to get coreclr_execute_assembly entry point in %s", coreClrDllPath.CString());
|
|
|
|
|
- return false;
|
|
|
|
|
|
|
+ netHost_->Shutdown();
|
|
|
|
|
+ netHost_ = 0;
|
|
|
}
|
|
}
|
|
|
-#endif
|
|
|
|
|
-
|
|
|
|
|
- return true;
|
|
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
-
|
|
|
|
|
extern "C"
|
|
extern "C"
|
|
|
{
|
|
{
|
|
|
|
|
|
|
@@ -268,232 +121,77 @@ void NETCore::AddAssemblyLoadPath(const String& assemblyPath)
|
|
|
|
|
|
|
|
bool NETCore::CreateDelegate(const String& assemblyName, const String& qualifiedClassName, const String& methodName, void** funcOut)
|
|
bool NETCore::CreateDelegate(const String& assemblyName, const String& qualifiedClassName, const String& methodName, void** funcOut)
|
|
|
{
|
|
{
|
|
|
-
|
|
|
|
|
return netHost_->CreateDelegate(assemblyName, qualifiedClassName, methodName, funcOut);
|
|
return netHost_->CreateDelegate(assemblyName, qualifiedClassName, methodName, funcOut);
|
|
|
-
|
|
|
|
|
- /*
|
|
|
|
|
- if (!sCreateDelegate)
|
|
|
|
|
- return false;
|
|
|
|
|
-
|
|
|
|
|
- *funcOut = 0;
|
|
|
|
|
-
|
|
|
|
|
- // TODO: wrap in SharedPtr to control delegate lifetime?
|
|
|
|
|
- int st = sCreateDelegate(hostHandle_,
|
|
|
|
|
- domainId_,
|
|
|
|
|
- assemblyName.CString(),
|
|
|
|
|
- qualifiedClassName.CString(),
|
|
|
|
|
- methodName.CString(),
|
|
|
|
|
- funcOut);
|
|
|
|
|
-
|
|
|
|
|
- // ensure ptr isn't uninitialized
|
|
|
|
|
- if (st < 0)
|
|
|
|
|
- *funcOut = 0;
|
|
|
|
|
-
|
|
|
|
|
- return st >= 0;
|
|
|
|
|
- */
|
|
|
|
|
-
|
|
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
bool NETCore::Initialize(String& errorMsg)
|
|
bool NETCore::Initialize(String& errorMsg)
|
|
|
{
|
|
{
|
|
|
|
|
+
|
|
|
#ifdef ATOMIC_PLATFORM_WINDOWS
|
|
#ifdef ATOMIC_PLATFORM_WINDOWS
|
|
|
netHost_ = new NETHostWindows(context_);
|
|
netHost_ = new NETHostWindows(context_);
|
|
|
#else
|
|
#else
|
|
|
|
|
+ netHost_ = new NETHostUnix(context_);
|
|
|
#endif
|
|
#endif
|
|
|
|
|
|
|
|
- netHost_->Initialize();
|
|
|
|
|
-
|
|
|
|
|
- SharedPtr<NETManaged> managed(new NETManaged(context_));
|
|
|
|
|
- context_->RegisterSubsystem(managed);
|
|
|
|
|
-
|
|
|
|
|
- SharedPtr<CSEventDispatcher> dispatcher(new CSEventDispatcher(context_));
|
|
|
|
|
- context_->RegisterSubsystem(dispatcher);
|
|
|
|
|
- context_->AddGlobalEventListener(dispatcher);
|
|
|
|
|
-
|
|
|
|
|
- if (!context_->GetEditorContext())
|
|
|
|
|
|
|
+ if (!netHost_->Initialize())
|
|
|
{
|
|
{
|
|
|
- SubscribeToEvent(E_UPDATE, HANDLER(NETCore, HandleUpdate));
|
|
|
|
|
- }
|
|
|
|
|
-
|
|
|
|
|
- managed->Initialize();
|
|
|
|
|
-
|
|
|
|
|
-
|
|
|
|
|
-#ifdef disabled
|
|
|
|
|
-
|
|
|
|
|
- if (!InitCoreCLRDLL(errorMsg))
|
|
|
|
|
- {
|
|
|
|
|
- Shutdown();
|
|
|
|
|
|
|
+ errorMsg = "NETHost Failed to Initialize";
|
|
|
return false;
|
|
return false;
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
- // Allowed property names:
|
|
|
|
|
- // APPBASE
|
|
|
|
|
- // - The base path of the application from which the exe and other assemblies will be loaded
|
|
|
|
|
- //
|
|
|
|
|
- // TRUSTED_PLATFORM_ASSEMBLIES
|
|
|
|
|
- // - The list of complete paths to each of the fully trusted assemblies
|
|
|
|
|
- //
|
|
|
|
|
- // APP_PATHS
|
|
|
|
|
- // - The list of paths which will be probed by the assembly loader
|
|
|
|
|
- //
|
|
|
|
|
- // APP_NI_PATHS
|
|
|
|
|
- // - The list of additional paths that the assembly loader will probe for ngen images
|
|
|
|
|
- //
|
|
|
|
|
- // NATIVE_DLL_SEARCH_DIRECTORIES
|
|
|
|
|
- // - The list of paths that will be probed for native DLLs called by PInvoke
|
|
|
|
|
- //
|
|
|
|
|
-
|
|
|
|
|
- const char *propertyKeys[] = {
|
|
|
|
|
- "TRUSTED_PLATFORM_ASSEMBLIES",
|
|
|
|
|
- "APP_PATHS",
|
|
|
|
|
- "APP_NI_PATHS",
|
|
|
|
|
- "NATIVE_DLL_SEARCH_DIRECTORIES",
|
|
|
|
|
- "AppDomainCompatSwitch"
|
|
|
|
|
- };
|
|
|
|
|
-
|
|
|
|
|
- String tpaList;
|
|
|
|
|
- GenerateTPAList(tpaList);
|
|
|
|
|
-
|
|
|
|
|
- String appPath = coreCLRFilesAbsPath_;// "/Users/josh/Desktop/";
|
|
|
|
|
- Vector<String> nativeSearch;
|
|
|
|
|
- nativeSearch.Push(coreCLRFilesAbsPath_);
|
|
|
|
|
- //nativeSearch.Push("/Users/josh/Dev/atomic/AtomicGameEngine-build/Source/AtomicNET/NETNative");
|
|
|
|
|
- //nativeSearch.Push("/Users/josh/Dev/atomic/AtomicGameEngine-build/Source/AtomicEditor/AtomicEditor.app/Contents/MacOS");
|
|
|
|
|
-
|
|
|
|
|
- String nativeDllSearchDirs;
|
|
|
|
|
- nativeDllSearchDirs.Join(nativeSearch, ":");
|
|
|
|
|
-
|
|
|
|
|
- const char *propertyValues[] = {
|
|
|
|
|
- // TRUSTED_PLATFORM_ASSEMBLIES
|
|
|
|
|
- tpaList.CString(),
|
|
|
|
|
- // APP_PATHS
|
|
|
|
|
- appPath.CString(),
|
|
|
|
|
- // APP_NI_PATHS
|
|
|
|
|
- appPath.CString(),
|
|
|
|
|
- // NATIVE_DLL_SEARCH_DIRECTORIES
|
|
|
|
|
- nativeDllSearchDirs.CString(),
|
|
|
|
|
- // AppDomainCompatSwitch
|
|
|
|
|
- "UseLatestBehaviorWhenTFMNotSpecified"
|
|
|
|
|
- };
|
|
|
|
|
-
|
|
|
|
|
- int st = sInitializeCoreCLR(
|
|
|
|
|
- "AtomicEditor.exe",
|
|
|
|
|
- "NETCore",
|
|
|
|
|
- sizeof(propertyKeys) / sizeof(propertyKeys[0]),
|
|
|
|
|
- propertyKeys,
|
|
|
|
|
- propertyValues,
|
|
|
|
|
- &hostHandle_,
|
|
|
|
|
- &domainId_);
|
|
|
|
|
-
|
|
|
|
|
- if (st < 0)
|
|
|
|
|
- {
|
|
|
|
|
- Shutdown();
|
|
|
|
|
- errorMsg = ToString("NETCore: coreclr_initialize failed - status: 0x%08x\n", st);
|
|
|
|
|
- return false;
|
|
|
|
|
- }
|
|
|
|
|
-
|
|
|
|
|
- typedef void (*StartupFunction)();
|
|
|
|
|
|
|
+ // MOVE THIS!
|
|
|
|
|
+ typedef void (*StartupFunction)(const char* assemblyLoadPaths);
|
|
|
StartupFunction startup;
|
|
StartupFunction startup;
|
|
|
|
|
|
|
|
// The coreclr binding model will become locked upon loading the first assembly that is not on the TPA list, or
|
|
// The coreclr binding model will become locked upon loading the first assembly that is not on the TPA list, or
|
|
|
// upon initializing the default context for the first time. For this test, test assemblies are located alongside
|
|
// upon initializing the default context for the first time. For this test, test assemblies are located alongside
|
|
|
// corerun, and hence will be on the TPA list. So, we should be able to set the default context once successfully,
|
|
// corerun, and hence will be on the TPA list. So, we should be able to set the default context once successfully,
|
|
|
- // and fail on the second try.
|
|
|
|
|
|
|
+ // and fail on the second try.
|
|
|
|
|
|
|
|
// AssemblyLoadContext
|
|
// AssemblyLoadContext
|
|
|
// https://github.com/dotnet/corefx/issues/3054
|
|
// https://github.com/dotnet/corefx/issues/3054
|
|
|
// dnx loader
|
|
// dnx loader
|
|
|
// https://github.com/aspnet/dnx/tree/dev/src/Microsoft.Dnx.Loader
|
|
// https://github.com/aspnet/dnx/tree/dev/src/Microsoft.Dnx.Loader
|
|
|
|
|
|
|
|
- st = sCreateDelegate(hostHandle_,
|
|
|
|
|
- domainId_,
|
|
|
|
|
|
|
+ bool result = netHost_->CreateDelegate(
|
|
|
"AtomicNETBootstrap",
|
|
"AtomicNETBootstrap",
|
|
|
"Atomic.Bootstrap.AtomicLoadContext",
|
|
"Atomic.Bootstrap.AtomicLoadContext",
|
|
|
"Startup",
|
|
"Startup",
|
|
|
(void**) &startup);
|
|
(void**) &startup);
|
|
|
|
|
|
|
|
- if (st >= 0)
|
|
|
|
|
|
|
+ if (result)
|
|
|
{
|
|
{
|
|
|
- startup();
|
|
|
|
|
|
|
+ startup(netHost_->GetCoreCLRAssemblyLoadPaths().CString());
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
- st = sCreateDelegate(hostHandle_,
|
|
|
|
|
- domainId_,
|
|
|
|
|
|
|
+ // MOVE THIS!
|
|
|
|
|
+ typedef void (*InitializeFunction)();
|
|
|
|
|
+ InitializeFunction init;
|
|
|
|
|
+
|
|
|
|
|
+ result = netHost_->CreateDelegate(
|
|
|
"AtomicNETEngine",
|
|
"AtomicNETEngine",
|
|
|
"AtomicEngine.Atomic",
|
|
"AtomicEngine.Atomic",
|
|
|
"Initialize",
|
|
"Initialize",
|
|
|
- (void**) &startup);
|
|
|
|
|
-
|
|
|
|
|
- if (st >= 0)
|
|
|
|
|
- {
|
|
|
|
|
- startup();
|
|
|
|
|
- }
|
|
|
|
|
-
|
|
|
|
|
- /*
|
|
|
|
|
-
|
|
|
|
|
-
|
|
|
|
|
- RefCountedDeletedFunction rcdFunction;
|
|
|
|
|
-
|
|
|
|
|
- st = sCreateDelegate(hostHandle_,
|
|
|
|
|
- domainId_,
|
|
|
|
|
- "AtomicNETEngine",
|
|
|
|
|
- "AtomicEngine.NativeCore",
|
|
|
|
|
- "RefCountedDeleted",
|
|
|
|
|
- (void**) &rcdFunction);
|
|
|
|
|
-
|
|
|
|
|
- if (st >= 0)
|
|
|
|
|
- {
|
|
|
|
|
- RefCounted::SetRefCountedDeletedFunction(rcdFunction);
|
|
|
|
|
- }
|
|
|
|
|
-
|
|
|
|
|
- NETUpdateFunctionPtr updateFunction;
|
|
|
|
|
-
|
|
|
|
|
- st = sCreateDelegate(hostHandle_,
|
|
|
|
|
- domainId_,
|
|
|
|
|
- "AtomicNETEngine",
|
|
|
|
|
- "AtomicEngine.NativeCore",
|
|
|
|
|
- "NETUpdate",
|
|
|
|
|
- (void**) &updateFunction);
|
|
|
|
|
|
|
+ (void**) &init);
|
|
|
|
|
|
|
|
- if (st >= 0)
|
|
|
|
|
|
|
+ if (result)
|
|
|
{
|
|
{
|
|
|
- GetSubsystem<NETManaged>()->SetNETUpdate(updateFunction);
|
|
|
|
|
|
|
+ init();
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
- typedef void (*InpectAssemblyFuctionPtr)(const char* path);
|
|
|
|
|
-
|
|
|
|
|
- InpectAssemblyFuctionPtr inspectAssembly;
|
|
|
|
|
|
|
+ SharedPtr<NETManaged> managed(new NETManaged(context_));
|
|
|
|
|
+ context_->RegisterSubsystem(managed);
|
|
|
|
|
|
|
|
- st = sCreateDelegate(hostHandle_,
|
|
|
|
|
- domainId_,
|
|
|
|
|
- "AtomicEditor",
|
|
|
|
|
- "AtomicEditor.AtomicEditor",
|
|
|
|
|
- "InspectAssembly",
|
|
|
|
|
- (void**) &inspectAssembly);
|
|
|
|
|
|
|
+ SharedPtr<CSEventDispatcher> dispatcher(new CSEventDispatcher(context_));
|
|
|
|
|
+ context_->RegisterSubsystem(dispatcher);
|
|
|
|
|
+ context_->AddGlobalEventListener(dispatcher);
|
|
|
|
|
|
|
|
- if (st >= 0)
|
|
|
|
|
|
|
+ if (!context_->GetEditorContext())
|
|
|
{
|
|
{
|
|
|
- //inspectAssembly("/Users/josh/Desktop/AtomicNETTest.dll");
|
|
|
|
|
|
|
+ SubscribeToEvent(E_UPDATE, HANDLER(NETCore, HandleUpdate));
|
|
|
}
|
|
}
|
|
|
- */
|
|
|
|
|
-
|
|
|
|
|
-
|
|
|
|
|
- /*
|
|
|
|
|
- unsigned int exitCode;
|
|
|
|
|
-
|
|
|
|
|
- st = sExecuteAssembly(
|
|
|
|
|
- hostHandle_,
|
|
|
|
|
- domainId_,
|
|
|
|
|
- 0,
|
|
|
|
|
- 0,
|
|
|
|
|
- "/Users/josh/Desktop/OSX.x64.Debug/HelloWorld.exe",
|
|
|
|
|
- (unsigned int*)&exitCode);
|
|
|
|
|
- */
|
|
|
|
|
-
|
|
|
|
|
-
|
|
|
|
|
-#endif
|
|
|
|
|
|
|
|
|
|
- return true;
|
|
|
|
|
|
|
+ return managed->Initialize();
|
|
|
|
|
|
|
|
}
|
|
}
|
|
|
|
|
|