Browse Source

updating saving of file

Bartek Przybylski 13 năm trước cách đây
mục cha
commit
58efa22cae
1 tập tin đã thay đổi với 33 bổ sung7 xóa
  1. 33 7
      src/eu/alefzero/owncloud/datamodel/OCFile.java

+ 33 - 7
src/eu/alefzero/owncloud/datamodel/OCFile.java

@@ -18,6 +18,7 @@
 
 package eu.alefzero.owncloud.datamodel;
 
+import java.io.File;
 import java.util.Vector;
 
 import eu.alefzero.owncloud.db.ProviderMeta.ProviderTableMeta;
@@ -32,6 +33,7 @@ public class OCFile {
   private static String TAG = "OCFile";
   
   private long id_;
+  private long parent_id_;
   private long length_;
   private long creation_timestamp_;
   private long modified_timestamp_;
@@ -89,20 +91,39 @@ public class OCFile {
   public long getModificationTimestamp() { return modified_timestamp_; }
   public void setModificationTimestamp(long modification_timestamp) { modified_timestamp_ = modification_timestamp; }
 
+  public String getFileName() {
+    if (path_ != null) {
+      File f = new File(path_);
+      return f.getName();
+    }
+    return null;
+  }
+
   public void save() {
     ContentValues cv = new ContentValues();
     cv.put(ProviderTableMeta.FILE_MODIFIED, modified_timestamp_);
     cv.put(ProviderTableMeta.FILE_CREATION, creation_timestamp_);
     cv.put(ProviderTableMeta.FILE_CONTENT_LENGTH, length_);
     cv.put(ProviderTableMeta.CONTENT_TYPE, mimetype_);
+    cv.put(ProviderTableMeta.FILE_NAME, getFileName());
+    cv.put(ProviderTableMeta.FILE_PARENT, parent_id_);
+    cv.put(ProviderTableMeta.FILE_PATH, path_);
+    cv.put(ProviderTableMeta.FILE_STORAGE_PATH, storage_path_);
+    cv.put(ProviderTableMeta.FILE_ACCOUNT_OWNER, account_.name);
     
-    Uri new_entry = cp_.insert(ProviderTableMeta.CONTENT_URI, cv);
-    try {
-      id_ = Integer.parseInt(new_entry.getEncodedPath());
-    } catch (NumberFormatException e) {
-      Log.e(TAG, "Can't retrieve file id from uri: " + new_entry.toString() +
-                ", reason: " + e.getMessage());
-      id_ = -1; 
+    if (fileExtist()) {
+      cp_.update(ProviderTableMeta.CONTENT_URI,
+                 cv,
+                 ProviderTableMeta._ID + "=?", new String[]{String.valueOf(id_)});
+    } else {
+      Uri new_entry = cp_.insert(ProviderTableMeta.CONTENT_URI, cv);
+      try {
+        id_ = Integer.parseInt(new_entry.getEncodedPath());
+      } catch (NumberFormatException e) {
+        Log.e(TAG, "Can't retrieve file id from uri: " + new_entry.toString() +
+                  ", reason: " + e.getMessage());
+        id_ = -1; 
+      }
     }
   }
   
@@ -125,6 +146,11 @@ public class OCFile {
     return null;
   }
   
+  public void addFile(OCFile file) {
+    file.parent_id_ = id_;
+    file.save();
+  }
+
   private OCFile(ContentProvider cp, Account account) {
     account_ = account;
     cp_ = cp;