HTML entity encoder/decoder for Gleam
Find a file
2024-08-10 20:21:19 +03:00
src optimised implementation of html_encoder 2024-05-10 11:10:22 +02:00
test optimised implementation of html_encoder 2024-05-10 11:10:22 +02:00
.gitignore Initial commit 2023-02-12 21:25:09 +02:00
.tool-versions Updated repo location 2024-08-10 20:18:41 +03:00
CHANGELOG.txt Add missing changes to git 2024-05-23 21:28:39 +03:00
gleam.toml Redo that 2024-08-10 20:21:19 +03:00
LICENSE Initial commit 2023-02-12 21:25:09 +02:00
manifest.toml Update for Gleam 0.33, split codebase 2023-12-27 22:54:45 +02:00
README.md Update for Gleam 0.33, split codebase 2023-12-27 22:54:45 +02:00

glentities

Package Version Hex Docs

An HTML entity encoder/decoder for Gleam.

Entities can be encoded using named or hex entity references. Named entity references use the WHATWG "Named character references" list available at https://html.spec.whatwg.org/multipage/named-characters.html#named-character-references.

Quick start

import glentities

glentities.encode("</html>", glentities.HTMLBody) // "&lt;/html&gt;"
glentities.encode("</html>", glentities.Named)    // "&lt;&sol;html&gt;"
glentities.encode("</html>", glentities.Hex)      // "&#x3C;&#x2F;html&#x3E;"

glentities.decode("&#x3C;&#x2F;html&#x3E;")       // "</html>"
glentities.decode("&lt;&sol;html&gt;")            // "</html>"

Code size

If you import glentities, it will pull in all the encoders and the entire named decoder. Since there are so many different entity names, this will result in a hefty JS payload. If you need to minimise the payload size, prefer importing glentities/decoder or one of the glentities/*_encoder modules directly.

Development

gleam test  # Run the tests

Installation

This package can be added to your Gleam project:

gleam add glentities

and its documentation can be found at https://hexdocs.pm/glentities.