Go to file
Christian Ebner 95c9460c4a pxar::fuse: Always use start offset of entries as inode.
Previously it was disciminated based on the entry mode.
For directories, the inode was the offset of the corresponding
goodbye tail mark while for all others it was the offset of the filename.

By simply using the start offset as calculated from the corresponding
goodbye table entry (which yields the archive offset of the filename),
the code is simplified and the more ambiguous read_directory_entry()
function can be used.
The disatvantage of this approach is the need to keep track of the
start and end offsets for each entry, as the end offset is needed in
order to access the goodbye table of directory entries.
The root node still has to be treated special, as it's inode is 1 as per fuse
definition and it has no filename as per the pxar file format definition.

Signed-off-by: Christian Ebner <c.ebner@proxmox.com>
2020-01-17 09:40:39 +01:00
.cargo cargo: switch to use packaged crates by default 2020-01-03 09:40:33 +01:00
debian update tokio to 0.2.9 2020-01-16 13:23:24 +01:00
docs various packaging fixes, bump version 2019-12-20 12:55:32 +01:00
etc proxmox-backup-proxy.service: order after proxmox-backup.service 2019-12-17 14:11:25 +01:00
qemu-io add qemu-io crate, AioContext reactor helper 2019-05-16 11:59:55 +02:00
src pxar::fuse: Always use start offset of entries as inode. 2020-01-17 09:40:39 +01:00
tests pxar: encoder: limit number of max entries held at once in memory during archive creation. 2020-01-10 13:45:08 +01:00
www DataStoreContent.js - render_backup_type: use better default 2019-12-22 11:09:30 +01:00
.gitignore add Cargo.lock 2019-09-02 15:21:56 +02:00
Cargo.toml update tokio to 0.2.9 2020-01-16 13:23:24 +01:00
defines.mk various packaging fixes, bump version 2019-12-20 12:55:32 +01:00
Makefile various packaging fixes, bump version 2019-12-20 12:55:32 +01:00
README.rst remove the rust-toolchain file 2020-01-16 10:45:46 +01:00
rustfmt.toml import rustfmt.toml 2019-08-22 13:44:57 +02:00
TODO.rst pxar: encoder: warn on lacking read permissions instead of fail. 2020-01-09 10:41:19 +01:00

``rustup`` Toolchain
====================

We normally want to build with the ``rustc`` Debian package. To do that
you can set the following ``rustup`` configuration:

    # rustup toolchain link system /usr
    # rustup default system


Versioning of proxmox helper crates
===================================

To use current git master code of the proxmox* helper crates, add::

   git = "ssh://gitolite3@proxdev.maurer-it.com/rust/proxmox"

or::

   path = "../proxmox/proxmox"

to the proxmox dependency, and update the version to reflect the current,
pre-release version number (e.g., "0.1.1-dev.1" instead of "0.1.0").

Local cargo config
==================

This repository ships with a ``.cargo/config`` that replaces the crates.io
registry with packaged crates located in ``/usr/share/cargo/registry``.

A similar config is also applied building with dh_cargo. Cargo.lock needs to be
deleted when switching between packaged crates and crates.io, since the
checksums are not compatible.

To reference new dependencies (or updated versions) that are not yet packaged,
the dependency needs to point directly to a path or git source (e.g., see
example for proxmox crate above).