OLD | NEW |
1 /* | 1 /* |
2 * Copyright (C) 2008 Apple Inc. All Rights Reserved. | 2 * Copyright (C) 2008 Apple Inc. All Rights Reserved. |
3 * Copyright (C) 2009, 2011 Google Inc. All Rights Reserved. | 3 * Copyright (C) 2009, 2011 Google Inc. All Rights Reserved. |
4 * | 4 * |
5 * Redistribution and use in source and binary forms, with or without | 5 * Redistribution and use in source and binary forms, with or without |
6 * modification, are permitted provided that the following conditions | 6 * modification, are permitted provided that the following conditions |
7 * are met: | 7 * are met: |
8 * 1. Redistributions of source code must retain the above copyright | 8 * 1. 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 * 2. Redistributions in binary form must reproduce the above copyright | 10 * 2. Redistributions in binary form must reproduce the above copyright |
(...skipping 44 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
55 | 55 |
56 FileSystemType fileSystemType = static_cast<FileSystemType>(type); | 56 FileSystemType fileSystemType = static_cast<FileSystemType>(type); |
57 if (!DOMFileSystemBase::isValidType(fileSystemType)) { | 57 if (!DOMFileSystemBase::isValidType(fileSystemType)) { |
58 DOMFileSystem::scheduleCallback(&worker, errorCallback, FileError::creat
e(FileError::INVALID_MODIFICATION_ERR)); | 58 DOMFileSystem::scheduleCallback(&worker, errorCallback, FileError::creat
e(FileError::INVALID_MODIFICATION_ERR)); |
59 return; | 59 return; |
60 } | 60 } |
61 | 61 |
62 LocalFileSystem::from(worker)->requestFileSystem(&worker, fileSystemType, si
ze, FileSystemCallbacks::create(successCallback, errorCallback, &worker, fileSys
temType)); | 62 LocalFileSystem::from(worker)->requestFileSystem(&worker, fileSystemType, si
ze, FileSystemCallbacks::create(successCallback, errorCallback, &worker, fileSys
temType)); |
63 } | 63 } |
64 | 64 |
65 PassRefPtrWillBeRawPtr<DOMFileSystemSync> WorkerGlobalScopeFileSystem::webkitReq
uestFileSystemSync(WorkerGlobalScope& worker, int type, long long size, Exceptio
nState& exceptionState) | 65 DOMFileSystemSync* WorkerGlobalScopeFileSystem::webkitRequestFileSystemSync(Work
erGlobalScope& worker, int type, long long size, ExceptionState& exceptionState) |
66 { | 66 { |
67 ExecutionContext* secureContext = worker.executionContext(); | 67 ExecutionContext* secureContext = worker.executionContext(); |
68 if (!secureContext->securityOrigin()->canAccessFileSystem()) { | 68 if (!secureContext->securityOrigin()->canAccessFileSystem()) { |
69 exceptionState.throwSecurityError(FileError::securityErrorMessage); | 69 exceptionState.throwSecurityError(FileError::securityErrorMessage); |
70 return nullptr; | 70 return 0; |
71 } | 71 } |
72 | 72 |
73 FileSystemType fileSystemType = static_cast<FileSystemType>(type); | 73 FileSystemType fileSystemType = static_cast<FileSystemType>(type); |
74 if (!DOMFileSystemBase::isValidType(fileSystemType)) { | 74 if (!DOMFileSystemBase::isValidType(fileSystemType)) { |
75 exceptionState.throwDOMException(InvalidModificationError, "the type mus
t be TEMPORARY or PERSISTENT."); | 75 exceptionState.throwDOMException(InvalidModificationError, "the type mus
t be TEMPORARY or PERSISTENT."); |
76 return nullptr; | 76 return 0; |
77 } | 77 } |
78 | 78 |
79 RefPtr<FileSystemSyncCallbackHelper> helper = FileSystemSyncCallbackHelper::
create(); | 79 RefPtr<FileSystemSyncCallbackHelper> helper = FileSystemSyncCallbackHelper::
create(); |
80 OwnPtr<AsyncFileSystemCallbacks> callbacks = FileSystemCallbacks::create(hel
per->successCallback(), helper->errorCallback(), &worker, fileSystemType); | 80 OwnPtr<AsyncFileSystemCallbacks> callbacks = FileSystemCallbacks::create(hel
per->successCallback(), helper->errorCallback(), &worker, fileSystemType); |
81 callbacks->setShouldBlockUntilCompletion(true); | 81 callbacks->setShouldBlockUntilCompletion(true); |
82 | 82 |
83 LocalFileSystem::from(worker)->requestFileSystem(&worker, fileSystemType, si
ze, callbacks.release()); | 83 LocalFileSystem::from(worker)->requestFileSystem(&worker, fileSystemType, si
ze, callbacks.release()); |
84 return helper->getResult(exceptionState); | 84 return helper->getResult(exceptionState); |
85 } | 85 } |
86 | 86 |
87 void WorkerGlobalScopeFileSystem::webkitResolveLocalFileSystemURL(WorkerGlobalSc
ope& worker, const String& url, PassOwnPtr<EntryCallback> successCallback, PassO
wnPtr<ErrorCallback> errorCallback) | 87 void WorkerGlobalScopeFileSystem::webkitResolveLocalFileSystemURL(WorkerGlobalSc
ope& worker, const String& url, PassOwnPtr<EntryCallback> successCallback, PassO
wnPtr<ErrorCallback> errorCallback) |
88 { | 88 { |
89 KURL completedURL = worker.completeURL(url); | 89 KURL completedURL = worker.completeURL(url); |
90 ExecutionContext* secureContext = worker.executionContext(); | 90 ExecutionContext* secureContext = worker.executionContext(); |
91 if (!secureContext->securityOrigin()->canAccessFileSystem() || !secureContex
t->securityOrigin()->canRequest(completedURL)) { | 91 if (!secureContext->securityOrigin()->canAccessFileSystem() || !secureContex
t->securityOrigin()->canRequest(completedURL)) { |
92 DOMFileSystem::scheduleCallback(&worker, errorCallback, FileError::creat
e(FileError::SECURITY_ERR)); | 92 DOMFileSystem::scheduleCallback(&worker, errorCallback, FileError::creat
e(FileError::SECURITY_ERR)); |
93 return; | 93 return; |
94 } | 94 } |
95 | 95 |
96 if (!completedURL.isValid()) { | 96 if (!completedURL.isValid()) { |
97 DOMFileSystem::scheduleCallback(&worker, errorCallback, FileError::creat
e(FileError::ENCODING_ERR)); | 97 DOMFileSystem::scheduleCallback(&worker, errorCallback, FileError::creat
e(FileError::ENCODING_ERR)); |
98 return; | 98 return; |
99 } | 99 } |
100 | 100 |
101 LocalFileSystem::from(worker)->resolveURL(&worker, completedURL, ResolveURIC
allbacks::create(successCallback, errorCallback, &worker)); | 101 LocalFileSystem::from(worker)->resolveURL(&worker, completedURL, ResolveURIC
allbacks::create(successCallback, errorCallback, &worker)); |
102 } | 102 } |
103 | 103 |
104 PassRefPtrWillBeRawPtr<EntrySync> WorkerGlobalScopeFileSystem::webkitResolveLoca
lFileSystemSyncURL(WorkerGlobalScope& worker, const String& url, ExceptionState&
exceptionState) | 104 EntrySync* WorkerGlobalScopeFileSystem::webkitResolveLocalFileSystemSyncURL(Work
erGlobalScope& worker, const String& url, ExceptionState& exceptionState) |
105 { | 105 { |
106 KURL completedURL = worker.completeURL(url); | 106 KURL completedURL = worker.completeURL(url); |
107 ExecutionContext* secureContext = worker.executionContext(); | 107 ExecutionContext* secureContext = worker.executionContext(); |
108 if (!secureContext->securityOrigin()->canAccessFileSystem() || !secureContex
t->securityOrigin()->canRequest(completedURL)) { | 108 if (!secureContext->securityOrigin()->canAccessFileSystem() || !secureContex
t->securityOrigin()->canRequest(completedURL)) { |
109 exceptionState.throwSecurityError(FileError::securityErrorMessage); | 109 exceptionState.throwSecurityError(FileError::securityErrorMessage); |
110 return nullptr; | 110 return 0; |
111 } | 111 } |
112 | 112 |
113 if (!completedURL.isValid()) { | 113 if (!completedURL.isValid()) { |
114 exceptionState.throwDOMException(EncodingError, "the URL '" + url + "' i
s invalid."); | 114 exceptionState.throwDOMException(EncodingError, "the URL '" + url + "' i
s invalid."); |
115 return nullptr; | 115 return 0; |
116 } | 116 } |
117 | 117 |
118 RefPtr<EntrySyncCallbackHelper> resolveURLHelper = EntrySyncCallbackHelper::
create(); | 118 RefPtr<EntrySyncCallbackHelper> resolveURLHelper = EntrySyncCallbackHelper::
create(); |
119 OwnPtr<AsyncFileSystemCallbacks> callbacks = ResolveURICallbacks::create(res
olveURLHelper->successCallback(), resolveURLHelper->errorCallback(), &worker); | 119 OwnPtr<AsyncFileSystemCallbacks> callbacks = ResolveURICallbacks::create(res
olveURLHelper->successCallback(), resolveURLHelper->errorCallback(), &worker); |
120 callbacks->setShouldBlockUntilCompletion(true); | 120 callbacks->setShouldBlockUntilCompletion(true); |
121 | 121 |
122 LocalFileSystem::from(worker)->resolveURL(&worker, completedURL, callbacks.r
elease()); | 122 LocalFileSystem::from(worker)->resolveURL(&worker, completedURL, callbacks.r
elease()); |
123 | 123 |
124 RefPtrWillBeRawPtr<EntrySync> entry = resolveURLHelper->getResult(exceptionS
tate); | 124 return resolveURLHelper->getResult(exceptionState); |
125 if (!entry) | |
126 return nullptr; | |
127 return entry.release(); | |
128 } | 125 } |
129 | 126 |
130 COMPILE_ASSERT(static_cast<int>(WorkerGlobalScopeFileSystem::TEMPORARY) == stati
c_cast<int>(FileSystemTypeTemporary), enum_mismatch); | 127 COMPILE_ASSERT(static_cast<int>(WorkerGlobalScopeFileSystem::TEMPORARY) == stati
c_cast<int>(FileSystemTypeTemporary), enum_mismatch); |
131 COMPILE_ASSERT(static_cast<int>(WorkerGlobalScopeFileSystem::PERSISTENT) == stat
ic_cast<int>(FileSystemTypePersistent), enum_mismatch); | 128 COMPILE_ASSERT(static_cast<int>(WorkerGlobalScopeFileSystem::PERSISTENT) == stat
ic_cast<int>(FileSystemTypePersistent), enum_mismatch); |
132 | 129 |
133 } // namespace WebCore | 130 } // namespace WebCore |
OLD | NEW |