-
Notifications
You must be signed in to change notification settings - Fork 12.9k
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
split up libextra (move some out to rustpkg packages, some to libstd) #8784
Comments
Tagging as an RFC, because we need to go through the modules and decide whether each one is a reasonable module to clean up and freeze with a stable (mostly) interface. I think Go is a good case study here because they have lots of the cryptography and Unicode support outside of the main repository. |
Nominating. |
cc #9343 I think there are three destinations for extra modules:
Some notes:
|
1.0, backwards-compat |
Just two cents from a user here. From what I have seen in other language the "batteries not included" approach can be quite frustrating. In node for example many very simple things require a package, and since there isn't really a list of packages blessed by the core language team or even by the community, newcomers can end up having to try many packages of dubious quality before they find one that fits. I can fully understand the fact that you need to reduce the scope to stabilize the core ASAP, but I hope you keep this in mind and think of a strategy for the future. Either create a rust organization on github where blessed packages can be moved to, or maybe even rebuild a libextra later where popular and proven packages can be pulled in to form a stronger base language distribution (kind of like in PHP where anything you can possibly want is included, though I don't think we'd need to go as far). |
@Seldaek The intent is to have an offical rust incubator (http://github.com/rust-lang) where the official packages reside, along with a process for promoting community packages to official packages. Whether crates reside in the installed distribution or are built from remote repos, I hope we have a situation where it's clear what crates you should use for many common tasks and adding them to your project is easy. So I fully agree with you. |
Does libextra (or the split crates) belongs to Rust's "standard library"? |
It was decided a long, long time ago that libextra should not exist, but rather its modules should be split out into smaller independent libraries maintained outside of the compiler itself. The theory was to use `rustpkg` to manage dependencies in order to move everything out of the compiler, but maintain an ease of usability. Sadly, the work on `rustpkg` isn't making progress as quickly as expected, but the need for dissolving libextra is becoming more and more pressing. Because of this, we've thought that a good interim solution would be to simply package more libraries with the rust distribution itself. Instead of dissolving libextra into libraries outside of the mozilla/rust repo, we can dissolve libraries into the mozilla/rust repo for now. Work on this has been excruciatingly painful in the past because the makefiles are completely opaque to all but a few. Adding a new library involved adding about 100 lines spread out across 8 files (incredibly error prone). The first commit of this pull request targets this pain point. It does not rewrite the build system, but rather refactors large portions of it. Afterwards, adding a new library is as simple as modifying 2 lines (easy, right?). The build system automatically keeps track of dependencies between crates (rust *and* native), promotes binaries between stages, tracks dependencies of installed tools, etc, etc. With this newfound buildsystem power, I chose the `extra::flate` module as the first candidate for removal from libextra. While a small module, this module is relative complex in that is has a C dependency and the compiler requires it (messing with the dependency graph a bit). Albeit I modified more than 2 lines of makefiles to accomodate libflate (the native dependency required 2 extra lines of modifications), but the removal process was easy to do and straightforward. --- Testing-wise, I've cross-compiled, run tests, built some docs, installed, uninstalled, etc. I'm still working out a few kinks, and I'm sure that there's gonna be built system issues after this, but it should be working well for basic use! cc #8784
I think |
|
I'm working on |
In line with the dissolution of libextra - rust-lang#8784 - moves arena to its own library libarena. Changes based on PR rust-lang#11787. Updates .gitignore to ignore doc/arena.
Could this mean libcrypto could come back? |
That's an interesting question! I think we'd have to talk about how "official" the libcrypto library is and whether we'd want to consider its interface a candidate for stabilization. You may want to post to the mailing list soliciting opinions about introducing libcrypto into the standard distribution. Our stance has been to not include crypto in the standard library, but I don't think we made a decision about the standard distribution in general. |
I think we mostly don't want to write crypto in rust. Bindings to good crypto may be welcome. |
I agree with @brson here. Crypto sounds like something that should be implemented / maintained outside Rust. |
Part of #8784 Also removed the one glob import.
This also inverts the dependency between libserialize and libcollections. cc rust-lang#8784
This also inverts the dependency between libserialize and libcollections. cc #8784
The plan seems to be that we'll move some of this out to
rustpkg
, and move a conservative set of modules tolibstd
that we are willing to stabilize/standardize.As far as I can tell there's still no issue open for this, so here we are!
The text was updated successfully, but these errors were encountered: