<?php
-/////////////////////////////////////////////////
// PukiWiki - Yet another WikiWikiWeb clone.
+// $Id: mbstring.php,v 1.4 2005/04/29 11:24:20 henoheno Exp $
+// Copyright (C) 2003-2005 PukiWiki Developers Team
+// License: GPL v2 or (at your option) any later version
//
-// $Id: mbstring.php,v 1.1 2004/08/01 01:54:35 henoheno Exp $
-//
+// mbstring-extension alternate functions
+// (will work with LANG == 'ja' and EUC-JP environment only)
/*
- * mbstring extension ¤¬¥µ¡¼¥Ð¡¼Â¦¤Ë¸ºß¤·¤Ê¤¤»þ¤ÎÂåÂشؿô
+ * mbstring extension がサーバー側に存在しない時の代替関数
*
- * Ãí°Õ»ö¹à
+ * 注意事項
*
- * 1. ¼ÂºÝ¤Ë´Á»ú¥³¡¼¥ÉÊÑ´¹¤ò¹Ô¤ï¤»¤ë¤¿¤á¤Ë¤Ï¡¢ÊÌÅÓ jcode.php
- * (TOMOºî)¤ò¥¤¥ó¥¹¥È¡¼¥ë¤¹¤ëɬÍפ¬¤¢¤ê¤Þ¤¹¡£
+ * 1. 実際に漢字コード変換を行わせるためには、別途 jcode.php
+ * (TOMO作)をインストールする必要があります。
*
- * http://www.spencernetwork.org/jcode/ ¤è¤êjcode¤òÆþ¼ê¤·¡¢
- * °Ê²¼¤ÎÍͤËŸ³«¤·¤Æ¤¯¤À¤µ¤¤¡£
+ * http://www.spencernetwork.org/jcode/ よりjcodeを入手し、
+ * 以下の様に展開してください。
*
* -+--- mbstring.php -r--
* +-+- jcode_1.34/ dr-x
* +--- code_table.ucs2jis -r--
* +--- code_table.jis2ucs -r--
*
- * 2. EUC-JPÀìÍѤǤ¹¡£(½ÐÎϤµ¤ì¤ë¥Ç¡¼¥¿¤¬EUC-JP¤Ç¤¢¤ëɬÍפ¬¤¢¤ê¤Þ¤¹)
+ * 2. EUC-JP専用です。(出力されるデータがEUC-JPである必要があります)
*
*/
-// jcode¤Î½êºß
-define('JCODE_DIR','./jcode_1.34');
+// jcodeの所在
+define('JCODE_DIR', './jcode_1.34/');
+define('JCODE_FILE', JCODE_DIR . 'jcode_wrapper.php');
-if (is_readable(JCODE_DIR . '/jcode_wrapper.php'))
-{
- require_once(JCODE_DIR . '/jcode_wrapper.php');
+if (is_readable(JCODE_FILE)) {
+ require_once(JCODE_FILE);
}
-// jcode¤¬Â¸ºß¤·¤Ê¤¤¾ì¹ç¡¢¥Þ¥ë¥Á¥Ð¥¤¥Èʸ»ú¤ä´Á»ú¥³¡¼¥É¤ò°·¤¨¤Ê¤¤
-if (!function_exists('jcode_convert_encoding'))
-{
+// jcodeが存在しない場合、マルチバイト文字や漢字コードを扱えない
+if (! function_exists('jcode_convert_encoding')) {
+
// die_message('Multibyte functions cannot be used. Please read "mbstring.php" for an additional installation procedure of "jcode".');
+
function jstrlen($str)
{
return strlen($str);
}
- function jsubstr($str,$start,$length)
+
+ function jsubstr($str, $start, $length)
{
- return substr($str,$start,$length);
+ return substr($str, $start, $length);
}
+
function AutoDetect($str)
{
return 0;
}
- function jcode_convert_encoding($str,$to_encoding,$from_encoding)
+
+ function jcode_convert_encoding($str, $to_encoding, $from_encoding)
{
return $str;
}
}
-// mb_convert_encoding -- ʸ»ú¥¨¥ó¥³¡¼¥Ç¥£¥ó¥°¤òÊÑ´¹¤¹¤ë
-function mb_convert_encoding($str,$to_encoding,$from_encoding='')
+// mb_convert_encoding -- 文字エンコーディングを変換する
+function mb_convert_encoding($str, $to_encoding, $from_encoding = '')
{
- // ³ÈÄ¥: ÇÛÎó¤ò¼õ¤±¤é¤ì¤ë¤è¤¦¤Ë
- // mb_convert_variableÂкö
- if (is_array($str))
- {
- foreach ($str as $key=>$value)
- {
- $str[$key] = mb_convert_encoding($value,$to_encoding,$from_encoding);
+ // 拡張: 配列を受けられるように
+ // mb_convert_variable対策
+ if (is_array($str)) {
+ foreach ($str as $key=>$value) {
+ $str[$key] = mb_convert_encoding($value, $to_encoding, $from_encoding);
}
return $str;
}
- return jcode_convert_encoding($str,$to_encoding,$from_encoding);
+ return jcode_convert_encoding($str, $to_encoding, $from_encoding);
}
-// mb_convert_variables -- ÊÑ¿ô¤Îʸ»ú¥³¡¼¥É¤òÊÑ´¹¤¹¤ë
-function mb_convert_variables($to_encoding,$from_encoding,&$vars)
+// mb_convert_variables -- 変数の文字コードを変換する
+function mb_convert_variables($to_encoding, $from_encoding, &$vars)
{
- // Ãí: ²ÄÊÑĹ°ú¿ô¤Ç¤Ï¤Ê¤¤¡£init.php¤«¤é¸Æ¤Ð¤ì¤ë1°ú¿ô¤Î¥Ñ¥¿¡¼¥ó¤Î¤ß¤ò¥µ¥Ý¡¼¥È
- // ÀµÄ¾¤Ë¼ÂÁõ¤¹¤ë¤Ê¤é¡¢²ÄÊÑ°ú¿ô¤ò¥ê¥Õ¥¡¥ì¥ó¥¹¤Ç¼õ¤±¤ëÊýË¡¤¬É¬Í×
- if (is_array($from_encoding) or $from_encoding == '' or $from_encoding == 'auto')
- {
- $from_encoding = mb_detect_encoding(join_array(' ',$vars));
- }
- if ($from_encoding != 'ASCII' and $from_encoding != SOURCE_ENCODING)
- {
- $vars = mb_convert_encoding($vars,$to_encoding,$from_encoding);
- }
+ // 注: 可変長引数ではない。init.phpから呼ばれる1引数のパターンのみをサポート
+ // 正直に実装するなら、可変引数をリファレンスで受ける方法が必要
+ if (is_array($from_encoding) || $from_encoding == '' || $from_encoding == 'auto')
+ $from_encoding = mb_detect_encoding(join_array(' ', $vars));
+
+ if ($from_encoding != 'ASCII' && $from_encoding != SOURCE_ENCODING)
+ $vars = mb_convert_encoding($vars, $to_encoding, $from_encoding);
+
return $from_encoding;
}
-// Êä½õ´Ø¿ô:ÇÛÎó¤òºÆµ¢Åª¤Ëjoin¤¹¤ë
-function join_array($glue,$pieces)
+// 補助関数:配列を再帰的にjoinする
+function join_array($glue, $pieces)
{
$arr = array();
- foreach ($pieces as $piece)
- {
- $arr[] = is_array($piece) ? join_array($glue,$piece) : $piece;
+ foreach ($pieces as $piece) {
+ $arr[] = is_array($piece) ? join_array($glue, $piece) : $piece;
}
- return join($glue,$arr);
+ return join($glue, $arr);
}
-// mb_detect_encoding -- ʸ»ú¥¨¥ó¥³¡¼¥Ç¥£¥ó¥°¤ò¸¡½Ð¤¹¤ë
-function mb_detect_encoding($str,$encoding_list='')
+// mb_detect_encoding -- 文字エンコーディングを検出する
+function mb_detect_encoding($str, $encoding_list = '')
{
- static $codes = array(0=>'ASCII',1=>'EUC-JP',2=>'SJIS',3=>'JIS',4=>'UTF-8');
+ static $codes = array(0=>'ASCII', 1=>'EUC-JP', 2=>'SJIS', 3=>'JIS', 4=>'UTF-8');
- // Ãí: $encoding_list¤Ï»ÈÍѤ·¤Ê¤¤¡£
+ // 注: $encoding_listは使用しない。
$code = AutoDetect($str);
- if (!array_key_exists($code,$codes))
- {
- $code = 0; // oh ;(
- }
+ if (! isset($codes[$code])) $code = 0; // oh ;(
+
return $codes[$code];
}
-// mb_detect_order -- ʸ»ú¥¨¥ó¥³¡¼¥Ç¥£¥ó¥°¸¡½Ð½ç½ø¤ÎÀßÄê/¼èÆÀ
-function mb_detect_order($encoding_list=NULL)
+// mb_detect_order -- 文字エンコーディング検出順序の設定/取得
+function mb_detect_order($encoding_list = NULL)
{
static $list = array();
- // Ãí: ¾¤Î´Ø¿ô¤Ë±Æ¶Á¤òµÚ¤Ü¤µ¤Ê¤¤¡£¸Æ¤ó¤Ç¤â̵°ÕÌ£¡£
- if ($encoding_list === NULL)
- {
- return $list;
- }
- $list = is_array($encoding_list) ? $encoding_list : explode(',',$encoding_list);
+ // 注: 他の関数に影響を及ぼさない。呼んでも無意味。
+ if ($encoding_list === NULL) return $list;
+
+ $list = is_array($encoding_list) ? $encoding_list : explode(',', $encoding_list);
return TRUE;
}
-// mb_encode_mimeheader -- MIME¥Ø¥Ã¥À¤Îʸ»úÎó¤ò¥¨¥ó¥³¡¼¥É¤¹¤ë
-function mb_encode_mimeheader($str,$charset='ISO-2022-JP',$transfer_encoding='B',$linefeed="\r\n")
+// mb_encode_mimeheader -- MIMEヘッダの文字列をエンコードする
+function mb_encode_mimeheader($str, $charset = 'ISO-2022-JP', $transfer_encoding = 'B', $linefeed = "\r\n")
{
- // Ãí: $transfer_encoding¤Ë´Ø¤ï¤é¤ºbase64¥¨¥ó¥³¡¼¥É¤òÊÖ¤¹
- $str = mb_convert_encoding($str,$charset,'auto');
- return '=?'.$charset.'?B?'.$str;
+ // 注: $transfer_encodingに関わらずbase64エンコードを返す
+ $str = mb_convert_encoding($str, $charset, 'auto');
+ return '=?' . $charset . '?B?' . $str;
}
-// mb_http_output -- HTTP½ÐÎÏʸ»ú¥¨¥ó¥³¡¼¥Ç¥£¥ó¥°¤ÎÀßÄê/¼èÆÀ
-function mb_http_output($encoding='')
+// mb_http_output -- HTTP出力文字エンコーディングの設定/取得
+function mb_http_output($encoding = '')
{
- // Ãí: ²¿¤â¤·¤Ê¤¤
- return SOURCE_ENCODING;
+ return SOURCE_ENCODING; // 注: 何もしない
}
-// mb_internal_encoding -- ÆâÉôʸ»ú¥¨¥ó¥³¡¼¥Ç¥£¥ó¥°¤ÎÀßÄê/¼èÆÀ
-function mb_internal_encoding($encoding='')
+// mb_internal_encoding -- 内部文字エンコーディングの設定/取得
+function mb_internal_encoding($encoding = '')
{
- // Ãí: ²¿¤â¤·¤Ê¤¤
- return SOURCE_ENCODING;
+ return SOURCE_ENCODING; // 注: 何もしない
}
-// mb_language -- ¥«¥ì¥ó¥È¤Î¸À¸ì¤òÀßÄê/¼èÆÀ
-function mb_language($language=NULL)
+// mb_language -- カレントの言語を設定/取得
+function mb_language($language = NULL)
{
static $mb_language = FALSE;
- if ($language === NULL)
- {
- return $mb_language;
- }
- // Ãí: ¾ï¤ËTRUE¤òÊÖ¤¹
+
+ if ($language === NULL) return $mb_language;
$mb_language = $language;
- return TRUE;
+
+ return TRUE; // 注: 常にTRUEを返す
}
-// mb_strimwidth -- »ØÄꤷ¤¿Éý¤Çʸ»úÎó¤ò´Ý¤á¤ë
-function mb_strimwidth($str,$start,$width,$trimmarker='',$encoding='')
+// mb_strimwidth -- 指定した幅で文字列を丸める
+function mb_strimwidth($str, $start, $width, $trimmarker = '', $encoding = '')
{
- if ($start == 0 and $width <= strlen($str))
- {
- return $str;
- }
+ if ($start == 0 && $width <= strlen($str)) return $str;
- // Ãí: EUC-JPÀìÍÑ, $encoding¤ò»ÈÍѤ·¤Ê¤¤
+ // 注: EUC-JP専用, $encodingを使用しない
$chars = unpack('C*', $str);
$substr = '';
- while (count($chars) and $start > 0)
- {
- $start--;
+ while (! empty($chars) && $start > 0) {
+ --$start;
if (array_shift($chars) >= 0x80)
- {
array_shift($chars);
- }
}
- if ($b_trimmarker = (count($chars) > $width))
- {
+ if ($b_trimmarker = (count($chars) > $width)) {
$width -= strlen($trimmarker);
}
- while (count($chars) and $width-- > 0)
- {
+ while (! empty($chars) && $width-- > 0) {
$char = array_shift($chars);
- if ($char >= 0x80)
- {
- if ($width-- == 0)
- {
- break;
- }
+ if ($char >= 0x80) {
+ if ($width-- == 0) break;
$substr .= chr($char);
$char = array_shift($chars);
}
$substr .= chr($char);
}
- if ($b_trimmarker)
- {
- $substr .= $trimmarker;
- }
+ if ($b_trimmarker) $substr .= $trimmarker;
+
return $substr;
}
-// mb_strlen -- ʸ»úÎó¤ÎŤµ¤òÆÀ¤ë
-function mb_strlen($str,$encoding='')
+// mb_strlen -- 文字列の長さを得る
+function mb_strlen($str, $encoding = '')
{
- // Ãí: EUC-JPÀìÍÑ, $encoding¤ò»ÈÍѤ·¤Ê¤¤
+ // 注: EUC-JP専用, $encodingを使用しない
return jstrlen($str);
}
-// mb_substr -- ʸ»úÎó¤Î°ìÉô¤òÆÀ¤ë
-function mb_substr($str,$start,$length=NULL,$encoding='')
+// mb_substr -- 文字列の一部を得る
+function mb_substr($str, $start, $length = NULL, $encoding = '')
{
- // Ãí: EUC-JPÀìÍÑ, $encoding¤ò»ÈÍѤ·¤Ê¤¤
- return jsubstr($str,$start,($length === NULL) ? jstrlen($str) : $length);
+ // 注: EUC-JP専用, $encodingを使用しない
+ return jsubstr($str, $start, ($length === NULL) ? jstrlen($str) : $length);
}
?>