OLD | NEW |
1 /* | 1 /* |
2 * Copyright (C) 2012 Apple Inc. All rights reserved. | 2 * Copyright (C) 2012 Apple Inc. All rights reserved. |
3 * | 3 * |
4 * Redistribution and use in source and binary forms, with or without | 4 * Redistribution and use in source and binary forms, with or without |
5 * modification, are permitted provided that the following conditions | 5 * modification, are permitted provided that the following conditions |
6 * are met: | 6 * are met: |
7 * 1. Redistributions of source code must retain the above copyright | 7 * 1. Redistributions of source code must retain the above copyright |
8 * notice, this list of conditions and the following disclaimer. | 8 * notice, this list of conditions and the following disclaimer. |
9 * 2. Redistributions in binary form must reproduce the above copyright | 9 * 2. Redistributions in binary form must reproduce the above copyright |
10 * notice, this list of conditions and the following disclaimer in the | 10 * notice, this list of conditions and the following disclaimer in the |
(...skipping 30 matching lines...) Expand all Loading... |
41 #include "modules/webdatabase/DatabaseClient.h" | 41 #include "modules/webdatabase/DatabaseClient.h" |
42 #include "modules/webdatabase/DatabaseContext.h" | 42 #include "modules/webdatabase/DatabaseContext.h" |
43 #include "modules/webdatabase/DatabaseServer.h" | 43 #include "modules/webdatabase/DatabaseServer.h" |
44 #include "modules/webdatabase/DatabaseTask.h" | 44 #include "modules/webdatabase/DatabaseTask.h" |
45 #include "platform/weborigin/SecurityOrigin.h" | 45 #include "platform/weborigin/SecurityOrigin.h" |
46 | 46 |
47 namespace blink { | 47 namespace blink { |
48 | 48 |
49 DatabaseManager& DatabaseManager::manager() | 49 DatabaseManager& DatabaseManager::manager() |
50 { | 50 { |
51 AtomicallyInitializedStatic(DatabaseManager*, dbManager = new DatabaseManage
r); | 51 ASSERT(isMainThread()); |
52 return *dbManager; | 52 DEFINE_STATIC_LOCAL(DatabaseManager, dbManager, ()); |
| 53 return dbManager; |
53 } | 54 } |
54 | 55 |
55 DatabaseManager::DatabaseManager() | 56 DatabaseManager::DatabaseManager() |
56 #if ENABLE(ASSERT) | 57 #if ENABLE(ASSERT) |
57 : m_databaseContextRegisteredCount(0) | 58 : m_databaseContextRegisteredCount(0) |
58 , m_databaseContextInstanceCount(0) | 59 , m_databaseContextInstanceCount(0) |
59 #endif | 60 #endif |
60 { | 61 { |
61 m_server = new DatabaseServer; | 62 m_server = new DatabaseServer; |
62 ASSERT(m_server); // We should always have a server to work with. | 63 ASSERT(m_server); // We should always have a server to work with. |
(...skipping 21 matching lines...) Expand all Loading... |
84 , m_creationCallback(callback) | 85 , m_creationCallback(callback) |
85 { | 86 { |
86 } | 87 } |
87 | 88 |
88 RefPtrWillBePersistent<Database> m_database; | 89 RefPtrWillBePersistent<Database> m_database; |
89 OwnPtrWillBePersistent<DatabaseCallback> m_creationCallback; | 90 OwnPtrWillBePersistent<DatabaseCallback> m_creationCallback; |
90 }; | 91 }; |
91 | 92 |
92 DatabaseContext* DatabaseManager::existingDatabaseContextFor(ExecutionContext* c
ontext) | 93 DatabaseContext* DatabaseManager::existingDatabaseContextFor(ExecutionContext* c
ontext) |
93 { | 94 { |
94 MutexLocker locker(m_contextMapLock); | |
95 | |
96 ASSERT(m_databaseContextRegisteredCount >= 0); | 95 ASSERT(m_databaseContextRegisteredCount >= 0); |
97 ASSERT(m_databaseContextInstanceCount >= 0); | 96 ASSERT(m_databaseContextInstanceCount >= 0); |
98 ASSERT(m_databaseContextRegisteredCount <= m_databaseContextInstanceCount); | 97 ASSERT(m_databaseContextRegisteredCount <= m_databaseContextInstanceCount); |
99 #if ENABLE(OILPAN) | |
100 const Persistent<DatabaseContext>* databaseContext = m_contextMap.get(contex
t); | |
101 return databaseContext ? databaseContext->get() : 0; | |
102 #else | |
103 return m_contextMap.get(context); | 98 return m_contextMap.get(context); |
104 #endif | |
105 } | 99 } |
106 | 100 |
107 DatabaseContext* DatabaseManager::databaseContextFor(ExecutionContext* context) | 101 DatabaseContext* DatabaseManager::databaseContextFor(ExecutionContext* context) |
108 { | 102 { |
109 if (DatabaseContext* databaseContext = existingDatabaseContextFor(context)) | 103 if (DatabaseContext* databaseContext = existingDatabaseContextFor(context)) |
110 return databaseContext; | 104 return databaseContext; |
111 // We don't need to hold a reference returned by DatabaseContext::create | 105 // We don't need to hold a reference returned by DatabaseContext::create |
112 // because DatabaseContext::create calls registerDatabaseContext, and the | 106 // because DatabaseContext::create calls registerDatabaseContext, and the |
113 // DatabaseManager holds a reference. | 107 // DatabaseManager holds a reference. |
114 return DatabaseContext::create(context).get(); | 108 return DatabaseContext::create(context).get(); |
115 } | 109 } |
116 | 110 |
117 void DatabaseManager::registerDatabaseContext(DatabaseContext* databaseContext) | 111 void DatabaseManager::registerDatabaseContext(DatabaseContext* databaseContext) |
118 { | 112 { |
119 MutexLocker locker(m_contextMapLock); | |
120 ExecutionContext* context = databaseContext->executionContext(); | 113 ExecutionContext* context = databaseContext->executionContext(); |
121 #if ENABLE(OILPAN) | |
122 m_contextMap.set(context, adoptPtr(new Persistent<DatabaseContext>(databaseC
ontext))); | |
123 #else | |
124 m_contextMap.set(context, databaseContext); | 114 m_contextMap.set(context, databaseContext); |
125 #endif | |
126 #if ENABLE(ASSERT) | 115 #if ENABLE(ASSERT) |
127 m_databaseContextRegisteredCount++; | 116 m_databaseContextRegisteredCount++; |
128 #endif | 117 #endif |
129 } | 118 } |
130 | 119 |
131 void DatabaseManager::unregisterDatabaseContext(DatabaseContext* databaseContext
) | 120 void DatabaseManager::unregisterDatabaseContext(DatabaseContext* databaseContext
) |
132 { | 121 { |
133 MutexLocker locker(m_contextMapLock); | |
134 ExecutionContext* context = databaseContext->executionContext(); | 122 ExecutionContext* context = databaseContext->executionContext(); |
135 ASSERT(m_contextMap.get(context)); | 123 ASSERT(m_contextMap.get(context)); |
136 #if ENABLE(ASSERT) | 124 #if ENABLE(ASSERT) |
137 m_databaseContextRegisteredCount--; | 125 m_databaseContextRegisteredCount--; |
138 #endif | 126 #endif |
139 m_contextMap.remove(context); | 127 m_contextMap.remove(context); |
140 } | 128 } |
141 | 129 |
142 #if ENABLE(ASSERT) | 130 #if ENABLE(ASSERT) |
143 void DatabaseManager::didConstructDatabaseContext() | 131 void DatabaseManager::didConstructDatabaseContext() |
144 { | 132 { |
145 MutexLocker lock(m_contextMapLock); | |
146 m_databaseContextInstanceCount++; | 133 m_databaseContextInstanceCount++; |
147 } | 134 } |
148 | 135 |
149 void DatabaseManager::didDestructDatabaseContext() | 136 void DatabaseManager::didDestructDatabaseContext() |
150 { | 137 { |
151 MutexLocker lock(m_contextMapLock); | |
152 m_databaseContextInstanceCount--; | 138 m_databaseContextInstanceCount--; |
153 ASSERT(m_databaseContextRegisteredCount <= m_databaseContextInstanceCount); | 139 ASSERT(m_databaseContextRegisteredCount <= m_databaseContextInstanceCount); |
154 } | 140 } |
155 #endif | 141 #endif |
156 | 142 |
157 void DatabaseManager::throwExceptionForDatabaseError(DatabaseError error, const
String& errorMessage, ExceptionState& exceptionState) | 143 void DatabaseManager::throwExceptionForDatabaseError(DatabaseError error, const
String& errorMessage, ExceptionState& exceptionState) |
158 { | 144 { |
159 switch (error) { | 145 switch (error) { |
160 case DatabaseError::None: | 146 case DatabaseError::None: |
161 return; | 147 return; |
(...skipping 69 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
231 | 217 |
232 ASSERT(database); | 218 ASSERT(database); |
233 return database.release(); | 219 return database.release(); |
234 } | 220 } |
235 | 221 |
236 String DatabaseManager::fullPathForDatabase(SecurityOrigin* origin, const String
& name, bool createIfDoesNotExist) | 222 String DatabaseManager::fullPathForDatabase(SecurityOrigin* origin, const String
& name, bool createIfDoesNotExist) |
237 { | 223 { |
238 return m_server->fullPathForDatabase(origin, name, createIfDoesNotExist); | 224 return m_server->fullPathForDatabase(origin, name, createIfDoesNotExist); |
239 } | 225 } |
240 | 226 |
241 void DatabaseManager::closeDatabasesImmediately(const String& originIdentifier,
const String& name) | |
242 { | |
243 m_server->closeDatabasesImmediately(originIdentifier, name); | |
244 } | |
245 | |
246 void DatabaseManager::logErrorMessage(ExecutionContext* context, const String& m
essage) | 227 void DatabaseManager::logErrorMessage(ExecutionContext* context, const String& m
essage) |
247 { | 228 { |
248 context->addConsoleMessage(ConsoleMessage::create(StorageMessageSource, Erro
rMessageLevel, message)); | 229 context->addConsoleMessage(ConsoleMessage::create(StorageMessageSource, Erro
rMessageLevel, message)); |
249 } | 230 } |
250 | 231 |
251 } // namespace blink | 232 } // namespace blink |
OLD | NEW |