Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/typst/pdf-writer
A step-by-step PDF writer.
https://github.com/typst/pdf-writer
pdf-generation rust
Last synced: 7 days ago
JSON representation
A step-by-step PDF writer.
- Host: GitHub
- URL: https://github.com/typst/pdf-writer
- Owner: typst
- License: apache-2.0
- Created: 2020-11-16T22:57:36.000Z (almost 4 years ago)
- Default Branch: main
- Last Pushed: 2024-10-30T12:23:53.000Z (17 days ago)
- Last Synced: 2024-10-30T13:27:11.550Z (17 days ago)
- Topics: pdf-generation, rust
- Language: Rust
- Homepage:
- Size: 2.11 MB
- Stars: 482
- Watchers: 8
- Forks: 26
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE-APACHE
Awesome Lists containing this project
README
# pdf-writer
[![Crates.io](https://img.shields.io/crates/v/pdf-writer.svg)](https://crates.io/crates/pdf-writer)
[![Documentation](https://docs.rs/pdf-writer/badge.svg)](https://docs.rs/pdf-writer)A step-by-step PDF writer.
```toml
[dependencies]
pdf-writer = "0.12"
```The entry point into the API is the main `Pdf`, which constructs the document
into one big internal buffer. The top-level writer has many methods to create
specialized writers for specific PDF objects. These all follow the same general
pattern: They borrow the main buffer mutably, expose a builder pattern for
writing individual fields in a strongly typed fashion and finish up the object
when dropped.There are a few more top-level structs with internal buffers, like the builder
for `Content` streams, but wherever possible buffers are borrowed from parent
writers to minimize allocations.## Minimal example
The following example creates a PDF with a single, empty A4 page.```rust
use pdf_writer::{Pdf, Rect, Ref};// Define some indirect reference ids we'll use.
let catalog_id = Ref::new(1);
let page_tree_id = Ref::new(2);
let page_id = Ref::new(3);// Write a document catalog and a page tree with one A4 page that uses no resources.
let mut pdf = Pdf::new();
pdf.catalog(catalog_id).pages(page_tree_id);
pdf.pages(page_tree_id).kids([page_id]).count(1);
pdf.page(page_id)
.parent(page_tree_id)
.media_box(Rect::new(0.0, 0.0, 595.0, 842.0))
.resources();// Finish with cross-reference table and trailer and write to file.
std::fs::write("target/empty.pdf", pdf.finish())?;
```For more examples, check out the [examples folder] in the repository.
## Safety
This crate forbids unsafe code, but it depends on a few popular crates that use
unsafe internally.## License
This crate is dual-licensed under the MIT and Apache 2.0 licenses.[examples folder]: https://github.com/typst/pdf-writer/tree/main/examples