Skip to content

Commit

Permalink
Docs: convert to markdown
Browse files Browse the repository at this point in the history
  • Loading branch information
baseplate-admin committed May 14, 2024
1 parent ce350b2 commit 75b22c7
Show file tree
Hide file tree
Showing 10 changed files with 178 additions and 205 deletions.
1 change: 1 addition & 0 deletions docs/conf.py
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@
# https://www.sphinx-doc.org/en/master/usage/configuration.html#general-configuration

extensions = [
"myst_parser",
"sphinx.ext.autodoc",
"sphinx.ext.intersphinx",
"sphinx.ext.viewcode",
Expand Down
48 changes: 48 additions & 0 deletions docs/contributing.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,48 @@
# Contributing

Thank you taking interest in this project.

## Goals

My goal for this project is:

- To enable all the features available in [resvg](https://github.com/razrfalcon/resvg) but don't write to the disk, everything must be done in memory.
- Use the bare minimum amount of packages, in both python side and rust side
- Make the package as user friendly as possible

## Getting Started

Pre-requisite packages:

- Install [poetry](https://python-poetry.org/)
- Install [pipx](https://pipx.pypa.io/stable/installation/)
- Install [maturin](https://www.maturin.rs/tutorial)

Then do the modifications to the [lib.rs]{.title-ref} file and add test
in tests directory.

1. Install **poetry** dependencies:

```sh
poetry install
```

2. Activate **poetry** shell:

```sh
poetry shell
```

3. Build with **maturin**:

```sh
maturin develop
```

4. Run tests:

```sh
pytest .
```

If all tests pass, please send a Pull Request to the main repository.
57 changes: 0 additions & 57 deletions docs/contributing.rst

This file was deleted.

35 changes: 35 additions & 0 deletions docs/debugging.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
# Debugging

While [resvg-py](https://github.com/baseplate-admin/resvg-py) is a very
thin wrapper around the [resvg](https://docs.rs/resvg/latest/resvg/)
project there might be bugs in _resvg-py_ (or _resvg_).

In order to debug the issue you have to enable logging in
[resvg-py](https://github.com/baseplate-admin/resvg-py)

How to log in [resvg-py](https://github.com/baseplate-admin/resvg-py)?

When you call [resvg-py](https://github.com/baseplate-admin/resvg-py)\'s
function in your code you can pass [log_information=True]{.title-ref} to
print debug information to the stdout

For example:

```python
import resvg_py
import base64

svg_string = """
<svg width="300" height="130" xmlns="http://www.w3.org/2000/svg">
  <rect width="200" height="100" x="10" y="10" rx="20" ry="20" fill="blue" />
</svg>
"""

# a large list of bytes
png_bytes: list[bytes] = resvg_py.svg_to_bytes(
svg_string=svg_string,
log_information = True ## <----------- CHECK THIS LINE
)
base64_utf8_str = base64.b64encode(bytes(png_bytes)).decode("utf-8")
print(f"data:image/png;base64,{base64_utf8_str}")
```
37 changes: 0 additions & 37 deletions docs/debugging.rst

This file was deleted.

15 changes: 15 additions & 0 deletions docs/installation.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
# Installation

## Requirements

Python 3.8 to 3.12 supported.

<sub>Currently it builds the non-EOL python versions with `maturin`\_ github-actions.</sub>

## Installation

1. Install with **pip**:

```python
python -m pip install resvg_py
```
22 changes: 0 additions & 22 deletions docs/installation.rst

This file was deleted.

19 changes: 11 additions & 8 deletions docs/resvg.rst → docs/resvg.md
Original file line number Diff line number Diff line change
@@ -1,8 +1,11 @@
Resvg Module
============

.. currentmodule:: resvg_py

.. autofunction:: svg_to_bytes

.. autofunction:: version
# Resvg Module

```{eval-rst}
.. currentmodule:: resvg_py
.. autofunction:: svg_to_bytes
.. autoclass:: __version__
```
68 changes: 68 additions & 0 deletions docs/usage.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,68 @@
# Usage

The module takes in **utf-8** encoded `svg_string` and returns `base64` encoded **PNG** string.

Lets say our svg looks like this :

<center>
<svg width="300" height="130" xmlns="http://www.w3.org/2000/svg">
<rect width="200" height="100" x="10" y="10" rx="20" ry="20" fill="blue" ></rect>
</svg>
</center>

We can convert it to `PNG` by:

```python
import resvg_py

svg_string = """
<svg width="300" height="130" xmlns="http://www.w3.org/2000/svg">
  <rect width="200" height="100" x="10" y="10" rx="20" ry="20" fill="blue" />
</svg>
"""

png_bytes: list[bytes] = resvg_py.svg_to_bytes(svg_string=svg_string) # a large list of bytes

```

In order to convert image to base64:

```python

import resvg_py
import base64

svg_string = """
<svg width="300" height="130" xmlns="http://www.w3.org/2000/svg">
  <rect width="200" height="100" x="10" y="10" rx="20" ry="20" fill="blue" />
</svg>
"""

# a large list of bytes
png_bytes: list[bytes] = resvg_py.svg_to_bytes(svg_string=svg_string)
base64_utf8_str = base64.b64encode(bytes(png_bytes)).decode("utf-8")
print(f"data:image/png;base64,{base64_utf8_str}")
```

This should return the following **PNG** image (check using inspect element):

<center>
<img src="" ></img>
</center>

We can also do something like this :

```python

import resvg_py

svg = ... # path to svg file

print(resvg_py.svg_to_bytes(svg_path=svg))
```

But please do note that `resvg` first looks for _svg_string_ and if that is empty then it looks for _svg_path_

```{eval-rst}
For extra parameters refer to :doc:`resvg <../resvg>`
```
Loading

0 comments on commit 75b22c7

Please sign in to comment.