-
Notifications
You must be signed in to change notification settings - Fork 701
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
Add a cabal target command #9744
base: master
Are you sure you want to change the base?
Conversation
64443a6
to
6d9267d
Compare
Related PR: #7500 |
Thanks for the link @fendor. I can see you've put a lot of effort into a larger scoped change. |
This looks plausible to me. We definitely need a test and changelog entry -- though I understand this only makes sense to do if the feature is generally agreed upon, which I can't guarantee by myself. I'll bring it up in the dev meeting on Thursday. |
Warning These problems with an older implementation no longer exist. Because this uses Note I'm suprised to see
|
In investigating further, trying to build only the dependencies, I hit an error I've never seen before;
|
Maybe
Let me emphasise that those are only the targets within the project (as the help already points out) and that different commands can interpret their arguments more liberally (e.g. any package-id is a valid target for |
@philderbeast Ill give it a proper review ASAP |
6d9267d
to
262b008
Compare
I dislike the |
What about |
Can we have a
|
Yes @michaelpj a subcommand instead is a possibility. As implemented this is acting as |
I like |
I favour
|
-1 for attaching this to
Make is different because a) it doesn't have sub-commands and b) the only operation on targets is building them. Food for thought: https://doc.rust-lang.org/cargo/commands/cargo-metadata.html |
My main motivation for this change, no matter which command or subcommand or option we put it under, is to help interactive use of cabal itself and not for producing a machine readable format for IDE tooling like the |
I understand and support this motivation. I think we should avoid too many top-level commands, as I fear trouble down the line with UX and discoverability. While |
2887bc1
to
14f3985
Compare
We have targets when there is no actual project file, when there is just a |
So a top-level |
What else would we do with targets rather than list them that is not already covered by other commands taking targets? Perhaps we should pluralize it as |
14f3985
to
adeb5cf
Compare
Let's keep discussing this. Does anybody remember the conclusions of the discussion of the command names (related to |
adeb5cf
to
ed75265
Compare
914c355
to
3c76893
Compare
29cb4b8
to
7f1f5be
Compare
The suggested changes were made.
f14355d
to
a9443e9
Compare
@Kleidukos I've brought the user guide docs up to date with the |
@philderbeast That's the last thing on my part, I'm pre-emptively approving. |
2abd1ea
to
2135858
Compare
@mpilgrem this is similar to stack ide targets component types that I added in May 20231. Instead of taking explicit Most Footnotes
|
@geekosaur you approved the cut down build implementation on Feb 29, 2024. The newer implementation is better. Care to take another look? |
952f975
to
1a0425f
Compare
Label merge+no rebase is necessary when the pull request is from an organisation. |
- Avoid list in the help - Use establishProjectBaseContext - Remove withContextAndSelectors - Use rebuildInstallPlan and resolveTargets - Extract targetForms - Satisfy hlint - Remove unnecessary do - Use safeHead - Call printPlanTargetForms for everything - Remove planTargetForms - Rework command description - Remove script as a possible TARGET form - Section help into; intro, targetFroms and ctypes - Use pretty printing for examples - Short form and long form - Add a changelog entry - Need nixStyleOptions for cabal-testsuite - unrecognized 'v2-target' option `-vverbose +markoutput +nowrap' - unrecognized 'v2-target' option `--builddir' - unrecognized 'v2-target' option `-j1' - Use notice so target forms are marked output - Add tests of target all, implicit and explicit - Add tests of all:exes and all:tests - Add test of all:benches - Add tests with --enable-tests and --enable-benchmarks - Warn that package targets display libs and exes - Add package target tests - Add path target tests - Add component target tests - Add c package with only a library - Add tests for missing ctypes - Exclude new-target from other commands - Move target command to configuration group - Add target command docs - Add cabal target docs - A significant change - Drop cleans from tests - Use noticeDoc to preserve indent - Satisfy fourmolu - Show the number of matches found matching query - Change synopsis of command, target verb - Remove disclosed, use show, WARN and NOTE - Typo command singular - Bring the command docs inline with --help docs - Remove disclosing from changelog - Only by default, not *only*. Co-Authored-By: brandon s allbery kf8nh <[email protected]>
1a0425f
to
f1fbee2
Compare
As a brief aside, in my view, the Stack 'information' UI is suboptimal (i.e. not to be emulated) but the 'costs' of getting to a better UI would outweigh the relative benefits of the end point. If |
Fixes #8953. Adds a
cabal target
command for showing targets that can be supplied to other commands like thecabal build
command.Note
Comments prior to #9744 (review), prior to Jun 26 2024, refer to an earlier implementation that was a cut down build command. The newer implementation is based off of a suggestion by @andreabedini.
Motivation
When a project has but one package the targets are easy to find by looking inside the
.cabal
file but when a project has hundreds of packages that method is hard with information under layers of folders and files.Using grep in
.cabal
files is tough to get right when we need to exclude stuff that is not in the project.Here's
all:exes
found with this new target command:The initial motivation would have been #8953. Other related issues are #8683, #9732, #1382 and #4070.
Help
Here's the help;
$ cabal --help ... [project building and installing] + target Disclose selected targets. build Compile targets within the project.
The command specific help, a lot of which is taken straight from the user guide on target forms;
Use
The command in action on the haskell/cabal project:
Note
Tests are included above because the project enables them:
cabal/cabal.project
Line 6 in 1082c0b
The query 'all' is used when none is given.
significance: significant
in the changelog file.QA Notes
cabal target
is a new command that produces a list of fully-qualified targets. Please check that these are unique. I haven't added a module test tocabal-testsuite/PackageTests/Target/cabal.test.hs
but it does work: