Presented by Nishishi via Movable Type. Last Updated: 2010/09/12. 00:53:55.

Undefined subroutine &jcode::convert と言われた

ローカルのPerl環境や、うちのウェブサーバでは問題なく動作するCGIが、なぜかクライアントのサーバではエラーを吐きます。500 Internal Server Errorになってしまいます。
サーバのエラーログを調べてみたところ、以下のようなエラーが記録されていました。

Undefined subroutine &jcode::convert called at hoge.cgi line 119.

jcode.plのconvertサブルーチンを呼び出している箇所でエラーになっているようです。
でも、うちのウェブサーバでは動きますし、ローカル環境でもエラーは出ません。
jcodeの使い方自体に間違いはないと思うんですが。

このエラーが出ている119行目は以下のように記述していました。

&jcode'convert(*name,'sjis');

これをふと、以下のように書き換えてみたところ、

&jcode::convert(*name,'sjis');

なんと、エラーが消えて、うまく動作するようになりました!(爆)
アポストロフィー記号「 ' 」をコロン2つ「 :: 」に書き換えただけです。
こ、こんなところに原因が?

しかし不思議なのは、このPerlソース内には、まだ119行目以降に、

&jcode'convert(*constr,'jis');
&jcode'convert(*notes,'sjis');

……のように、アポストロフィー記号を使っている箇所は残ってるんですが。
全部を「 :: 」に書き換えたのではなく、最初に出てくる1個だけを書き換えただけです。
これで問題なく動作するようになるって、どういうわけだ……?

この日記へのコメントはお気軽に! コメント数:0 トラックバック数:0

コメント

コメント数: 0件

コメント投稿欄 この日記に対するコメント投稿を歓迎します。

保存しますか?



※本文中にURLは書けません。(書くと投稿が拒否されますのでご注意下さい。)

投稿後、投稿できていないように見えることがあります。ブラウザのキャッシュが読まれているだけですので、ページを再読込すれば(=たいてい[F5]キーを押せば)投稿内容が反映されていることが確認できるはずです。連続投稿を試す前にご確認下さい。(^^;)

トラックバック

このエントリーへのトラックバックURLを表示するにはここをクリック
※スパム防止のため、トラックバックURLは別ウインドウで表示します。(JavaScriptが有効でないと表示されません。)