OLD | NEW |
---|---|
1 /* | 1 /* |
2 * Copyright (C) 2010 Google Inc. All rights reserved. | 2 * Copyright (C) 2010 Google 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 * | 7 * |
8 * 1. Redistributions of source code must retain the above copyright | 8 * 1. Redistributions of source code must retain the above copyright |
9 * notice, this list of conditions and the following disclaimer. | 9 * notice, this list of conditions and the following disclaimer. |
10 * 2. Redistributions in binary form must reproduce the above copyright | 10 * 2. Redistributions in binary form must reproduce the above copyright |
(...skipping 19 matching lines...) Expand all Loading... | |
30 #define HRTFDatabaseLoader_h | 30 #define HRTFDatabaseLoader_h |
31 | 31 |
32 #include "platform/WebThreadSupportingGC.h" | 32 #include "platform/WebThreadSupportingGC.h" |
33 #include "platform/audio/HRTFDatabase.h" | 33 #include "platform/audio/HRTFDatabase.h" |
34 #include "platform/heap/Handle.h" | 34 #include "platform/heap/Handle.h" |
35 #include "wtf/HashMap.h" | 35 #include "wtf/HashMap.h" |
36 #include "wtf/ThreadingPrimitives.h" | 36 #include "wtf/ThreadingPrimitives.h" |
37 | 37 |
38 namespace blink { | 38 namespace blink { |
39 | 39 |
40 class TaskSynchronizer; | |
41 | |
40 // HRTFDatabaseLoader will asynchronously load the default HRTFDatabase in a new thread. | 42 // HRTFDatabaseLoader will asynchronously load the default HRTFDatabase in a new thread. |
41 | 43 |
42 class PLATFORM_EXPORT HRTFDatabaseLoader final : public GarbageCollectedFinalize d<HRTFDatabaseLoader> { | 44 class PLATFORM_EXPORT HRTFDatabaseLoader final : public GarbageCollectedFinalize d<HRTFDatabaseLoader> { |
43 public: | 45 public: |
44 // Lazily creates a HRTFDatabaseLoader (if not already created) for the give n sample-rate | 46 // Lazily creates a HRTFDatabaseLoader (if not already created) for the give n sample-rate |
45 // and starts loading asynchronously (when created the first time). | 47 // and starts loading asynchronously (when created the first time). |
46 // Returns the HRTFDatabaseLoader. | 48 // Returns the HRTFDatabaseLoader. |
47 // Must be called from the main thread. | 49 // Must be called from the main thread. |
48 static HRTFDatabaseLoader* createAndLoadAsynchronouslyIfNecessary(float samp leRate); | 50 static HRTFDatabaseLoader* createAndLoadAsynchronouslyIfNecessary(float samp leRate); |
49 | 51 |
50 // Both constructor and destructor must be called from the main thread. | 52 // Both constructor and destructor must be called from the main thread. |
51 ~HRTFDatabaseLoader(); | 53 ~HRTFDatabaseLoader(); |
52 | 54 |
53 // Returns true once the default database has been completely loaded. | 55 // Returns true once the default database has been completely loaded. |
54 bool isLoaded(); | 56 bool isLoaded(); |
55 | 57 |
56 // waitForLoaderThreadCompletion() may be called more than once and is threa d-safe. | 58 // waitForLoaderThreadCompletion() may be called more than once and is threa d-safe. |
57 void waitForLoaderThreadCompletion(); | 59 void waitForLoaderThreadCompletion(); |
58 | 60 |
59 HRTFDatabase* database() { return m_hrtfDatabase.get(); } | 61 HRTFDatabase* database() { return m_hrtfDatabase.get(); } |
60 | 62 |
61 float databaseSampleRate() const { return m_databaseSampleRate; } | 63 float databaseSampleRate() const { return m_databaseSampleRate; } |
62 | 64 |
63 // Called in asynchronous loading thread. | 65 // Called in asynchronous loading thread. |
64 void load(); | 66 void loadTask(); |
67 | |
68 void cleanupTask(TaskSynchronizer*); | |
sof
2014/11/11 12:05:30
Can we make this private?
haraken
2014/11/11 14:25:41
Done.
| |
65 | 69 |
66 void trace(Visitor*) { } | 70 void trace(Visitor*) { } |
67 | 71 |
68 private: | 72 private: |
69 // Both constructor and destructor must be called from the main thread. | 73 // Both constructor and destructor must be called from the main thread. |
70 explicit HRTFDatabaseLoader(float sampleRate); | 74 explicit HRTFDatabaseLoader(float sampleRate); |
71 | 75 |
72 // If it hasn't already been loaded, creates a new thread and initiates asyn chronous loading of the default database. | 76 // If it hasn't already been loaded, creates a new thread and initiates asyn chronous loading of the default database. |
73 // This must be called from the main thread. | 77 // This must be called from the main thread. |
74 void loadAsynchronously(); | 78 void loadAsynchronously(); |
75 | 79 |
76 // Holding a m_lock is required when accessing m_hrtfDatabase since we acces s it from multiple threads. | 80 // Holding a m_lock is required when accessing m_hrtfDatabase since we acces s it from multiple threads. |
77 Mutex m_lock; | 81 Mutex m_lock; |
78 OwnPtr<HRTFDatabase> m_hrtfDatabase; | 82 OwnPtr<HRTFDatabase> m_hrtfDatabase; |
79 | 83 |
80 OwnPtr<WebThreadSupportingGC> m_thread; | 84 OwnPtr<WebThreadSupportingGC> m_thread; |
81 | 85 |
82 float m_databaseSampleRate; | 86 float m_databaseSampleRate; |
83 }; | 87 }; |
84 | 88 |
85 } // namespace blink | 89 } // namespace blink |
86 | 90 |
87 #endif // HRTFDatabaseLoader_h | 91 #endif // HRTFDatabaseLoader_h |
OLD | NEW |