An open API service indexing awesome lists of open source software.

https://github.com/mrdotb/resvg_nif

:pencil2: Elixir NIF bindings for the Resvg library.
https://github.com/mrdotb/resvg_nif

elixir png rustler svg

Last synced: about 2 months ago
JSON representation

:pencil2: Elixir NIF bindings for the Resvg library.

Awesome Lists containing this project

README

        

# Resvg (Rust NIFs for elixir)

[![Build Status](https://github.com/mrdotb/resvg_nif/workflows/Tests/badge.svg)](https://github.com/mrdotb/resvg_nif/workflows/Tests/badge.svg)
[![Module Version](https://img.shields.io/hexpm/v/resvg.svg)](https://hex.pm/packages/resvg)
[![Hex Docs](https://img.shields.io/badge/hex-docs-lightgreen.svg)](https://hexdocs.pm/resvg)
[![Total Download](https://img.shields.io/hexpm/dt/resvg.svg)](https://hex.pm/packages/resvg)
[![License](https://img.shields.io/hexpm/l/resvg.svg)](https://github.com/mrdotb/resvg_nif/blob/master/LICENSE.md)

Native Implemented Function (NIF) bindings for the [resvg](https://github.com/RazrFalcon/resvg) library.

About resvg from its documentation:
> resvg is an SVG rendering library. The core idea is to make a fast, small, portable SVG library with the goal to support the whole SVG spec.

## Installation

The package can be installed
by adding `resvg_nif` to your list of dependencies in `mix.exs`:

```elixir
def deps do
[
{:resvg, "~> 0.5.0"}
]
end
```

## Usage

Convert svg to png with:

```elixir
:ok = Resvg.svg_to_png("input.svg", "output.png")

svg_string = """

"""
:ok = Resvg.svg_string_to_png(svg_string, "output.png", resources_dir: "/tmp")
```

## Livebook introduction

Easiest way to get started and try more advanced example is is to run the Livebook.

[![Run in Livebook](https://livebook.dev/badge/v1/blue.svg)](https://livebook.dev/run?url=https%3A%2F%2Fgithub.com%2Fmrdotb%2Fresvg_nif%2Fblob%2Fmaster%2Flivebooks%2Fexample.livemd)

## Contributing

You can contribute to resvg_nif. Please check the [CONTRIBUTING.md](CONTRIBUTING.md) guide for more information.

This project is intended to be a safe, welcoming space for collaboration, and contributors are expected to adhere to our [CODE_OF_CONDUCT.md](/CODE_OF_CONDUCT.md).

### How to release a new version to hex

1. Update the version in both `mix.exs` and `README.md`.
2. Tag the commit with the version number, for example: `git tag v0.4.0 commit_hash`.
3. Push the commit and the tag using: `git push origin master && git push --tags`.
4. Wait for the CI to generate all the NIFs.
5. Generate the NIF checksum with: `mix rustler_precompiled.download Resvg.Native --all`.
6. Verify that the generated checksum is correct.
7. Publish the package with: `mix hex.publish`.

Let me know if you'd like to adjust anything further!
## Copyright and License

Copyright (c) 2023 Mrdotb

This work is free. You can redistribute it and / or modify it under the terms of the MIT License. See the LICENSE.md file for more details.