View source code Display the source code in std/encoding.d from which this page was generated on github. Improve this page Quickly fork, edit online, and submit a pull request for this page. Requires a signed-in GitHub account. This works well for small changes. If you'd like to make larger changes you may want to consider using local clone. Page wiki View or edit the community-maintained wiki page associated with this page.

Function std.encoding.sanitize

Sanitizes a string by replacing malformed code unit sequences with valid code unit sequences. The result is guaranteed to be valid for this encoding.

If the input string is already valid, this function returns the original, otherwise it constructs a new string by replacing all illegal code unit sequences with the encoding's replacement character, Invalid sequences will be replaced with the Unicode replacement character (U+FFFD) if the character repertoire contains it, otherwise invalid sequences will be replaced with '?'.

Prototype

immutable(E)[] sanitize(E)(
  immutable(E)[] s
);

Standards

Unicode 5.0, ASCII, ISO-8859-1, WINDOWS-1252

Parameters

NameDescription
s the string to be sanitized

Example

assert(sanitize("hello \xF0\x80world") == "hello \xEF\xBF\xBDworld");

Authors

Janice Caron

License

Boost License 1.0.

Comments