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

Fix Dockerfile editor settings writing #158

Merged
merged 1 commit into from
Oct 22, 2024

Conversation

Calinou
Copy link
Collaborator

@Calinou Calinou commented Oct 19, 2024

The script relies on Bash-specific features, so Bash must be used instead of POSIX sh or dash.


@NetSysFire
Copy link
Contributor

Why do this hack? This could be solved with much less effort by simply changing to bash for the time being. Apparently Dockerfiles support SHELL: moby/moby#7281 (comment)

I'd revert all those changes and simply slap a SHELL statement that points to bash onto the Dockerfile. This way the variables and substitutions can stay as they are.
Support should be fine as bash is pretty much omnipresent everywhere.

@NetSysFire
Copy link
Contributor

I'd revert RUN <<EOF, too because that renders you unable to place proper comments, which you even had to remove for this. I think you did that in the first place to accomodate the first attempt of trying to make this work. I am unfamiliar with docker but I would not be surprised that if anything in that giant run block fails, it will not point out what specific line but just the giant run block as a whole, making debugging slightly harder.

So the commit should ideally just be adding that single SHELL line.

Also, to get back to the bashisms part because I think it may be good to elaborate: Yes, it does make sense to avoid them for compatibility. Yet as you can see, pure POSIX does lack a lot of features, making things generally more complex to achieve. However, this is a container with a controlled environment. This is not going to run on weird embedded systems with only busybox.
The compatibility loss is thus very low to potentially nonexistent. Bash is present by default on virtually any Linux distribution.

I'd amend the PR description as you are embracing bashisms now for the sake of simplicity.

The script relies on Bash-specific features, so Bash must
be used instead of POSIX sh or dash.
@Calinou Calinou merged commit da71038 into abarichello:master Oct 22, 2024
@Calinou Calinou deleted the fix-dockerfile branch October 22, 2024 21:48
@Calinou
Copy link
Collaborator Author

Calinou commented Oct 22, 2024

The standard image build succeeds now: https://github.com/abarichello/godot-ci/actions/runs/11469069732

The Mono image needs further fixes still.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants