Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(972)

Unified Diff: Source/core/fileapi/File.h

Issue 157363003: Implement Blob.close(). (Closed) Base URL: https://chromium.googlesource.com/chromium/blink.git@master
Patch Set: Rebased Created 6 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « Source/core/fileapi/Blob.idl ('k') | Source/core/fileapi/File.cpp » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: Source/core/fileapi/File.h
diff --git a/Source/core/fileapi/File.h b/Source/core/fileapi/File.h
index 6c5dd1a2c2acbdff87878de5491b3aae451a56e1..1688f4321291ad239c8c829d9403e5733e8e1b51 100644
--- a/Source/core/fileapi/File.h
+++ b/Source/core/fileapi/File.h
@@ -32,6 +32,7 @@
namespace WebCore {
+class ExecutionContext;
struct FileMetadata;
class KURL;
@@ -75,7 +76,7 @@ public:
return adoptRef(new File(url, metadata));
}
- KURL fileSystemURL() const { ASSERT(m_hasBackingFile); return m_fileSystemURL; }
+ KURL fileSystemURL() const { ASSERT(hasValidFileSystemURL()); return m_fileSystemURL; }
// Create a file with a name exposed to the author (via File.name and associated DOM properties) that differs from the one provided in the path.
static PassRefPtr<File> createWithName(const String& path, const String& name, ContentTypeLookupPolicy policy = WellKnownContentTypes)
@@ -87,16 +88,17 @@ public:
virtual unsigned long long size() const OVERRIDE;
virtual PassRefPtr<Blob> slice(long long start = 0, long long end = std::numeric_limits<long long>::max(), const String& contentType = String()) const OVERRIDE;
+ virtual void close(ExecutionContext*) OVERRIDE;
virtual bool isFile() const OVERRIDE { return true; }
virtual bool hasBackingFile() const OVERRIDE { return m_hasBackingFile; }
virtual void appendTo(BlobData&) const OVERRIDE;
- const String& path() const { ASSERT(m_hasBackingFile); return m_path; }
- const String& name() const { return m_name; }
+ const String& path() const { ASSERT(hasValidFilePath()); return m_path; }
+ const String name() const { return m_name; }
- // This returns the current date and time if the file's last modifiecation date is not known (per spec: http://www.w3.org/TR/FileAPI/#dfn-lastModifiedDate).
+ // This returns the current date and time if the file's last modification date is not known (per spec: http://www.w3.org/TR/FileAPI/#dfn-lastModifiedDate).
double lastModifiedDate() const;
// Returns the relative path of this file in the context of a directory selection.
@@ -116,6 +118,14 @@ private:
File(const String& name, const FileMetadata&);
File(const KURL& fileSystemURL, const FileMetadata&);
+ void invalidateSnapshotMetadata() { m_snapshotSize = -1; }
+
+#ifndef NDEBUG
+ bool hasValidFileSystemURL() const { return hasBackingFile(); }
+ // Instances not backed by a file must have an empty path set.
+ bool hasValidFilePath() const { return hasBackingFile() || m_path.isEmpty(); }
+#endif
+
bool m_hasBackingFile;
String m_path;
String m_name;
@@ -124,7 +134,7 @@ private:
// If m_snapshotSize is negative (initialized to -1 by default), the snapshot metadata is invalid and we retrieve the latest metadata synchronously in size(), lastModifiedTime() and slice().
// Otherwise, the snapshot metadata are used directly in those methods.
- const long long m_snapshotSize;
+ long long m_snapshotSize;
const double m_snapshotModificationTime;
String m_relativePath;
« no previous file with comments | « Source/core/fileapi/Blob.idl ('k') | Source/core/fileapi/File.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698