89de5b6e9a
We don't need the ability it provided, and it is causing crashes on some machines. Fixes #850.
63 lines
1.5 KiB
C++
63 lines
1.5 KiB
C++
// Copyright (c) 2014 GitHub, Inc.
|
|
// Use of this source code is governed by the MIT license that can be
|
|
// found in the LICENSE file.
|
|
|
|
#ifndef ATOM_BROWSER_UI_WIN_NOTIFY_ICON_HOST_H_
|
|
#define ATOM_BROWSER_UI_WIN_NOTIFY_ICON_HOST_H_
|
|
|
|
#include <windows.h>
|
|
|
|
#include <vector>
|
|
|
|
#include "base/compiler_specific.h"
|
|
#include "base/memory/scoped_ptr.h"
|
|
|
|
namespace atom {
|
|
|
|
class NotifyIcon;
|
|
|
|
class NotifyIconHost {
|
|
public:
|
|
NotifyIconHost();
|
|
~NotifyIconHost();
|
|
|
|
NotifyIcon* CreateNotifyIcon();
|
|
void Remove(NotifyIcon* notify_icon);
|
|
|
|
private:
|
|
typedef std::vector<NotifyIcon*> NotifyIcons;
|
|
|
|
// Static callback invoked when a message comes in to our messaging window.
|
|
static LRESULT CALLBACK
|
|
WndProcStatic(HWND hwnd, UINT message, WPARAM wparam, LPARAM lparam);
|
|
|
|
LRESULT CALLBACK
|
|
WndProc(HWND hwnd, UINT message, WPARAM wparam, LPARAM lparam);
|
|
|
|
UINT NextIconId();
|
|
|
|
// The unique icon ID we will assign to the next icon.
|
|
UINT next_icon_id_;
|
|
|
|
// List containing all active NotifyIcons.
|
|
NotifyIcons notify_icons_;
|
|
|
|
// The window class of |window_|.
|
|
ATOM atom_;
|
|
|
|
// The handle of the module that contains the window procedure of |window_|.
|
|
HMODULE instance_;
|
|
|
|
// The window used for processing events.
|
|
HWND window_;
|
|
|
|
// The message ID of the "TaskbarCreated" message, sent to us when we need to
|
|
// reset our status icons.
|
|
UINT taskbar_created_message_;
|
|
|
|
DISALLOW_COPY_AND_ASSIGN(NotifyIconHost);
|
|
};
|
|
|
|
} // namespace atom
|
|
|
|
#endif // ATOM_BROWSER_UI_WIN_NOTIFY_ICON_HOST_H_
|