Skip to main content

Random Access Read-Only Tar Mount Library

Project description

Random Access Read-Only Tar Mount (Ratarmount) Library

This is the library used as backend by ratarmount (CLI). For a full description including motivation and performance comparisons, see ratarmount.

Table of Contents

  1. Installation
  2. Usage

Installation

PIP Package Installation

In many cases a simple pip install should work:

pip install ratarmountcore[full]

If there is trouble with one of the compression dependencies, first try installing it without dependencies:

pip install ratarmountcore

And if that works, only install those dependencies you need, e.g.:

pip install ratarmountcore[bzip2,gzip]

You can install the latest development version with:

python3 -m pip install --user --force-reinstall 'git+https://github.com/mxmlnkn/ratarmount.git@develop#egginfo=ratarmountcore&subdirectory=core'

Dependencies

Python 3.6+ and preferably pip 19.0+ are required. These should be preinstalled on most systems.

Ratarmountcore has as few required dependencies as necessary in order to cause the least troubles on all possible systems. This means that only uncompressed TAR and ZIP support will work by default. All optional dependencies are offered as extras.

Extras

Ratarmountcore offers these extras (optional dependencies):

  • full, bzip2, gzip, rar, xz, zip, zstd

Full includes all dependencies of the other extras. The zip extra is currently only a placeholder because the built-in zipfile module is being used.

In order to install one of these extract, append them in brackets:

python3 -m pip install --user ratarmount[bzip2]

If you are installing on a system for which there exists no manylinux wheel, then you'll have to install dependencies required to build from source:

sudo apt install python3 python3-pip fuse build-essential software-properties-common zlib1g-dev libzstd-dev liblzma-dev

Usage

This library offers an interface which is sufficient to work with FUSE. This MountSource interface has methods for listing paths and getting file metadata and contents.

The ratarmountcore library offers multiple implementations of MountSource for different archive formats:

  • SQLiteIndexedTar: This is the oldest and most powerful implementation. It supports fast access to files inside (compressed) TARs.
  • RarMountSource: An implementation for RARs using rarfile.
  • ZipMountSource: An implementation for ZIPs using zipfile.
  • FolderMountSource: An implementation taking an existing folder as input.

There also are these functional implementations of MountSource:

  • UnionMountSource: Takes multiple MountSource implementations and shows a merged view of their file hierarchy.
  • FileVersionLayer: Takes a MountSource as input, decodes the requested paths, also accepting <file>.version/<number> paths, and calls the methods of the MountSource with the given file version.
  • AutoMountLayer: Takes one MountSource, goes over all its files and mounts archives recursively in a similar manner to UnionMountSource.

The factory function open opens one of the archive MountSource implementations according to the file type.

Mount Source Class Diagram

Example

import ratarmountcore as rmc

archive = rmc.open("foo.tar", recursive=True)
archive.listDir("/")
info = archive.getFileInfo("/bar")

print "Contents of /bar:"
with archive.open(info) as file:
    print(file.read())

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ratarmountcore-0.1.4.tar.gz (42.0 kB view details)

Uploaded Source

Built Distribution

ratarmountcore-0.1.4-py3-none-any.whl (47.8 kB view details)

Uploaded Python 3

File details

Details for the file ratarmountcore-0.1.4.tar.gz.

File metadata

  • Download URL: ratarmountcore-0.1.4.tar.gz
  • Upload date:
  • Size: 42.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.1 importlib_metadata/4.10.0 pkginfo/1.8.2 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.8.12

File hashes

Hashes for ratarmountcore-0.1.4.tar.gz
Algorithm Hash digest
SHA256 e85a302afeecd478e0064cd4cd20dbeb4128669083902e1961a3ce3f8d4bbbcb
MD5 e086523bf92404520a63cb867774466c
BLAKE2b-256 bd07bb2a35f1abb0ebbf99401c131fea7726243ee0d434925278c9cd89b56f3c

See more details on using hashes here.

File details

Details for the file ratarmountcore-0.1.4-py3-none-any.whl.

File metadata

  • Download URL: ratarmountcore-0.1.4-py3-none-any.whl
  • Upload date:
  • Size: 47.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.1 importlib_metadata/4.10.0 pkginfo/1.8.2 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.8.12

File hashes

Hashes for ratarmountcore-0.1.4-py3-none-any.whl
Algorithm Hash digest
SHA256 342a88f43e401529a3492c5206b2c9dd46706ea6489e3885962cdd58f4a003c1
MD5 a2e94d9bdeb5212ab6ff4c5fa29ed4e9
BLAKE2b-256 4eebb58e5f940f870d4ce3ffa89c53dce384e902d673e3fb0efc28757f7a2c3b

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page