lib/icu/Normalize: wrapper for unorm2_normalize()

This commit is contained in:
Max Kellermann 2022-11-14 22:48:03 +01:00
parent 154fb4317f
commit 7be39e07e1
3 changed files with 102 additions and 0 deletions

61
src/lib/icu/Normalize.cxx Normal file
View File

@ -0,0 +1,61 @@
/*
* Copyright 2003-2022 The Music Player Daemon Project
* http://www.musicpd.org
*
* 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 2 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.
*/
#include "Normalize.hxx"
#include "util/AllocatedArray.hxx"
#include <unicode/unorm2.h>
static AllocatedArray<UChar>
IcuNormalize(const UNormalizer2 *norm2, std::basic_string_view<UChar> src) noexcept
{
AllocatedArray<UChar> dest{src.size() * 2U};
UErrorCode error_code = U_ZERO_ERROR;
auto dest_length = unorm2_normalize(norm2, src.data(), src.size(),
dest.data(), dest.size(),
&error_code);
if (U_FAILURE(error_code))
return nullptr;
dest.SetSize(dest_length);
return dest;
}
AllocatedArray<UChar>
IcuNormalize(std::basic_string_view<UChar> src) noexcept
{
UErrorCode error_code = U_ZERO_ERROR;
auto *norm2 = unorm2_getNFKCInstance(&error_code);
if (U_FAILURE(error_code))
return nullptr;
return IcuNormalize(norm2, src);
}
AllocatedArray<UChar>
IcuNormalizeCaseFold(std::basic_string_view<UChar> src) noexcept
{
UErrorCode error_code = U_ZERO_ERROR;
auto *norm2 = unorm2_getNFKCCasefoldInstance(&error_code);
if (U_FAILURE(error_code))
return nullptr;
return IcuNormalize(norm2, src);
}

40
src/lib/icu/Normalize.hxx Normal file
View File

@ -0,0 +1,40 @@
/*
* Copyright 2003-2022 The Music Player Daemon Project
* http://www.musicpd.org
*
* 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 2 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.
*/
#pragma once
#include <unicode/umachine.h>
#include <string_view>
template<class T> class AllocatedArray;
/**
* @return the normalized string (or nullptr on error)
*/
[[gnu::pure]]
AllocatedArray<UChar>
IcuNormalize(std::basic_string_view<UChar> src) noexcept;
/**
* @return the normalized string (or nullptr on error)
*/
[[gnu::pure]]
AllocatedArray<UChar>
IcuNormalizeCaseFold(std::basic_string_view<UChar> src) noexcept;

View File

@ -18,6 +18,7 @@ if icu_dep.found()
'Init.cxx', 'Init.cxx',
'Util.cxx', 'Util.cxx',
'FoldCase.cxx', 'FoldCase.cxx',
'Normalize.cxx',
] ]
else else
if meson.version().version_compare('>= 0.60') if meson.version().version_compare('>= 0.60')