about summary refs log tree commit diff
diff options
context:
space:
mode:
-rw-r--r--.flatpak-builder/cache/objects/7b/4e4c09b0bc406e51d17e190e39f3b6bcbf1aa42fc3bbbcfb950a0bf4539430.commit (renamed from .flatpak-builder/cache/objects/f0/cc690b56fe98a4764ec43262f77125e655473aa9b41d7e6f0db18896a6a87c.commit)bin324 -> 324 bytes
-rw-r--r--.flatpak-builder/cache/refs/heads/x86_64-com.lakoliu.Furtherance.Devel.json/init2
-rw-r--r--src/database.rs22
3 files changed, 22 insertions, 2 deletions
diff --git a/.flatpak-builder/cache/objects/f0/cc690b56fe98a4764ec43262f77125e655473aa9b41d7e6f0db18896a6a87c.commit b/.flatpak-builder/cache/objects/7b/4e4c09b0bc406e51d17e190e39f3b6bcbf1aa42fc3bbbcfb950a0bf4539430.commit
index 6c33e47..0085763 100644
--- a/.flatpak-builder/cache/objects/f0/cc690b56fe98a4764ec43262f77125e655473aa9b41d7e6f0db18896a6a87c.commit
+++ b/.flatpak-builder/cache/objects/7b/4e4c09b0bc406e51d17e190e39f3b6bcbf1aa42fc3bbbcfb950a0bf4539430.commit
Binary files differdiff --git a/.flatpak-builder/cache/refs/heads/x86_64-com.lakoliu.Furtherance.Devel.json/init b/.flatpak-builder/cache/refs/heads/x86_64-com.lakoliu.Furtherance.Devel.json/init
index 9f93685..d07bc28 100644
--- a/.flatpak-builder/cache/refs/heads/x86_64-com.lakoliu.Furtherance.Devel.json/init
+++ b/.flatpak-builder/cache/refs/heads/x86_64-com.lakoliu.Furtherance.Devel.json/init
@@ -1 +1 @@
-f0cc690b56fe98a4764ec43262f77125e655473aa9b41d7e6f0db18896a6a87c
+7b4e4c09b0bc406e51d17e190e39f3b6bcbf1aa42fc3bbbcfb950a0bf4539430
diff --git a/src/database.rs b/src/database.rs
index 589ff2d..7050cbb 100644
--- a/src/database.rs
+++ b/src/database.rs
@@ -241,13 +241,33 @@ pub fn retrieve(sort: TaskSort, order: SortOrder) -> Result<Vec<Task>, rusqlite:
 /// Exports the database as CSV.
 /// The delimiter parameter is interpreted as a ASCII character.
 pub fn export_as_csv(sort: TaskSort, order: SortOrder, delimiter: u8) -> anyhow::Result<String> {
+    #[derive(Clone, Debug, serde::Serialize, serde::Deserialize)]
+    struct CSVTask {
+        pub id: i32,
+        pub task_name: String,
+        pub start_time: String,
+        pub stop_time: String,
+        pub tags: String,
+        pub seconds: i64,
+    }
+
     let mut csv_writer = csv::WriterBuilder::new()
         .delimiter(delimiter)
         .from_writer(vec![]);
     let tasks = retrieve(sort, order)?;
 
     for task in tasks {
-        csv_writer.serialize(task)?;
+        let start_time = DateTime::parse_from_rfc3339(&task.start_time).unwrap();
+        let stop_time = DateTime::parse_from_rfc3339(&task.stop_time).unwrap();
+        let duration = stop_time - start_time;
+        csv_writer.serialize(CSVTask{
+            id: task.id,
+            task_name: task.task_name,
+            start_time: task.start_time,
+            stop_time: task.stop_time,
+            tags: task.tags,
+            seconds: duration.num_seconds(),
+        })?;
     }
 
     csv_writer.flush()?;