Commit 91475997 authored by Hleb Shauchenka's avatar Hleb Shauchenka
Browse files

uni-sync: 0.2.0 -> 0.3.1



Use `finalAttrs` instead of `rec`

Co-authored-by: default avataryunfachi <yunfachi@gmail.com>
parent 85f5bb8e
Loading
Loading
Loading
Loading
+0 −38
Original line number Diff line number Diff line
diff --git a/src/main.rs b/src/main.rs
index 357a33b..7073497 100644
--- a/src/main.rs
+++ b/src/main.rs
@@ -1,4 +1,4 @@
-use std::env;
+use std::path::PathBuf;
 
 mod devices;
 
@@ -8,12 +8,23 @@ fn main() -> Result<(), std::io::Error> {
         configs: vec![]
     };
 
-    let mut config_path = env::current_exe()?;
-    config_path.pop();
-    config_path.push("uni-sync.json");
+    let mut config_path = PathBuf::from("/etc/uni-sync/uni-sync.json");
 
     if !config_path.exists() {
-        std::fs::write(&config_path, serde_json::to_string_pretty(&configs).unwrap())?;
+        match std::fs::create_dir_all(config_path.parent().unwrap()) {
+            Ok(result) => result,
+            Err(_) => {
+                println!("Please run uni-sync with elevated permissions.");
+                std::process::exit(0);
+            }
+        };
+        match std::fs::write(&config_path, serde_json::to_string_pretty(&configs).unwrap()) {
+            Ok(result) => result,
+            Err(_) => {
+                println!("Please run uni-sync with elevated permissions.");
+                std::process::exit(0);
+            }
+        };
     }
 
     let config_content = std::fs::read_to_string(&config_path).unwrap();
+6 −7
Original line number Diff line number Diff line
@@ -2,13 +2,12 @@ diff --git a/src/main.rs b/src/main.rs
index f07cc64..357a33b 100644
--- a/src/main.rs
+++ b/src/main.rs
@@ -20,7 +20,7 @@ fn main() -> Result<(), std::io::Error> {
     configs = serde_json::from_str::<devices::Configs>(&config_content).unwrap();
@@ -46,7 +46,7 @@ fn main() -> Result<(), std::io::Error> {
     configs = serde_json::from_str::<devices::Configs>(&config_content)?;

     let new_configs = devices::run(configs);
-    std::fs::write(&config_path, serde_json::to_string_pretty(&new_configs).unwrap())?;
+    std::fs::write(&config_path, serde_json::to_string_pretty(&new_configs).unwrap());
-    std::fs::write(&config_path, serde_json::to_string_pretty(&new_configs)?)?;
+    let _ = std::fs::write(&config_path, serde_json::to_string_pretty(&new_configs)?);

     Ok(())
 }
\ No newline at end of file
+8 −9
Original line number Diff line number Diff line
@@ -3,28 +3,27 @@
  fetchFromGitHub,
  rustPlatform,
  pkg-config,
  libudev-zero,
  libusb1,
}:
rustPlatform.buildRustPackage {
rustPlatform.buildRustPackage (finalAttrs: {
  pname = "uni-sync";
  version = "0.2.0";
  version = "0.3.1";

  src = fetchFromGitHub {
    owner = "EightB1ts";
    repo = "uni-sync";
    rev = "ca349942c06fabcc028ce24e79fc6ce7c758452b";
    hash = "sha256-K2zX3rKtTaKO6q76xlxX+rDLL0gEsJ2l8x/s1vsp+ZQ=";
    rev = finalAttrs.version;
    hash = "sha256-Qf4tDj55dBHcnCiSEoWt+uwq/gTm0DSTzlOvdw3QThU=";
  };

  nativeBuildInputs = [ pkg-config ];
  buildInputs = [ libudev-zero ];
  buildInputs = [ libusb1 ];

  patches = [
    ./config_path.patch
    ./ignore_read-only_filesystem.patch
  ];

  cargoHash = "sha256-Qb0TPpYGDjsqHkI4B8QRz5c9rqZ+H98YjOg5K++zpBg=";
  cargoHash = "sha256-ot2pbCddvw3njsz36WbFFJ9AAtmojUnRxlUbym1RcgU=";

  meta = with lib; {
    description = "Synchronization tool for Lian Li Uni Controllers";
@@ -33,4 +32,4 @@ rustPlatform.buildRustPackage {
    maintainers = with maintainers; [ yunfachi ];
    mainProgram = "uni-sync";
  };
}
})