summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTomáš Pazdiora <[email protected]>2021-01-06 14:26:48 +0100
committerTomáš Pazdiora <[email protected]>2021-01-06 14:26:48 +0100
commita249ac942811b995e25ed4af02cb748c5c5a284d (patch)
tree5dd7bb10433047c886bbdc805b3b2dff9e657ca7
parentMerge pull request #53 from termhn/patch-1 (diff)
downloadrawaccel-a249ac942811b995e25ed4af02cb748c5c5a284d.tar.xz
rawaccel-a249ac942811b995e25ed4af02cb748c5c5a284d.zip
better information for user when installing/removing driver
-rw-r--r--installer/installer.cpp4
-rw-r--r--uninstaller/uninstaller.cpp23
2 files changed, 24 insertions, 3 deletions
diff --git a/installer/installer.cpp b/installer/installer.cpp
index 916209f..279fefc 100644
--- a/installer/installer.cpp
+++ b/installer/installer.cpp
@@ -53,6 +53,10 @@ int main() {
fs::path target = get_target_path();
+ if (fs::exists(target)) {
+ std::cout << "Driver already installed. Removing previous installation.\n";
+ }
+
add_service(target);
fs::path tmp = make_temp_path(target);
diff --git a/uninstaller/uninstaller.cpp b/uninstaller/uninstaller.cpp
index 8d9e890..bd9c564 100644
--- a/uninstaller/uninstaller.cpp
+++ b/uninstaller/uninstaller.cpp
@@ -4,13 +4,23 @@
int main() {
try {
- modify_upper_filters([](std::vector<std::wstring>& filters) {
- std::erase(filters, DRIVER_NAME);
+ bool reboot_required = false;
+ modify_upper_filters([&reboot_required](std::vector<std::wstring>& filters) {
+ // check if driver is present in upper filters
+ bool driver_present = std::find(filters.begin(), filters.end(), DRIVER_NAME) != filters.end();
+ if (driver_present) {
+ std::erase(filters, DRIVER_NAME);
+ reboot_required = true;
+ }
});
fs::path target = get_target_path();
fs::path tmp = make_temp_path(target);
+ if (fs::exists(target) || fs::exists(tmp)) {
+ reboot_required = true;
+ }
+
// schedule tmp to be deleted if rename target -> tmp is successful
if (MoveFileExW(target.c_str(), tmp.c_str(), MOVEFILE_REPLACE_EXISTING)) {
MoveFileExW(tmp.c_str(), NULL, MOVEFILE_DELAY_UNTIL_REBOOT);
@@ -18,7 +28,14 @@ int main() {
else { // tmp is in use and delete is already scheduled
if (fs::exists(target)) fs::remove(target);
}
- std::cout << "Removal complete, change will take effect after restart.\n";
+
+ if (reboot_required) {
+ std::cout << "Removal complete, change will take effect after restart.\n";
+ }
+ else {
+ std::cout << "No installed driver found.\n";
+ }
+
}
catch (const std::system_error& e) {
std::cerr << "Error: " << e.what() << ' ' << e.code() << '\n';