| // 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_ |