Skip to content

Commit

Permalink
Remove option to use USVFS prebuilt. (#135)
Browse files Browse the repository at this point in the history
  • Loading branch information
Holt59 authored Jun 3, 2024
1 parent 27483d6 commit d1965ac
Show file tree
Hide file tree
Showing 3 changed files with 13 additions and 159 deletions.
1 change: 0 additions & 1 deletion mob.ini
Original file line number Diff line number Diff line change
Expand Up @@ -89,7 +89,6 @@ lz4 = true
openssl = true
pyqt = true
python = true
usvfs = false

[versions]
vs = 17
Expand Down
11 changes: 0 additions & 11 deletions src/tasks/tasks.h
Original file line number Diff line number Diff line change
Expand Up @@ -646,21 +646,10 @@ namespace mob::tasks {
void do_build_and_install() override;

private:
void fetch_prebuilt();
void fetch_from_source();
void build_and_install_prebuilt();
void build_and_install_from_source();

void download_from_appveyor(arch a);
void copy_prebuilt(arch a);

msbuild create_msbuild_tool(arch a, msbuild::ops o = msbuild::build) const;

std::vector<std::shared_ptr<downloader>>
create_appveyor_downloaders(arch a,
downloader::ops o = downloader::download) const;

std::string prebuilt_directory_name(arch a) const;
};

class zlib : public basic_task<zlib> {
Expand Down
160 changes: 13 additions & 147 deletions src/tasks/usvfs.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@ namespace mob::tasks {

bool usvfs::prebuilt()
{
return conf().prebuilt().get<bool>("usvfs");
return false;
}

fs::path usvfs::source_path()
Expand All @@ -32,68 +32,29 @@ namespace mob::tasks {

void usvfs::do_clean(clean c)
{
if (prebuilt()) {
if (is_set(c, clean::redownload)) {
// the `downloader` class knows how to delete its own files, so
// create the same downloaders and ask them to clean
// delete the whole directory
if (is_set(c, clean::reclone)) {
git_wrap::delete_directory(cx(), source_path());

const auto x86_dls =
create_appveyor_downloaders(arch::x86, downloader::clean);

const auto x64_dls =
create_appveyor_downloaders(arch::x64, downloader::clean);

for (auto dl : x86_dls)
run_tool(*dl);

for (auto dl : x64_dls)
run_tool(*dl);
}
// nothing more to do
return;
}
else {
// delete the whole directory
if (is_set(c, clean::reclone)) {
git_wrap::delete_directory(cx(), source_path());

// nothing more to do
return;
}

if (is_set(c, clean::rebuild)) {
// msbuild clean
run_tool(create_msbuild_tool(arch::x86, msbuild::clean));
run_tool(create_msbuild_tool(arch::x64, msbuild::clean));
}

if (is_set(c, clean::rebuild)) {
// msbuild clean
run_tool(create_msbuild_tool(arch::x86, msbuild::clean));
run_tool(create_msbuild_tool(arch::x64, msbuild::clean));
}
}

void usvfs::do_fetch()
{
if (prebuilt())
fetch_prebuilt();
else
fetch_from_source();
}

void usvfs::do_build_and_install()
{
if (prebuilt())
build_and_install_prebuilt();
else
build_and_install_from_source();
}

void usvfs::fetch_prebuilt()
{
fetch_from_source();
download_from_appveyor(arch::x64);
download_from_appveyor(arch::x86);
}

void usvfs::build_and_install_prebuilt()
void usvfs::do_build_and_install()
{
copy_prebuilt(arch::x86);
copy_prebuilt(arch::x64);
build_and_install_from_source();
}

void usvfs::fetch_from_source()
Expand All @@ -110,41 +71,6 @@ namespace mob::tasks {
run_tool(create_msbuild_tool(arch::x64));
}

void usvfs::download_from_appveyor(arch a)
{
// create all downloaders, run them in parallel

parallel_functions v;

for (auto dl : create_appveyor_downloaders(a))
v.emplace_back("usvfs", [this, dl] {
run_tool(*dl);
});

parallel(v);
}

void usvfs::copy_prebuilt(arch a)
{
const auto path = conf().path();
const auto src = path.build() / prebuilt_directory_name(a);

// dlls and exes to install/bin/
op::copy_glob_to_dir_if_better(cx(), src / "*.dll", path.install_bin(),
op::copy_files);

op::copy_glob_to_dir_if_better(cx(), src / "*.exe", path.install_bin(),
op::copy_files);

// pdbs
op::copy_glob_to_dir_if_better(cx(), src / "*.pdb", path.install_pdbs(),
op::copy_files);

// libs
op::copy_glob_to_dir_if_better(cx(), src / "*.lib", path.install_libs(),
op::copy_files);
}

msbuild usvfs::create_msbuild_tool(arch a, msbuild::ops o) const
{
// usvfs doesn't use "Win32" for 32-bit, it uses "x86"
Expand All @@ -171,64 +97,4 @@ namespace mob::tasks {
.set("BOOST_PATH", path_to_utf8(boost::source_path()))));
}

std::vector<std::shared_ptr<downloader>>
usvfs::create_appveyor_downloaders(arch a, downloader::ops o) const
{
std::string arch_s;

switch (a) {
case arch::x86:
arch_s = "x86";
break;

case arch::x64:
arch_s = "x64";
break;

case arch::dont_care:
default:
cx().bail_out(context::generic, "bad arch");
}

// returns an appveyor downloader for the given filename that outputs into
// build/usvfs_bin[_32]/
auto make_dl = [&](std::string filename) {
const auto u = make_appveyor_artifact_url(a, "usvfs", filename);
const std::string dir = prebuilt_directory_name(a);

auto dl = std::make_shared<downloader>(o);

dl->url(u);
dl->file(conf().path().build() / dir / u.filename());

return dl;
};

std::vector<std::shared_ptr<downloader>> v;

// five downloaders for the pdbs, dlls, libs and exes
v.push_back(make_dl("lib/usvfs_" + arch_s + ".pdb"));
v.push_back(make_dl("lib/usvfs_" + arch_s + ".dll"));
v.push_back(make_dl("lib/usvfs_" + arch_s + ".lib"));
v.push_back(make_dl("bin/usvfs_proxy_" + arch_s + ".exe"));
v.push_back(make_dl("bin/usvfs_proxy_" + arch_s + ".pdb"));

return v;
}

std::string usvfs::prebuilt_directory_name(arch a) const
{
switch (a) {
case arch::x86:
return "usvfs_bin_32";

case arch::x64:
return "usvfs_bin";

case arch::dont_care:
default:
cx().bail_out(context::generic, "bad arch");
}
}

} // namespace mob::tasks

0 comments on commit d1965ac

Please sign in to comment.