Continuing along in my series about how to make Windows more palatable for Linux users, one thing that’s been more difficult to find a workaround for is the
For about an hour, I went on a wild goose chase for some sort of alternative in Windows, and found relatively little. I discovered a win32 implementation of
mandoc here, which sounds interesting, but I decided not to explore it further than seeing if it’d run (spoiler: it does), since where would I download all the man files for the utilities that were included with git-bash? Sounded like too much of a chore.
Instead, I opted to go with an entirely new shell framework, called msys2. It’s slightly different than git-bash, in that, although both link to
cygwin.dll for their tools, it starts logins an entirely new user folder in the
C:\tools\msys64\home\user directory, and uses pacman as a package manager. You can supposedly compile tools that are totally win32 compatible with minGW (also included in the installation package) without having to link to
cygwin.dll, but I’ve yet to see that in action.
Besides, all I really cared about at the time was getting my
man back! Does that sound like you? Are you also a Windows user missing your
man? Well, read further!
msys2 can be easily installed using chocolatey, ala:
C:\>choco install msys2
This will install it to its default directory in
C:\tools\msys64. If you’re interested in other command line arguments for the installation, head over to: https://community.chocolatey.org/packages/msys2/
I mostly just wanted to have a working man command, for which I invoked:
$ pacman -Syuu $ pacman -S man-db $ pacman -S git
This updates the package references, downloads any updates, and then installs man-db, the framework for man files on an Arch Linux machine (and apparently msys2, as well). In fact, I would assume, at least in terms of package management, it should operate very similarly to Arch Linux. I’m not the hugest fan of pacman, as it uses short flags instead of verb + noun syntax, which I find, although shorter, requires more memorization since it’s not as intuitive. For a reference to the command flags, look here (short and sweet). For the official manual, go here.
Since I wanted the man file for
git, I installed it. Sure enough, it came along with the commensurate
man file. Finally, it looks like my lack of
man in Windows has been solved!
I’m not really sure if I’ll need to re-install any of the packages I’ve been using through git-bash all this time, or if I can put msys2’s utilities in my
%PATH% for Windows and use them from any terminal like I had been the ones from git-bash. I’ll update both those posts in the future if that’s something I end up implementing.
I did test a binary in msys2’s
bin directory from cmd.exe and it worked just fine – I’m not sure if it’s statically linked to
cygwin.dll or “natively” compatible with Windows, but I suppose if I have msys2 installed it doesn’t really matter…
But for now, I just wanted to get this post up quickly since I was so excited I’d managed to get
man in Windows (!) which I had been lacking all this time. My penguinification of Windows is nearly complete!
One exciting thing I did notice about msys2 relative to git-bash is
bash itself has been well updated – I wonder if that’s because it’s compiled from Arch Linux repositories? I’ll have to do some investigating as to the source of the source codes…
So I do suppose I’ll probably end up replacing git-bash’s utilities with the ones from msys2 in my
%PATH% if they work everywhere on my machine, and they’re more up to date. I presume I can keep all the standard utilities updated using
pacman, now, too, which was a feature missing in git-bash, as git-bash lacks its own package manager.
I suppose while I’m at it, I should probably link to the official msys2 documentation. I also found this a while back about the differences between MinGW and msys2 (which can get rather confusing), but disclaimer: I have not verified its accuracy or current status.
BTW, if anyone liked my prompt, here’s the code to add to your
.bashrc file – it’ll test if there’s a
.git directory present in the pwd, and if so, tell you which branch you’re in:
PS1='\[\033[0;32m\]\[\033[0m\033[0;32m\]\u\[\033[0;36m\] @ \[\033[0;36m\]\h \w\[\033[0;32m\]`[ -d ./.git ] && git branch`\n\[\033[0;32m\]└─\[\033[0m\033[0;32m\] ▶\[\033[0m\] '
git branch feature is compatible with git-bash and msys2 in Windows. Through all this, I discovered
$(cmd) references are not compatible with
.bashrc / bash startup files (but hopefully not any shell script) in Windows, but backticks are, e.g.
`cmd`. Good to know.
If you’re interested in learning more about initalizing
bash on startup, there’s a great reference here – or I suppose now you can run
man bash if you’ve installed msys2 on your machine 😎 Also, if you’re in a hurry, the first answer in this stack exchange question is very helpful for differentiating startup files and identifying their purposes.
Alright, this is getting off-topic, I suppose I’d better stop writing…