Skip to main content

Fetch and manage Quarto paper repositories

Project description

Quarto Fetch

Python 3.12+ License: MIT

A command-line tool for managing multiple Quarto paper repositories in a research project. It automatically fetches, updates, and organizes Quarto paper repositories while maintaining their build caches.

Features

  • ๐Ÿ“ฆ Manage multiple Quarto paper repositories in a single project
  • ๐Ÿ”„ Automatically fetch and update papers from Git repositories
  • ๐Ÿ—๏ธ Support for both manuscript and default Quarto project types
  • โ„๏ธ Smart handling of Quarto freeze directories
  • ๐Ÿ“‹ Detailed logging with progress tracking
  • โšก Efficient updates by tracking commit hashes
  • ๐Ÿ›ก๏ธ Built-in validation and error handling

Installation

We recommend using uv for installation. First, install uv if you haven't already:

curl -LsSf https://astral.sh/uv/install.sh | sh

Quick Run (Recommended)

Use uvx to run quartofetch directly without installation:

uvx quartofetch

Permanent Installation

If you prefer to install the tool permanently:

uv tool install quartofetch

Development Installation

For development work:

git clone https://github.com/MitchellAcoustics/quartofetch
cd quartofetch
uv sync

Quick Start

  1. Create a configuration file research/_paper_sources.yml:
papers:
  - repo_url: "https://github.com/username/paper1"
    target_folder: "paper1"
    branch: "main"  # optional

  - repo_url: "https://github.com/username/paper2"
    target_folder: "paper2"
    commit: "abc123"  # optional, pin to specific commit
  1. Run the fetcher:
# Using uvx (recommended)
uvx quartofetch

# Or with specific options
uvx quartofetch --config path/to/config.yml --force --log-level DEBUG

# If permanently installed
quartofetch --config path/to/config.yml

Project Structure

The tool expects and creates the following directory structure:

your-research-project/
โ”œโ”€โ”€ research/
โ”‚   โ”œโ”€โ”€ _paper_sources.yml
โ”‚   โ””โ”€โ”€ papers/
โ”‚       โ”œโ”€โ”€ paper1/
โ”‚       โ”‚   โ”œโ”€โ”€ _quarto.yml
โ”‚       โ”‚   โ”œโ”€โ”€ paper.qmd
โ”‚       โ”‚   โ””โ”€โ”€ ...
โ”‚       โ””โ”€โ”€ paper2/
โ”‚           โ”œโ”€โ”€ _quarto.yml
โ”‚           โ”œโ”€โ”€ manuscript.qmd
โ”‚           โ””โ”€โ”€ ...
โ””โ”€โ”€ _freeze/
    โ””โ”€โ”€ research/
        โ””โ”€โ”€ papers/
            โ”œโ”€โ”€ paper1/
            โ”‚   โ””โ”€โ”€ ...
            โ””โ”€โ”€ paper2/
                โ””โ”€โ”€ ...

Configuration

Paper Sources (_paper_sources.yml)

Field Description Required
repo_url Git repository URL Yes
target_folder Local folder name Yes
branch Git branch to use No
commit Specific commit hash No

Command Line Options

Option Description Default
--config Path to configuration file research/_paper_sources.yml
--force Force update all papers False
--log-level Set logging level SUCCESS
--debug Enable debug logging False
--log-file Path to log file None

Error Handling

The tool includes comprehensive error handling for:

  • Git operation failures
  • Network timeouts
  • Authentication issues
  • Invalid configurations
  • File system operations

Development

Requirements

  • Python 3.12+
  • Git

Testing

# Install development dependencies
uv sync # or pip install ".[dev]"

# Run tests
pytest

Contributing

  1. Fork the repository
  2. Create a feature branch (git checkout -b feature/amazing-feature)
  3. Commit your changes (git commit -m 'Add amazing feature')
  4. Push to the branch (git push origin feature/amazing-feature)
  5. Open a Pull Request

License

This project is licensed under the MIT License - see the LICENSE file for details.

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

quartofetch-0.1.2.tar.gz (19.4 kB view details)

Uploaded Source

Built Distribution

quartofetch-0.1.2-py3-none-any.whl (13.5 kB view details)

Uploaded Python 3

File details

Details for the file quartofetch-0.1.2.tar.gz.

File metadata

  • Download URL: quartofetch-0.1.2.tar.gz
  • Upload date:
  • Size: 19.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.1 CPython/3.12.7

File hashes

Hashes for quartofetch-0.1.2.tar.gz
Algorithm Hash digest
SHA256 7d735215d115a7549451dbef014b0de3cf957f97eb1cc5d57ba3ebe8ceb433df
MD5 b463a7681877939ae2350bd42057ae7c
BLAKE2b-256 b38cf93483387d4fd61aa184abdc07ace31f2e594a87b7adfc648d8b77078aab

See more details on using hashes here.

Provenance

The following attestation bundles were made for quartofetch-0.1.2.tar.gz:

Publisher: publish.yml on MitchellAcoustics/quartofetch

Attestations:

File details

Details for the file quartofetch-0.1.2-py3-none-any.whl.

File metadata

  • Download URL: quartofetch-0.1.2-py3-none-any.whl
  • Upload date:
  • Size: 13.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.1 CPython/3.12.7

File hashes

Hashes for quartofetch-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 d8bafe57dc4cb7136b53d9e1db39c0a8fafdcf042a6562214064e01d07e016bf
MD5 fcb9dcc3e33e6012efd98264be5a60c2
BLAKE2b-256 ae9fd00d3438fb22eaa398b992be9aa54a0e425bc68e5880655708f154a087e4

See more details on using hashes here.

Provenance

The following attestation bundles were made for quartofetch-0.1.2-py3-none-any.whl:

Publisher: publish.yml on MitchellAcoustics/quartofetch

Attestations:

Supported by

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