mirror of
https://github.com/mintty/wsltty.git
synced 2025-11-05 17:41:51 +00:00
Compare commits
48 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
be4e7fef44 | ||
|
|
a2df28017b | ||
|
|
09972471b9 | ||
|
|
c13340b328 | ||
|
|
8d7ffa75bb | ||
|
|
305fd0f273 | ||
|
|
fb1bf601e9 | ||
|
|
adc7036609 | ||
|
|
fef944e1bb | ||
|
|
d40e5919af | ||
|
|
a141e760f4 | ||
|
|
14f6d1e631 | ||
|
|
e189d87a2c | ||
|
|
399dff4226 | ||
|
|
8fbee63214 | ||
|
|
effb0ce46a | ||
|
|
ca4670bd44 | ||
|
|
ab84d5bbde | ||
|
|
943d83da69 | ||
|
|
0be30273f5 | ||
|
|
e8177d77d7 | ||
|
|
756f5f5844 | ||
|
|
bbbef4fc89 | ||
|
|
eee9516a23 | ||
|
|
449a310d90 | ||
|
|
87aa168b41 | ||
|
|
9de7d8d6f1 | ||
|
|
c91ec886b5 | ||
|
|
4caa2c34eb | ||
|
|
73fcc66790 | ||
|
|
5cee2c341b | ||
|
|
ea570a191e | ||
|
|
2dd099265d | ||
|
|
2ddd2cd1ff | ||
|
|
d1fa49985b | ||
|
|
76fad756e1 | ||
|
|
600df69bb8 | ||
|
|
97dc68d64a | ||
|
|
9469b2b5f5 | ||
|
|
5b27a3d3c8 | ||
|
|
ab46c2b1b0 | ||
|
|
2e56730282 | ||
|
|
d67ce45c3e | ||
|
|
6e74ab4d5b | ||
|
|
ee4e403f4c | ||
|
|
a332cf8eaa | ||
|
|
07aa6c692d | ||
|
|
74dad091ce |
@@ -1,36 +1,16 @@
|
|||||||
Date: Tue, 15 Sep 2020 06:15:34 +0200
|
|
||||||
Subject: [PATCH] notify window size change via escaped inband information
|
|
||||||
(Biswa96/wslbridge2#21, mintty/wsltty#220)
|
|
||||||
Co-authored-by: Thomas Wolff <towo@towo.net>
|
|
||||||
|
|
||||||
---
|
|
||||||
src/wslbridge2-backend.cpp | 87 +++++++++++++++++++++++++++++++++++++-
|
|
||||||
src/wslbridge2.cpp | 83 ++++++++++++++++++++++++++++++------
|
|
||||||
2 files changed, 155 insertions(+), 15 deletions(-)
|
|
||||||
|
|
||||||
diff --git a/src/wslbridge2-backend.cpp b/src/wslbridge2-backend.cpp
|
diff --git a/src/wslbridge2-backend.cpp b/src/wslbridge2-backend.cpp
|
||||||
index b50ee9c..ad429ae 100644
|
index 8b86cc6..63a19e5 100644
|
||||||
--- a/src/wslbridge2-backend.cpp
|
--- a/src/wslbridge2-backend.cpp
|
||||||
+++ b/src/wslbridge2-backend.cpp
|
+++ b/src/wslbridge2-backend.cpp
|
||||||
@@ -24,6 +24,7 @@
|
@@ -17,6 +17,7 @@
|
||||||
#include <termios.h>
|
#include <sys/wait.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <wordexp.h>
|
#include <wordexp.h>
|
||||||
+#include <limits.h> // PIPE_BUF
|
+#include <limits.h> // PIPE_BUF
|
||||||
|
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
@@ -315,6 +316,9 @@ int main(int argc, char *argv[])
|
@@ -196,6 +197,7 @@ int main(int argc, char *argv[])
|
||||||
/* Use dupped master fd to read OR write */
|
|
||||||
const int mfd_dp = dup(mfd);
|
|
||||||
assert(mfd_dp > 0);
|
|
||||||
+#ifdef debug_to_input
|
|
||||||
+ FILE * debug = fdopen(mfd_dp, "w"); // for fprintf
|
|
||||||
+#endif
|
|
||||||
|
|
||||||
sigset_t set;
|
|
||||||
sigemptyset(&set);
|
|
||||||
@@ -333,6 +337,7 @@ int main(int argc, char *argv[])
|
|
||||||
|
|
||||||
ssize_t readRet = 0, writeRet = 0;
|
ssize_t readRet = 0, writeRet = 0;
|
||||||
char data[1024]; /* Buffer to hold raw data from pty */
|
char data[1024]; /* Buffer to hold raw data from pty */
|
||||||
@@ -38,13 +18,12 @@ index b50ee9c..ad429ae 100644
|
|||||||
|
|
||||||
do
|
do
|
||||||
{
|
{
|
||||||
@@ -343,8 +348,86 @@ int main(int argc, char *argv[])
|
@@ -206,8 +208,85 @@ int main(int argc, char *argv[])
|
||||||
if (fds[0].revents & POLLIN)
|
if (fds[0].revents & POLLIN)
|
||||||
{
|
{
|
||||||
readRet = recv(ioSockets.inputSock, data, sizeof data, 0);
|
readRet = recv(ioSockets.inputSock, data, sizeof data, 0);
|
||||||
- if (readRet > 0)
|
- if (readRet > 0)
|
||||||
- writeRet = write(mfd_dp, data, readRet);
|
- writeRet = write(mfd_dp, data, readRet);
|
||||||
+
|
|
||||||
+ char * s = data;
|
+ char * s = data;
|
||||||
+ int len = readRet;
|
+ int len = readRet;
|
||||||
+ writeRet = 1;
|
+ writeRet = 1;
|
||||||
@@ -128,14 +107,13 @@ index b50ee9c..ad429ae 100644
|
|||||||
|
|
||||||
/* Resize window when buffer received in control socket */
|
/* Resize window when buffer received in control socket */
|
||||||
diff --git a/src/wslbridge2.cpp b/src/wslbridge2.cpp
|
diff --git a/src/wslbridge2.cpp b/src/wslbridge2.cpp
|
||||||
index 75ccb1b..e9fbbf7 100644
|
index 300ad57..3ba9096 100644
|
||||||
--- a/src/wslbridge2.cpp
|
--- a/src/wslbridge2.cpp
|
||||||
+++ b/src/wslbridge2.cpp
|
+++ b/src/wslbridge2.cpp
|
||||||
@@ -56,32 +56,85 @@ union IoSockets
|
@@ -43,19 +43,41 @@ union IoSockets
|
||||||
/* global variable */
|
/* global variable */
|
||||||
static union IoSockets g_ioSockets = { 0, 0, 0 };
|
static volatile union IoSockets g_ioSockets = { 0 };
|
||||||
|
|
||||||
+
|
|
||||||
+#define dont_debug_inband
|
+#define dont_debug_inband
|
||||||
+#define dont_use_controlsocket
|
+#define dont_use_controlsocket
|
||||||
+
|
+
|
||||||
@@ -148,7 +126,7 @@ index 75ccb1b..e9fbbf7 100644
|
|||||||
|
|
||||||
/* Send terminal window size to control socket */
|
/* Send terminal window size to control socket */
|
||||||
- ioctl(STDIN_FILENO, TIOCGWINSZ, &winp);
|
- ioctl(STDIN_FILENO, TIOCGWINSZ, &winp);
|
||||||
send(g_ioSockets.controlSock, &winp, sizeof winp, 0);
|
send(g_ioSockets.controlSock, (char *)&winp, sizeof winp, 0);
|
||||||
+#else
|
+#else
|
||||||
+ static char wins[2 + sizeof(struct winsize)] = {0, 16};
|
+ static char wins[2 + sizeof(struct winsize)] = {0, 16};
|
||||||
+ static struct winsize * winsp = (struct winsize *)&wins[2];
|
+ static struct winsize * winsp = (struct winsize *)&wins[2];
|
||||||
@@ -171,27 +149,16 @@ index 75ccb1b..e9fbbf7 100644
|
|||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
char data[1024];
|
char data[1024];
|
||||||
-
|
|
||||||
- struct pollfd fds = { STDIN_FILENO, POLLIN, 0 };
|
|
||||||
+ assert(sizeof data <= PIPE_BUF);
|
+ assert(sizeof data <= PIPE_BUF);
|
||||||
|
|
||||||
while (1)
|
while (1)
|
||||||
{
|
{
|
||||||
+#ifdef use_poll
|
@@ -65,8 +87,33 @@ static void* send_buffer(void *param)
|
||||||
+ // we could poll on a single channel but we don't need to
|
closesocket(g_ioSockets.inputSock);
|
||||||
+ static struct pollfd fds = { STDIN_FILENO, POLLIN, 0 };
|
break;
|
||||||
ret = poll(&fds, 1, -1);
|
}
|
||||||
|
- if (!send(g_ioSockets.inputSock, data, ret, 0))
|
||||||
if (fds.revents & POLLIN)
|
- break;
|
||||||
+#else
|
|
||||||
+ if (1)
|
|
||||||
+#endif
|
|
||||||
{
|
|
||||||
ret = read(STDIN_FILENO, data, sizeof data);
|
|
||||||
- if (ret > 0)
|
|
||||||
- ret = send(g_ioSockets.inputSock, data, ret, 0);
|
|
||||||
- else
|
|
||||||
+
|
|
||||||
+ char * s = data;
|
+ char * s = data;
|
||||||
+ int len = ret;
|
+ int len = ret;
|
||||||
+ while (ret > 0 && len > 0)
|
+ while (ret > 0 && len > 0)
|
||||||
@@ -219,25 +186,27 @@ index 75ccb1b..e9fbbf7 100644
|
|||||||
+ }
|
+ }
|
||||||
+ }
|
+ }
|
||||||
+ }
|
+ }
|
||||||
+ if (ret <= 0)
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -537,13 +590,6 @@ int main(int argc, char *argv[])
|
|
||||||
closesocket(controlSocket);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
- /* Create thread to send window size through control socket */
|
pthread_exit(&ret);
|
||||||
- struct sigaction act = {};
|
@@ -480,16 +527,6 @@ int main(int argc, char *argv[])
|
||||||
|
g_ioSockets.controlSock = win_local_accept(controlSock);
|
||||||
|
}
|
||||||
|
|
||||||
|
- /* Capture window resize signal and send buffer to control socket */
|
||||||
|
- {
|
||||||
|
- struct sigaction act;
|
||||||
|
- memset(&act, 0, sizeof act);
|
||||||
- act.sa_handler = resize_window;
|
- act.sa_handler = resize_window;
|
||||||
- act.sa_flags = SA_RESTART;
|
- act.sa_flags = SA_RESTART;
|
||||||
- ret = sigaction(SIGWINCH, &act, NULL);
|
- ret = sigaction(SIGWINCH, &act, NULL);
|
||||||
- assert(ret == 0);
|
- assert(ret == 0);
|
||||||
|
- }
|
||||||
-
|
-
|
||||||
/* Create thread to send input buffer to input socket */
|
/* Create thread to send input buffer to input socket */
|
||||||
pthread_t tidInput;
|
pthread_t tidInput;
|
||||||
ret = pthread_create(&tidInput, nullptr, send_buffer, nullptr);
|
ret = pthread_create(&tidInput, nullptr, send_buffer, nullptr);
|
||||||
@@ -556,6 +602,17 @@ int main(int argc, char *argv[])
|
@@ -502,6 +539,17 @@ int main(int argc, char *argv[])
|
||||||
|
|
||||||
termState.enterRawMode();
|
termState.enterRawMode();
|
||||||
|
|
||||||
|
|||||||
62
0002-add-com-for-lifted-wsl.patch
Normal file
62
0002-add-com-for-lifted-wsl.patch
Normal file
@@ -0,0 +1,62 @@
|
|||||||
|
diff -rup src/sav/GetVmId.cpp src/GetVmId.cpp
|
||||||
|
--- src/sav/GetVmId.cpp 2021-04-27 13:50:51.000000000 +0000
|
||||||
|
+++ src/GetVmId.cpp 2022-02-03 19:43:53.684999800 +0000
|
||||||
|
@@ -46,11 +46,24 @@ void ComInit(void)
|
||||||
|
EOAC_STATIC_CLOAKING, NULL);
|
||||||
|
assert(hRes == 0);
|
||||||
|
|
||||||
|
- hRes = CoCreateInstance(CLSID_LxssUserSession,
|
||||||
|
+ // First try with COM server in lifted WSL service
|
||||||
|
+ hRes = CoCreateInstance(CLSID_WslService,
|
||||||
|
NULL,
|
||||||
|
CLSCTX_LOCAL_SERVER,
|
||||||
|
- IID_ILxssUserSession,
|
||||||
|
+ IID_IWSLService,
|
||||||
|
(PVOID *)&wslSession);
|
||||||
|
+
|
||||||
|
+
|
||||||
|
+ // Now try with COM server in system WSL service
|
||||||
|
+ if (FAILED(hRes))
|
||||||
|
+ {
|
||||||
|
+ hRes = CoCreateInstance(CLSID_LxssUserSession,
|
||||||
|
+ NULL,
|
||||||
|
+ CLSCTX_LOCAL_SERVER,
|
||||||
|
+ IID_ILxssUserSession,
|
||||||
|
+ (PVOID *)&wslSession);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
assert(hRes == 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
diff -rup src/sav/LxssUserSession.hpp src/LxssUserSession.hpp
|
||||||
|
--- src/sav/LxssUserSession.hpp 2021-04-27 13:50:51.000000000 +0000
|
||||||
|
+++ src/LxssUserSession.hpp 2022-02-03 19:45:22.846298200 +0000
|
||||||
|
@@ -11,14 +11,26 @@
|
||||||
|
#ifndef LXSSUSERSESSION_H
|
||||||
|
#define LXSSUSERSESSION_H
|
||||||
|
|
||||||
|
-/* Class identifier */
|
||||||
|
+// COM IDs for lifted WSL service
|
||||||
|
+static const GUID CLSID_WslService = {
|
||||||
|
+ 0xF122531F,
|
||||||
|
+ 0x326B,
|
||||||
|
+ 0x4514,
|
||||||
|
+ { 0x85, 0xAE, 0xDC, 0x99, 0xD3, 0x1D, 0x82, 0x56 } };
|
||||||
|
+
|
||||||
|
+static const GUID IID_IWSLService = {
|
||||||
|
+ 0x50047071,
|
||||||
|
+ 0x122C,
|
||||||
|
+ 0x4CAD,
|
||||||
|
+ { 0x9C, 0x93, 0x94, 0x72, 0x0E, 0xB7, 0x7B, 0x06 } };
|
||||||
|
+
|
||||||
|
+// COM IDs for system WSL service
|
||||||
|
static const GUID CLSID_LxssUserSession = {
|
||||||
|
0x4F476546,
|
||||||
|
0xB412,
|
||||||
|
0x4579,
|
||||||
|
{ 0xB6, 0x4C, 0x12, 0x3D, 0xF3, 0x31, 0xE3, 0xD6 } };
|
||||||
|
|
||||||
|
-/* Interface identifier */
|
||||||
|
static const GUID IID_ILxssUserSession = {
|
||||||
|
0x536A6BCF,
|
||||||
|
0xFE04,
|
||||||
40
0012-get-vmid-from-registry.patch
Normal file
40
0012-get-vmid-from-registry.patch
Normal file
@@ -0,0 +1,40 @@
|
|||||||
|
--- wslbridge2/src/wslbridge2.cpp 2024-10-10 20:20:21.931891800 +0000
|
||||||
|
+++ wslbridge2-0.12/src/wslbridge2.cpp 2024-10-08 09:31:35.954145800 +0000
|
||||||
|
@@ -228,6 +228,26 @@ static void start_dummy(std::wstring wsl
|
||||||
|
CloseHandle(pi.hThread);
|
||||||
|
}
|
||||||
|
|
||||||
|
+bool GetIdFromRegistry(GUID *guid) {
|
||||||
|
+ HKEY hKeyRoot = HKEY_LOCAL_MACHINE;
|
||||||
|
+ std::wstring subKey = L"SOFTWARE\\Microsoft\\Windows NT\\CurrentVersion\\HostComputeService\\VolatileStore\\ComputeSystem";
|
||||||
|
+ HKEY hKey;
|
||||||
|
+ if (RegOpenKeyEx(hKeyRoot, subKey.c_str(), 0, KEY_READ, &hKey) == ERROR_SUCCESS) {
|
||||||
|
+ DWORD index = 0;
|
||||||
|
+ WCHAR keyName[256];
|
||||||
|
+ DWORD keyNameSize = sizeof(keyName) / sizeof(keyName[0]);
|
||||||
|
+
|
||||||
|
+ while (RegEnumKeyEx(hKey, index, keyName, &keyNameSize, nullptr, nullptr, nullptr, nullptr) == ERROR_SUCCESS) {
|
||||||
|
+ RegCloseKey(hKey);
|
||||||
|
+ std::wstring id = L"{" + std::wstring(keyName) + L"}";
|
||||||
|
+ return IIDFromString(id.c_str(), guid) == S_OK;
|
||||||
|
+ }
|
||||||
|
+ RegCloseKey(hKey);
|
||||||
|
+ }
|
||||||
|
+ return false;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+
|
||||||
|
int main(int argc, char *argv[])
|
||||||
|
{
|
||||||
|
/* Minimum requirement Windows 10 build 17763 aka. version 1809 */
|
||||||
|
@@ -387,8 +407,8 @@ int main(int argc, char *argv[])
|
||||||
|
if (LiftedWSLVersion)
|
||||||
|
start_dummy(wslPath, wslCmdLine, distroName, debugMode);
|
||||||
|
|
||||||
|
- const HRESULT hRes = GetVmId(&DistroId, &VmId, LiftedWSLVersion);
|
||||||
|
- if (hRes != 0)
|
||||||
|
+ const bool hRes = GetIdFromRegistry(&VmId);
|
||||||
|
+ if (!hRes)
|
||||||
|
fatal("GetVmId: %s\n", GetErrorMessage(hRes).c_str());
|
||||||
|
|
||||||
|
inputSock = win_vsock_create();
|
||||||
@@ -1,4 +1,4 @@
|
|||||||
mintty is copyright 2008-13 Andy Koppe, 2015-18 Thomas Wolff.
|
mintty is copyright 2008-23 Andy Koppe, 2015-23 Thomas Wolff.
|
||||||
|
|
||||||
Licensed under the terms of the GNU General Public License version 3 or later,
|
Licensed under the terms of the GNU General Public License version 3 or later,
|
||||||
amended with the bundling clause to clarify ambiguous interpretation.
|
amended with the bundling clause to clarify ambiguous interpretation.
|
||||||
|
|||||||
80
README.md
80
README.md
@@ -11,13 +11,21 @@ WSLtty components
|
|||||||
(“home”-located configuration files from a previously installed version
|
(“home”-located configuration files from a previously installed version
|
||||||
will be migrated to the new default location)
|
will be migrated to the new default location)
|
||||||
* Start Menu shortcuts to start WSL terminals
|
* Start Menu shortcuts to start WSL terminals
|
||||||
|
* Desktop shorcut to start a terminal for the default WSL distribution
|
||||||
* `*.bat` scripts to invoke WSL terminals from the command line
|
* `*.bat` scripts to invoke WSL terminals from the command line
|
||||||
* optional context menu entries for Windows Explorer to start WSL terminals in the respective folder
|
* optional context menu entries for Windows Explorer to start WSL terminals in the respective folder
|
||||||
* install/uninstall context menu items from Start Menu subfolder `WSLtty`
|
* install/uninstall context menu items from Start Menu subfolder `WSLtty`
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
### Requirement ###
|
### Requirements ###
|
||||||
|
|
||||||
|
Wsltty does not seem to work with WSL V2 mode since release 2.0.0 (#343).
|
||||||
|
As a workaround until a solution in the wslbridge gateway, it is suggested
|
||||||
|
to install [release 1.3.17](https://github.com/microsoft/WSL/releases/tag/1.3.17);
|
||||||
|
maybe uninstall WSL first, see [issue 343 comment](https://github.com/mintty/wsltty/issues/343#issuecomment-1818367512).
|
||||||
|
Another remedy could be to configure your WSL distributions to run in WSL V1 mode, for example:
|
||||||
|
`wsl --set-version Ubuntu 1`.
|
||||||
|
|
||||||
Since release 3.0.5, WSLtty requires Windows version 1809 (the November 2018 release).
|
Since release 3.0.5, WSLtty requires Windows version 1809 (the November 2018 release).
|
||||||
|
|
||||||
@@ -27,19 +35,38 @@ Since release 3.0.5, WSLtty requires Windows version 1809 (the November 2018 rel
|
|||||||
|
|
||||||
#### WSLtty installer ([Download](https://github.com/mintty/wsltty/releases) standalone installation) ####
|
#### WSLtty installer ([Download](https://github.com/mintty/wsltty/releases) standalone installation) ####
|
||||||
|
|
||||||
Run the [installer](https://github.com/mintty/wsltty/releases) to install
|
From the [release downloads](https://github.com/mintty/wsltty/releases),
|
||||||
the components listed above.
|
run the wsltty-VERSION-x86_64-install.exe installer to install
|
||||||
|
the components listed above. Make sure to select a 64-bit installer
|
||||||
|
on a 64-bit system.
|
||||||
If Windows complains with a “Windows protected your PC” popup,
|
If Windows complains with a “Windows protected your PC” popup,
|
||||||
you may need to click “Run anyway” to proceed with the installation.
|
you may need to click “Run anyway” to proceed with the installation.
|
||||||
You may need to open the Properties of the installer first, tab “General”
|
You may need to open the Properties of the installer first, tab “General”
|
||||||
section “Security” (if available) and select “Unblock”,
|
section “Security” (if available) and select “Unblock”,
|
||||||
to enable the “Run anyway” button.
|
to enable the “Run anyway” button.
|
||||||
|
|
||||||
|
#### WSLtty Portable installer
|
||||||
|
|
||||||
|
For a portable installation, e.g. on a USB stick, choose the
|
||||||
|
“-install-portable.exe” file for download. Installation will prompt
|
||||||
|
for a portable installation folder interactively.
|
||||||
|
For example, choosing `U:\opt` will create and use folder
|
||||||
|
`U:\opt\wsltty` both as installation directory and configuration directory.
|
||||||
|
Portable installation does not install any start menu or desktop shortcuts
|
||||||
|
and no context menu entries. It creates a shortcut in the selected
|
||||||
|
portable installation folder to start the default WSL distribution.
|
||||||
|
|
||||||
#### Installation from archive ####
|
#### Installation from archive ####
|
||||||
|
|
||||||
In case a local anti-virus guard barfs about the wsltty installer, the
|
In case a local anti-virus guard barfs about the wsltty installer, the
|
||||||
release also contains a `.cab` file. Download it, open it, extract its files
|
release also contains a `.cab` file. Download it, open it, extract its files
|
||||||
to some temporary deployment directory, and invoke `install.bat` from there.
|
to some temporary deployment directory, and invoke `install.bat` from there,
|
||||||
|
or `install-portable.bat` for a portable installation.
|
||||||
|
|
||||||
|
#### Quiet installer ####
|
||||||
|
|
||||||
|
The wsltty-VERSION-x86_64-install-quiet.exe installer is intended for
|
||||||
|
integration in another installation framework.
|
||||||
|
|
||||||
#### Installation from source repository ####
|
#### Installation from source repository ####
|
||||||
|
|
||||||
@@ -53,6 +80,12 @@ environment for this purpose would be installed with the
|
|||||||
from [cygwin.com](https://cygwin.com/),
|
from [cygwin.com](https://cygwin.com/),
|
||||||
with additional packages `make`, `gcc-g++`, `unzip`, `zoo`, `patch`, (`lcab`).
|
with additional packages `make`, `gcc-g++`, `unzip`, `zoo`, `patch`, (`lcab`).
|
||||||
|
|
||||||
|
#### Build installers ####
|
||||||
|
|
||||||
|
Install a minimal Cygwin environment plus the additional packages as
|
||||||
|
listed for «Installation from source repository».
|
||||||
|
Invoke `make pkg` or just `make`.
|
||||||
|
|
||||||
#### Installation to non-default locations ####
|
#### Installation to non-default locations ####
|
||||||
|
|
||||||
(For experts)
|
(For experts)
|
||||||
@@ -62,19 +95,28 @@ the optional second parameter designates the configuration directory.
|
|||||||
|
|
||||||
### Installation with other package management environments ###
|
### Installation with other package management environments ###
|
||||||
|
|
||||||
Note that these are 3rd-party contributions and do not necessarily
|
Note: These are 3rd-party packages, not managed by this repository.
|
||||||
provide the latest version.
|
|
||||||
|
#### Windows Package Manager ####
|
||||||
|
|
||||||
|
([Check package](https://github.com/microsoft/winget-pkgs/tree/master/manifests/m/Mintty/WSLtty))
|
||||||
|
To install wsltty from the
|
||||||
|
[Windows Package Manager Community Repository](https://github.com/microsoft/winget-pkgs),
|
||||||
|
invoke one of
|
||||||
|
* `winget install wsltty`
|
||||||
|
* `winget upgrade wsltty`
|
||||||
|
|
||||||
#### Chocolatey ####
|
#### Chocolatey ####
|
||||||
|
|
||||||
|
([Check package](https://community.chocolatey.org/packages/wsltty))
|
||||||
If you use the [Chocolatey package manager](https://chocolatey.org/),
|
If you use the [Chocolatey package manager](https://chocolatey.org/),
|
||||||
invoke one of
|
invoke one of
|
||||||
<img height=222 align=right src=https://github.com/mintty/wsltty.appx/raw/master/wsltty.appx.png>
|
|
||||||
* `choco install wsltty`
|
* `choco install wsltty`
|
||||||
* `choco upgrade wsltty`
|
* `choco upgrade wsltty`
|
||||||
|
|
||||||
#### Scoop ####
|
#### Scoop ####
|
||||||
|
|
||||||
|
([Check package](https://scoop.sh/#/apps?q=wsltty))
|
||||||
If you use the [Scoop package manager](https://scoop.sh/),
|
If you use the [Scoop package manager](https://scoop.sh/),
|
||||||
* `scoop bucket add extras`
|
* `scoop bucket add extras`
|
||||||
|
|
||||||
@@ -82,10 +124,6 @@ then, invoke one of
|
|||||||
* `scoop install wsltty`
|
* `scoop install wsltty`
|
||||||
* `scoop update wsltty`
|
* `scoop update wsltty`
|
||||||
|
|
||||||
#### Windows Appx package ####
|
|
||||||
|
|
||||||
A Windows Appx package and certificate is available in the [wsltty.appx](https://github.com/mintty/wsltty.appx/) repository.
|
|
||||||
|
|
||||||
### Uninstallation ###
|
### Uninstallation ###
|
||||||
|
|
||||||
To uninstall wsltty desktop, start menu, and context menu integration:
|
To uninstall wsltty desktop, start menu, and context menu integration:
|
||||||
@@ -99,7 +137,7 @@ To uninstall wsltty software completely, remove the installation folder manually
|
|||||||
|
|
||||||
WSLtty can be invoked with
|
WSLtty can be invoked with
|
||||||
* installed Start Menu shortcuts (or Desktop shortcuts if copied there)
|
* installed Start Menu shortcuts (or Desktop shortcuts if copied there)
|
||||||
* *.bat scripts (optionally with WSL command as parameters)
|
* *.bat scripts (optionally with WSL command as parameters) (see [Command line scripts](#command-line-scripts-wslbat) below)
|
||||||
* Explorer context menu (if installed from the Start Menu `WSLtty` subfolder)
|
* Explorer context menu (if installed from the Start Menu `WSLtty` subfolder)
|
||||||
|
|
||||||
Starting the mintty terminal directly from the WSLtty installation location
|
Starting the mintty terminal directly from the WSLtty installation location
|
||||||
@@ -160,7 +198,7 @@ from the Start Menu if desired.
|
|||||||
The Start menu folder WSLtty contains the link
|
The Start menu folder WSLtty contains the link
|
||||||
<img align=absmiddle height=25 src=https://user-images.githubusercontent.com/12740416/57078483-a7846a00-6cee-11e9-9c5e-8c2e9e56cae4.png>`configure WSL shortcuts`.
|
<img align=absmiddle height=25 src=https://user-images.githubusercontent.com/12740416/57078483-a7846a00-6cee-11e9-9c5e-8c2e9e56cae4.png>`configure WSL shortcuts`.
|
||||||
This function is initially run when wsltty is installed.
|
This function is initially run when wsltty is installed.
|
||||||
If should be rerun after adding or removing WSL distributions,
|
It should be rerun after adding or removing WSL distributions,
|
||||||
in order to create the respective set of shortcuts in the Start menu.
|
in order to create the respective set of shortcuts in the Start menu.
|
||||||
|
|
||||||
#### Command line scripts `wsl*.bat` ####
|
#### Command line scripts `wsl*.bat` ####
|
||||||
@@ -196,7 +234,7 @@ Start Menu subfolder `WSLtty`:
|
|||||||
|
|
||||||
Wsltty installation and the mintty terminal try to use the icon of the
|
Wsltty installation and the mintty terminal try to use the icon of the
|
||||||
respective WSL distribution. If it cannot be determined, a penguin icon
|
respective WSL distribution. If it cannot be determined, a penguin icon
|
||||||
is used as a default. You can replace it with your preferred fallback icon
|
is used as a fallback. You can replace it with your preferred default icon
|
||||||
by replacing the icon file `%LOCALAPPDATA%\wsltty\wsl.ico`.
|
by replacing the icon file `%LOCALAPPDATA%\wsltty\wsl.ico`.
|
||||||
|
|
||||||
#### Mintty settings ####
|
#### Mintty settings ####
|
||||||
@@ -227,6 +265,20 @@ Note:
|
|||||||
If you define `HOME` at Windows level, this changes accordingly.
|
If you define `HOME` at Windows level, this changes accordingly.
|
||||||
Note, however, that the WSL `$HOME` is a completely different setting.
|
Note, however, that the WSL `$HOME` is a completely different setting.
|
||||||
|
|
||||||
|
#### Emoji deployment ####
|
||||||
|
|
||||||
|
Mintty and the wsltty package do not bundle actual emoji graphics but
|
||||||
|
there are scripts to support easy download and deployment.
|
||||||
|
If you have another instance of mintty installed (e.g. in cygwin)
|
||||||
|
and have emojis deployed already in the common config folder
|
||||||
|
`%APPDATA%\mintty\emojis`, they will be reused by wsltty.
|
||||||
|
|
||||||
|
To deploy emojis standalone for wsltty, use the scripts installed in
|
||||||
|
`%APPDATA%\wsltty\emojis` within WSL:
|
||||||
|
* `cd $(wslpath "$APPDATA/wsltty/emojis")`
|
||||||
|
* `getemojis` to provide emoji graphics as listed by Unicode.org
|
||||||
|
* `getflags` to provide emoji flag graphics (extending Unicode dynamically) from various sources
|
||||||
|
|
||||||
#### Shell selection and Login shell ####
|
#### Shell selection and Login shell ####
|
||||||
|
|
||||||
The WSLtty deployment does not impose a shell preference;
|
The WSLtty deployment does not impose a shell preference;
|
||||||
|
|||||||
31
appveyor.yml
Normal file
31
appveyor.yml
Normal file
@@ -0,0 +1,31 @@
|
|||||||
|
# This file is part of wsltty project
|
||||||
|
|
||||||
|
# Build image; of course wsltty has nothing to do with Visual Studio -
|
||||||
|
# this is just the name of Appveyor's build environment image
|
||||||
|
# that also contains cygwin
|
||||||
|
image: Visual Studio 2022
|
||||||
|
|
||||||
|
# Version format
|
||||||
|
version: "#{build}"
|
||||||
|
|
||||||
|
# Do not increment build number after pull requests
|
||||||
|
pull_requests:
|
||||||
|
do_not_increment_build_number: true
|
||||||
|
|
||||||
|
# Do not start a new build when a new Git tag is created
|
||||||
|
skip_tags: true
|
||||||
|
|
||||||
|
init:
|
||||||
|
- cmd: |
|
||||||
|
set PATH=C:\cygwin64;C:\cygwin64\bin;%windir%\System32
|
||||||
|
setup-x86_64 -q -P unzip -P zoo -P patch -P lcab
|
||||||
|
winget install Alpine
|
||||||
|
|
||||||
|
build_script:
|
||||||
|
- cmd: |
|
||||||
|
make
|
||||||
|
|
||||||
|
test_script:
|
||||||
|
- cmd: |
|
||||||
|
bin\mintty.exe --log mintty.log --exec echo hello mintty
|
||||||
|
grep echo mintty.log
|
||||||
@@ -291,6 +291,15 @@ config () {
|
|||||||
echoc "- root $root"
|
echoc "- root $root"
|
||||||
wdir=%USERPROFILE%
|
wdir=%USERPROFILE%
|
||||||
|
|
||||||
|
case "$name" in
|
||||||
|
docker*) echo skipping docker system
|
||||||
|
return;;
|
||||||
|
esac
|
||||||
|
case "$root" in
|
||||||
|
*\\Docker*) echo skipping docker system
|
||||||
|
return;;
|
||||||
|
esac
|
||||||
|
|
||||||
if $ok && ! $remove && [ -n "$distro" ]
|
if $ok && ! $remove && [ -n "$distro" ]
|
||||||
then # fix #163: backend missing +x with certain mount options
|
then # fix #163: backend missing +x with certain mount options
|
||||||
echo Setting +x wslbridge2 backends for distro "'$distro'"
|
echo Setting +x wslbridge2 backends for distro "'$distro'"
|
||||||
|
|||||||
27
install-portable.bat
Executable file
27
install-portable.bat
Executable file
@@ -0,0 +1,27 @@
|
|||||||
|
@echo off
|
||||||
|
|
||||||
|
set sel="Select folder to place installation of portable wsltty"
|
||||||
|
|
||||||
|
for /f "usebackq delims=" %%f in (`powershell "(new-object -COM Shell.Application).BrowseForFolder(0, '%sel%', 0, 0).self.path"`) do set f=%%f
|
||||||
|
set instdir=%f%\wsltty
|
||||||
|
|
||||||
|
if "%f%"=="" (
|
||||||
|
echo no installation
|
||||||
|
exit
|
||||||
|
) else if not exist "%f%" (
|
||||||
|
echo invalid installation folder %instdir%
|
||||||
|
exit
|
||||||
|
)
|
||||||
|
|
||||||
|
call install "%instdir%" "%instdir%" /P
|
||||||
|
|
||||||
|
rem create shortcut
|
||||||
|
cd /D "%instdir%"
|
||||||
|
set instpath=%instdir:~2%
|
||||||
|
set target=%%COMSPEC%%
|
||||||
|
set minttyargs=/C bin\mintty.exe --WSL= --icon=/wsl.ico --configdir=. -~
|
||||||
|
set bridgeargs= -
|
||||||
|
set wdir=%instpath%
|
||||||
|
set icon=%instpath%\wsl.ico
|
||||||
|
cscript /nologo mkshortcut.vbs "/name:WSL Terminal Portable"
|
||||||
|
|
||||||
21
install.bat
21
install.bat
@@ -1,9 +1,9 @@
|
|||||||
@echo off
|
@echo off
|
||||||
|
|
||||||
set refinstalldir=%%LOCALAPPDATA%%\wsltty
|
set refinstalldir=%%LOCALAPPDATA%%\wsltty
|
||||||
set installdir="%LOCALAPPDATA%\wsltty"
|
|
||||||
set refconfigdir=%%APPDATA%%\wsltty
|
set refconfigdir=%%APPDATA%%\wsltty
|
||||||
set configdir="%APPDATA%\wsltty"
|
if "%installdir%" == "" set installdir="%LOCALAPPDATA%\wsltty"
|
||||||
|
if "%configdir%" == "" set configdir="%APPDATA%\wsltty"
|
||||||
call dequote installdir
|
call dequote installdir
|
||||||
call dequote configdir
|
call dequote configdir
|
||||||
set oldroot="%installdir%"
|
set oldroot="%installdir%"
|
||||||
@@ -71,7 +71,7 @@ rem copy cygpopt-0.dll "%installdir%"\bin
|
|||||||
rem copy cygiconv-2.dll "%installdir%"\bin
|
rem copy cygiconv-2.dll "%installdir%"\bin
|
||||||
rem copy cygintl-8.dll "%installdir%"\bin
|
rem copy cygintl-8.dll "%installdir%"\bin
|
||||||
|
|
||||||
rem create system config directory and copy config archive
|
rem create system config directory and copy config archive and scripts
|
||||||
mkdir "%installdir%\usr\share\mintty\lang" 2> nul:
|
mkdir "%installdir%\usr\share\mintty\lang" 2> nul:
|
||||||
copy lang.zoo "%installdir%\usr\share\mintty\lang"
|
copy lang.zoo "%installdir%\usr\share\mintty\lang"
|
||||||
mkdir "%installdir%\usr\share\mintty\themes" 2> nul:
|
mkdir "%installdir%\usr\share\mintty\themes" 2> nul:
|
||||||
@@ -83,6 +83,9 @@ copy charnames.txt "%installdir%\usr\share\mintty\info"
|
|||||||
mkdir "%installdir%\usr\share\mintty\icon" 2> nul:
|
mkdir "%installdir%\usr\share\mintty\icon" 2> nul:
|
||||||
copy tux.ico "%installdir%\usr\share\mintty\icon"
|
copy tux.ico "%installdir%\usr\share\mintty\icon"
|
||||||
copy mintty.ico "%installdir%\usr\share\mintty\icon"
|
copy mintty.ico "%installdir%\usr\share\mintty\icon"
|
||||||
|
mkdir "%installdir%\usr\share\mintty\emojis" 2> nul:
|
||||||
|
copy getemojis "%installdir%\usr\share\mintty\emojis" 2> nul:
|
||||||
|
copy getflags "%installdir%\usr\share\mintty\emojis" 2> nul:
|
||||||
|
|
||||||
|
|
||||||
rem create Start Menu Folder
|
rem create Start Menu Folder
|
||||||
@@ -131,17 +134,25 @@ rmdir "%oldroot%\home" 2> nul:
|
|||||||
|
|
||||||
:userconfig
|
:userconfig
|
||||||
|
|
||||||
rem create user config directory and subfolders
|
rem create user config directory and subfolders, copy scripts
|
||||||
mkdir "%configdir%\lang" 2> nul:
|
mkdir "%configdir%\lang" 2> nul:
|
||||||
mkdir "%configdir%\themes" 2> nul:
|
mkdir "%configdir%\themes" 2> nul:
|
||||||
mkdir "%configdir%\sounds" 2> nul:
|
mkdir "%configdir%\sounds" 2> nul:
|
||||||
|
mkdir "%configdir%\emojis" 2> nul:
|
||||||
|
copy "%installdir%\usr\share\mintty\emojis\getemojis" "%configdir%\emojis" 2> nul:
|
||||||
|
copy "%installdir%\usr\share\mintty\emojis\getflags" "%configdir%\emojis" 2> nul:
|
||||||
|
|
||||||
rem create config file if it does not yet exist
|
rem create config file if it does not yet exist
|
||||||
if not exist "%configdir%\config" echo # To use common configuration in %%APPDATA%%\mintty, simply remove this file>"%configdir%\config"
|
if exist "%configdir%\config" goto appconfig
|
||||||
|
echo # To use common configuration in %%APPDATA%%\mintty, simply remove this file>"%configdir%\config"
|
||||||
|
if "%3" == "/P" echo # Do not remove this file for WSLtty Portable>>"%configdir%\config"
|
||||||
|
|
||||||
|
|
||||||
:appconfig
|
:appconfig
|
||||||
|
|
||||||
|
rem skip configuration for WSLtty Portable
|
||||||
|
if "%3" == "/P" goto end
|
||||||
|
|
||||||
rem distro-specific stuff: shortcuts and launch scripts
|
rem distro-specific stuff: shortcuts and launch scripts
|
||||||
cd /D "%installdir%"
|
cd /D "%installdir%"
|
||||||
echo Configuring for WSL distributions
|
echo Configuring for WSL distributions
|
||||||
|
|||||||
73
makefile
73
makefile
@@ -10,16 +10,16 @@
|
|||||||
|
|
||||||
|
|
||||||
# wsltty release
|
# wsltty release
|
||||||
ver=3.4.5
|
ver=3.7.6
|
||||||
|
|
||||||
# wsltty appx release - must have 4 parts!
|
# wsltty appx release - must have 4 parts!
|
||||||
verx=3.4.5.0
|
verx=3.7.6.1
|
||||||
|
|
||||||
|
|
||||||
##############################
|
##############################
|
||||||
# mintty release version
|
# mintty release version
|
||||||
|
|
||||||
minttyver=3.4.5
|
minttyver=3.7.6
|
||||||
|
|
||||||
##############################
|
##############################
|
||||||
|
|
||||||
@@ -27,7 +27,7 @@ minttyver=3.4.5
|
|||||||
repo=Biswa96/wslbridge2
|
repo=Biswa96/wslbridge2
|
||||||
|
|
||||||
# wslbridge2 master release version
|
# wslbridge2 master release version
|
||||||
wslbridgever=0.6
|
wslbridgever=0.12
|
||||||
|
|
||||||
# wslbridge2 latest version
|
# wslbridge2 latest version
|
||||||
#archive=master
|
#archive=master
|
||||||
@@ -56,7 +56,7 @@ wslbridgedir=wslbridge2-$(wslbridgever)
|
|||||||
#minttyver=master
|
#minttyver=master
|
||||||
|
|
||||||
# wslbridge branch or commit to build from source;
|
# wslbridge branch or commit to build from source;
|
||||||
wslbridge=wslbridge-frontend wslbridge-backend
|
wslbridge=wslbridge-source wslbridge-frontend wslbridge-backend
|
||||||
|
|
||||||
##############################
|
##############################
|
||||||
# build backend on a musl-libc-based distribution
|
# build backend on a musl-libc-based distribution
|
||||||
@@ -73,10 +73,15 @@ WINSDKVER=`regtool list '$(WINSDKKEY)' | sed -e '$$ q' -e d`
|
|||||||
|
|
||||||
all: all-$(notdir $(CURDIR))
|
all: all-$(notdir $(CURDIR))
|
||||||
|
|
||||||
all-wsltty: check pkg
|
# targets and version checking
|
||||||
|
|
||||||
|
all-wsltty: check committed pkg
|
||||||
|
|
||||||
all-wsltty.appx: appx
|
all-wsltty.appx: appx
|
||||||
|
|
||||||
|
committed:
|
||||||
|
if git status -suno | sed -e "s,^..,," | grep .; then false; fi
|
||||||
|
|
||||||
#############################################################################
|
#############################################################################
|
||||||
# target checking and some defs
|
# target checking and some defs
|
||||||
|
|
||||||
@@ -148,10 +153,16 @@ $(wslbridgedir).zip:
|
|||||||
wslbridge-source: $(wslbridgedir).zip
|
wslbridge-source: $(wslbridgedir).zip
|
||||||
unzip -o $(wslbridgedir).zip
|
unzip -o $(wslbridgedir).zip
|
||||||
cp $(wslbridgedir)/LICENSE LICENSE.wslbridge2
|
cp $(wslbridgedir)/LICENSE LICENSE.wslbridge2
|
||||||
# patch
|
# the following two patches are obsolete with wslbridge2 v0.9
|
||||||
cd $(wslbridgedir); patch -p1 < ../0001-notify-size-change-inband.patch
|
# patch to fix #220
|
||||||
|
# test case in mintty: (sleep 0.1; echo -e "\e[31;80t") & wslbridge2
|
||||||
|
#cd $(wslbridgedir); patch -p1 < ../0001-notify-size-change-inband.patch
|
||||||
|
# patch to https://github.com/Biswa96/wslbridge2/commit/41575379b416703c49e2687e957440239a4cdfb7
|
||||||
|
#cd $(wslbridgedir); patch -p0 < ../0002-add-com-for-lifted-wsl.patch
|
||||||
|
# patch to fix WSL 2 launching, again
|
||||||
|
cd $(wslbridgedir); patch -p1 < ../0012-get-vmid-from-registry.patch
|
||||||
|
|
||||||
wslbridge-frontend: wslbridge-source
|
wslbridge-frontend:
|
||||||
echo ------------- Compiling wslbridge2 frontend
|
echo ------------- Compiling wslbridge2 frontend
|
||||||
mkdir -p bin
|
mkdir -p bin
|
||||||
# frontend build
|
# frontend build
|
||||||
@@ -161,7 +172,7 @@ wslbridge-frontend: wslbridge-source
|
|||||||
|
|
||||||
windir=$(shell cd "${WINDIR}"; pwd)
|
windir=$(shell cd "${WINDIR}"; pwd)
|
||||||
|
|
||||||
wslbridge-backend: wslbridge-source
|
wslbridge-backend:
|
||||||
echo ------------- Compiling wslbridge2 backend
|
echo ------------- Compiling wslbridge2 backend
|
||||||
#uname -m | grep x86_64
|
#uname -m | grep x86_64
|
||||||
mkdir -p bin
|
mkdir -p bin
|
||||||
@@ -172,10 +183,16 @@ wslbridge-backend: wslbridge-source
|
|||||||
# extract binaries
|
# extract binaries
|
||||||
cp $(wslbridgedir)/bin/wslbridge2-backend bin/
|
cp $(wslbridgedir)/bin/wslbridge2-backend bin/
|
||||||
|
|
||||||
mintty-get:
|
mintty-get: mintty-git # mintty-download or mintty-git
|
||||||
|
cp mintty-$(minttyver)/icon/terminal.ico mintty.ico
|
||||||
|
|
||||||
|
mintty-download:
|
||||||
$(wgeto) https://github.com/mintty/mintty/archive/$(minttyver).zip -o mintty-$(minttyver).zip
|
$(wgeto) https://github.com/mintty/mintty/archive/$(minttyver).zip -o mintty-$(minttyver).zip
|
||||||
unzip -o mintty-$(minttyver).zip
|
unzip -o mintty-$(minttyver).zip
|
||||||
cp mintty-$(minttyver)/icon/terminal.ico mintty.ico
|
|
||||||
|
mintty-git:
|
||||||
|
test -d mintty-$(minttyver) || git clone --depth 111 https://github.com/mintty/mintty.git mintty-$(minttyver)
|
||||||
|
cd mintty-$(minttyver); git checkout $(minttyver)
|
||||||
|
|
||||||
wslbuild=LDFLAGS="-static -static-libgcc -s"
|
wslbuild=LDFLAGS="-static -static-libgcc -s"
|
||||||
appxbuild=$(wslbuild) CCOPT=-DWSLTTY_APPX
|
appxbuild=$(wslbuild) CCOPT=-DWSLTTY_APPX
|
||||||
@@ -185,6 +202,7 @@ appxversion=VERSION_SUFFIX="– wsltty appx $(verx)" WSLTTY_VERSION="$(verx)"
|
|||||||
mintty-build:
|
mintty-build:
|
||||||
# ensure rebuild of version-specific check and message
|
# ensure rebuild of version-specific check and message
|
||||||
rm -f mintty-$(minttyver)/bin/*/windialog.o
|
rm -f mintty-$(minttyver)/bin/*/windialog.o
|
||||||
|
rm -f mintty-$(minttyver)/bin/*/winmain.o
|
||||||
# build mintty
|
# build mintty
|
||||||
cd mintty-$(minttyver)/src; make $(wslbuild) $(wslversion)
|
cd mintty-$(minttyver)/src; make $(wslbuild) $(wslversion)
|
||||||
mkdir -p bin
|
mkdir -p bin
|
||||||
@@ -211,7 +229,7 @@ mintty-pkg:
|
|||||||
|
|
||||||
mintty-appx:
|
mintty-appx:
|
||||||
mkdir -p usr/share/mintty
|
mkdir -p usr/share/mintty
|
||||||
cd usr/share/mintty; mkdir -p lang themes sounds info
|
cd usr/share/mintty; mkdir -p lang themes sounds info emojis
|
||||||
cp mintty-$(minttyver)/lang/*.po usr/share/mintty/lang/
|
cp mintty-$(minttyver)/lang/*.po usr/share/mintty/lang/
|
||||||
cp mintty-$(minttyver)/themes/*[!~] usr/share/mintty/themes/
|
cp mintty-$(minttyver)/themes/*[!~] usr/share/mintty/themes/
|
||||||
cp mintty-$(minttyver)/sounds/*.wav usr/share/mintty/sounds/
|
cp mintty-$(minttyver)/sounds/*.wav usr/share/mintty/sounds/
|
||||||
@@ -219,6 +237,7 @@ mintty-appx:
|
|||||||
# add charnames.txt to support "Character Info"
|
# add charnames.txt to support "Character Info"
|
||||||
cd mintty-$(minttyver)/src; sh ./mknames
|
cd mintty-$(minttyver)/src; sh ./mknames
|
||||||
cp mintty-$(minttyver)/src/charnames.txt usr/share/mintty/info/
|
cp mintty-$(minttyver)/src/charnames.txt usr/share/mintty/info/
|
||||||
|
cp /usr/share/mintty/emojis/get*[!~] usr/share/mintty/emojis/
|
||||||
|
|
||||||
cygwin: # mkshortcutexe
|
cygwin: # mkshortcutexe
|
||||||
mkdir -p bin
|
mkdir -p bin
|
||||||
@@ -271,19 +290,41 @@ copcab: ver
|
|||||||
cp *.bat $(CAB)/
|
cp *.bat $(CAB)/
|
||||||
cp config-distros.sh $(CAB)/
|
cp config-distros.sh $(CAB)/
|
||||||
cp mkshortcut.vbs $(CAB)/
|
cp mkshortcut.vbs $(CAB)/
|
||||||
|
cp mintty-$(minttyver)/tools/get*[!~] $(CAB)/
|
||||||
|
|
||||||
cop: copcab
|
cop: copcab
|
||||||
mkdir -p rel
|
mkdir -p rel
|
||||||
cp -fl $(CAB)/* rel/
|
cp -fl $(CAB)/* rel/
|
||||||
|
|
||||||
installer: cop
|
installer: cop cab normal-installer silent-installer portable-installer
|
||||||
|
|
||||||
|
cab:
|
||||||
|
# build cab archive
|
||||||
|
lcab -r $(CAB) rel/$(CAB).cab
|
||||||
|
|
||||||
|
normal-installer:
|
||||||
# prepare build of installer
|
# prepare build of installer
|
||||||
rm -f rel/$(CAB)-install.exe
|
rm -f rel/$(CAB)-install.exe
|
||||||
sed -e "s,%version%,$(ver)," -e "s,%arch%,$(arch)," makewinx.cfg > rel/wsltty.SED
|
sed -e "s,%version%,$(ver)," -e "s,%arch%,$(arch)," makewinx.cfg > rel/wsltty.SED
|
||||||
# build installer
|
# build installer
|
||||||
cd rel; iexpress /n wsltty.SED
|
cd rel; iexpress /n wsltty.SED
|
||||||
# build cab archive
|
|
||||||
lcab -r $(CAB) rel/$(CAB).cab
|
silent-installer:
|
||||||
|
# prepare build of installer
|
||||||
|
rm -f rel/$(CAB)-install-quiet.exe
|
||||||
|
cd rel; sed -e "/ShowInstallProgramWindow/ s/0/1/" -e "/HideExtractAnimation/ s/0/1/" -e "/InstallPrompt/ s/=.*/=/" -e "/FinishMessage/ s/=.*/=/" -e "/TargetName/ s/install.exe/install-quiet.exe/" wsltty.SED > wsltty-quiet.SED
|
||||||
|
# build installer
|
||||||
|
cd rel; iexpress /n wsltty-quiet.SED
|
||||||
|
|
||||||
|
InstallPrompt=Install Mintty terminal for WSL Portable?
|
||||||
|
FinishMessage=Mintty for WSL Portable installation finished
|
||||||
|
|
||||||
|
portable-installer:
|
||||||
|
# prepare build of installer
|
||||||
|
rm -f rel/$(CAB)-install-portable.exe
|
||||||
|
cd rel; sed -e "/InstallPrompt/ s/=.*/=$(InstallPrompt)/" -e "/FinishMessage/ s/=.*/=$(FinishMessage)/" -e "/AppLaunched/ s/install/install-portable/" -e "/TargetName/ s/install.exe/install-portable.exe/" wsltty.SED > wsltty-portable.SED
|
||||||
|
# build installer
|
||||||
|
cd rel; iexpress /n wsltty-portable.SED
|
||||||
|
|
||||||
install: cop installbat
|
install: cop installbat
|
||||||
|
|
||||||
|
|||||||
@@ -60,6 +60,9 @@ FILE24="mintty.ico"
|
|||||||
FILE25="mkshortcut.vbs"
|
FILE25="mkshortcut.vbs"
|
||||||
FILE26="dequote.bat"
|
FILE26="dequote.bat"
|
||||||
FILE27="cmd2.bat"
|
FILE27="cmd2.bat"
|
||||||
|
FILE28="install-portable.bat"
|
||||||
|
FILE29="getemojis"
|
||||||
|
FILE30="getflags"
|
||||||
|
|
||||||
[SourceFiles]
|
[SourceFiles]
|
||||||
SourceFiles0=.
|
SourceFiles0=.
|
||||||
@@ -93,4 +96,7 @@ SourceFiles0=.
|
|||||||
%FILE25%=
|
%FILE25%=
|
||||||
%FILE26%=
|
%FILE26%=
|
||||||
%FILE27%=
|
%FILE27%=
|
||||||
|
%FILE28%=
|
||||||
|
%FILE29%=
|
||||||
|
%FILE30%=
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user