++begin
[backups/.git] / filedata.hpp
index 3df81d9378772e0cbab5e5ca9bc17fb6f6a4226f..b339f05f92b2fcc4c425e13c119b56bbb37a8a5b 100644 (file)
@@ -4,19 +4,12 @@
 #include <string>
 #include <set>
 #include <vector>
+#include <cassert>
 
 class FileData {
   public:
     // Construct a FileData object with default values
-    FileData( char,
-              std::string,
-              std::string,
-              std::string,
-              unsigned long long,
-              unsigned long long,
-              std::string,
-              unsigned long long = 0
-              );
+    FileData() {}
 
     char               getFileType()       const { return filetype; }
     const std::string &getPermissions()    const { return permissions; }
@@ -37,7 +30,6 @@ class FileData {
     void setLastBackupDate( unsigned long long arg ) { last_backup_date = arg; }
 
   private:
-    FileData();
     FileData( const FileData & );
 
     char               filetype;
@@ -46,11 +38,16 @@ class FileData {
     std::string        groupname;
     unsigned long long filesize;
     unsigned long long modified_date;
-    std::string        filename;
-
     unsigned long long last_backup_date;
+    std::string        filename;
 };
 
+std::ostream &operator<<( std::ostream &o, const FileData *d );
+std::istream &operator>>( std::istream &i, FileData *d );
+
+std::ostream &operator<<( std::ostream &o, const FileData &d );
+std::istream &operator>>( std::istream &i, FileData &d );
+
 struct FileDataLastBackupCmp {
   bool operator()( const FileData *a, const FileData *b ) {
     return a->getLastBackupDate() < b->getLastBackupDate();
@@ -71,6 +68,8 @@ struct FileDataNameCmp {
     std::less<std::string> cmp;
 };
 
+bool needs_backup( const FileData *before, const FileData *after );
+
 typedef std::set<FileData*,FileDataNameCmp> file_set;
 typedef std::vector<FileData*> file_vector;