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

FR/RFC: Docker Compose enhancements #229

Open
pataquets opened this issue Nov 14, 2023 · 4 comments
Open

FR/RFC: Docker Compose enhancements #229

pataquets opened this issue Nov 14, 2023 · 4 comments

Comments

@pataquets
Copy link

pataquets commented Nov 14, 2023

docker.el is totally awesome, thanks for sharing.
While working with docker-compose.yml files, I've found that no specific actions/mode is enabled. Some enhancements/ideas I'd like to propose and, with proper guidance and if they're in my knowledge range, happy to tackle sometime.

  • Derived docker-compose-mode to allow more granular key bindings.
  • Automatically enable docker-mode for docker-compose.yml files.
  • Make the Compose prefix the root/default when invoking the transient for docker-compose mode.
    Afterwards, more workflow improvements might be possible to code/document for the hack->compose-up->repeat workflow.

Dumping the idea, so far 😄

EDIT: Turns out there is already a docker-compose-mode, albeit it seems inactive. Maybe it can be of some help.

@LaurenceWarne
Copy link
Contributor

FWIW, for general editing (e.g. completions) in docker-compose.el files, you can use the yaml language server: https://github.com/redhat-developer/yaml-language-server. If you're an lsp mode user M-x lsp should just work (at least it does for me!).

I've added an entry to auto-mode-alist for it:

(use-package lsp-mode
  :mode "docker-compose.yml"
  ;; ....
)

@pataquets
Copy link
Author

Adding meqif/docker-compose-mode to OP.

@Silex
Copy link
Owner

Silex commented Aug 2, 2024

Sorry I completely missed this issue. It sounds nice, but with my limited time I'm a bit afraid of the complexity of maintaining a docker-compose mode.

Also, maybe design wise I'm not sure if this belongs to docker.el or to docker-compose.el.

About automatically changing to the directory root, this should already happen if you start the transient from the docker-compose.yml file... tho what you describe seems to hint at some projectile-docker-compose mode or smth?

@pataquets
Copy link
Author

pataquets commented Aug 2, 2024

Sorry I completely missed this issue. It sounds nice, but with my limited time I'm a bit afraid of the complexity of maintaining a docker-compose mode.

Eminently reasonable. Sounds fair enough.
Maybe downsizing the feature scope (and clearly set expectations) would be an acceptable solution.

Also, maybe design wise I'm not sure if this belongs to docker.el or to docker-compose.el.

I was also concerned about this at first and I was leaning in doing it in docker-compose.el.
However, two things happened since the OP:

  • docker-compose.el project is completely abandoned.
  • Docker Compose is now part of Docker, as a subcommand.

These had me 50/50, specially the last one.

About automatically changing to the directory root, this should already happen if you start the transient from the docker-compose.yml file... tho what you describe seems to hint at some projectile-docker-compose mode or smth?

Yup. CWD should change to run DC. Maybe just at the last second, just before calling DC.
Also, good call on Projectile integration. I hadn't thought about it, even being a user myself. It sounds very promising, although I'm not that familiar with extending Projectile, but worth considering, anyway.
IIRC, Projectile has some sort of find-project-file-at-root or similar and more useful API functions for sure, which could help offloading some functionalities.
If you or anyone reading happen to come with some specific idea, please share. I may come back in the future with more info, as my Projectile knowledge improves.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants