summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorOskar <[email protected]>2024-10-19 16:00:16 +0200
committerOskar <[email protected]>2024-10-19 16:00:16 +0200
commit81bdb3db4811b7e8bd29649bcb368932bb5969d3 (patch)
tree398bb23e41b623215099796066d83c8d4a887c3c
parent47228e8f2098135a625b7ef3abf6ab9d26d10a78 (diff)
more functions done, not at all thoroughly tested yet
-rw-r--r--trashsystem2.cpp27
1 files changed, 22 insertions, 5 deletions
diff --git a/trashsystem2.cpp b/trashsystem2.cpp
index 1a2f79d..8e446df 100644
--- a/trashsystem2.cpp
+++ b/trashsystem2.cpp
@@ -3,6 +3,7 @@
#include <unistd.h>
#include <cstdio>
#include <cstdlib>
+#include <ctime>
/*
*
@@ -172,17 +173,34 @@ int64_t determine_highest_id(const initial_path_info &ipi) {
return highest_id;
}
-/*
+
TS_FUNCTION_RESULT get_file_info(const std::filesystem::path &path,
std::vector<trashsys_log_info> &vtli,
const initial_path_info &ipi) {
+
+ if(!std::filesystem::exists(path)) {
+ DEBUG_STREAM( << path << " does not exist" << std::endl);
+ std::cerr << g_argv << ": '"<< std::string(path) << "' No such file or directory." << std::endl;
+ return FUNCTION_FAILURE;
+ }
+
+ if(!std::filesystem::is_regular_file(path) && !std::filesystem::is_directory(path)) {
+ DEBUG_STREAM( << path << " is not a directory or regular file." << std::endl);
+ std::cerr << g_argv << ": '"<< std::string(path) << "' is not a directory or a regular file." << std::endl;
+ return FUNCTION_FAILURE;
+ }
- trashsys_log_info tli(1,1,1,"/","/",1);
+ std::cout << path << std::endl;
+ auto id = determine_highest_id(ipi);
+ auto filesize = std::filesystem::file_size(path);
+ auto trashtime = std::time(nullptr);
+ auto file_name = path.filename();
+ trashsys_log_info tli(id,filesize,trashtime,file_name,path,1);
vtli.push_back(tli);
return FUNCTION_SUCCESS;
}
-*/
+
TS_FUNCTION_RESULT write_log_entry(const initial_path_info &ipi) { // function that writes logs
if(ipi.is_fail()) {}
@@ -366,9 +384,8 @@ int main (int argc, char **argv) {
std::vector<trashsys_log_info> vtli;
for (index = optind ; index < argc ; index++) { // Actual loop that trashes files etc
std::filesystem::path file_to_trash = argv[index];
- //get_file_info(file_to_trash, vtli);
+ get_file_info(file_to_trash, vtli, ipi);
}
- determine_highest_id(ipi);
return 0;
}