Hacker News new | past | comments | ask | show | jobs | submit login

This is neat, but...

> SoundStream requires that you have the PortAudio lib installed on your system

Meh.

Theres really no excuse, given cargo now has proper support for building cross platform dependencies.

My least favourite thing about rust is trying to use a crate only to find 'author assumed you already had dependencies installed. sorry'




Compiling external dependencies is non-trivial, even though cargo gives the bare minimum of tools to make it possible. I think it's unreasonable to expect rust to construct it's own replica of distribution's packages for C/C++ code. To my knowledge no other language has a package manager or repository which does this, or even attempts to.


Cargo's build system doesn't have to build the dependencies, it just has to resolve them somehow.

That can be via package manager, pkg-config, static library download, building them, or via prompting the user to install them manually.

Since rust supports the #[cfg(target="foo")] in build scripts, you can even implement your solution for just one platform, and then slowly add additional platform support as people demand it.

A message like: "Hey, your platform isn't supported by our build script; submit a bug at ... if you'd like to get support added. We welcome push requests". <-- A+++

For example, android support is probably not a target for most crates, but it may be an important target in the future for many libraries. ...and building a cross-compiled android binary is a LOT more involved than just an 'apt-get install foo'.

Just failing? Nope.


I know what you mean.

I've talked with the author of the PortAudio bindings and we're planning on including a static lib with the repo instead (along with a cargo build script), so that should hopefully make it as easy to use as any other crate.


Could a config option be used to make the bindings still use the system's portaudio if it's already there? Or will it actually check if portaudio is installed before building its own?


Hopefully this is doable! I believe Jeremy's currently having a go at getting a build script working that will:

1. check if PA is already installed 2. if not, will download and install PA.

The pull request is open and is here if you(/anyone) want to check it out / comment / contribute:

https://github.com/jeremyletang/rust-portaudio/pull/37


Your least favourite thing is having to {apt-get|yum|pkg|whatever} install somelib[-dev]?


Astonishingly, some people don't use linux.


Every distribution has common libraries in its package manager.




Consider applying for YC's Spring batch! Applications are open till Feb 11.

Guidelines | FAQ | Lists | API | Security | Legal | Apply to YC | Contact

Search: