aboutsummaryrefslogtreecommitdiff
path: root/toolsrc/src
diff options
context:
space:
mode:
authorCurtis.Bezault <curtbezault@gmail.com>2019-08-09 14:21:58 -0700
committerCurtis.Bezault <curtbezault@gmail.com>2019-08-09 14:21:58 -0700
commit0c7d8f414669c6e025794c374f2837e5fa24d02b (patch)
tree79324956501e2dce1b5032da310bb123b1322010 /toolsrc/src
parentc4f1a91ef245ed3e44ea11f13040a77453126165 (diff)
downloadvcpkg-0c7d8f414669c6e025794c374f2837e5fa24d02b.tar.gz
vcpkg-0c7d8f414669c6e025794c374f2837e5fa24d02b.zip
Change purpose of this PR to just overriding the abi
Diffstat (limited to 'toolsrc/src')
-rw-r--r--toolsrc/src/vcpkg/binaryparagraph.cpp59
-rw-r--r--toolsrc/src/vcpkg/build.cpp128
-rw-r--r--toolsrc/src/vcpkg/dependencies.cpp7
3 files changed, 42 insertions, 152 deletions
diff --git a/toolsrc/src/vcpkg/binaryparagraph.cpp b/toolsrc/src/vcpkg/binaryparagraph.cpp
index ef194f9f3..231380b19 100644
--- a/toolsrc/src/vcpkg/binaryparagraph.cpp
+++ b/toolsrc/src/vcpkg/binaryparagraph.cpp
@@ -25,33 +25,6 @@ namespace vcpkg
static const std::string MAINTAINER = "Maintainer";
static const std::string DEPENDS = "Depends";
static const std::string DEFAULTFEATURES = "Default-Features";
- static const std::string EXTERNALFILES = "External-Files";
- }
-
- bool BinaryParagraph::is_consistent() const
- {
- switch (consistency)
- {
- case ConsistencyState::UNKNOWN :
- for (const auto& file_hash : external_files)
- {
- const auto& realfs = Files::get_real_filesystem();
-
- if (!realfs.is_regular_file(file_hash.first) ||
- Hash::get_file_hash(realfs, file_hash.first, "SHA1") != file_hash.second)
- {
- consistency = ConsistencyState::INCONSISTENT;
- return false;
- }
- }
-
- consistency = ConsistencyState::CONSISTENT;
- return true;
- case ConsistencyState::CONSISTENT : return true;
- case ConsistencyState::INCONSISTENT : return false;
- }
-
- Checks::unreachable(VCPKG_LINE_INFO);
}
BinaryParagraph::BinaryParagraph() = default;
@@ -89,26 +62,6 @@ namespace vcpkg
this->default_features = parse_comma_list(parser.optional_field(Fields::DEFAULTFEATURES));
}
- std::vector<std::string> external_files_or_hashes =
- parse_comma_list(parser.optional_field(Fields::EXTERNALFILES));
-
- if (external_files_or_hashes.size() % 2 != 0)
- {
- Checks::exit_with_message(
- VCPKG_LINE_INFO,
- "The External-Files field is not composed of key-value pairs for ",
- this->spec);
- }
-
- for (decltype(external_files_or_hashes)::size_type i = 0;
- i < external_files_or_hashes.size();
- i += 2)
- {
- external_files.emplace(
- std::move(external_files_or_hashes[i]),
- std::move(external_files_or_hashes[i+1]));
- }
-
if (const auto err = parser.error_info(this->spec.to_string()))
{
System::print2(System::Color::error, "Error: while parsing the Binary Paragraph for ", this->spec, '\n');
@@ -168,17 +121,5 @@ namespace vcpkg
if (!pgh.maintainer.empty()) out_str.append("Maintainer: ").append(pgh.maintainer).push_back('\n');
if (!pgh.abi.empty()) out_str.append("Abi: ").append(pgh.abi).push_back('\n');
if (!pgh.description.empty()) out_str.append("Description: ").append(pgh.description).push_back('\n');
-
- if (!pgh.external_files.empty())
- {
- out_str.append("External-Files: ");
- out_str.append(Strings::join(",",
- Util::fmap(
- pgh.external_files,
- [](const std::pair<fs::path, std::string>& kv)
- {
- return kv.first.u8string() + "," + kv.second;
- }))).push_back('\n');
- }
}
}
diff --git a/toolsrc/src/vcpkg/build.cpp b/toolsrc/src/vcpkg/build.cpp
index 6f14f46f8..147bbe796 100644
--- a/toolsrc/src/vcpkg/build.cpp
+++ b/toolsrc/src/vcpkg/build.cpp
@@ -277,13 +277,6 @@ namespace vcpkg::Build
bpgh.version = *p_ver;
}
- for (auto& file_hash : pre_build_info.external_files)
- {
- bpgh.external_files.emplace(
- file_hash.first.u8string(),
- std::move(file_hash.second));
- }
-
bcf->core_paragraph = std::move(bpgh);
return bcf;
}
@@ -451,45 +444,6 @@ namespace vcpkg::Build
return command;
}
- static std::vector<std::pair<fs::path, std::string>> get_external_file_hashes(
- const VcpkgPaths& paths,
- const std::vector<fs::path>& files)
- {
- static std::map<fs::path, std::string> s_hash_cache;
-
- const auto& fs = paths.get_filesystem();
-
- std::vector<std::pair<fs::path, std::string>> hashes;
- for (const fs::path& external_file : files)
- {
- auto it_hash = s_hash_cache.find(external_file);
-
- if (it_hash != s_hash_cache.end())
- {
- hashes.emplace_back(external_file, it_hash->second);
- }
- else if (Files::get_real_filesystem().is_regular_file(external_file))
- {
- auto emp = s_hash_cache.emplace(
- external_file.u8string(),
- Hash::get_file_hash(
- Files::get_real_filesystem(),
- external_file, "SHA1"));
-
- hashes.emplace_back(external_file.u8string(), emp.first->second);
- }
- else
- {
- Checks::exit_with_message(
- VCPKG_LINE_INFO,
- external_file.u8string() +
- " was listed as an additional file for calculating the abi, but was not found.");
- }
- }
-
- return hashes;
- }
-
static std::string get_triplet_abi(const VcpkgPaths& paths,
const PreBuildInfo& pre_build_info,
const Triplet& triplet)
@@ -645,6 +599,15 @@ namespace vcpkg::Build
const PreBuildInfo& pre_build_info,
Span<const AbiEntry> dependency_abis)
{
+ if (pre_build_info.public_abi_override)
+ {
+ return AbiTagAndFile
+ {
+ "override",
+ pre_build_info.public_abi_override.value_or_exit(VCPKG_LINE_INFO)
+ };
+ }
+
auto& fs = paths.get_filesystem();
const Triplet& triplet = config.triplet;
const std::string& name = config.scf.core_paragraph->name;
@@ -694,29 +657,6 @@ namespace vcpkg::Build
}
}
- //Make a copy of the external file names and their hashes, and sort by
- //hash.
- std::vector<std::pair<std::string, std::string>> additional_file_hashes
- = Util::fmap(pre_build_info.external_files,
- [](const std::pair<fs::path, std::string>& file_hash)
- {
- return std::pair<std::string, std::string>{
- file_hash.second,
- file_hash.first.filename().u8string()
- };
- });
-
- std::sort(additional_file_hashes.begin(), additional_file_hashes.end());
-
- for (auto& hash_file : additional_file_hashes)
- {
- abi_tag_entries.emplace_back(
- AbiEntry{
- std::move(hash_file.second),
- std::move(hash_file.first)
- });
- }
-
abi_tag_entries.emplace_back(AbiEntry{"cmake", paths.get_tool_version(Tools::CMAKE)});
abi_tag_entries.emplace_back(AbiEntry{
@@ -835,11 +775,16 @@ namespace vcpkg::Build
if (!required_fspecs.empty())
{
- return {BuildResult::CASCADED_DUE_TO_MISSING_DEPENDENCIES, std::move(required_fspecs)};
+ return {
+ BuildResult::CASCADED_DUE_TO_MISSING_DEPENDENCIES,
+ std::move(required_fspecs)
+ };
}
const PackageSpec spec =
- PackageSpec::from_name_and_triplet(config.scf.core_paragraph->name, triplet).value_or_exit(VCPKG_LINE_INFO);
+ PackageSpec::from_name_and_triplet(
+ config.scf.core_paragraph->name,
+ triplet).value_or_exit(VCPKG_LINE_INFO);
std::vector<AbiEntry> dependency_abis;
@@ -856,15 +801,27 @@ namespace vcpkg::Build
const auto pre_build_info = PreBuildInfo::from_triplet_file(paths, triplet, config.scfl);
auto maybe_abi_tag_and_file = compute_abi_tag(paths, config, pre_build_info, dependency_abis);
+ if (!maybe_abi_tag_and_file)
+ {
+ return do_build_package_and_clean_buildtrees(
+ paths,
+ pre_build_info,
+ spec,
+ AbiTagAndFile{}.tag,
+ config);
+ }
+ std::error_code ec;
const auto abi_tag_and_file = maybe_abi_tag_and_file.get();
const fs::path archives_root_dir = paths.root / "archives";
const std::string archive_name = abi_tag_and_file->tag + ".zip";
const fs::path archive_subpath = fs::u8path(abi_tag_and_file->tag.substr(0, 2)) / archive_name;
const fs::path archive_path = archives_root_dir / archive_subpath;
const fs::path archive_tombstone_path = archives_root_dir / "fail" / archive_subpath;
+ const fs::path abi_package_dir = paths.package_dir(spec) / "share" / spec.name();
+ const fs::path abi_file_in_package = paths.package_dir(spec) / "share" / spec.name() / "vcpkg_abi_info.txt";
- if (config.build_package_options.binary_caching == BinaryCaching::YES && abi_tag_and_file)
+ if (config.build_package_options.binary_caching == BinaryCaching::YES)
{
if (fs.exists(archive_path))
{
@@ -900,20 +857,19 @@ namespace vcpkg::Build
System::printf("Could not locate cached archive: %s\n", archive_path.u8string());
}
+ fs.create_directories(abi_package_dir, ec);
+ Checks::check_exit(VCPKG_LINE_INFO, !ec, "Coud not create directory %s", abi_package_dir.u8string());
+ fs.copy_file(abi_tag_and_file->tag_file, abi_file_in_package, fs::stdfs::copy_options::none, ec);
+ Checks::check_exit(VCPKG_LINE_INFO, !ec, "Could not copy into file: %s", abi_file_in_package.u8string());
+
ExtendedBuildResult result =
do_build_package_and_clean_buildtrees(
paths,
pre_build_info,
spec,
- maybe_abi_tag_and_file.value_or(AbiTagAndFile{}).tag,
+ maybe_abi_tag_and_file.value_or_exit(VCPKG_LINE_INFO).tag,
config);
- std::error_code ec;
- fs.create_directories(paths.package_dir(spec) / "share" / spec.name(), ec);
- auto abi_file_in_package = paths.package_dir(spec) / "share" / spec.name() / "vcpkg_abi_info.txt";
- fs.copy_file(abi_tag_and_file->tag_file, abi_file_in_package, fs::stdfs::copy_options::none, ec);
- Checks::check_exit(VCPKG_LINE_INFO, !ec, "Could not copy into file: %s", abi_file_in_package.u8string());
-
if (config.build_package_options.binary_caching == BinaryCaching::YES &&
result.code == BuildResult::SUCCEEDED)
{
@@ -1098,6 +1054,8 @@ namespace vcpkg::Build
PreBuildInfo pre_build_info;
+ pre_build_info.port = port;
+
const auto e = lines.cend();
auto cur = std::find(lines.cbegin(), e, FLAG_GUID);
if (cur != e) ++cur;
@@ -1154,15 +1112,9 @@ namespace vcpkg::Build
case VcpkgTripletVar::ENV_PASSTHROUGH :
pre_build_info.passthrough_env_vars = Strings::split(variable_value, ";");
break;
- case VcpkgTripletVar::EXTERNAL_FILES :
- pre_build_info.external_files =
- get_external_file_hashes(
- paths,
- Util::fmap(Strings::split(variable_value, ";"),
- [](const std::string& path)
- {
- return fs::path{path};
- }));
+ case VcpkgTripletVar::PUBLIC_ABI_OVERRIDE :
+ pre_build_info.public_abi_override =
+ variable_value.empty() ? nullopt : Optional<std::string>{variable_value};
break;
}
}
diff --git a/toolsrc/src/vcpkg/dependencies.cpp b/toolsrc/src/vcpkg/dependencies.cpp
index c175cc86f..8c8b2f810 100644
--- a/toolsrc/src/vcpkg/dependencies.cpp
+++ b/toolsrc/src/vcpkg/dependencies.cpp
@@ -663,16 +663,13 @@ namespace vcpkg::Dependencies
if (auto p_installed = cluster.installed.get())
{
- if (p_installed->original_features.find(feature) != p_installed->original_features.end() &&
- p_installed->ipv.core->package.is_consistent())
+ if (p_installed->original_features.find(feature) != p_installed->original_features.end())
{
return MarkPlusResult::SUCCESS;
}
}
- //The feature was not previously installed or the external files of the
- //port are no longer consistent with the last installation of this port
- //(they've either been modified or removed). Mark the cluster
+ //The feature was not previously installed. Mark the cluster
//(aka the entire port) to be removed before re-adding it.
mark_minus(cluster, graph, graph_plan, prevent_default_features);