Function: rfc6068-unhexify-string
rfc6068-unhexify-string is a byte-compiled function defined in
rfc6068.el.gz.
Signature
(rfc6068-unhexify-string STRING &optional INHIBIT-DECODE)
Documentation
Unhexify STRING -- e.g. hello%20there -> hello there.
STRING is assumed to be a percentage-encoded utf-8 string.
If INHIBIT-DECODE is non-nil, return the resulting raw byte string instead of decoding as utf-8.
Probably introduced at or before Emacs version 28.1.
Source Code
;; Defined in /usr/src/emacs/lisp/mail/rfc6068.el.gz
;;; rfc6068.el --- support for rfc6068 -*- lexical-binding: t -*-
;; Copyright (C) 2021-2022 Free Software Foundation, Inc.
;; Keywords: mail
;; This file is part of GNU Emacs.
;; GNU Emacs is free software: you can redistribute it and/or modify
;; it under the terms of the GNU General Public License as published by
;; the Free Software Foundation, either version 3 of the License, or
;; (at your option) any later version.
;; GNU Emacs is distributed in the hope that it will be useful,
;; but WITHOUT ANY WARRANTY; without even the implied warranty of
;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
;; GNU General Public License for more details.
;; You should have received a copy of the GNU General Public License
;; along with GNU Emacs. If not, see <https://www.gnu.org/licenses/>.
;;; Commentary:
;;; Code:
(defun rfc6068-unhexify-string (string &optional inhibit-decode)
"Unhexify STRING -- e.g. `hello%20there' -> `hello there'.
STRING is assumed to be a percentage-encoded utf-8 string.
If INHIBIT-DECODE is non-nil, return the resulting raw byte
string instead of decoding as utf-8."
(let ((string
(with-temp-buffer
(set-buffer-multibyte nil)
(insert string)
(goto-char (point-min))
(while (re-search-forward "%\\([[:xdigit:]]\\{2\\}\\)" nil t)
(replace-match (string (string-to-number (match-string 1) 16))
t t))
(buffer-string))))
(if inhibit-decode
string
(decode-coding-string string 'utf-8))))