package mrmime

  1. Overview
  2. Docs
type charset = [
  1. | `UTF_8
  2. | `UTF_16
  3. | `UTF_16BE
  4. | `UTF_16LE
  5. | Rosetta.encoding
  6. | `US_ASCII
  7. | `Charset of string
]
type encoding = Rfc2047.encoding =
  1. | Quoted_printable
  2. | Base64
val b : encoding

Base64 encoding.

val q : encoding

Inline quoted-printable encoding.

type t = Rfc2047.encoded_word = {
  1. charset : charset;
  2. encoding : encoding;
  3. raw : string * char * string;
  4. data : (string, Rresult.R.msg) Stdlib.result;
}
val is_normalized : t -> bool
val make : encoding:encoding -> string -> (t, [ `Msg of string ]) Stdlib.result

make ~encoding x returns an encoded word according encoding (Quoted Printable encoding or Base64 encoding). x must be a valid UTF-8 string. charset of encoded word will be, by the way, "UTF-8".

NOTE: If you expect to generate an encoded word with something else than UTF-8 (like latin1), we decided to not handle this case and just produce valid UTF-8 contents in any cases.

val make_exn : encoding:encoding -> string -> t

Alias of make but raises an Invalid_argument if it fails.

Accessors.

val encoding : t -> encoding
val charset : t -> charset
val data : t -> (string, Rresult.R.msg) Stdlib.result

Pretty-printer.

val pp_charset : charset Fmt.t
val pp_encoding : encoding Fmt.t
val pp : t Fmt.t

Equal.

val equal_charset : charset -> charset -> bool
val equal_encoding : encoding -> encoding -> bool
val equal : t -> t -> bool
val reconstruct : t -> string

reconstruct t reconstructs t as it is in the mail.

val charset_of_string : string -> Rfc2047.charset

charset_of_string s returns charset of well-formed charset identifier s (according IANA).

val normalize_to_utf8 : charset:Rfc2047.charset -> string -> (string, [ `Msg of string ]) Stdlib.result

normalize_to_utf8 ~charset s maps a source s which is encoded with the charset charset and try to map/normalize it to UTF-8.

val of_string : string -> (t, [ `Msg of string ]) Stdlib.result

of_string v tries to parse v as an encoded-word (according RFC 2047).

Encoders.

module Encoder : sig ... end
OCaml

Innovation. Community. Security.