Namespaces
Variants

mbrtowc

From cppreference.net
Défini dans l'en-tête <wchar.h>
size_t mbrtowc ( wchar_t * pwc, const char * s, size_t n, mbstate_t * ps ) ;
(depuis C95)
size_t mbrtowc ( wchar_t * restrict pwc, const char * restrict s, size_t n,
mbstate_t * restrict ps ) ;
(depuis C99)

Convertit un caractère multioctet étroit en sa représentation de caractère large.

Si s n'est pas un pointeur nul, examine au plus n octets de la chaîne de caractères multioctets, en commençant par l'octet pointé par s pour déterminer le nombre d'octets nécessaires pour compléter le prochain caractère multioctet (incluant toute séquence de changement, et en tenant compte de l'état de conversion multioctet actuel * ps ). Si la fonction détermine que le prochain caractère multioctet dans s est complet et valide, le convertit en caractère large correspondant et le stocke dans * pwc (si pwc n'est pas nul).

Si s est un pointeur nul, les valeurs de n et pwc sont ignorées et l'appel est équivalent à mbrtowc ( NULL , "" , 1 , ps ) .

Si le caractère large produit est le caractère nul, l'état de conversion stocké dans * ps est l'état de décalage initial.

Si la macro d'environnement __STDC_ISO_10646__ est définie, les valeurs du type wchar_t sont identiques aux identifiants courts des caractères dans le jeu requis par Unicode (généralement l'encodage UTF-32) ; sinon, cela est défini par l'implémentation. Dans tous les cas, l'encodage des caractères multioctets utilisé par cette fonction est spécifié par les paramètres régionaux C actuellement actifs.

Table des matières

Paramètres

pwc - pointeur vers l'emplacement où le caractère large résultant sera écrit
s - pointeur vers la chaîne de caractères multioctets utilisée en entrée
n - limite du nombre d'octets dans s pouvant être examinés
ps - pointeur vers l'état de conversion utilisé lors de l'interprétation de la chaîne de caractères multioctets

Valeur de retour

Le premier des éléments suivants qui s'applique :

  • 0 si le caractère converti à partir de s (et stocké dans pwc s'il n'est pas nul) était le caractère nul
  • le nombre d'octets [ 1 ... n ] du caractère multi-octets converti avec succès à partir de s
  • ( size_t ) - 2 si les n octets suivants constituent un caractère multi-octets incomplet, mais jusqu'ici valide. Rien n'est écrit dans * pwc .
  • ( size_t ) - 1 si une erreur d'encodage se produit. Rien n'est écrit dans *pwc , la valeur EILSEQ est stockée dans errno et la valeur de * ps reste non spécifiée.

Exemple

#include <stdio.h>
#include <locale.h>
#include <string.h>
#include <wchar.h>
int main(void)
{
    setlocale(LC_ALL, "en_US.utf8");
    mbstate_t state;
    memset(&state, 0, sizeof state);
    char in[] = u8"z\u00df\u6c34\U0001F34C"; // or u8"zß水🍌"
    size_t in_sz = sizeof in / sizeof *in;
    printf("Processing %zu UTF-8 code units: [ ", in_sz);
    for(size_t n = 0; n < in_sz; ++n) printf("%#x ", (unsigned char)in[n]);
    puts("]");
    wchar_t out[in_sz];
    char *p_in = in, *end = in + in_sz;
    wchar_t *p_out = out;
    int rc;
    while((rc = mbrtowc(p_out, p_in, end - p_in, &state)) > 0)
    {
        p_in += rc;
        p_out += 1;
    }
    size_t out_sz = p_out - out + 1;
    printf("into %zu wchar_t units: [ ", out_sz);
    for(size_t x = 0; x < out_sz; ++x) printf("%#x ", out[x]);
    puts("]");
}

Sortie :

Processing 11 UTF-8 code units: [ 0x7a 0xc3 0x9f 0xe6 0xb0 0xb4 0xf0 0x9f 0x8d 0x8c 0 ]
into 5 wchar_t units: [ 0x7a 0xdf 0x6c34 0x1f34c 0 ]

Références

  • Norme C11 (ISO/CEI 9899:2011) :
  • 7.29.6.3.2 La fonction mbrtowc (p: 443)
  • Norme C99 (ISO/CEI 9899:1999) :
  • 7.24.6.3.2 La fonction mbrtowc (p: 389)

Voir aussi

convertit le prochain caractère multioctet en caractère large
(fonction)
convertit un caractère large en sa représentation multioctet, avec état
(fonction)
Documentation C++ pour mbrtowc