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

Side by Side Diff: Source/modules/filesystem/FileWriter.cpp

Issue 188503002: Oilpan: add transition types to FileSystem APIs. (Closed) Base URL: https://chromium.googlesource.com/chromium/blink.git@master
Patch Set: Improve some type names Created 6 years, 9 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 unified diff | Download patch
OLDNEW
1 /* 1 /*
2 * Copyright (C) 2010 Google Inc. All rights reserved. 2 * Copyright (C) 2010 Google Inc. All rights reserved.
3 * 3 *
4 * Redistribution and use in source and binary forms, with or without 4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions are 5 * modification, are permitted provided that the following conditions are
6 * met: 6 * met:
7 * 7 *
8 * * Redistributions of source code must retain the above copyright 8 * * Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer. 9 * notice, this list of conditions and the following disclaimer.
10 * * Redistributions in binary form must reproduce the above 10 * * Redistributions in binary form must reproduce the above
(...skipping 26 matching lines...) Expand all
37 #include "core/fileapi/Blob.h" 37 #include "core/fileapi/Blob.h"
38 #include "public/platform/WebFileWriter.h" 38 #include "public/platform/WebFileWriter.h"
39 #include "public/platform/WebURL.h" 39 #include "public/platform/WebURL.h"
40 #include "wtf/CurrentTime.h" 40 #include "wtf/CurrentTime.h"
41 41
42 namespace WebCore { 42 namespace WebCore {
43 43
44 static const int kMaxRecursionDepth = 3; 44 static const int kMaxRecursionDepth = 3;
45 static const double progressNotificationIntervalMS = 50; 45 static const double progressNotificationIntervalMS = 50;
46 46
47 PassRefPtr<FileWriter> FileWriter::create(ExecutionContext* context) 47 PassRefPtrWillBeRawPtr<FileWriter> FileWriter::create(ExecutionContext* context)
48 { 48 {
49 RefPtr<FileWriter> fileWriter(adoptRef(new FileWriter(context))); 49 RefPtrWillBeRawPtr<FileWriter> fileWriter(adoptRefWillBeRefCountedGarbageCol lected(new FileWriter(context)));
50 fileWriter->suspendIfNeeded(); 50 fileWriter->suspendIfNeeded();
51 return fileWriter.release(); 51 return fileWriter.release();
52 } 52 }
53 53
54 FileWriter::FileWriter(ExecutionContext* context) 54 FileWriter::FileWriter(ExecutionContext* context)
55 : ActiveDOMObject(context) 55 : ActiveDOMObject(context)
56 , m_readyState(INIT) 56 , m_readyState(INIT)
57 , m_operationInProgress(OperationNone) 57 , m_operationInProgress(OperationNone)
58 , m_queuedOperation(OperationNone) 58 , m_queuedOperation(OperationNone)
59 , m_bytesWritten(0) 59 , m_bytesWritten(0)
60 , m_bytesToWrite(0) 60 , m_bytesToWrite(0)
61 , m_truncateLength(-1) 61 , m_truncateLength(-1)
62 , m_numAborts(0) 62 , m_numAborts(0)
63 , m_recursionDepth(0) 63 , m_recursionDepth(0)
64 , m_lastProgressNotificationTimeMS(0) 64 , m_lastProgressNotificationTimeMS(0)
65 { 65 {
66 ScriptWrappable::init(this); 66 ScriptWrappable::init(this);
67 } 67 }
68 68
69 FileWriter::~FileWriter() 69 FileWriter::~FileWriter()
haraken 2014/03/10 01:55:26 Just to confirm: Is this destructor safe? This des
sof 2014/03/10 10:01:23 Re-verified that it is safe as it currently is. N
haraken 2014/03/10 10:19:35 Won't be needed :) Once we have the ASAN build in
70 { 70 {
71 ASSERT(!m_recursionDepth); 71 ASSERT(!m_recursionDepth);
72 if (m_readyState == WRITING) 72 if (m_readyState == WRITING)
73 stop(); 73 stop();
74 } 74 }
75 75
76 const AtomicString& FileWriter::interfaceName() const 76 const AtomicString& FileWriter::interfaceName() const
77 { 77 {
78 return EventTargetNames::FileWriter; 78 return EventTargetNames::FileWriter;
79 } 79 }
(...skipping 232 matching lines...) Expand 10 before | Expand all | Expand 10 after
312 ASSERT(m_recursionDepth >= 0); 312 ASSERT(m_recursionDepth >= 0);
313 } 313 }
314 314
315 void FileWriter::setError(FileError::ErrorCode errorCode, ExceptionState& except ionState) 315 void FileWriter::setError(FileError::ErrorCode errorCode, ExceptionState& except ionState)
316 { 316 {
317 ASSERT(errorCode); 317 ASSERT(errorCode);
318 FileError::throwDOMException(exceptionState, errorCode); 318 FileError::throwDOMException(exceptionState, errorCode);
319 m_error = FileError::create(errorCode); 319 m_error = FileError::create(errorCode);
320 } 320 }
321 321
322 void FileWriter::trace(Visitor* visitor)
323 {
324 visitor->trace(m_error);
325 visitor->trace(m_blobBeingWritten);
326 FileWriterBase::trace(visitor);
327 }
328
322 } // namespace WebCore 329 } // namespace WebCore
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698