Manpages

名 前

wcstombs − ワ イ ド 文 字 列 を マ ル チ バ イ ト 文 字 列 に 変 換 す る

書 式

#include <stdlib.h>

size_t wcstombs(char *dest, const wchar_t *src, size_t n);

説 明

dest が NULL で な い 場 合 、 wcstombs() 関 数 は ワ イ ド 文 字 列 srcdest か ら 始 ま る マ ル チ バ イ ト 文 字 列 に 変 換 す る 。 dest に は 最 大 で n バ イ ト が 書 き 込 ま れ る 。 変 換 は 初 期 状 態 で 開 始 さ れ る 。 変 換 は 以 下 の 3つ の 理 由 に よ り 停 止 す る 。

1. (現 在 の ロ ケ ー ル に お け る )マ ル チ バ イ ト 列 で 表 現 で き な い ワ イ ド 文 字 に 遭 遇 し た 場 合 。 こ の 場 合 に は (size_t) −1 が 返 さ れ る 。

2. 長 さ 制 限 に よ っ て 強 制 停 止 さ せ ら れ た 場 合 。 こ の 場 合 に は dest に 書 き 込 ま れ た バ イ ト 数 が 返 さ れ る 。 し か し こ の 時 点 で の シ フ ト 状 態 は 失 わ れ る 。

3. ワ イ ド 文 字 列 が 終 端 の ヌ ル ワ イ ド 文 字 (L'\0') を 含 め て 完 全 に 変 換 さ れ た 場 合 。 こ の 場 合 に は 変 換 は 初 期 状 態 で 終 了 し 、 dest に 書 き 込 ま れ た バ イ ト 数 を 返 す (終 端 の ヌ ル バ イ ト ('\0') は 含 ま れ な い )。 プ ロ グ ラ マ ー は dest に 最 低 で も n バ イ ト の 空 き が あ る こ と を 保 証 し な け れ ば な ら な い 。

dest が NULL の 場 合 、 n は 無 視 さ れ る 。 上 記 と 同 様 に 変 換 が 行 な わ れ る が 変 換 結 果 の バ イ ト 列 は メ モ リ ー に は 書 き 込 ま れ な い 。 ま た 長 さ の 上 限 が 存 在 し な い 。 上 記 の 2. の 場 合 を 避 け る た め に 、 プ ロ グ ラ マ ー は nwcstombs(NULL,src,0)+1 以 上 で あ る こ と を 保 証 し な け れ ば な ら な い 。

返 り 値

wcstombs() 関 数 は 生 成 し た マ ル チ バ イ ト 列 の バ イ ト 数 を 返 す 。 終 端 の ヌ ル 文 字 は 含 ま な い 。 も し 変 換 で き な い ワ イ ド 文 字 に 遭 遇 し た 場 合 に は (size_t) −1 を 返 す 。

準 拠

C99.

注 意

wcstombs() の 動 作 は 現 在 の ロ ケ ー ル の LC_CTYPE カ テ ゴ リ ー に 依 存 し て い る 。

wcsrtombs() 関 数 は 同 じ 機 能 の た め の ス レ ッ ド セ ー フ な イ ン タ ー フ ェ ー ス を 提 供 す る 。

関 連 項 目

mblen(3), mbtowc(3), mbstowcs(3), wcsrtombs(3) wctom(3)

こ の 文 書 に つ い て

こ の man ペ ー ジ は Linux man−pages プ ロ ジ ェ ク ト の リ リ ー ス 3.79 の 一 部 で あ る 。 プ ロ ジ ェ ク ト の 説 明 と バ グ 報 告 に 関 す る 情 報 は http://www.kernel.org/doc/man−pages/ に 書 か れ て い る 。