|  | // Copyright (c) 2012 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_MESSAGE_LOOP_MESSAGE_PUMP_DISPATCHER_H | 
|  | #define BASE_MESSAGE_LOOP_MESSAGE_PUMP_DISPATCHER_H | 
|  |  | 
|  | #include <stdint.h> | 
|  |  | 
|  | #include "base/base_export.h" | 
|  | #include "base/event_types.h" | 
|  |  | 
|  | namespace base { | 
|  |  | 
|  | // Dispatcher is used during a nested invocation of Run to dispatch events when | 
|  | // |RunLoop(dispatcher).Run()| is used.  If |RunLoop().Run()| is invoked, | 
|  | // MessageLoop does not dispatch events (or invoke TranslateMessage), rather | 
|  | // every message is passed to Dispatcher's Dispatch method for dispatch. It is | 
|  | // up to the Dispatcher whether or not to dispatch the event. | 
|  | // | 
|  | // The nested loop is exited by either posting a quit, or setting the | 
|  | // POST_DISPATCH_QUIT_LOOP flag on the return value from Dispatch. | 
|  | class BASE_EXPORT MessagePumpDispatcher { | 
|  | public: | 
|  | enum PostDispatchAction { | 
|  | POST_DISPATCH_NONE = 0x0, | 
|  | POST_DISPATCH_QUIT_LOOP = 0x1, | 
|  | POST_DISPATCH_PERFORM_DEFAULT = 0x2, | 
|  | }; | 
|  |  | 
|  | virtual ~MessagePumpDispatcher() {} | 
|  |  | 
|  | // Dispatches the event. The return value can have more than one | 
|  | // PostDispatchAction flags OR'ed together. If POST_DISPATCH_PERFORM_DEFAULT | 
|  | // is set in the returned value, then the message-pump performs the default | 
|  | // action. If POST_DISPATCH_QUIT_LOOP is set, in the return value, then the | 
|  | // nested loop exits immediately. | 
|  | virtual uint32_t Dispatch(const NativeEvent& event) = 0; | 
|  | }; | 
|  |  | 
|  | }  // namespace base | 
|  |  | 
|  | #endif  // BASE_MESSAGE_LOOP_MESSAGE_PUMP_DISPATCHER_H |