Fetch and manage Quarto paper repositories
Project description
Quarto Fetch
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
- 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
- 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
- Fork the repository
- Create a feature branch (
git checkout -b feature/amazing-feature
) - Commit your changes (
git commit -m 'Add amazing feature'
) - Push to the branch (
git push origin feature/amazing-feature
) - Open a Pull Request
License
This project is licensed under the MIT License - see the LICENSE file for details.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file quartofetch-0.1.3.tar.gz
.
File metadata
- Download URL: quartofetch-0.1.3.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
Algorithm | Hash digest | |
---|---|---|
SHA256 | e71cce18aef6a291312fa94865dc07e29c43753904029fb683dd20808201dcf8 |
|
MD5 | db63172ab7e657c7dd11b348452e4d72 |
|
BLAKE2b-256 | d3e424e4ef54d1d56110e76c0d1cf8107553728eab53d56bc82c8845ceeac9f2 |
Provenance
The following attestation bundles were made for quartofetch-0.1.3.tar.gz
:
Publisher:
publish.yml
on MitchellAcoustics/quartofetch
-
Statement type:
https://in-toto.io/Statement/v1
- Predicate type:
https://docs.pypi.org/attestations/publish/v1
- Subject name:
quartofetch-0.1.3.tar.gz
- Subject digest:
e71cce18aef6a291312fa94865dc07e29c43753904029fb683dd20808201dcf8
- Sigstore transparency entry: 147284461
- Sigstore integration time:
- Predicate type:
File details
Details for the file quartofetch-0.1.3-py3-none-any.whl
.
File metadata
- Download URL: quartofetch-0.1.3-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
Algorithm | Hash digest | |
---|---|---|
SHA256 | 33e28d93cc9fd6fd0b897b5687cd09dcf0cbe98b729c3732a02244e8c8038175 |
|
MD5 | 2fe073c112a1d0e8da5635467a9503d0 |
|
BLAKE2b-256 | cdafab296443c0134a7be05a8c712a73fc7f718ecd3710aa5d4ed4c44edac909 |
Provenance
The following attestation bundles were made for quartofetch-0.1.3-py3-none-any.whl
:
Publisher:
publish.yml
on MitchellAcoustics/quartofetch
-
Statement type:
https://in-toto.io/Statement/v1
- Predicate type:
https://docs.pypi.org/attestations/publish/v1
- Subject name:
quartofetch-0.1.3-py3-none-any.whl
- Subject digest:
33e28d93cc9fd6fd0b897b5687cd09dcf0cbe98b729c3732a02244e8c8038175
- Sigstore transparency entry: 147284463
- Sigstore integration time:
- Predicate type: