mirror of
https://github.com/librespot-org/librespot.git
synced 2025-01-07 17:24:04 +00:00
94d174c33d
* discovery: use opaque error type for DnsSdError This helps to decouple discovery and core by not leaking implementation details of the zeroconf backend into Error conversion impls in core. * discovery: map all MDNS/DNS-SD errors to DiscoveryError::DnsSdError previously, libmdns errors would use a generic conversion from std::io::Error to core::Error * discovery: use an opaque type for the handle to the DNS-SD service * discovery: make features additive i.e. add with-libmdns instead of using not(with-dns-sd). The logic is such that enabling with-dns-sd in addition to the default with-libmdns will still end up using dns-sd, as before. If only with-libmdns is enabled, that will be the default. If none of the features is enabled, attempting to build a `Discovery` will yield an error. * discovery: add --zeroconf-backend CLI flag * discovery: Add minimal Avahi zeroconf backend * bump MSRV to 1.75 required by zbus >= 4 * discovery: ensure that server and dns-sd backend shutdown gracefully Previously, on drop the the shutdown_tx/close_tx, it wasn't guaranteed the corresponding tasks would continue to be polled until they actually completed their shutdown. Since dns_sd::Service is not Send and non-async, and because libmdns is non-async, put them on their own threads. * discovery: use a shared channel for server and zeroconf status messages * discovery: add Avahi reconnection logic This deals gracefully with the case where the Avahi daemon is restarted or not running initially. * discovery: allow running when compiled without zeroconf backend... ...but exit with an error if there's no way to authenticate * better error messages for invalid options with no short flag
53 lines
2.9 KiB
Docker
53 lines
2.9 KiB
Docker
# Cross compilation environment for librespot
|
|
# Build the docker image from the root of the project with the following command :
|
|
# $ docker build -t librespot-cross -f contrib/Dockerfile .
|
|
#
|
|
# The resulting image can be used to build librespot for linux x86_64, armhf, armel, aarch64
|
|
# $ docker run -v /tmp/librespot-build:/build librespot-cross
|
|
#
|
|
# The compiled binaries will be located in /tmp/librespot-build
|
|
#
|
|
# If only one architecture is desired, cargo can be invoked directly with the appropriate options :
|
|
# $ docker run -v /tmp/librespot-build:/build librespot-cross cargo build --release --no-default-features --features "alsa-backend"
|
|
# $ docker run -v /tmp/librespot-build:/build librespot-cross cargo build --release --target arm-unknown-linux-gnueabihf --no-default-features --features alsa-backend
|
|
# $ docker run -v /tmp/librespot-build:/build librespot-cross cargo build --release --target arm-unknown-linux-gnueabi --no-default-features --features alsa-backend
|
|
# $ docker run -v /tmp/librespot-build:/build librespot-cross cargo build --release --target aarch64-unknown-linux-gnu --no-default-features --features alsa-backend
|
|
|
|
FROM debian:bookworm
|
|
|
|
RUN echo "deb http://deb.debian.org/debian bookworm main" > /etc/apt/sources.list
|
|
RUN echo "deb http://deb.debian.org/debian bookworm-updates main" >> /etc/apt/sources.list
|
|
RUN echo "deb http://deb.debian.org/debian-security bookworm-security main" >> /etc/apt/sources.list
|
|
|
|
RUN dpkg --add-architecture arm64
|
|
RUN dpkg --add-architecture armhf
|
|
RUN dpkg --add-architecture armel
|
|
RUN apt-get update
|
|
|
|
RUN apt-get install -y cmake libclang-dev
|
|
RUN apt-get install -y curl git build-essential crossbuild-essential-arm64 crossbuild-essential-armel crossbuild-essential-armhf pkg-config
|
|
RUN apt-get install -y libasound2-dev libasound2-dev:arm64 libasound2-dev:armel libasound2-dev:armhf
|
|
RUN apt-get install -y libpulse0 libpulse0:arm64 libpulse0:armel libpulse0:armhf
|
|
|
|
RUN curl https://sh.rustup.rs -sSf | sh -s -- --default-toolchain 1.75 -y
|
|
ENV PATH="/root/.cargo/bin/:${PATH}"
|
|
RUN rustup target add aarch64-unknown-linux-gnu
|
|
RUN rustup target add arm-unknown-linux-gnueabi
|
|
RUN rustup target add arm-unknown-linux-gnueabihf
|
|
RUN cargo install bindgen-cli
|
|
|
|
RUN mkdir /.cargo && \
|
|
echo '[target.aarch64-unknown-linux-gnu]\nlinker = "aarch64-linux-gnu-gcc"' > /.cargo/config && \
|
|
echo '[target.arm-unknown-linux-gnueabihf]\nlinker = "arm-linux-gnueabihf-gcc"' >> /.cargo/config && \
|
|
echo '[target.arm-unknown-linux-gnueabi]\nlinker = "arm-linux-gnueabi-gcc"' >> /.cargo/config
|
|
|
|
ENV CARGO_TARGET_DIR=/build
|
|
ENV CARGO_HOME=/build/cache
|
|
ENV PKG_CONFIG_ALLOW_CROSS=1
|
|
ENV PKG_CONFIG_PATH_aarch64-unknown-linux-gnu=/usr/lib/aarch64-linux-gnu/pkgconfig/
|
|
ENV PKG_CONFIG_PATH_arm-unknown-linux-gnueabihf=/usr/lib/arm-linux-gnueabihf/pkgconfig/
|
|
ENV PKG_CONFIG_PATH_arm-unknown-linux-gnueabi=/usr/lib/arm-linux-gnueabi/pkgconfig/
|
|
|
|
ADD . /src
|
|
WORKDIR /src
|
|
CMD ["/src/contrib/docker-build.sh"]
|