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

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

Issue 23537011: FileAPI: Add WebFileSystem::resolveURL (Closed) Base URL: https://chromium.googlesource.com/chromium/blink.git@master
Patch Set: Created 7 years, 3 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 198 matching lines...) Expand 10 before | Expand all | Expand 10 after
209 { 209 {
210 } 210 }
211 211
212 void ResolveURICallbacks::didOpenFileSystem(const String& name, const KURL& root URL, PassOwnPtr<AsyncFileSystem> asyncFileSystem) 212 void ResolveURICallbacks::didOpenFileSystem(const String& name, const KURL& root URL, PassOwnPtr<AsyncFileSystem> asyncFileSystem)
213 { 213 {
214 ASSERT(asyncFileSystem); 214 ASSERT(asyncFileSystem);
215 RefPtr<DirectoryEntry> root = DOMFileSystem::create(m_scriptExecutionContext .get(), name, m_type, rootURL, asyncFileSystem)->root(); 215 RefPtr<DirectoryEntry> root = DOMFileSystem::create(m_scriptExecutionContext .get(), name, m_type, rootURL, asyncFileSystem)->root();
216 root->getDirectory(m_filePath, Dictionary(), m_successCallback, ErrorCallbac kWrapper::create(m_successCallback, m_errorCallback, root, m_filePath)); 216 root->getDirectory(m_filePath, Dictionary(), m_successCallback, ErrorCallbac kWrapper::create(m_successCallback, m_errorCallback, root, m_filePath));
217 } 217 }
218 218
219 void ResolveURICallbacks::didResolveURL(const String& name, const KURL& rootURL, const String& filePath, bool isDirectory, PassOwnPtr<AsyncFileSystem> asyncFile System)
220 {
221 ASSERT(asyncFileSystem);
222
223 RefPtr<DOMFileSystem> filesystem = DOMFileSystem::create(m_scriptExecutionCo ntext.get(), name, m_type, rootURL, asyncFileSystem);
224 RefPtr<DirectoryEntry> root = filesystem->root();
225
226 String absolutePath;
227 if (!DOMFileSystemBase::pathToAbsolutePath(m_type, root.get(), filePath, abs olutePath))
228 filesystem->scheduleCallback(m_errorCallback.release(), FileError::creat e(FileError::INVALID_MODIFICATION_ERR));
229
230 if (isDirectory)
231 m_successCallback->handleEvent(DirectoryEntry::create(filesystem, absolu tePath).get());
232 else
233 m_successCallback->handleEvent(FileEntry::create(filesystem, absolutePat h).get());
234 m_successCallback.clear();
235 }
236
219 // MetadataCallbacks ---------------------------------------------------------- 237 // MetadataCallbacks ----------------------------------------------------------
220 238
221 PassOwnPtr<MetadataCallbacks> MetadataCallbacks::create(PassRefPtr<MetadataCallb ack> successCallback, PassRefPtr<ErrorCallback> errorCallback) 239 PassOwnPtr<MetadataCallbacks> MetadataCallbacks::create(PassRefPtr<MetadataCallb ack> successCallback, PassRefPtr<ErrorCallback> errorCallback)
222 { 240 {
223 return adoptPtr(new MetadataCallbacks(successCallback, errorCallback)); 241 return adoptPtr(new MetadataCallbacks(successCallback, errorCallback));
224 } 242 }
225 243
226 MetadataCallbacks::MetadataCallbacks(PassRefPtr<MetadataCallback> successCallbac k, PassRefPtr<ErrorCallback> errorCallback) 244 MetadataCallbacks::MetadataCallbacks(PassRefPtr<MetadataCallback> successCallbac k, PassRefPtr<ErrorCallback> errorCallback)
227 : FileSystemCallbacksBase(errorCallback) 245 : FileSystemCallbacksBase(errorCallback)
228 , m_successCallback(successCallback) 246 , m_successCallback(successCallback)
(...skipping 43 matching lines...) Expand 10 before | Expand all | Expand 10 after
272 } 290 }
273 291
274 void VoidCallbacks::didSucceed() 292 void VoidCallbacks::didSucceed()
275 { 293 {
276 if (m_successCallback) 294 if (m_successCallback)
277 m_successCallback->handleEvent(); 295 m_successCallback->handleEvent();
278 m_successCallback.clear(); 296 m_successCallback.clear();
279 } 297 }
280 298
281 } // namespace 299 } // namespace
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698