static const std::array<const pal::char_t*, deps_entry_t::asset_types::count> s_known_asset_types;
+ pal::string_t deps_file;
pal::string_t library_type;
pal::string_t library_name;
pal::string_t library_version;
}
void deps_json_t::reconcile_libraries_with_targets(
+ const pal::string_t& deps_path,
const json_value& json,
const std::function<bool(const pal::string_t&)>& library_exists_fn,
const std::function<const std::vector<pal::string_t>&(const pal::string_t&, int, bool*)>& get_rel_paths_by_asset_type_fn)
{
+ pal::string_t deps_file = get_filename(deps_path);
+
const auto& libraries = json.at(_X("libraries")).as_object();
for (const auto& library : libraries)
{
entry.relative_path = rel_path;
entry.is_serviceable = serviceable;
entry.is_rid_specific = rid_specific;
+ entry.deps_file = deps_file;
// TODO: Deps file does not follow spec. It uses '\\', should use '/'
replace_char(&entry.relative_path, _X('\\'), _X('/'));
return true;
}
-bool deps_json_t::load_portable(const json_value& json, const pal::string_t& target_name, const rid_fallback_graph_t& rid_fallback_graph)
+bool deps_json_t::load_portable(const pal::string_t& deps_path, const json_value& json, const pal::string_t& target_name, const rid_fallback_graph_t& rid_fallback_graph)
{
if (!process_runtime_targets(json, target_name, rid_fallback_graph, &m_rid_assets))
{
return empty;
};
- reconcile_libraries_with_targets(json, package_exists, get_relpaths);
+ reconcile_libraries_with_targets(deps_path, json, package_exists, get_relpaths);
return true;
}
-bool deps_json_t::load_standalone(const json_value& json, const pal::string_t& target_name)
+bool deps_json_t::load_standalone(const pal::string_t& deps_path, const json_value& json, const pal::string_t& target_name)
{
if (!process_targets(json, target_name, &m_assets))
{
return m_assets.libs[package].by_type[type_index].vec;
};
- reconcile_libraries_with_targets(json, package_exists, get_relpaths);
+ reconcile_libraries_with_targets(deps_path, json, package_exists, get_relpaths);
const auto& json_object = json.as_object();
const auto iter = json_object.find(_X("runtimes"));
trace::verbose(_X("Loading deps file... %s as portable=[%d]"), deps_path.c_str(), portable);
- return (portable) ? load_portable(json, name, rid_fallback_graph) : load_standalone(json, name);
+ return (portable) ? load_portable(deps_path, json, name, rid_fallback_graph) : load_standalone(deps_path, json, name);
}
catch (const std::exception& je)
{
const deps_entry_t& try_ni(const deps_entry_t& entry) const;
private:
- bool load_standalone(const json_value& json, const pal::string_t& target_name);
- bool load_portable(const json_value& json, const pal::string_t& target_name, const rid_fallback_graph_t& rid_fallback_graph);
+ bool load_standalone(const pal::string_t& deps_path, const json_value& json, const pal::string_t& target_name);
+ bool load_portable(const pal::string_t& deps_path, const json_value& json, const pal::string_t& target_name, const rid_fallback_graph_t& rid_fallback_graph);
bool load(bool portable, const pal::string_t& deps_path, const rid_fallback_graph_t& rid_fallback_graph);
bool process_runtime_targets(const json_value& json, const pal::string_t& target_name, const rid_fallback_graph_t& rid_fallback_graph, rid_specific_assets_t* p_assets);
bool process_targets(const json_value& json, const pal::string_t& target_name, deps_assets_t* p_assets);
void reconcile_libraries_with_targets(
+ const pal::string_t& deps_path,
const json_value& json,
const std::function<bool(const pal::string_t&)>& library_exists_fn,
const std::function<const std::vector<pal::string_t>&(const pal::string_t&, int, bool*)>& get_rel_paths_by_asset_type_fn);
continue;
}
pal::string_t probe_dir = config.probe_dir;
-
- if (config.probe_deps_json)
+
+ if (config.probe_deps_json)
{
// If the deps json has the package name and version, then someone has already done rid selection and
// put the right asset in the dir. So checking just package name and version would suffice.
bool report_missing_assembly_in_manifest(const deps_entry_t& entry)
{
+ trace::error(_X(
+ "Error: An assembly specified in the application dependencies manifest (%s) was not found:\n"
+ " package: '%s', version: '%s'\n"
+ " path: '%s'"),
+ entry.deps_file.c_str(), entry.library_name.c_str(), entry.library_version.c_str(), entry.relative_path.c_str());
+
if (!entry.runtime_store_manifest_list.empty())
{
- trace::error(_X("Error: assembly specified in the dependencies manifest was not found probably due to missing runtime store associated with %s -- package: '%s', version: '%s', path: '%s'"),
- entry.runtime_store_manifest_list.c_str(), entry.library_name.c_str(), entry.library_version.c_str(), entry.relative_path.c_str());
- }
- else
- {
- trace::error(_X("Error: assembly specified in the dependencies manifest was not found -- package: '%s', version: '%s', path: '%s'"),
- entry.library_name.c_str(), entry.library_version.c_str(), entry.relative_path.c_str());
+ trace::error(_X(
+ " This assembly was expected to be in the local runtime store as the application was published using the following target manifest files:\n"
+ " %s"),
+ entry.runtime_store_manifest_list.c_str());
}
return false;