Search code examples
windowsshellpowershellcommand-promptgit-bash

On Windows what is the difference between Git Bash vs Windows Power Shell vs Command prompt


I am a Mac guy who is used to Mac's Terminal. Now I am using Windows.

  • Whats the diff between those CLI options?
  • When should I use one over the other?
  • Are there more CLI options that I should consider?
  • What CLI would you use if you were a Mac person trying to adapt to Windows?

The reason I am trying to use Windows, is that I want to ensure the CLI of my Docker projects work for Windows users, that I can write files coming from my container to Windows and ensure my README files have instructions for Windows users. And basically test everything I do on Windows too, like Python.


Solution

  • Git bash is bash, which is IIRC the default shell on MacOS as well as (AFAIK) most Linux distros. It is not the default shell on Windows, although several implementations exist (CygWin, MinGW, ...).
    Git is bundled with a number of POSIX (UNIX/Linux/etc.) utilities / commands in addition to bash; in order to avoid "collisions" with similarly named Windows commands, the most common installation option is to install bash in such a way that the other POSIX commands are only available when running bash. The Git installer will create a shortcut to launch this "private" version of bash, hence "git bash".

    The Windows command prompt runs the default Windows shell, CMD.EXE, which is a derivative of the old MS-DOS command shell, COMMAND.COM. It is much less capable than most POSIX shells; for example, it did not until relatively recently support an if/then/else construct, and it does not support shell functions or aliases (although there are some workarounds for these limitations).

    PowerShell is more of a scripting environment. I'd compare it to Perl on UNIX/Linux systems -- much more powerful than the standard shell, but not necessarily something I'd want to use at the command line.
    One thing to be aware of is that some of the nicer PowerShell features may require you to update your version of PowerShell -- the version bundled with Windows is typically a few years old. And updating PowerShell usually requires admin privilege; depending on the version, you may also need to update the .NET framework.


    If I were a Mac person trying to adapt to Windows ... it depends. In the short term it would be easier to use something familiar like bash. But long term, you -- and more importantly, your potential users -- may not want to be dependent on a third party tool, especially since for Windows users that will typically present an additional learning curve.

    As to which to use when ... it really depends on what you're trying to accomplish -- both in terms of technical functionality and the interface you want to present to your users. As noted above, I'd consider PowerShell more appropriate for scripting than the CLI, unless you just need to run a cmdlet (either a built-in or one you've created yourself).