Run canExecute before executing delete command.
[chromium-blink-merge.git] / chrome / browser / bad_message.h
blob36026851192532bb710730ec60fa05c22f945af3
1 // Copyright 2015 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef CHROME_BROWSER_BAD_MESSAGE_H_
6 #define CHROME_BROWSER_BAD_MESSAGE_H_
8 namespace content {
9 class BrowserMessageFilter;
10 class RenderProcessHost;
13 namespace bad_message {
15 // The browser process often chooses to terminate a renderer if it receives
16 // a bad IPC message. The reasons are tracked for metrics.
18 // See also content/browser/bad_message.h.
20 // NOTE: Do not remove or reorder elements in this list. Add new entries at the
21 // end. Items may be renamed but do not change the values. We rely on the enum
22 // values in histograms. Also update histograms.xml with any new values by
23 // running:
24 // python tools/metrics/histograms/update_bad_message_reasons.py
25 enum BadMessageReason {
26 WRLHH_LOGGING_STOPPED_BAD_STATE = 0,
28 // Please add new elements here. The naming convention is abbreviated class
29 // name (e.g. RenderFrameHost becomes RFH) plus a unique description of the
30 // reason.
31 BAD_MESSAGE_MAX
34 // Called when the browser receives a bad IPC message from a renderer process on
35 // the UI thread. Logs the event, records a histogram metric for the |reason|,
36 // and terminates the process for |host|.
37 void ReceivedBadMessage(content::RenderProcessHost* host,
38 BadMessageReason reason);
40 // Called when a browser message filter receives a bad IPC message from a
41 // renderer or other child process. Logs the event, records a histogram metric
42 // for the |reason|, and terminates the process for |filter|.
43 void ReceivedBadMessage(content::BrowserMessageFilter* filter,
44 BadMessageReason reason);
46 } // namespace bad_message
48 #endif // CHROME_BROWSER_BAD_MESSAGE_H_