| OLD | NEW |
| 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 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 | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #ifndef BASE_THREADING_NON_THREAD_SAFE_IMPL_H_ | 5 #ifndef BASE_THREADING_NON_THREAD_SAFE_IMPL_H_ |
| 6 #define BASE_THREADING_NON_THREAD_SAFE_IMPL_H_ | 6 #define BASE_THREADING_NON_THREAD_SAFE_IMPL_H_ |
| 7 #pragma once | 7 #pragma once |
| 8 | 8 |
| 9 #include "base/base_api.h" |
| 9 #include "base/threading/thread_checker_impl.h" | 10 #include "base/threading/thread_checker_impl.h" |
| 10 | 11 |
| 11 namespace base { | 12 namespace base { |
| 12 | 13 |
| 13 // Full implementation of NonThreadSafe, for debug mode or for occasional | 14 // Full implementation of NonThreadSafe, for debug mode or for occasional |
| 14 // temporary use in release mode e.g. when you need to CHECK on a thread | 15 // temporary use in release mode e.g. when you need to CHECK on a thread |
| 15 // bug that only occurs in the wild. | 16 // bug that only occurs in the wild. |
| 16 // | 17 // |
| 17 // Note: You should almost always use the NonThreadSafe class to get | 18 // Note: You should almost always use the NonThreadSafe class to get |
| 18 // the right version of the class for your build configuration. | 19 // the right version of the class for your build configuration. |
| 19 class NonThreadSafeImpl { | 20 class BASE_API NonThreadSafeImpl { |
| 20 public: | 21 public: |
| 21 ~NonThreadSafeImpl(); | 22 ~NonThreadSafeImpl(); |
| 22 | 23 |
| 23 bool CalledOnValidThread() const; | 24 bool CalledOnValidThread() const; |
| 24 | 25 |
| 25 protected: | 26 protected: |
| 26 // Changes the thread that is checked for in CalledOnValidThread. The next | 27 // Changes the thread that is checked for in CalledOnValidThread. The next |
| 27 // call to CalledOnValidThread will attach this class to a new thread. It is | 28 // call to CalledOnValidThread will attach this class to a new thread. It is |
| 28 // up to the NonThreadSafe derived class to decide to expose this or not. | 29 // up to the NonThreadSafe derived class to decide to expose this or not. |
| 29 // This may be useful when an object may be created on one thread and then | 30 // This may be useful when an object may be created on one thread and then |
| 30 // used exclusively on another thread. | 31 // used exclusively on another thread. |
| 31 void DetachFromThread(); | 32 void DetachFromThread(); |
| 32 | 33 |
| 33 private: | 34 private: |
| 34 ThreadCheckerImpl thread_checker_; | 35 ThreadCheckerImpl thread_checker_; |
| 35 }; | 36 }; |
| 36 | 37 |
| 37 } // namespace base | 38 } // namespace base |
| 38 | 39 |
| 39 #endif // BASE_THREADING_NON_THREAD_SAFE_IMPL_H_ | 40 #endif // BASE_THREADING_NON_THREAD_SAFE_IMPL_H_ |
| OLD | NEW |