Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

No executable found for scripts when using --symlink-install and install(PROGRAMS) #545

Open
yschulz opened this issue Aug 19, 2024 · 4 comments
Labels
enhancement New feature or request help wanted Extra attention is needed

Comments

@yschulz
Copy link

yschulz commented Aug 19, 2024

Redirected from colcon-core #638

TLDR
On Linux systems:
Exectuables installed without --symlink-install gain executing permissions fine.
Exectuables installed with --symlink-install do not gain executing permission because symbolic links do not have their own permissions.

@cottsay suggested one two things:
1. Detect this scenario and fall back to the non-symlink behavior while possibly displaying a warning
2. Refuse to do anything and demand that the developer make the original script executable so that we can proceed with the symlink

I would strongly vote for solution 1. as the loss of permissions may easily be coming from an automation pipeline or such. Refusal would be terrible in a scenario like that.

@clalancette
Copy link
Contributor

I would strongly vote for solution 1. as the loss of permissions may easily be coming from an automation pipeline or such. Refusal would be terrible in a scenario like that.

The thing about doing 1 is that it completely breaks the expectation of --symlink-install. While printing a warning in that scenario is nice, the fact of the matter is that people don't read warnings, and so will become frustrated when --symlink-install doesn't work how they would expect. Thus, my suggestion would be for 2, though there are some complications there in determining what "should" be an executable or not.

@yschulz
Copy link
Author

yschulz commented Aug 19, 2024

I see your point, but personally I still rather have things work with a warning than break at a point that sometimes still work under different circumstances. Then again, I rather build verbosely and someone else may not.

Anyhow, being more specific about the situation using the PROGRAMS flag, which specifies the developers intent clearly, the distinction for 2 would be implicit (as the non-sym version does give the permission if not yet set).

@cottsay
Copy link
Contributor

cottsay commented Aug 19, 2024

Worth noting is that git can store executable permissions on files just fine. If ament were to process the non-executable script as an error (option 2), the developer could simply change the script to be executable, right?

@yschulz
Copy link
Author

yschulz commented Aug 19, 2024

Git does, yes. But let say before you ship your code, you build it first somewhere else to test. Then you rather copy, compress or do something else, rather than cloning it somewhere else. Might work 99% of cases, but I would hate that 1%.

Just a thought, I discovered this bug by quickly creating a script with a umask that didnt set it to executable :P
Number 2 is totally fine

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request help wanted Extra attention is needed
Projects
None yet
Development

No branches or pull requests

4 participants