Port Android relocation packer to chromium build
[chromium-blink-merge.git] / base / threading / thread_checker_impl.h
blobc92e143db0c3cbd1e5a2a6cdf5fc6a9608dcfea3
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.
5 #ifndef BASE_THREADING_THREAD_CHECKER_IMPL_H_
6 #define BASE_THREADING_THREAD_CHECKER_IMPL_H_
8 #include "base/base_export.h"
9 #include "base/compiler_specific.h"
10 #include "base/synchronization/lock.h"
11 #include "base/threading/platform_thread.h"
13 namespace base {
15 // Real implementation of ThreadChecker, for use in debug mode, or
16 // for temporary use in release mode (e.g. to CHECK on a threading issue
17 // seen only in the wild).
19 // Note: You should almost always use the ThreadChecker class to get the
20 // right version for your build configuration.
21 class BASE_EXPORT ThreadCheckerImpl {
22 public:
23 ThreadCheckerImpl();
24 ~ThreadCheckerImpl();
26 bool CalledOnValidThread() const WARN_UNUSED_RESULT;
28 // Changes the thread that is checked for in CalledOnValidThread. This may
29 // be useful when an object may be created on one thread and then used
30 // exclusively on another thread.
31 void DetachFromThread();
33 private:
34 void EnsureThreadIdAssigned() const;
36 mutable base::Lock lock_;
37 // This is mutable so that CalledOnValidThread can set it.
38 // It's guarded by |lock_|.
39 mutable PlatformThreadRef valid_thread_id_;
42 } // namespace base
44 #endif // BASE_THREADING_THREAD_CHECKER_IMPL_H_