-
-
Notifications
You must be signed in to change notification settings - Fork 238
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
Remove packages from erlang.mk by default; package indexes as plugins; + better hex.pm integration #907
Comments
The intent is to remove the index but there are no good alternatives. On the other hand at this point the Cowboy commit can safely be set back to master since nobody uses 1.x in new projects anymore. |
Using github URIs with tag or hash is an alternative. The examples in the README and maybe also the erlang.mk guide might influence or mislead new users. Maybe some of them assume that the index is updated and that Cowboy 1.0.4 is a recent version.... |
Just need to set |
Yes I know. Automatically updating the index to the latest tag of each project using some script perhaps, but if you don't want to spend time on the index, perhaps just add |
Sure but like I said, |
You can regard the PR as an example or suggestion. Just by showing how to specify a version explicitly may make the users think a bit and choose a version. |
OK so the plan is to do work around both #902 and the package index. Group breaking changes with potentially breaking changes together, even though #902 work will not be enabled by default. In the case of the package index I will add proper support for Hex via https://github.com/hexpm/hex_core and then when not providing a version number Erlang.mk will first look into its own package index, and then if it finds nothing it will look into Hex. Maybe we can make the lookup order configurable as well. At the same time I will remove most packages from the Erlang.mk index. As a first pass I will remove:
|
For publishing this is what RabbitMQ currently does:
We should stay compatible as much as possible. |
Useful links:
I'd much rather test against a real Hex repo though. I wonder if that's possible. Any pointer is helpful. |
Opened #910 with the initial work on this. |
Register a Hex user, publish a test package using rebar and then update it using make, is that real enough? You can use Mix as well, to compare the results. Otherwise, you could ask the hex maintainers of e.g. cowboy to add you as an owner. I guess they will approve. You can undo a publish within an hour or so, so it should be fine to test publishing. I have a package as well (mysql) but I almost don't remember how I did it. :-) |
I think it's possible to run https://github.com/hexpm/hexpm locally and test against that. That'll work out much better than doing stuff against real packages. |
I will soon drop the packages that are currently in Erlang.mk. I will move them to an external plugin that can be used for quick compatibility. I will keep the package system, the only difference being that packages will be defined by external plugins. This will allow users to curate their own packages if necessary, without having to go through Erlang.mk itself. Decentralized for the win. Those external plugins will be defined as packages inside Erlang.mk itself for convenience, so you can use them in At the same time I will create another external plugin that will contain my own list of curated packages. This will include the most recent Cowboy, Gun and other projects. It is an extra step compared to today, but it should allow people to curate packages better than today. |
Plan is to do this sometimes next year. |
erlang.mk uses Cowboy 1.0.4 for some reason. There's some discussion here: ninenines/erlang.mk#907 I need to update my code to use Cowboy 2
I have removed most of the packages from the index and made Erlang.mk use hex_core to fetch Hex packages. I have kept a few packages that Erlang.mk uses for its own functionality as well as its tests so people using e.g. Cowboy as a package can still use it. I have however changed the versions to not point to very old versions anymore. I have not created external plugins for compatibility, I believe the extra wait time was enough to make that unnecessary. Plus adding dep lines (or pkg lines!) isn't too difficult. |
Maybe new users will get old version by mistake. The example in the used in the README contains
DEPS = cowboy
which will give them 1.0.4. The index file for cowboy contains:Either the examples could include an explicit version for each dep or the index could be updated. I don't know which is better. Personally, I don't use the index.
The text was updated successfully, but these errors were encountered: