PHP-5.1 以降で、new プラグインが正常動作しない。 †
- 元タイトル:php-5.1.0RC1でnewプラグインが正常動作しない。
- ページ: BugTrack2
- 投稿者: よっちい
- 優先順位: 重要
- 状態: 提案
- カテゴリー: プラグイン
- 投稿日: 2005-11-02 (水) 11:29:20
- バージョン: 1.4.6
メッセージ †
php-5.1.0RC1を用いてPukiWikiを運用すると、newプラグインにおいて「New!」表示の対象であってもそのように表示されません。
php-5.0.5では「New!」表示が出ます。
php-5.0.5以前(?)とphp-5.1.0RC1では時間の書式が異なる
&new{2005-11-02 12:03:50 (水)}; <- php-5.1.0b1のcomment pluginの入力結果
&new{2005-11-02 (水) 12:03:50}; <- php-5.1.0RC1のcomment pluginの入力結果
ようです。 php-5.0.5とphp-5.1.0RC1は同じでした。php-5.1.0RC1ではどちらも「New!」表示がされませが、php-5.0.5ではどちらも「New!」表示されます。 -- よっちい
- PHP5.1 で strtotime の関数の挙動が変更されたのが原因のようです。 -- kawai?
- この修正は結構根が深いですね…。とりあえず次のパッチで動くようになるようです。 -- kawai?
Index: new.inc.php
===================================================================
RCS file: /cvsroot/pukiwiki/pukiwiki/plugin/new.inc.php,v
retrieving revision 1.9
diff -u -r1.9 new.inc.php
--- new.inc.php 16 Jun 2005 15:04:08 -0000 1.9
+++ new.inc.php 5 Nov 2005 14:34:15 -0000
@@ -34,8 +34,12 @@
// Show 'New!' message by the time of the $date string
if (func_num_args() > 2) return '&new([nodate]){date};';
- $timestamp = strtotime($date);
- if ($timestamp === -1) return '&new([nodate]){date}: Invalid date string;';
+ $timestamp = strtotime(preg_replace('/\([^\x00-\x7F]+\)/','',$date));
+ if(version_compare(phpversion(),'5.1')<0){
+ if ($timestamp === -1) return '&new([nodate]){date}: Invalid date string;';
+ }else{
+ if ($timestamp === FALSE) return '&new([nodate]){date}: Invalid date string;';
+ }
$timestamp -= ZONETIME;
$retval = in_array('nodate', $args) ? '' : htmlspecialchars($date);
- 本当は strptime を使ってパースしたかったのですけれども、date のフォーマット文字列と strftime のフォーマット文字列は違うので上手なコード方法が思いつきませんでした。とりあえず「strtotime でなんとなくパースする」という方針のもと、動作を妨げている非 ASCII 文字を除去しました。 -- kawai?
- なるほど、
- strtotime()が非ASCII文字を厳密に扱うようになった(?)
- エラーの戻り値の変更によりエラーハンドリングができていない
という2つの問題があったわけですね。とりあえず上記修正にて「New!」表示されるようになりました(RC4で確認)。 -- よっちい
- 英語モードでは関係ないと思うので、このように
--- new.inc.php.orig Tue Nov 8 09:17:37 2005
+++ new.inc.php Tue Nov 8 09:19:47 2005
@@ -34,8 +34,12 @@
// Show 'New!' message by the time of the $date string
if (func_num_args() > 2) return '&new([nodate]){date};';
- $timestamp = strtotime($date);
- if ($timestamp === -1) return '&new([nodate]){date}: Invalid date string;';
+ if(LANG == 'ja'){
+ $timestamp = strtotime(preg_replace('/\([^\x00-\x7f]+\)/','',$date));
+ } else {
+ $timestamp = strtotime($date);
+ }
+ if ($timestamp === -1 || $timestamp === FALSE) return '&new([nodate]){date}: Invalid date string;';
$timestamp -= ZONETIME;
$retval = in_array('nodate', $args) ? '' : htmlspecialchars($date);
してみました。 -- よっちい
- BugTrack2/141 --
- PHP5.1.4でも状況は変わりませんでした。なので上記パッチを取り込んでいただけないでしょうか?*1 -- okkez
- $weeklabelsを積極的に使うようにすれば、
--- new.inc.php.orig Fri Jun 17 00:04:08 2005
+++ new.inc.php Fri Nov 3 16:41:26 2006
@@ -24,7 +24,7 @@
function plugin_new_inline()
{
- global $vars, $_plugin_new_elapses;
+ global $vars, $_plugin_new_elapses, $weeklabels;
$retval = '';
$args = func_get_args();
@@ -34,8 +34,8 @@
// Show 'New!' message by the time of the $date string
if (func_num_args() > 2) return '&new([nodate]){date};';
- $timestamp = strtotime($date);
- if ($timestamp === -1) return '&new([nodate]){date}: Invalid date string;';
+ $timestamp = strtotime(str_replace($weeklabels,'',$date));
+ if ($timestamp === -1 || $timestamp === FALSE) return '&new([nodate]){date}: Invalid date string;';
$timestamp -= ZONETIME;
$retval = in_array('nodate', $args) ? '' : htmlspecialchars($date);
言語に依存しない書き方ができそうですが、カッコ()が残るのでこれでも動作しません。lngファイルをいじれば
--- ja.lng.php.orig Tue Apr 11 02:36:56 2006
+++ ja.lng.php Fri Nov 3 15:01:08 2006
@@ -52,7 +52,7 @@
$_msg_symbol = '記号';
$_msg_other = '日本語';
$_msg_help = 'テキスト整形のルールを表示する';
-$_msg_week = array('日','月','火','水','木','金','土');
+$_msg_week = array('日','月','火','水','木','金','土','(',')');
$_msg_content_back_to_top = '<div class="jumpmenu"><a href="#navigator">↑</a></div>';
$_msg_word = 'これらのキーワードがハイライトされています:';
イケそうですが、ちょっとイマイチ感があります。 -- よっちい
- イマイチかもしれませんが、単純にこのようにしてはどうでしょうか。 -- teanan
$_date = str_replace($weeklabels, '', $date);
$_date = str_replace('()', '', $_date);
$timestamp = strtotime($_date);
- あ、それはわたしも考えました。2回書くの嫌だな、と思っただけです。preg_replace()よりはコスト的にいいんでしょうね。しかし、本質的にはformat_date()で生成する文字列をplugin以下でゴニョゴニョするのはいかがかなぁと思ってます。 -- よっちい
- 掘り起こしありがとうございます :) どうやるかはともかく、私も上手にparseできるならそれがいいと思います。 -- henoheno
- SourceForge.jp がPHP 5.2 になったので、なるべく早く解決することを希望します。 --
- とはいえ、上の方法だと
$date_format = 'Y年m月d日';
のように設定して、&new{2008年03月21日 (金) 19:00:00}; として使っている場合はダメなんですよね・・・ --
- これphp4で動作してましたか? この関数はUS英文形式の日付を含む文字列が指定されることを期待しており....とありますから正常動作する気がしないのですけど。 -- よっちい
- あ、曜日の件も含めて2バイト文字をハイフンに変換してみるのがいいのかな.... -- よっちい
- わざわざ、すみません。実際には上のようにして使ってはいないのですが、全面解決させるのなら$date_format や$time_format がデフォルトでない時のことも考えた方がいいのかな、と提示しただけです。 --
- ちなみに、PHP-4.4.8 で試したら動いてました。それどころか、&new{2008-03-21- --- 19:00:00}; みたいな日時表示としてはアウトだろ、というのでも動いてます。どちらも、ここ(PHP-5.2)では動かないんですけどね。 --
|