From: Jon Turney <jon.turney@dronecode.org.uk>
To: cygwin-apps@cygwin.com
Cc: Jon Turney <jon.turney@dronecode.org.uk>
Subject: [PATCH setup 03/11] Factor out the iteration over archive files to install
Date: Tue, 10 Aug 2021 18:02:20 +0100 [thread overview]
Message-ID: <20210810170228.1690-4-jon.turney@dronecode.org.uk> (raw)
In-Reply-To: <20210810170228.1690-1-jon.turney@dronecode.org.uk>
---
install.cc | 53 +++++++++++++++++++++++++++++++++++++----------------
1 file changed, 37 insertions(+), 16 deletions(-)
diff --git a/install.cc b/install.cc
index 51ec4b5..cec31a9 100644
--- a/install.cc
+++ b/install.cc
@@ -93,7 +93,13 @@ class Installer
private:
bool extract_replace_on_reboot(archive *, const std::string&,
const std::string&, std::string);
-
+ bool _installOne (packagemeta &pkgm,
+ const std::string& prefixURL,
+ const std::string& prefixPath,
+ HWND owner,
+ io_stream *pkgfile,
+ archive *tarstream,
+ io_stream *lst);
};
Installer::Installer() : errors(0)
@@ -529,13 +535,39 @@ Installer::installOne (packagemeta &pkgm, const packageversion &ver,
}
}
+ package_bytes = source.size;
+ Log (LOG_PLAIN) << "Extracting from " << source.Cached () << endLog;
+
+ bool error_in_this_package = _installOne(pkgm, prefixURL, prefixPath, owner,
+ pkgfile, tarstream, lst);
+
+ if (lst)
+ delete lst;
+ delete tarstream;
+
+ total_bytes_sofar += package_bytes;
+ progress (0);
+
+ int df = diskfull (get_root_dir ().c_str ());
+ Progress.SetBar3 (df);
+
+ if (ver.Type () == package_binary && !error_in_this_package)
+ pkgm.installed = ver;
+}
+
+bool
+Installer::_installOne (packagemeta &pkgm,
+ const std::string& prefixURL,
+ const std::string& prefixPath,
+ HWND owner,
+ io_stream *pkgfile,
+ archive *tarstream,
+ io_stream *lst)
+{
bool error_in_this_package = false;
bool ignoreInUseErrors = false;
bool ignoreExtractErrors = unattended_mode;
- package_bytes = source.size;
- Log (LOG_PLAIN) << "Extracting from " << source.Cached () << endLog;
-
std::string fn;
while ((fn = tarstream->next_file_name ()).size ())
{
@@ -725,18 +757,7 @@ Installer::installOne (packagemeta &pkgm, const packageversion &ver,
num_installs++;
}
- if (lst)
- delete lst;
- delete tarstream;
-
- total_bytes_sofar += package_bytes;
- progress (0);
-
- int df = diskfull (get_root_dir ().c_str ());
- Progress.SetBar3 (df);
-
- if (ver.Type () == package_binary && !error_in_this_package)
- pkgm.installed = ver;
+ return error_in_this_package;
}
static void
--
2.32.0
next prev parent reply other threads:[~2021-08-10 17:04 UTC|newest]
Thread overview: 15+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-08-10 17:02 [PATCH setup 00/11] Add options to choose symlink type (v2) Jon Turney
2021-08-10 17:02 ` [PATCH setup 01/11] Add support for creating WSL symlinks Jon Turney
2021-08-10 17:02 ` [PATCH setup 02/11] Add support for creating native symlinks Jon Turney
2021-08-10 17:02 ` Jon Turney [this message]
2021-08-10 17:02 ` [PATCH setup 04/11] Add seek() method to archive and compress file classes Jon Turney
2021-08-10 17:02 ` [PATCH setup 05/11] Add separate symlink-creation phase when extracting archive Jon Turney
2021-08-10 17:02 ` [PATCH setup 06/11] Enable SeCreateSymbolicLink privilege Jon Turney
2021-08-11 8:46 ` Corinna Vinschen
2021-09-14 11:53 ` Jon Turney
2021-08-10 17:02 ` [PATCH setup 07/11] Add symlink capabilities to user-agent telemetry Jon Turney
2021-08-10 17:02 ` [PATCH setup 08/11] Factor out StringChoiceOption Jon Turney
2021-08-10 17:02 ` [PATCH setup 09/11] Add a command line option to choose symlink type used Jon Turney
2021-08-10 17:02 ` [PATCH setup 10/11] Propagate --symlink-type setting to post-install scripts Jon Turney
2021-08-10 17:02 ` [PATCH setup 11/11] Default symlink mode from CYGWIN env var Jon Turney
2021-09-14 11:53 ` [PATCH setup 00/11] Add options to choose symlink type (v2) Jon Turney
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20210810170228.1690-4-jon.turney@dronecode.org.uk \
--to=jon.turney@dronecode.org.uk \
--cc=cygwin-apps@cygwin.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).