summary refs log tree commit diff stats
path: root/src/main.rs
diff options
context:
space:
mode:
Diffstat (limited to 'src/main.rs')
-rw-r--r--src/main.rs58
1 files changed, 47 insertions, 11 deletions
diff --git a/src/main.rs b/src/main.rs
index 53cb2f9..8b6cb9a 100644
--- a/src/main.rs
+++ b/src/main.rs
@@ -11,11 +11,10 @@ mod logging;
 mod posts;
 mod user;
 
-fn main() -> error::Result<()> {
+fn main() {
     let arg_matches = &*conf::ARGS;
     let start = time::Instant::now();
-    let logfile = format!("/tmp/clinte_{}.log", *user::NAME);
-    logging::init(&logfile)?;
+    logging::checked_init();
 
     log::info!("clinte starting up!");
     println!("clinte v{}", clap::crate_version!());
@@ -30,26 +29,63 @@ fn main() -> error::Result<()> {
 
     if arg_matches.subcommand_matches("post").is_some() {
         log::info!("New post...");
-        posts::create(&db)?;
+        if let Err(e) = posts::create(&db) {
+            log::error!("Error creating new post");
+            if *conf::DEBUG {
+                log::error!("--> {}", e);
+            }
+            std::process::exit(1);
+        }
     } else if arg_matches.subcommand_matches("update").is_some() {
         let id: u32 = if let Some(val) = arg_matches.subcommand_matches("update_handler") {
-            val.value_of("id").unwrap().parse()?
+            match val.value_of("id").unwrap_or_else(|| "0").parse() {
+                Ok(n) => n,
+                Err(e) => {
+                    log::error!("Couldn't parse ID");
+                    if *conf::DEBUG {
+                        log::error!("--> {}", e);
+                    }
+                    std::process::exit(1);
+                }
+            }
         } else {
             0
         };
         log::info!("Updating post ...");
-        posts::update_handler(&db, id)?;
+        if let Err(e) = posts::update_handler(&db, id) {
+            log::error!("Error updating post {}", id);
+            if *conf::DEBUG {
+                log::error!("--> {}", e);
+            }
+            std::process::exit(1);
+        }
     } else if arg_matches.subcommand_matches("delete").is_some() {
         let id: u32 = if let Some(val) = arg_matches.subcommand_matches("update_handler") {
-            val.value_of("id").unwrap_or_else(|| "0").parse()?
+            match val.value_of("id").unwrap_or_else(|| "0").parse() {
+                Ok(n) => n,
+                Err(_) => {
+                    log::error!("Couldn't parse ID");
+                    std::process::exit(1);
+                }
+            }
         } else {
             0
         };
         log::info!("Deleting post");
-        posts::delete_handler(&db, id)?;
+        if let Err(e) = posts::delete_handler(&db, id) {
+            log::error!("Error deleting post {}", id);
+            if *conf::DEBUG {
+                log::error!("--> {}", e);
+            }
+            std::process::exit(1);
+        }
     }
 
-    posts::display(&db)?;
-
-    Ok(())
+    if let Err(e) = posts::display(&db) {
+        log::error!("Error displaying posts");
+        if *conf::DEBUG {
+            log::error!("--> {}", e);
+        }
+        std::process::exit(1);
+    }
 }
d=299d5ee6bedcf3285951caa515ad35c705a85f89'>^
a263b88 ^



6a3cb14 ^








8f5f24d ^

3368af1 ^
8f5f24d ^

4460dd2 ^















3368af1 ^
8f5f24d ^
3368af1 ^
8f5f24d ^
3368af1 ^


8f5f24d ^
3368af1 ^


8f5f24d ^
3368af1 ^



1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121