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

Side by Side Diff: content/browser/indexed_db/leveldb/leveldb_iterator.h

Issue 2760163002: [IndexedDB] Pool and evict leveldb iterators, to save memory (Closed)
Patch Set: comments & simplifying MRU interaction Created 3 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 // Copyright (c) 2013 The Chromium Authors. All rights reserved. 1 // Copyright (c) 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 CONTENT_BROWSER_INDEXED_DB_LEVELDB_LEVELDB_ITERATOR_H_ 5 #ifndef CONTENT_BROWSER_INDEXED_DB_LEVELDB_LEVELDB_ITERATOR_H_
6 #define CONTENT_BROWSER_INDEXED_DB_LEVELDB_LEVELDB_ITERATOR_H_ 6 #define CONTENT_BROWSER_INDEXED_DB_LEVELDB_LEVELDB_ITERATOR_H_
7 7
8 #include "base/strings/string_piece.h" 8 #include "base/strings/string_piece.h"
9 #include "content/common/content_export.h" 9 #include "content/common/content_export.h"
10 #include "third_party/leveldatabase/src/include/leveldb/status.h" 10 #include "third_party/leveldatabase/src/include/leveldb/status.h"
11 11
12 namespace content { 12 namespace content {
13 13
14 class CONTENT_EXPORT LevelDBIterator { 14 class CONTENT_EXPORT LevelDBIterator {
15 public: 15 public:
16 virtual ~LevelDBIterator() {} 16 virtual ~LevelDBIterator() {}
17 virtual bool IsValid() const = 0; 17 virtual bool IsValid() const = 0;
18 virtual leveldb::Status SeekToLast() = 0; 18 virtual leveldb::Status SeekToLast() = 0;
19 virtual leveldb::Status Seek(const base::StringPiece& target) = 0; 19 virtual leveldb::Status Seek(const base::StringPiece& target) = 0;
20 virtual leveldb::Status Next() = 0; 20 virtual leveldb::Status Next() = 0;
21 virtual leveldb::Status Prev() = 0; 21 virtual leveldb::Status Prev() = 0;
22 virtual base::StringPiece Key() const = 0; 22 virtual base::StringPiece Key() const = 0;
23 virtual base::StringPiece Value() const = 0; 23 virtual base::StringPiece Value() const = 0;
24
25 // Detaches the internal iterator which saves memory at the performance
26 // expense of reloading and seeking later if the iterator is needed again for
27 // |Seek*|, |Next|, |Prev|, or |Value|.
28 virtual void Detach(){};
jsbell 2017/03/27 15:35:34 Nit: space between ) and { Also, since we DCHECK
dmurph 2017/03/27 21:32:05 ugh. Darn clang format! Actually, should I just ke
pwnall 2017/03/27 21:52:18 I would suggest keeping the code as-is and and fil
29 virtual bool IsDetached() const;
24 }; 30 };
25 31
26 } // namespace content 32 } // namespace content
27 33
28 #endif // CONTENT_BROWSER_INDEXED_DB_LEVELDB_LEVELDB_ITERATOR_H_ 34 #endif // CONTENT_BROWSER_INDEXED_DB_LEVELDB_LEVELDB_ITERATOR_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698