Re: Suggestion: Allow .gitattributes to specify executable mode

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On 2021-10-17 at 20:56:05, some-java-user-99206970363698485155@xxxxxxxxxxxxxxx wrote:
> Hello,
> 
> some build systems have script files with certain specific names which are always intended to be executable.
> For example Gradle has a `gradlew` file, and Maven has a (currently unofficial) `mvnw` file.
> 
> For Windows users these script files often cause problems when checked in with Git and used by a CI (continuous
> integration) system running Linux. The CI build usually fails because the script files do not have the executable
> flag set (Windows does not have this concept).
> 
> Would it be possible to extend the `.gitattributes` file to allow specifying that files should automatically get
> the executable flag when added to the index? For example Gradle's `gradle init` command already creates a
> `.gitattributes` file; it could then add such a default entry to ease development for Windows users to make sure
> they add the `gradlew` script file with the correct file mode.
> 
> Assuming the flag is called `exec`, Gradle could then create the following `.gitattributes` entry:
> ```
> gradlew    text exec
> ```
> 
> It might also help with questions such as https://stackoverflow.com/q/14267441.
> 
> What do you think?

I think this might end up being duplicative on Unix systems, but you
could implement this with a pre-commit hook if you wanted.  Something
like this might work:

  #!/bin/sh
  
  files=$(git ls-files | git check-attr --stdin exec | grep 'exec: set$' | awk -F': ' '{print $1}')
  files=$(git ls-files -s $files | grep '^100644' | awk -F'\t' '{print $2}')
  git update-index --chmod=+x $files
  git add $files

This obviously doesn't handle filenames with spaces, so it would need
some improvements, but it might work for your case.

It may also be beneficial to actually check this in CI as a first sanity
check, although it sounds like this CI system does this implicitly.
-- 
brian m. carlson (he/him or they/them)
Toronto, Ontario, CA

Attachment: signature.asc
Description: PGP signature


[Index of Archives]     [Linux Kernel Development]     [Gcc Help]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [V4L]     [Bugtraq]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]     [Fedora Users]

  Powered by Linux