blob: 945309887c9e240dc30747ad4cc13fb679c466c3 [file] [log] [blame]
/*
* Copyright (C) 1999 Tom Tromey
* Copyright (C) 2000 Red Hat, Inc.
* Copyright (C) 2004-2021 Savoir-faire Linux Inc.
*
* Author: Pascal Potvin <pascal.potvin@extenway.com>
*
* This program 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.
*
* This program 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 this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
*/
#ifndef H_UTF8_UTILS
#define H_UTF8_UTILS
#include <cstdlib>
#include <string>
namespace jami {
/**
* utf8_validate:
*
* Validates UTF-8 encoded text. @str is the text to validate;
*
* Returns true if all of @str was valid. Dbus requires valid UTF-8 as input;
* sip packets should also be encoded in utf8; so data read from a file or the
* network should be checked with utf8_validate() before doing anything else
* with it.
*
* Returns: true if the text was valid UTF-8
*/
bool utf8_validate(const std::string& str);
/**
* utf8_make_valid:
* @name: a pointer to a nul delimited string.
*
* Transforms a unknown c_string into a pretty utf8 encoded std::string.
* Every unreadable or invalid byte will be transformed into U+FFFD
* (REPLACEMENT CHARACTER).
*
* Returns: a valid utf8 string.
*/
std::string utf8_make_valid(const std::string& name);
} // namespace jami
#endif // H_UTF8_UTILS