After committing my project\'s gradlew file from my Windows machine to the remote repo using Git, invoking gradlew on my Linux server failed with t
This is because the gradlew file has Windows file-endings.
You can install dos2unix with apt-get or yum by running:
sudo apt-get install dos2unix
sudo yum install -y dos2unix
and then use dos2unix to convert the line-endings
from CRLF Windows CarriageReturn + LineFeed
to LF Linux LineFeed only:
dos2unix ./gradlew
Then run your gradlew for a test:
./gradlew clean -d
The problem's cause was that Git on Windows converted the line endings of gradlew from Unix style (LF) to Windows style (CRLF).
You can turn off that automatic conversion using git config core.autocrlf false.
Setting the line endings of gradlew back to Unix style fixed the problem. In Vim this is done using :set fileformat=unix.
A vendor had shipped a gradlew with Windows carriage returns. Opening gradlew in vim revealed ^M line endings. Running :e ++ff=dos removed the line endings and resolved this issue.
As per https://vim.fandom.com/wiki/File_format
Thanks for the answers, these highlighted that the problem was Windows creating the gradlew, when I am on mac.
To fix this, from the directory of the app I ran the command:
gradle wrapper
This creates (replaces the broken) a gradle wrapper, that works! (notice it uses your local gradle install to fix the wrapper of the app)