Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(836)

Side by Side Diff: base/message_loop/message_pump_libevent.h

Issue 1255293006: Microoptimisation for OnLibeventNotification. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Try to improve readability by separating the cases. Created 5 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 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_MESSAGE_LOOP_MESSAGE_PUMP_LIBEVENT_H_ 5 #ifndef BASE_MESSAGE_LOOP_MESSAGE_PUMP_LIBEVENT_H_
6 #define BASE_MESSAGE_LOOP_MESSAGE_PUMP_LIBEVENT_H_ 6 #define BASE_MESSAGE_LOOP_MESSAGE_PUMP_LIBEVENT_H_
7 7
8 #include "base/basictypes.h" 8 #include "base/basictypes.h"
9 #include "base/compiler_specific.h" 9 #include "base/compiler_specific.h"
10 #include "base/memory/weak_ptr.h" 10 #include "base/memory/weak_ptr.h"
Lei Zhang 2015/08/05 23:59:58 Remove. Though this may cause other parts of the b
Adam Rice 2015/08/06 00:46:46 Done.
11 #include "base/message_loop/message_pump.h" 11 #include "base/message_loop/message_pump.h"
12 #include "base/observer_list.h" 12 #include "base/observer_list.h"
13 #include "base/threading/thread_checker.h" 13 #include "base/threading/thread_checker.h"
14 #include "base/time/time.h" 14 #include "base/time/time.h"
15 15
16 // Declare structs we need from libevent.h rather than including it 16 // Declare structs we need from libevent.h rather than including it
17 struct event_base; 17 struct event_base;
18 struct event; 18 struct event;
19 19
20 namespace base { 20 namespace base {
(...skipping 58 matching lines...) Expand 10 before | Expand all | Expand 10 after
79 MessagePumpLibevent* pump() const { return pump_; } 79 MessagePumpLibevent* pump() const { return pump_; }
80 80
81 void set_watcher(Watcher* watcher) { watcher_ = watcher; } 81 void set_watcher(Watcher* watcher) { watcher_ = watcher; }
82 82
83 void OnFileCanReadWithoutBlocking(int fd, MessagePumpLibevent* pump); 83 void OnFileCanReadWithoutBlocking(int fd, MessagePumpLibevent* pump);
84 void OnFileCanWriteWithoutBlocking(int fd, MessagePumpLibevent* pump); 84 void OnFileCanWriteWithoutBlocking(int fd, MessagePumpLibevent* pump);
85 85
86 event* event_; 86 event* event_;
87 MessagePumpLibevent* pump_; 87 MessagePumpLibevent* pump_;
88 Watcher* watcher_; 88 Watcher* watcher_;
89 WeakPtrFactory<FileDescriptorWatcher> weak_factory_; 89 // If this pointer is non-NULL, the pointee is set to true in the
90 // destructor.
91 bool* was_destroyed_;
90 92
91 DISALLOW_COPY_AND_ASSIGN(FileDescriptorWatcher); 93 DISALLOW_COPY_AND_ASSIGN(FileDescriptorWatcher);
92 }; 94 };
93 95
94 enum Mode { 96 enum Mode {
95 WATCH_READ = 1 << 0, 97 WATCH_READ = 1 << 0,
96 WATCH_WRITE = 1 << 1, 98 WATCH_WRITE = 1 << 1,
97 WATCH_READ_WRITE = WATCH_READ | WATCH_WRITE 99 WATCH_READ_WRITE = WATCH_READ | WATCH_WRITE
98 }; 100 };
99 101
(...skipping 68 matching lines...) Expand 10 before | Expand all | Expand 10 after
168 event* wakeup_event_; 170 event* wakeup_event_;
169 171
170 ObserverList<IOObserver> io_observers_; 172 ObserverList<IOObserver> io_observers_;
171 ThreadChecker watch_file_descriptor_caller_checker_; 173 ThreadChecker watch_file_descriptor_caller_checker_;
172 DISALLOW_COPY_AND_ASSIGN(MessagePumpLibevent); 174 DISALLOW_COPY_AND_ASSIGN(MessagePumpLibevent);
173 }; 175 };
174 176
175 } // namespace base 177 } // namespace base
176 178
177 #endif // BASE_MESSAGE_LOOP_MESSAGE_PUMP_LIBEVENT_H_ 179 #endif // BASE_MESSAGE_LOOP_MESSAGE_PUMP_LIBEVENT_H_
OLDNEW
« no previous file with comments | « no previous file | base/message_loop/message_pump_libevent.cc » ('j') | base/message_loop/message_pump_libevent.cc » ('J')

Powered by Google App Engine
This is Rietveld 408576698