aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorEnan Ajmain <3nan.ajmain@gmail.com>2022-10-13 18:48:12 +0600
committerGitHub <noreply@github.com>2022-10-13 05:48:12 -0700
commit730228f6db1f858795ea83ba2179c875dca37bc7 (patch)
treeb18acb4cf052a385c4317a4f73976e4d48eb7a13
parent06dfedc87ab4cc575a503195a1358b2984e248c4 (diff)
downloadrneovim-730228f6db1f858795ea83ba2179c875dca37bc7.tar.gz
rneovim-730228f6db1f858795ea83ba2179c875dca37bc7.tar.bz2
rneovim-730228f6db1f858795ea83ba2179c875dca37bc7.zip
feat(windows): show icon in terminal titlebar, taskbar #20607
closes #20071
-rw-r--r--cmake.packaging/CMakeLists.txt2
-rw-r--r--runtime/CMakeLists.txt12
-rw-r--r--runtime/neovim.ico (renamed from cmake.packaging/neovim.ico)bin122355 -> 122355 bytes
-rw-r--r--src/nvim/main.c60
4 files changed, 69 insertions, 5 deletions
diff --git a/cmake.packaging/CMakeLists.txt b/cmake.packaging/CMakeLists.txt
index 8538075388..df43f2806a 100644
--- a/cmake.packaging/CMakeLists.txt
+++ b/cmake.packaging/CMakeLists.txt
@@ -32,7 +32,7 @@ if(WIN32)
# The following guid is just a randomly generated guid that's been pasted here.
# It has no special meaning other than to supply it to WIX.
set(CPACK_WIX_UPGRADE_GUID "207A1A70-7B0C-418A-A153-CA6883E38F4D")
- set(CPACK_WIX_PRODUCT_ICON ${CMAKE_CURRENT_LIST_DIR}/neovim.ico)
+ set(CPACK_WIX_PRODUCT_ICON ${PROJECT_SOURCE_DIR}/runtime/neovim.ico)
# We use a wix patch to add further options to the installer. At present, it's just to add neovim to the path
# on installation, however, it can be extended.
diff --git a/runtime/CMakeLists.txt b/runtime/CMakeLists.txt
index 6b926e9fc1..9aa0c5eac0 100644
--- a/runtime/CMakeLists.txt
+++ b/runtime/CMakeLists.txt
@@ -110,12 +110,16 @@ if(NOT APPLE)
install_helper(
FILES ${CMAKE_CURRENT_SOURCE_DIR}/nvim.desktop
DESTINATION ${CMAKE_INSTALL_DATAROOTDIR}/applications)
-
- install_helper(
- FILES ${CMAKE_CURRENT_SOURCE_DIR}/nvim.png
- DESTINATION ${CMAKE_INSTALL_DATAROOTDIR}/icons/hicolor/128x128/apps)
endif()
+install_helper(
+ FILES ${CMAKE_CURRENT_SOURCE_DIR}/nvim.png
+ DESTINATION ${CMAKE_INSTALL_DATAROOTDIR}/icons/hicolor/128x128/apps)
+
+install_helper(
+ FILES ${CMAKE_CURRENT_SOURCE_DIR}/neovim.ico
+ DESTINATION ${CMAKE_INSTALL_DATAROOTDIR}/nvim/runtime)
+
globrecurse_wrapper(RUNTIME_PROGRAMS ${CMAKE_CURRENT_SOURCE_DIR} *.awk *.sh *.bat)
foreach(PROG ${RUNTIME_PROGRAMS})
diff --git a/cmake.packaging/neovim.ico b/runtime/neovim.ico
index e0c151c966..e0c151c966 100644
--- a/cmake.packaging/neovim.ico
+++ b/runtime/neovim.ico
Binary files differ
diff --git a/src/nvim/main.c b/src/nvim/main.c
index d5fa992218..f6ec08c8e0 100644
--- a/src/nvim/main.c
+++ b/src/nvim/main.c
@@ -207,6 +207,57 @@ void early_init(mparm_T *paramp)
init_signs();
}
+#ifdef MSWIN
+HWND hWnd = NULL;
+static HICON hOrigIconSmall = NULL;
+static HICON hOrigIcon = NULL;
+
+/// Save Windows console icon to be reset later
+static void SaveWin32ConsoleIcon(void)
+{
+ if ((hWnd = GetConsoleWindow()) == NULL) {
+ return;
+ }
+ hOrigIconSmall = (HICON)SendMessage(hWnd, WM_GETICON, (WPARAM)ICON_SMALL, (LPARAM)0);
+ hOrigIcon = (HICON)SendMessage(hWnd, WM_GETICON, (WPARAM)ICON_BIG, (LPARAM)0);
+}
+
+static void SetConsoleIcon(HWND hWindow, HICON hIconSmall, HICON hIcon)
+{
+ if (hWindow == NULL) {
+ return;
+ }
+ if (hIconSmall != NULL) {
+ SendMessage(hWnd, WM_SETICON, (WPARAM)ICON_SMALL, (LPARAM)hIconSmall);
+ }
+ if (hIcon != NULL) {
+ SendMessage(hWnd, WM_SETICON, (WPARAM)ICON_BIG, (LPARAM)hIcon);
+ }
+}
+
+/// Reset Windows console icon to original
+static void ResetWin32ConsoleIcon(void)
+{
+ SetConsoleIcon(hWnd, hOrigIconSmall, hOrigIcon);
+}
+
+/// Set Neovim logo as Windows console icon
+static void SetWin32ConsoleIcon(void)
+{
+ const char *vimruntime = os_getenv("VIMRUNTIME");
+ if (vimruntime != NULL) {
+ snprintf(NameBuff, MAXPATHL, "%s" _PATHSEPSTR "neovim.ico", vimruntime);
+ if (!os_path_exists(NameBuff)) {
+ WLOG("neovim.ico not found: %s", NameBuff);
+ } else {
+ HICON hVimIcon = LoadImage(NULL, NameBuff, IMAGE_ICON, 64, 64,
+ LR_LOADFROMFILE | LR_LOADMAP3DCOLORS);
+ SetConsoleIcon(hWnd, hVimIcon, hVimIcon);
+ }
+ }
+}
+#endif
+
#ifdef MAKE_LIB
int nvim_main(int argc, char **argv); // silence -Wmissing-prototypes
int nvim_main(int argc, char **argv)
@@ -256,6 +307,11 @@ int main(int argc, char **argv)
early_init(&params);
+#ifdef MSWIN
+ SaveWin32ConsoleIcon();
+ SetWin32ConsoleIcon();
+#endif
+
set_argv_var(argv, argc); // set v:argv
// Check if we have an interactive window.
@@ -721,6 +777,10 @@ void getout(int exitval)
garbage_collect(false);
}
+#ifdef MSWIN
+ ResetWin32ConsoleIcon();
+#endif
+
os_exit(exitval);
}