- add sources.
[platform/framework/web/crosswalk.git] / src / components / webdata / common / web_database_table.h
1 // Copyright (c) 2011 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 COMPONENTS_WEBDATA_COMMON_WEB_DATABASE_TABLE_H_
6 #define COMPONENTS_WEBDATA_COMMON_WEB_DATABASE_TABLE_H_
7
8 #include "base/logging.h"
9 #include "components/webdata/common/webdata_export.h"
10
11 namespace sql {
12 class Connection;
13 class MetaTable;
14 }
15
16 // An abstract base class representing a table within a WebDatabase.
17 // Each table should subclass this, adding type-specific methods as needed.
18 class WEBDATA_EXPORT WebDatabaseTable {
19  public:
20   // To look up a WebDatabaseTable of a certain type from WebDatabase,
21   // we use a void* key, so that we can simply use the address of one
22   // of the type's statics.
23   typedef void* TypeKey;
24
25   // The object is not ready for use until Init() has been called.
26   WebDatabaseTable();
27   virtual ~WebDatabaseTable();
28
29   // Retrieves the TypeKey for the concrete subtype.
30   virtual TypeKey GetTypeKey() const = 0;
31
32   // Attempts to initialize the table and returns true if successful.
33   //
34   // The base class stores the members passed and always return true;
35   // subclasses may perform other initialization as needed.
36   virtual bool Init(sql::Connection* db, sql::MetaTable* meta_table);
37
38   // In order to encourage developers to think about sync when adding or
39   // or altering new tables, this method must be implemented. Please get in
40   // contact with the sync team if you believe you're making a change that they
41   // should be aware of (or if you could break something).
42   // TODO(andybons): Implement something more robust.
43   virtual bool IsSyncable() = 0;
44
45   // Migrates this table to |version|. Returns false if there was
46   // migration work to do and it failed, true otherwise.
47   //
48   // Implementations may set |*update_compatible_version| to true if
49   // the compatible version should be changed to |version|.
50   // Implementations should otherwise not modify this parameter.
51   virtual bool MigrateToVersion(int version,
52                                 bool* update_compatible_version) = 0;
53
54  protected:
55   // Non-owning. These are owned by WebDatabase, valid as long as that
56   // class exists. Since lifetime of WebDatabaseTable objects slightly
57   // exceeds that of WebDatabase, they should not be used in
58   // ~WebDatabaseTable.
59   sql::Connection* db_;
60   sql::MetaTable* meta_table_;
61
62  private:
63   DISALLOW_COPY_AND_ASSIGN(WebDatabaseTable);
64 };
65
66 #endif  // COMPONENTS_WEBDATA_COMMON_WEB_DATABASE_TABLE_H_