| // Copyright 2016 The Chromium Authors. All rights reserved. |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| |
| #ifndef BASE_SEQUENCE_TOKEN_H_ |
| #define BASE_SEQUENCE_TOKEN_H_ |
| |
| #include "base/base_export.h" |
| #include "base/macros.h" |
| |
| namespace base { |
| |
| // A token that identifies a series of sequenced tasks (i.e. tasks that run one |
| // at a time in posting order). |
| class BASE_EXPORT SequenceToken { |
| public: |
| // Instantiates an invalid SequenceToken. |
| SequenceToken() = default; |
| |
| // Explicitly allow copy. |
| SequenceToken(const SequenceToken& other) = default; |
| SequenceToken& operator=(const SequenceToken& other) = default; |
| |
| // An invalid SequenceToken is not equal to any other SequenceToken, including |
| // other invalid SequenceTokens. |
| bool operator==(const SequenceToken& other) const; |
| bool operator!=(const SequenceToken& other) const; |
| |
| // Returns true if this is a valid SequenceToken. |
| bool IsValid() const; |
| |
| // Returns the integer uniquely representing this SequenceToken. This method |
| // should only be used for tracing and debugging. |
| int ToInternalValue() const; |
| |
| // Returns a valid SequenceToken which isn't equal to any previously returned |
| // SequenceToken. |
| static SequenceToken Create(); |
| |
| // Returns the SequenceToken associated with the task running on the current |
| // thread, as determined by the active ScopedSetSequenceTokenForCurrentThread |
| // if any. |
| static SequenceToken GetForCurrentThread(); |
| |
| private: |
| explicit SequenceToken(int token) : token_(token) {} |
| |
| static constexpr int kInvalidSequenceToken = -1; |
| int token_ = kInvalidSequenceToken; |
| }; |
| |
| // A token that identifies a task. |
| // |
| // This is used by ThreadCheckerImpl to determine whether calls to |
| // CalledOnValidThread() come from the same task and hence are deterministically |
| // single-threaded (vs. calls coming from different sequenced or parallel tasks, |
| // which may or may not run on the same thread). |
| class BASE_EXPORT TaskToken { |
| public: |
| // Instantiates an invalid TaskToken. |
| TaskToken() = default; |
| |
| // Explicitly allow copy. |
| TaskToken(const TaskToken& other) = default; |
| TaskToken& operator=(const TaskToken& other) = default; |
| |
| // An invalid TaskToken is not equal to any other TaskToken, including |
| // other invalid TaskTokens. |
| bool operator==(const TaskToken& other) const; |
| bool operator!=(const TaskToken& other) const; |
| |
| // Returns true if this is a valid TaskToken. |
| bool IsValid() const; |
| |
| // In the scope of a ScopedSetSequenceTokenForCurrentThread, returns a valid |
| // TaskToken which isn't equal to any TaskToken returned in the scope of a |
| // different ScopedSetSequenceTokenForCurrentThread. Otherwise, returns an |
| // invalid TaskToken. |
| static TaskToken GetForCurrentThread(); |
| |
| private: |
| friend class ScopedSetSequenceTokenForCurrentThread; |
| |
| explicit TaskToken(int token) : token_(token) {} |
| |
| // Returns a valid TaskToken which isn't equal to any previously returned |
| // TaskToken. This is private as it only meant to be instantiated by |
| // ScopedSetSequenceTokenForCurrentThread. |
| static TaskToken Create(); |
| |
| static constexpr int kInvalidTaskToken = -1; |
| int token_ = kInvalidTaskToken; |
| }; |
| |
| // Instantiate this in the scope where a single task runs. |
| class BASE_EXPORT ScopedSetSequenceTokenForCurrentThread { |
| public: |
| // Throughout the lifetime of the constructed object, |
| // SequenceToken::GetForCurrentThread() will return |sequence_token| and |
| // TaskToken::GetForCurrentThread() will return a TaskToken which is not equal |
| // to any TaskToken returned in the scope of another |
| // ScopedSetSequenceTokenForCurrentThread. |
| ScopedSetSequenceTokenForCurrentThread(const SequenceToken& sequence_token); |
| ~ScopedSetSequenceTokenForCurrentThread(); |
| |
| private: |
| const SequenceToken sequence_token_; |
| const TaskToken task_token_; |
| |
| DISALLOW_COPY_AND_ASSIGN(ScopedSetSequenceTokenForCurrentThread); |
| }; |
| |
| } // namespace base |
| |
| #endif // BASE_SEQUENCE_TOKEN_H_ |