|
1 /* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ |
|
2 /* vim:set ts=2 sw=2 sts=2 ci et: */ |
|
3 /* This Source Code Form is subject to the terms of the Mozilla Public |
|
4 * License, v. 2.0. If a copy of the MPL was not distributed with this |
|
5 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ |
|
6 |
|
7 #ifndef mozilla_AvailableMemoryTracker_h |
|
8 #define mozilla_AvailableMemoryTracker_h |
|
9 |
|
10 namespace mozilla { |
|
11 namespace AvailableMemoryTracker { |
|
12 |
|
13 // The AvailableMemoryTracker launches a memory pressure watcher on all |
|
14 // platforms to react to low-memory situations and on Windows it implements |
|
15 // the full functionality used to monitor how much memory is available. |
|
16 // |
|
17 // Init() must be called before any other threads have started, because it |
|
18 // modifies the in-memory implementations of some DLL functions in |
|
19 // non-thread-safe ways. |
|
20 // |
|
21 // The hooks don't do anything until Activate() is called. It's an error to |
|
22 // call Activate() without first calling Init(). |
|
23 |
|
24 void Init(); |
|
25 void Activate(); |
|
26 |
|
27 } // namespace AvailableMemoryTracker |
|
28 } // namespace mozilla |
|
29 |
|
30 #endif // ifndef mozilla_AvailableMemoryTracker_h |