• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
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
3 // found in the LICENSE file.
4 
5 #ifndef UI_GFX_SEQUENTIAL_ID_GENERATOR_H_
6 #define UI_GFX_SEQUENTIAL_ID_GENERATOR_H_
7 
8 #include <map>
9 
10 #include "base/basictypes.h"
11 #include "base/containers/hash_tables.h"
12 #include "ui/gfx/gfx_export.h"
13 
14 namespace ui {
15 
16 // This is used to generate a series of sequential ID numbers in a way that a
17 // new ID is always the lowest possible ID in the sequence.
18 class GFX_EXPORT SequentialIDGenerator {
19  public:
20    // Creates a new generator with the specified lower bound for the IDs.
21   explicit SequentialIDGenerator(uint32 min_id);
22   ~SequentialIDGenerator();
23 
24   // Generates a unique ID to represent |number|. The generated ID is the
25   // smallest available ID greater than or equal to the |min_id| specified
26   // during creation of the generator.
27   uint32 GetGeneratedID(uint32 number);
28 
29   // Checks to see if the generator currently has a unique ID generated for
30   // |number|.
31   bool HasGeneratedIDFor(uint32 number) const;
32 
33   // Removes the generated ID |id| from the internal mapping. Since the ID is
34   // no longer mapped to any number, subsequent calls to |GetGeneratedID()| can
35   // use this ID.
36   void ReleaseGeneratedID(uint32 id);
37 
38   // Removes the ID previously generated for |number| by calling
39   // |GetGeneratedID()|.
40   void ReleaseNumber(uint32 number);
41 
42  private:
43   typedef base::hash_map<uint32, uint32> IDMap;
44 
45   uint32 GetNextAvailableID();
46 
47   void UpdateNextAvailableIDAfterRelease(uint32 id);
48 
49   IDMap number_to_id_;
50   IDMap id_to_number_;
51 
52   uint32 min_id_;
53   uint32 min_available_id_;
54 
55   DISALLOW_COPY_AND_ASSIGN(SequentialIDGenerator);
56 };
57 
58 }  // namespace ui
59 
60 #endif  // UI_GFX_SEQUENTIAL_ID_GENERATOR_H_
61