From 616fd3f517dadefb8e40e74dde758f17b7af3ebf Mon Sep 17 00:00:00 2001 From: Tristan Konolige Date: Fri, 24 Jul 2020 14:23:31 -0700 Subject: [PATCH] Detailed error message when module loader is not found --- src/runtime/library_module.cc | 19 +++++++++++++++++-- src/runtime/stackvm/stackvm_module.cc | 19 +++++++++++++++++-- 2 files changed, 34 insertions(+), 4 deletions(-) diff --git a/src/runtime/library_module.cc b/src/runtime/library_module.cc index b12a9d195e2ee..651e19cdbd376 100644 --- a/src/runtime/library_module.cc +++ b/src/runtime/library_module.cc @@ -133,9 +133,24 @@ runtime::Module ProcessModuleBlob(const char* mblob, ObjectPtr lib) { CHECK(stream->Read(&import_tree_row_ptr)); CHECK(stream->Read(&import_tree_child_indices)); } else { - std::string fkey = "runtime.module.loadbinary_" + tkey; + std::string loadkey = "runtime.module.loadbinary_"; + std::string fkey = loadkey + tkey; const PackedFunc* f = Registry::Get(fkey); - CHECK(f != nullptr) << "Loader of " << tkey << "(" << fkey << ") is not presented."; + if (f == nullptr) { + std::string loaders = ""; + for (auto name : Registry::ListNames()) { + if (name.rfind(loadkey, 0) == 0) { + if (loaders.size() > 0) { + loaders += ", "; + } + loaders += name.substr(loadkey.size()); + } + } + CHECK(f != nullptr) + << "Binary was created using " << tkey + << " but a loader of that name is not registered. Available loaders are " << loaders + << ". Perhaps you need to recompile with this runtime enabled."; + } Module m = (*f)(static_cast(stream)); modules.emplace_back(m); } diff --git a/src/runtime/stackvm/stackvm_module.cc b/src/runtime/stackvm/stackvm_module.cc index 9e1f1f515f4a4..6c9af1cbeb429 100644 --- a/src/runtime/stackvm/stackvm_module.cc +++ b/src/runtime/stackvm/stackvm_module.cc @@ -101,9 +101,24 @@ class StackVMModuleNode : public runtime::ModuleNode { for (uint64_t i = 0; i < num_imports; ++i) { std::string tkey; CHECK(strm->Read(&tkey)); - std::string fkey = "runtime.module.loadbinary_" + tkey; + std::string loadkey = "runtime.module.loadbinary_"; + std::string fkey = loadkey + tkey; const PackedFunc* f = Registry::Get(fkey); - CHECK(f != nullptr) << "Loader of " << tkey << "(" << fkey << ") is not presented."; + if (f == nullptr) { + std::string loaders = ""; + for (auto name : Registry::ListNames()) { + if (name.rfind(loadkey, 0) == 0) { + if (loaders.size() > 0) { + loaders += ", "; + } + loaders += name.substr(loadkey.size()); + } + } + CHECK(f != nullptr) + << "Binary was created using " << tkey + << " but a loader of that name is not registered. Available loaders are " << loaders + << ". Perhaps you need to recompile with this runtime enabled."; + } Module m = (*f)(static_cast(strm)); n->imports_.emplace_back(std::move(m)); }