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