Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #ifndef CHROME_BROWSER_MEDIA_GALLERIES_FILEAPI_SAFE_PICASA_ALBUMS_INDEXER_H_ | 5 #ifndef CHROME_BROWSER_MEDIA_GALLERIES_FILEAPI_SAFE_PICASA_ALBUMS_INDEXER_H_ |
| 6 #define CHROME_BROWSER_MEDIA_GALLERIES_FILEAPI_SAFE_PICASA_ALBUMS_INDEXER_H_ | 6 #define CHROME_BROWSER_MEDIA_GALLERIES_FILEAPI_SAFE_PICASA_ALBUMS_INDEXER_H_ |
| 7 | 7 |
| 8 #include <queue> | 8 #include <queue> |
| 9 #include <vector> | 9 #include <vector> |
| 10 | 10 |
| 11 #include "base/callback.h" | 11 #include "base/callback.h" |
| 12 #include "base/compiler_specific.h" | 12 #include "base/compiler_specific.h" |
| 13 #include "base/memory/ref_counted.h" | |
| 13 #include "base/memory/weak_ptr.h" | 14 #include "base/memory/weak_ptr.h" |
| 14 #include "chrome/common/media_galleries/picasa_types.h" | 15 #include "chrome/common/media_galleries/picasa_types.h" |
| 16 #include "content/public/browser/utility_process_host.h" | |
| 15 #include "content/public/browser/utility_process_host_client.h" | 17 #include "content/public/browser/utility_process_host_client.h" |
| 16 | 18 |
| 17 namespace base { | 19 namespace base { |
| 18 class FilePath; | 20 class FilePath; |
| 19 } | 21 } |
| 20 | 22 |
| 21 namespace IPC { | 23 namespace IPC { |
| 22 class Message; | 24 class Message; |
| 23 } | 25 } |
| 24 | 26 |
| 25 namespace picasa { | 27 namespace picasa { |
| 26 | 28 |
| 27 // SafePicasaAlbumsIndexer indexes the contents of Picasa Albums by parsing the | 29 // SafePicasaAlbumsIndexer indexes the contents of Picasa Albums by parsing the |
| 28 // INI files found in Folders. The SafePicasaAlbumsIndexer object is ref-counted | 30 // INI files found in Folders. The SafePicasaAlbumsIndexer object is ref-counted |
| 29 // and kept alive after Start() is called until the ParserCallback is called. | 31 // and kept alive after Start() is called until the ParserCallback is called. |
| 30 // The ParserCallback is guaranteed to be called eventually either when the | 32 // The ParserCallback is guaranteed to be called eventually either when the |
| 31 // utility process replies or when it dies. | 33 // utility process replies or when it dies. |
| 32 class SafePicasaAlbumsIndexer : public content::UtilityProcessHostClient { | 34 class SafePicasaAlbumsIndexer : public content::UtilityProcessHostClient { |
| 33 public: | 35 public: |
| 34 typedef base::Callback<void(bool success, | 36 // Callback includes a refptr to itself to guarantee that this object |
| 37 // survives past the execution of its last posted callback. | |
| 38 typedef base::Callback<void(scoped_refptr<SafePicasaAlbumsIndexer>, | |
| 39 bool success, | |
| 35 const picasa::AlbumImagesMap&)> DoneCallback; | 40 const picasa::AlbumImagesMap&)> DoneCallback; |
| 36 | 41 |
| 37 SafePicasaAlbumsIndexer(const AlbumMap& albums, | 42 SafePicasaAlbumsIndexer(const AlbumMap& albums, |
| 38 const AlbumMap& folders, | 43 const AlbumMap& folders, |
| 39 const DoneCallback& callback); | 44 const DoneCallback& callback); |
| 40 | 45 |
| 41 void Start(); | 46 void Start(); |
| 42 | 47 |
| 43 private: | 48 private: |
| 44 enum ParserState { | 49 enum ParserState { |
| (...skipping 23 matching lines...) Expand all Loading... | |
| 68 virtual void OnProcessCrashed(int exit_code) OVERRIDE; | 73 virtual void OnProcessCrashed(int exit_code) OVERRIDE; |
| 69 virtual bool OnMessageReceived(const IPC::Message& message) OVERRIDE; | 74 virtual bool OnMessageReceived(const IPC::Message& message) OVERRIDE; |
| 70 | 75 |
| 71 AlbumUIDSet album_uids_; | 76 AlbumUIDSet album_uids_; |
| 72 | 77 |
| 73 // List of folders that still need their INI files read. | 78 // List of folders that still need their INI files read. |
| 74 std::queue<base::FilePath> folders_queue_; | 79 std::queue<base::FilePath> folders_queue_; |
| 75 | 80 |
| 76 std::vector<picasa::FolderINIContents> folders_inis_; | 81 std::vector<picasa::FolderINIContents> folders_inis_; |
| 77 | 82 |
| 83 // Only accessed on the IO thread. | |
| 84 base::WeakPtr<content::UtilityProcessHost> utility_process_host_; | |
|
vandebo (ex-Chrome)
2013/07/12 18:29:59
This isn't used in this CL?
tommycli
2013/07/12 21:37:19
This is an aborted attempt to make the utility pro
| |
| 85 | |
| 78 // Only accessed on the Media Task Runner. | 86 // Only accessed on the Media Task Runner. |
| 79 const DoneCallback callback_; | 87 const DoneCallback callback_; |
| 80 | 88 |
| 81 // Verifies the messages from the utility process came at the right time. | 89 // Verifies the messages from the utility process came at the right time. |
| 82 // Initialized on the Media Task Runner, but only accessed on the IO thread. | 90 // Initialized on the Media Task Runner, but only accessed on the IO thread. |
| 83 ParserState parser_state_; | 91 ParserState parser_state_; |
| 84 | 92 |
| 85 base::WeakPtrFactory<SafePicasaAlbumsIndexer> weak_factory_; | 93 base::WeakPtrFactory<SafePicasaAlbumsIndexer> weak_factory_; |
| 86 | 94 |
| 87 DISALLOW_COPY_AND_ASSIGN(SafePicasaAlbumsIndexer); | 95 DISALLOW_COPY_AND_ASSIGN(SafePicasaAlbumsIndexer); |
| 88 }; | 96 }; |
| 89 | 97 |
| 90 } // namespace picasa | 98 } // namespace picasa |
| 91 | 99 |
| 92 #endif // CHROME_BROWSER_MEDIA_GALLERIES_FILEAPI_SAFE_PICASA_ALBUMS_INDEXER_H_ | 100 #endif // CHROME_BROWSER_MEDIA_GALLERIES_FILEAPI_SAFE_PICASA_ALBUMS_INDEXER_H_ |
| OLD | NEW |