OLD | NEW |
1 // Copyright (c) 2008 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2010 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 // DataPack represents a read-only view onto an on-disk file that contains | 5 // DataPack represents a read-only view onto an on-disk file that contains |
6 // (key, value) pairs of data. It's used to store static resources like | 6 // (key, value) pairs of data. It's used to store static resources like |
7 // translation strings and images. | 7 // translation strings and images. |
8 | 8 |
9 #ifndef BASE_DATA_PACK_H_ | 9 #ifndef APP_DATA_PACK_H_ |
10 #define BASE_DATA_PACK_H_ | 10 #define APP_DATA_PACK_H_ |
11 #pragma once | 11 #pragma once |
12 | 12 |
13 #include <map> | 13 #include <map> |
14 | 14 |
15 #include "base/basictypes.h" | 15 #include "base/basictypes.h" |
16 #include "base/scoped_ptr.h" | 16 #include "base/scoped_ptr.h" |
17 | 17 |
| 18 namespace base { |
| 19 class StringPiece; |
| 20 } |
| 21 |
18 namespace file_util { | 22 namespace file_util { |
19 class MemoryMappedFile; | 23 class MemoryMappedFile; |
20 } | 24 } |
| 25 |
21 class FilePath; | 26 class FilePath; |
22 class RefCountedStaticMemory; | 27 class RefCountedStaticMemory; |
23 | 28 |
24 namespace base { | |
25 | 29 |
26 class StringPiece; | 30 namespace app { |
27 | 31 |
28 class DataPack { | 32 class DataPack { |
29 public: | 33 public: |
30 DataPack(); | 34 DataPack(); |
31 ~DataPack(); | 35 ~DataPack(); |
32 | 36 |
33 // Load a pack file from |path|, returning false on error. | 37 // Load a pack file from |path|, returning false on error. |
34 bool Load(const FilePath& path); | 38 bool Load(const FilePath& path); |
35 | 39 |
36 // Get resource by id |resource_id|, filling in |data|. | 40 // Get resource by id |resource_id|, filling in |data|. |
37 // The data is owned by the DataPack object and should not be modified. | 41 // The data is owned by the DataPack object and should not be modified. |
38 // Returns false if the resource id isn't found. | 42 // Returns false if the resource id isn't found. |
39 bool GetStringPiece(uint32 resource_id, StringPiece* data) const; | 43 bool GetStringPiece(uint32 resource_id, base::StringPiece* data) const; |
40 | 44 |
41 // Like GetStringPiece(), but returns a reference to memory. This interface | 45 // Like GetStringPiece(), but returns a reference to memory. This interface |
42 // is used for image data, while the StringPiece interface is usually used | 46 // is used for image data, while the StringPiece interface is usually used |
43 // for localization strings. | 47 // for localization strings. |
44 RefCountedStaticMemory* GetStaticMemory(uint32 resource_id) const; | 48 RefCountedStaticMemory* GetStaticMemory(uint32 resource_id) const; |
45 | 49 |
46 // Writes a pack file containing |resources| to |path|. | 50 // Writes a pack file containing |resources| to |path|. |
47 static bool WritePack(const FilePath& path, | 51 static bool WritePack(const FilePath& path, |
48 const std::map<uint32, StringPiece>& resources); | 52 const std::map<uint32, base::StringPiece>& resources); |
49 | 53 |
50 private: | 54 private: |
51 // The memory-mapped data. | 55 // The memory-mapped data. |
52 scoped_ptr<file_util::MemoryMappedFile> mmap_; | 56 scoped_ptr<file_util::MemoryMappedFile> mmap_; |
53 | 57 |
54 // Number of resources in the data. | 58 // Number of resources in the data. |
55 size_t resource_count_; | 59 size_t resource_count_; |
56 | 60 |
57 DISALLOW_COPY_AND_ASSIGN(DataPack); | 61 DISALLOW_COPY_AND_ASSIGN(DataPack); |
58 }; | 62 }; |
59 | 63 |
60 } // namespace base | 64 } // namespace app |
61 | 65 |
62 #endif // BASE_DATA_PACK_H_ | 66 #endif // APP_DATA_PACK_H_ |
OLD | NEW |