-
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
Adds new-update
#4809
Adds new-update
#4809
Conversation
This is basically a merge of the The command line options are not correct, so if someone could provide some guidance for those, I'd be happy to fix those properly. |
new-update uses the new-style logic to update the repositories. As such it respects `repository` fields in the `cabal.project(.local)` file and updates them as well. This is essential when working with hackage overlays, where the overlay repositories are specified as `repository` fields in the `cabal.project(.local)` file.
45aa40b
to
6f0db06
Compare
This still does not properly respect the index state, as I have no idea how to thread that through properly. However it does everything else as needed. Unless the index-state threading is trivial, I'd prefer that to be a separate PR. |
@angerman I agree; taking into account the PS: have you seen the failure
? |
@hvr, yea, that's just plain stupid. I've introduced a new datatype
and because I have not yet used What's the proper cabal approved fix for this? |
@angerman I'd just prefix it by |
Can we merge now? |
updateCommand = Client.installCommand { | ||
commandName = "new-update", | ||
commandSynopsis = "Updates list of known packages.", | ||
commandUsage = usageAlternatives "new-update" [ "[FLAGS]" ], |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think [FLAGS]
should reflect that we may also supply a list of repo labels. C.f.
Usage: cabal new-build [TARGETS] [FLAGS]
vs.
Usage: cabal new-update [FLAGS]
which would be better as
Usage: cabal new-update [FLAGS] [REPOS]
commandNotes = Just $ \pname -> | ||
"Examples:\n" | ||
++ " " ++ pname ++ " new-update\n" | ||
++ " Download the package list for all known remote repositories.\n\n" |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We may want to add an example here showing how to update a single repo
and we may point out that a TARGET
has the format <repo-id>[,<index-state>]
where <index-state>
is the same syntax as supported by the --index-state
flag which currently is:
--index-state=STATE Use source package index state as it
existed at a previous time. Accepts
unix-timestamps (e.g. '@1474732068'),
ISO8601 UTC timestamps (e.g.
'2016-09-24T17:47:48Z'), or 'HEAD'
(default: 'HEAD').
consequently, the following invocations are all valid (I tested them w/o your patch):
cabal new-update hackage.haskell.org,@1474732068
cabal new-update hackage.haskell.org,2016-09-24T17:47:48Z
cabal new-update hackage.haskell.org,HEAD
cabal new-update hackage.haskell.org
current_ts <- currentIndexTimestamp (lessVerbose verbosity) repoCtxt repo | ||
-- NB: always update the timestamp, even if we didn't actually | ||
-- download anything | ||
writeIndexTimestamp index (fromFlag (updateIndexState updateFlags)) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
So that's the call where we'd need to propagate the <index-state>
value to... what's the problem? :-)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@angerman just to make this more explicit:
As you can see, writeIndexTimestamp
writes the 01-index.timestamp
file which is stored alongside each 01-index.tar
in the package/repo cache:
-- | Write the 'IndexState' to the filesystem
writeIndexTimestamp :: Index -> IndexState -> IO ()
writeIndexTimestamp index st
= writeFile (timestampFile index) (display st)
so all you need to do, is pass writeIndexTimestamp
the optional [,<index-state>]
argument associated with that specific repository's index
.
Let's do this! |
new-update uses the new-style logic to update the repositories. As such it
respects
repository
fields in thecabal.project(.local)
file and updatesthem as well. This is essential when working with hackage overlays, where
the overlay repositories are specified as
repository
fields in thecabal.project(.local)
file.Please include the following checklist in your PR:
[ci skip]
is used to avoid triggering the build bots.Please also shortly describe how you tested your change. Bonus points for added tests!