perldiag - さまざまな Perl 診断メッセージ
これらのメッセージは以下のように分類されます (重要度が増す順に 並べてあります):
(W) 警告 (オプション)。
(D) 非推奨 (デフォルトでは有効)。
(S) 重大な警告 (デフォルトでは有効)。
(F) 致命的エラー (トラップ可能)。
(P) 起こるはずのない内部エラー (トラップ可能)。
(X) 重大致命的エラー (トラップ不可能)。
(A) 外部エラーメッセージ (Perl 以外で生成されたもの)。
上記のうち、最初の三つ (W, D, S) に分類されるメッセージの大部分は warings
プラグマで制御できます。
メッセージが warnings
プラグマで制御できる場合、警告カテゴリは以下の 説明で分類文字と共に記されています。 例えば、(W closed)
は closed
カテゴリの警告を意味します。
warnings
プラグマか -w と -W のオプションを使うと追加の警告が 有効になります。 警告は、表示する変わりに警告が出るたびに呼び出されるサブルーチンへの リファレンスを $SIG{__WARN__}
にセットすることで捕捉できます。 perlvar を参照してください。
warnings
プラグマか -X オプションで明示的に無効にされない限り、 厳しい警告は常に有効です。
トラップ可能なエラーは評価演算子を使ってトラップできます。 "eval" in perlfunc を参照してください。 ほとんど全ての場合、警告は warnings
プラグマを使うことで選択的に 無効にしたり致命的エラーに昇格させたりできます。 warnings を参照してください。
メッセージは大文字小文字を無視してアルファベット順に並んでいます。 これらの中には一般的なものもあります。 変化する部分は %s またはその他の printf スタイルの表記をしています。 これらの表記や、その他の英文字以外の文字は並び順に関しては 無視されています。 メッセージを探すには、英文字以外は無視してください。
(W closed) クローズされたソケットに accept を行なおうとしました。 socket() の呼び出し時に、返却値のチェックを忘れたのではありませんか。 "accept" in perlfunc を参照してください。
(X) MS-DOS マシンでは、64K を越えるメモリアロケートをおこなえません。
(F) pack() や unpack() での '!', '<', '>''!' の修飾子は特定のタイプの 後にのみつけることができます。 "pack" in perlfunc を参照してください。
(W ambiguous) 定義したサブルーチンの名前が Perl のキーワードと同じで、 どちらかを呼び出すために修飾なしで名前を使っています。 Perl は、サブルーチンがインポートされたものではないので、組み込みのものを 呼び出すことにしました。
サブルーチン呼び出しとして解釈することを強制させるためには、サブルーチン名の 前にアンパサンドをつけるか、名前をパッケージ名で修飾してください。 他の方法として、サブルーチンをインポートする(あるいは use subs
プラグマを使ってインポートされたふりをする)方法もあります。
警告なしに Perl 演算子として解釈させるためには、(CORE::log($x)
のように) 演算子に CORE::
接頭辞をつけるか、サブルーチンをオブジェクト メソッド("Subroutine Attributes" in perlsub や attributes を 参照してください)として定義してください。
(F) tr/a-z-0//
のような、何の意味もないことをしようとしました。 文字変換の文字に -
を加える時は、最初か最後に置いてください。 (以前は tr/a-z-0//
は tr/a-y//
と同義でしたが、これはおそらく 予想していたものと違うでしょう。)
(S ambiguous) 何か、あなたが考えているようには解釈できないものがありました。 普通は、不足しているクォート、演算子、かっこ、宣言を追加することでかなり 簡単にあいまいさを解消できます。
(S ambiguous) -foo
のようなものを書きました; これは文字列 "-foo"
かも 知れませんし、関数 foo
を呼び出してその否定かも知れません。 文字列のつもりなら、単に "-foo"
と書いてください。 関数呼び出しのつもりなら、-foo()
と書いてください。
(S ambiguous) %
, &
, *
は、中置演算子(剰余、ビット単位論理和、乗算) および 初期特殊文字(ハッシュ、サブルーチン、型グロブを示す)の 両方に使われますが、どちらとも解釈できる *foo * foo
のようなものが 書かれました。 これは中置演算子を意味していると仮定しますが、どうかより明確にするように してください -- 上述の例では、もし本当にグロブと関数呼び出しの結果の 積を意味しているなら、*foo * foo()
と書けます。
(W ambiguous) @{foo}
のようなものを書きました; これは変数 @foo
のこと かもしれませんし、foo という名前の関数を呼び出して、それを配列 リファレンスとしてデリファレンスするかもしれません。 もし変数がほしいなら、単に @foo
と書いてください。 関数を呼び出したいなら、@{foo()}
と書いてください…あるいは単に 変数と関数で同じ名前を使わないでください; これにより多くの問題から身を 守れます。
(W ambiguous) ${foo[2]}
のようなものを書きました (ここで foo は Perl の キーワード名を表します); これは @foo
という名前の配列の要素番号 2 を 探しているのかも知れません(その場合は $foo[2]
と書いてください)し、 foo という名前の関数に無名配列リファレンスを渡して、返り値をスカラ デリファレンスしているのかも知れません。 それを意味しているなら、${foo([2])}
と書いてください。
正規表現の中で、${foo[2]}
文法は配列添え字と文字クラスを区別するために 必要になります。 例えば、/$length[2345]/
は、$length
に文字クラス [2345]
が 引き続くと解釈されます。 配列添え字が求めているものなら、/${length[2345]}/
を (見にくい) /${\$length[2345]}/
と変更する、配列の名前を組み込みキーワードと 衝突しないものに変える、単に no warnings 'ambiguous';
として 警告をオフにする、のいずれかで警告を回避できます。
(F) VMS に固有のエラーです。 Perl は独自にコマンドラインのリダイレクトを扱っていて、STDIN がパイプで あることを発見しましたが、さらに '<' を使って STDIN をリダイレクトしようと しました。 STDIN ストリームは一つだけにしてください; お願いします。
(F) VMS に固有のエラーです。 Perl は独自にコマンドラインのリダイレクトを扱っていて、STDOUT を ファイルと他のコマンドへのパイプと両方にリダイレクトしようとしていると 判断しました。 どちらかを選ぶ必要がありますが、以下のように出力を二つのストリームに 「分割」するプログラムや Perl スクリプトにパイプすることを止めるものは 何もありません。
open(OUT,">$ARGV[0]") or die "Can't write to $ARGV[0]: $!";
while (<STDIN>) {
print;
print OUT;
}
close OUT;
(W misc) パターンマッチ (//
), 置換 (s///
), 文字置換 (tr///
) 演算子はスカラ値に対して動作します。 これらを配列やハッシュに適用すると、配列やハッシュをスカラ値 (配列の長さか ハッシュの大きさの情報) に変換し、そのスカラ値に対して動作します。 これはおそらくしたいこととは違うでしょう。 代替案については "grep" in perlfunc と "map" in perlfunc を参照してください。
(F) msgsnd() に渡す文字列は、少なくとも sizeof(long) の長さが必要です。
(W numeric) ここに示した文字列は、数値が必要な演算子の引数として、 与えられました。 運がよければ、このメッセージによって、どの演算子が問題となったかが わかります。
(W layer) Perl I/O システムに層を引数付きで追加するときに、引数リストを 閉じる ) を忘れています。 (層はデータの外部表現と内部表現の変換を扱います。) Perl はここで層のリストのパースを中止し、この層の追加は行われませんでした。 明示的に失敗する操作を要求していないのであれば、これは環境変数 PERLIO の 値が原因かもしれません。
(D deprecated) 本当に古い Perl では、場所によっては、配列名の @ を 省略できました。 これは廃止予定です。
(D) 連続して複数のスペース文字を持つ文字名を定義しました。 単一のスペースに変更してください。 普通はこれらの名前は use charnames
の :alias
インポート引数で 定義されますが、$^H{charnames}
にインストールされた変換器で 定義されているかも知れません。 "CUSTOM ALIASES" in charnames を参照してください。
(X) Perl に付属の malloc ルーティンが内部エラーを起こしました。
(X) 一般的なアサーションが失敗しました。 問題の file を調べる必要があります。
(F) (use v5.16;
のように) "array_base" 機能が無効の場合、廃止予定である 特殊変数 $[
は 0 固定です。
(F) 条件演算子へ代入を行なう場合には、二つめの引数と、3 つめの引数は、 ともにスカラか、ともにリストでなければなりません。 そうでないと、Perl は右辺のコンテキストを決めることができません。
(F) 制限ハッシュで許されているキーの集合に含まれていないキーに対して 取得または設定しようとして失敗しました。
(F) 現在のパッケージが解放されるような何かが起きた後で 1 引数の bless $foo
を書きました。 何がしたいのかが分からないので Perl はお手上げになりました。
(F) bless() 演算子の CLASSNAME 引数は結果のオブジェクトに bless する パッケージ名を想定しています。 そこに何かへのリファレンスが与えられました: おそらく以下のようにしたのでしょう:
bless $self, $proto;
以下を意図していたはずです:
bless $self, ref($proto) || $proto;
実際に与えられたリファレンスを文字列化したものに bless したい場合は、 以下のようにして自分で文字列化する必要があります:
bless $self, "$proto";
(S debugging) 配列が、解放されるときに代入されました。 解放された値は Perl コードからは見えないはずです。 これはまた、XS コードが配列のカスタムマジックコールバックから av_clear
を呼び出したときにも起こります。
(F) 制限ハッシュで、キー集合に含まれていないキーから削除しようとしました。
(F) 制限ハッシュで、読み込み専用として宣言されている値のキーを 削除しようとしました。
(S internal) すべての SV オブジェクトは、exit 時にガーベジコレクションが 行なわれるアリーナに割り当てるようになっています。 ある SV が、そういったアリーナに入っていないことが、見つかりました。
(S internal) Perl はストレージおよびハッシュキーとその他の文字列への アクセスを最適化するために、文字列の参照数テーブルを管理しています。 これは誰かがもうテーブルにない文字列の参照カウントを減らそうとしたことを 示します。
(S debugging) 消滅する値は、free_tmps() ルーティンで解放されるように なっています。 このメッセージは、free_tmps() ルーティンの前に何ものかが、SV を 解放しようとしていることを示していて、これは、free_tmps() が 解放しようとしたときには、どこからも参照されていないスカラを 解放することになるということです。
(S internal) シンボルのエイリアスについて、参照カウントの値がおかしな 状態になりました。
(S internal) Perl がスカラの参照カウントをデクリメントしようとして、0 に なるかを見たところ、既に 0 になっていることがわかりました; これは、既に解放されているべきものであり、実際は、おそらく、 解放されたものでしょう。 これは、SvREFCNT_dec() が必要以上に呼ばれたか、SvREFCNT_inc() が必要な ときに呼ばれなかったか、SV が消滅すべきで無いときに消滅してしまったか、 メモリ異常になったことが考えられます。
(W pack) (関数の結果や計算された式といった)一時的な値を pack() の "p" テンプレートに渡そうとしました。 これは、たとえ現在の文の終了前でも、不正な値となり得ます。 この警告を避けるためには、pack テンプレート "p" の引数として、リテラルか グローバルな値を使ってください。
(F) 既に一度コンパイルに失敗しているファイルを use
や require
で 読み込もうとしました。 Perl は %INC からこのファイルのエントリを削除するまで再びファイルを コンパイルしようとはしません。 "require" in perlfunc と "%INC" in perlvar を参照してください。
(W misc) 既に解放された配列の長さを設定しようとしました。 配列の最後のインデックスを表現するスカラをリファレンスに保存して、 後でこのリファレンスを通して代入することでこれを行えます。 例えば:
$r = do {my @a; \$#a};
$$r = 503
(W substr) 左辺値として使われる substr() の 1 番目の引数としてリファレンスを 渡しました; これはやや奇妙なことです。 おそらくはまずデリファレンスするのを忘れたのでしょう。 "substr" in perlfunc を参照してください。
(D deprecated) コードリファレンスの "locked" 属性を修正するために attributes プラグマを使いました。 :locked 属性は古いもので、5005 スレッドが削除されてから何の効果もなく、 将来の Perl 5 のメジャーリリースで削除されます。
(W misc) あるサブルーチンが、例えば sub foo : prototype(A) : prototype(B) {} のように宣言されました。 それぞれのサブルーチンは一つのプロトタイプしか持てないので、先に 宣言されたものは破棄され、最後のものが適用されます。
(D deprecated) 配列、ハッシュ、スカラリファレンスの "unique" 属性を 修正するために attributes プラグマを使いました。 :unique 属性は Perl 5.8.8 から何の効果もなく、将来の Perl 5 のメジャー リリースで削除されます。
(S debugging) これは、@_
や @DB::args
が tie されたことに関して何かが うまくいかなくて Perl が とても 混乱したことを示しています。
(F) msgctl()、semctl()、shmctl() のいずれかに、間違ったサイズのバッファを 渡してしまいました。 C の言い方で書くと、正しいサイズはそれぞれ、sizeof(struct msqid_ds *)、 sizeof(struct semid_ds *)、sizeof(struct shmid_ds *) です。
(F)置換のための置き換え文字列を評価するために /e
オプションを指定して いますが、評価するコードに文法エラーがありました; 最もありそうなことは、予期しない位置に右中かっこ '}' があったことです。
(F) ファイルハンドルが必要なものに、シンボルを渡しましたが、そのシンボルは、 それに伴うファイルハンドルがありません。 おそらく、open() を忘れたか、別のパッケージで open() したかでしょう。
(S malloc) まず、malloc() されていないものに対して、内部ルーティンが free() を呼びました。 強制ですが、環境変数 PERL_BADFREE
を 0 にすることで無効化できます。
このメッセージ は、AIX
や OS/2
のような、「ハード」動的リンクを 行うシステムで DB_File を使うとしばしば表示されます。 これは DB
がシステムの malloc() を許していることに気が付かない Berkeley DB
のバグです。
(P) 内部ハッシュルーティンで、ヌル HV ポインタを渡されたものがありました。
(A) スクリプトを perl ではなく csh で実行しようとしました。 #! 行をチェックするか、スクリプトを直接 Perl で起動してください。
(F) パッケージプレフィクスでシンボル名を書き始めましたが、そのシンボルが 終了しませんでした。 特に、クォートの外で、変数展開はできませんから、
$var = 'myvar';
$sym = mypack::$var;
は、以下と同じではありません。
$var = 'myvar';
$sym = "mypack::$var";
(F) キーワードプラグイン機構を使っているエクステンションがプラグイン API に 違反しました。
(S malloc) 内部ルーチンが、最初に malloc() されていない何かに対して realloc() を呼び出しました。 必須ですが、環境変数 PERL_BADFREE
に 1 をセットすることで無効化できます。
(P) シンボルテーブルエントリではないものに、配列エントリを登録するような 内部要求があがりました。
(P) シンボルテーブルエントリではないものに、ディレクトリハンドルエントリを 登録するような内部要求があがりました。
(P) シンボルテーブルエントリではないものに、ファイルハンドルエントリを 登録するような内部要求があがりました。
(P) シンボルテーブルエントリではないものに、ハッシュエントリを 登録するような内部要求があがった。
(W bareword) コンパイラが、条件が想定される位置に裸の単語を発見しました; これはしばしば、|| や && が直前の構造の最後の引数の一部として パースされたことを意味します; 例えば:
open FOO || die;
これはまた、裸の単語として解釈されるような定数をタイプミスしたことを 示している場合もあります:
use constant TYPO => 1;
if (TYOP) { print "foo" }
strict
プラグマはこのようなエラーを防ぐのに便利です。
"strict subs" が有効の場合、裸の単語はサブルーチンの識別子、中かっこの中、 シンボル "=>" の左側でのみ許されます。 おそらくサブルーチンを先行宣言する必要があるのでは?
(W bareword) Foo::
の形で修飾された裸の単語が使われていますが、 コンパイラはこの場所以外でこの名前空間が使われている場所を 発見できませんでした。 おそらくパッケージを専攻宣言する必要があるのでは?
(F) BEGIN サブルーチンの実行中にトラップ不可能な例外が発生しました。 コンパイルは即座に停止し、インタプリタは中止します。
(F) Perl は既にコンパイルエラーが発生した後に BEGIN {}
サブルーチン (または use
指示子(これは BEGIN {}
を暗示します))を発見しました。 BEGIN {}
が意図した環境は(エラーのために)保証されず、引き続くコードは 正しい処理に依存していると考えられるので、Perl は単に諦めました。
(W syntax) パターンの外では、後方参照は変数の形で存在します。 後方参照の利用は、置換の右側の部分で扱われますが、スタイル的には、他の Perl プログラマが期待し、9 個以上の後方参照があるときにもうまく動作する、 変数形式を使う方が良いでしょう。
(W portable) 指定された 2 進数が 2**32-1 (4294967295) を越えるので、 システム間での移植性がありません。 移植性に関するさらなる考察については perlport を参照してください。
(W closed) クローズされたソケットに bind を行なおうとしました。 socket() の呼び出し時に、返却値のチェックを忘れたのではありませんか。 "bind" in perlfunc を参照してください。
(W unopened) 開いていないファイルハンドルに binmode() を使おうとしました。 制御フローと引数の数をチェックしてください。
(W deprecated, regexp) \b
または \B
の直後にエスケープしない "{" を書くのは、将来のバージョンの perl での使用のために予約するために 廃止予定となりました。 中かっこの前に逆スラッシュを置くか、大かっこで囲むかしてください; 後者は、 パターンの区切り文字が {}
の場合は最良の方法です。
(W portable) 32 を越えるサイズのビットベクタは移植性がありません。
(P) コピーできない内部の値をコピーしようとしました。
(P) 新しいスレッドを始めたりスレッドから値を返したときに、Perl は不正な データ型に遭遇しました。
(W internal) VMS に固有の警告です。 Perl が %ENV を反復する準備中、長すぎる論理名かシンボル定義に遭遇したので、 文字列は表示したように切り詰められました。
(F) 外部パッケージから call_sv() で起動されたサブルーチンが exit を呼んで 終了しました。
(W prototype) 以前にパーサが宣言または定義されているのを見た、 プロトタイプ付きの関数を呼び出しましたが、Perl は呼び出しがプロトタイプに 従っているかどうかをチェックできませんでした。 問題になっているサブルーチンのプロトタイプ宣言を最初の方に追加するか、 適切なプロトタイプチェックを行うためにサブルーチン定義を呼び出しの前に 移動させる必要があります。 または、関数を正しく呼び出していることが確かな場合は、名前の前に アンパサンドを付けることで警告を回避できます。 perlsub を参照してください。
(D deprecated) 廃止予定の関数を呼び出しました。 詳しくは POSIX の関数名を参照してください。
(F) pack("w",...) の引数が、圧縮するには大きすぎます。 BER 圧縮整数フォーマットは正の整数のみ扱えますが、無限やとても大きい数 (> 1e308) を圧縮しようとしました。 "pack" in perlfunc を参照してください。
(F) pack("w",...) の引数が負数です。 BER 圧縮整数フォーマットは正の整数のみ扱えます。 "pack" in perlfunc を参照してください。
(F) あなたは Perl のシンボルテーブルを直接操作して、リファレンスをその中に 補完し、それからそのシンボルを伝統的な Perl の文法のよって アクセスしようとしました。 このアクセスによって、Perl はこの型グロブを自動有効化しますが、 リファレンス型から型グロブへの正当な変換方法はありません。
(P) Perl が、直接代入できない内部型に値をコピーしようとする試みを 検出しました。
(S io) open() または binmode() のファイルハンドルに存在しない エンコーディングを適用しようとしました。
(F) caller
は @DB::args
を設定しようとしましたが、tie されていました。 @DB::args
の tie は非対応です。 (このエラーが追加する前は、クラッシュしていました。)
(P) 参照カウントを保持していない配列を引数にして tie
を 呼び出そうとしましたがそうできませんでした。 このような配列は Perl コードからアクセスできると想定してはならず、 内部だけで使われます。
(F) pack("w",...) の引数が整数ではありません。 BER 圧縮整数フォーマットは正の整数のみ扱えますが、何か他のものを 圧縮しようとしました。 "pack" in perlfunc を参照してください。
(F) ハードリファレンスのみが bless できます。 これによって、Perl はオブジェクトのカプセル化を「強制」します。 perlobj を参照してください。
(F) break
を呼び出しましたが、given
ブロックではなく foreach
ブロック内でした。 おそらく next
や last
を使いたかったのでしょう。
(F) break
を呼び出しましたが、given
ブロックの内側ではありません。
(F) メソッド呼び出しの文法が使われていますが、オブジェクトリファレンスか パッケージ名であるべきところが未定義値です。 以下のように書くとエラーが再現します:
$BADREF = undef;
process $BADREF 1,2,3;
$BADREF->process(1,2,3);
(F) メソッド呼び出しは、自分が呼び出されたパッケージがどれであるかを 知る必要があります。 普通は、渡したオブジェクトリファレンスから その情報を受け取りますが、この場合にはオブジェクトリファレンスが 渡されませんでした。 リファレンスは、bless されて始めて、オブジェクトリファレンスとなります。 perlobj を参照してください。
(F) メソッド呼び出しの構文を用いましたが、オブジェクトリファレンス、 もしくはパッケージ名が書かれるべき場所に、オブジェクトリファレンスも パッケージ名も返さない定義された式が書かれています。 以下のように書くとエラーが再現します:
$BADREF = 42;
process $BADREF 1,2,3;
$BADREF->process(1,2,3);
(P) @ISA キャッシュを更新しようとしたときに、ハッシュが普通のハッシュか シンボルテーブルハッシュかについて perl は混乱しました。
(F) XS モジュールが、シンボルテーブルにアタッチされていないハッシュに対して mro_method_changed_in
を呼び出しました。
(F) perl -x/foo/bar
のようにして起動しましたが、/foo/bar に chdir することができません; おそらく、存在しないのではないでしょうか。
(P) なぜかスクリプトが nosuid かどうかをファイルシステムから 調べることができません。
(F) ある種の SV、特に本物のシンボルテーブルエントリ (型グロブ) は、 一つの型に留めておくことができません。 したがって、以下のようにすることはできません:
*foo += 1;
以下のようにはできますが:
$foo = *foo;
$foo += 1;
$foo にはもはやグロブは残っていません。
(F) continue
を呼び出しましたが、when
か default
のブロックの 内側ではありません。
(P) VMS に固有のエラーです。 プロセスはクォータを使い切ったか、その他の設備問題の影響を受けました。
(F) スカラ変数、配列変数、ハッシュ変数だけが、"my", "our", "state" 変数として 宣言できます。 これらは、名前として通常の識別子を持たなければなりません。
(F) foreach
ループや given
ブロックの内側でないところで default
ブロックを使いました。 (このエラーは default
ブロックから出るときに発生するので、明示的な continue
を使うとエラーは発生しません。)
(S inplace) /dev, FIFO, 変更できないディレクトリのような、特殊ファイルに対して -i スイッチを使おうとしました。 このファイルは無視されます。
(S inplace) 表示された理由により、新しいファイルの生成に失敗しました。
(F) 削除した (が、まだオープンされている) ファイルを読もうとすると おかしくなる MS-DOS のようなシステムで実行しています。 -i.bak
のようにバックアップを指定してください。
(S inplace) ファイルシステムが 14 文字より長いファイル名に対応しておらず、 Perl は -i オプションによるその場編集の間のユニークなファイル名の 作成ができませんでした。 このファイルは無視されます。
(F) このマシンには、waitpid() も wait4() もありませんので、 フラグの無い waitpid() のみがエミュレート可能です。
(F) #! 行にその時点で意味をなさないスイッチが指定されました。 たとえば、#! 行に -x をおいても意味がありません。
(F) プラットフォームのバイト順序がビッグエンディアンでも リトルエンディアンでもないか、ポインタサイズがとても変わっています。 ビッグエンディアンやリトルエンディアンの不動小数点数やポインタの pack や unpack はできません。 "pack" in perlfunc を参照してください。
(W exec) 提示した理由によって、system() や exec() やパイプオープン 呼び出しの指定されたプログラムが実行できませんでした。 考えられる理由には: ファイルのパーミッションが間違っている、 ファイルが $ENV{PATH}
の中にない、問題の実行ファイルが このマシン用ではない、スクリプトの #! 行が同じような理由で実行できない インタプリタを指している、というようなものがあります。 (あるいは、このシステムで、#! がサポートされていません。)
(F) #! 行に書かれた内容にしたがって、Perl は示されたプログラムを 実行しようとしました。 そうしたくないのであれば、#! 行のどこかに、"perl" と書いておいてください。
(F) -S スイッチを使いましたが、PATH に見つかった実行するスクリプトが 正しいパーミッションではありませんでした。
(F) CORE::word
の形の文字列が prototype() に与えられましたが、 名前 word
は組み込みではありません。
(F) \p{}
か \P{}
を使っていますが、そのような名前の文字特性は 見つかりませんでした。 おそらくプロパティ名をタイプミスしたのでは? 公式に利用可能な特性の完全な一覧については "Properties accessible through \p{} and \P{}" in perluniprops を 参照してください。
(F) どこにも見つからないラベルへ goto を行なおうとしました。 "goto" in perlfunc を参照してください。
-S オプションを使いましたが、実行するスクリプトは PATH に 見つかりませんでした。
(F) -S オプションが使われましたが、 PATH に実行するスクリプトが 見つからないか、少なくとも適切なパーミッションがありません。 スクリプトはカレントディレクトリにはありますが、PATH に カレントディレクトリは含まれていません。
(F) Perl の文字列は、複数行に渡ることができます。このメッセージは、 文字列を終わる区切り文字が見つからなかったことを意味します。 かっこ類の区切り文字では、ネストを数えるので、以下では、最後のかっこが 無いと言われます:
print q(The character '(' starts a side comment.);
このエラーがヒアドキュメントで起きた場合、閉じタグの前か後に 見えない空白を含んでいるか、その後に改行がないのかもしれません。 よいプログラマ用エディタには、このような文字(または文字がないこと)を探す 助けになる方法があります。 ヒアドキュメントに関する完全な詳細については perlop を参照してください。
(F) (例えば \p{Lu} が全て大文字にマッチング、のように) Unicode 特性を 意味する\p
を使おうとしました。 Unicode 特性を使いたい場合は、利用可能な特性の完全なリストを "Properties accessible through \p{} and \P{}" in perluniprops で 参照してください。 Unicode 特性を使うつもりでない場合は、\\p
(単に \p
) または \Q\p
(残りの文字列 または \E
まで) を使って \p
を エスケープしてください。
(F) パイプラインをオープンしようとして、fork を行なおうとして、 致命的エラーが発生しました。
(W pipe) パイプの open での fork が EAGAIN で失敗し、5 秒後に 再試行されます。
(S) VMS に固有の警告です。 これは VMS と、Perl が仮定している Unix モデルでは、アクセスチェックに違いが あることによって起こります。 VMS では、アクセスチェックは stat バッファのビットではなくファイル名によって 行われるので、ACL やその他の保護が考慮されます。 残念ながら、Perl は stat バッファに全ての必要な情報が含まれていると仮定して、 アクセスチェックルーチンにはファイルスペックではなくこれを渡します。 stat バッファにあるデバイス名と FID を使ってファイルスペックを 取得しようとしますが、これは引き続いて CRTL stat() ルーチンを呼び出さない 場合にのみ動作します; なぜならデバイス名は呼出し毎に上書きされるからです。 この警告が出ると、名前の検索が失敗し、アクセスチェックルーチンは諦めて、 安全のためだけに FALSE を返します。 (注意: アクセスチェックルーチンは Perl の stat
演算子とファイル テストについて知っているので、Perl コマンドの結果としてこの警告を見ることは ないはずです; これは内部コートが stat バッファを軽率に扱った場合にのみ 発生します。)
(P) VMS に固有のエラーです。 パイプとして働くメールボックスの作成後、後で使うための名前を Perl が取得できませんでした。
(P) VMS に固有のエラーです。 メールボックスバッファをどれくらいとるべきかを $GETSYI に 問い合わせましたが、答えが得られませんでした。
(F) "goto" 文で foreach ループの中に飛び込もうとしました。 ここからそこへは行けません。 "goto" in perlfunc を参照してください。
(F) "goto" 文でブロックのように見えるけれども、適切な ブロックではないところから飛び出そうとしました。 これは普通 sort() ブロックやサブルーチンから飛び出そうとしたときに 起きますが、それはできません。 "goto" in perlfunc を参照してください。
(F) "goto subroutine" 呼び出しは eval "string" やブロックから 飛び出すことはできません。
(F) "goto subroutine" 呼び出しは、sort() のための比較サブルーチンや、 (List::Util の reduce() 関数のような) 似たようなコールバックから 飛び出すことはできません。
(F) 結構マジカルな "goto subroutine" の呼び出しは、あるサブルーチン 呼び出しを別のもので置き換えるだけです。 反物の状態から作り上げることはできません。 一般に、これを行なうのは、AUTOLOAD ルーティンから抜け出すときだけに しておくべきです。 "goto" in perlfunc を参照してください。
(W signal) Perl は、SIGCHLD (SIGCLD としても知られます) シグナルが 無効化された状態で実行されていることを検出しました。 このシグナルが無効化されると子プロセスの終了ステータスを適切に 決定できなくなるので、Perl はシグナルをデフォルト値にリセットしました。 この状況は典型的には Perl が動作している親プログラム(cron など)が とても不注意であることを示しています。
(F) プロセス識別子は(符号付き)整数でなければなりません。 未定義値、空文字列、その他の非数値プロセス識別子を使って kill() しようとすることは致命的エラーです。
(F) 現在のブロックから脱出するために、"last" 文を実行しましたが、 残念なことにブロックの中ではありませんでした。 "if" や "else" のブロックは、sort(), map(), grep() のブロックが違うのと 同様「ループ風」ブロックではないので、注意してください。 ただし、中かっこを二重にすれば、内側の中かっこが、1 度だけループする ブロックとみなされますから、同じ効果が得られます。 "last" in perlfunc を参照してください。
(F) Perl はパッケージのメソッド解決順序 (MRO) を計算しようとしましたが、 パッケージ stash に名前がないので失敗しました。
(F) 読み込もうとしたモジュールは、動的拡張モジュールの読み込みに 失敗しました。 これは古い動的拡張モジュールと互換性のない perl にアップグレードしたか (これは perl のメジャーバージョン間で起きることが知られています)、 (よりあり得るのは)動的拡張モジュールがシステムにインストールされている古い バージョンのライブラリに対してビルドされているかです。 古い動的拡張モジュールをリビルドする必要があるでしょう。
(F) 以前に "my" や "state" を使ってレキシカル変数として宣言された変数名に 対して local を使いました。 これは認められていません。 同じ名前のパッケージ変数をローカル化したい場合は、 パッケージ名で修飾してください。
(F) local $$ref
のようなことをしましたが、Perl は現在のところこれを 扱えません; なぜなら、local() のスコープが終了した後、$ref が 指しているものの古い値を戻すとき、$ref がまだリファレンスかどうかが わからないからです。
(F) ファイルを do
(または、require
、use
) するように 指示されましたが、見つかりませんでした。 Perl は、フルパスで指定されていない場合ファイルを @INC で示される 全ての場所を検索します。 おそらく、追加ライブラリの場所を示すために、 PERL5LIB または PERL5OPT の環境変数を指定する必要があるか、 スクリプトの中で @INC にライブラリ名を追加する必要があります。 ファイル名のスペルミスの可能性もあります。 "require" in perlfunc と lib を参照してください。
(F) 関数(またはメソッド)がオートロードを許可しているパッケージで 呼び出されましたが、オートロードする関数がありませんでした。 最も可能性のある原因は関数/メソッド名の誤記か、make install
と することによるファイルの AutoSplit
の失敗です。
(F) 読み込まれたモジュールは foo.so や bar.dll のような外部 ライブラリを読み込もうとしましたが、DynaLoader モジュールは、この ライブラリの位置がわかりませんでした。 DynaLoader を参照してください。
(F) 正しくメソッドを呼び出し、それは、クラスとして機能するパッケージを 正しく示していますが、そのパッケージにも、基底クラスにも、 該当のメソッドが定義されていません。 perlobj を参照してください。
(W syntax) 配列 @ISA に別のパッケージ名が記されていますが、 存在していないようです。
(F) 例えば、open(FH, ">:nosuchlayer", "somefile") のように、 open() で 存在しない PerlIO 層を使おうとしました。
(F) %ENV へのリスト代入はいくつかのシステム、特に VMS では 対応していません。
(W) モジュールが、プロセスの中でグローバルに利用可能な固定ファイルから シンボルを読み込むことを要求するために、DynaLoader::dl_load_file() に 0x01 フラグを渡しましたが、この機能はこのプラットフォームでは利用できません。 モジュールはおそらく動作しますが、perl インタプリタによる、固定ファイルの C や XS コードで定義された関数へ直接リンクする必要のあるその他の XS ベースの エクステンションの読み込みが妨げられるかもしれません。
(F) 指定されたものは、代入、インクリメントなど、変更が許されていません。
(P) substr() への代入を行なう内部ルーティンに NULL が渡されました。
(F) 左辺値コンテキストとして使うサブルーチンは、そのように 宣言しなければなりません。 "Lvalue subroutines" in perlsub を参照してください。
(F) msgrcv で使用する変数は、受信バッファとして使用しますので、 変更可能なものでなければなりません。
(F) 現在のブロックの繰り返しを進めるために、"next" 文を実行しましたが、 ブロックの中ではありませんでした。 "if" や "else" のブロックは、sort(), map(), grep() のブロックが違うのと 同様「ループ風」ブロックではないので、注意してください。 ただし、中かっこを二重にすれば、内側の中かっこが、1 度だけループする ブロックとみなされますから、同じ効果が得られます。 "next" in perlfunc を参照してください。
(F) PERL_XMLDUMP 環境変数を設定して MAD 対応でビルドした perl を 実行しようとしましたが、環境変数で指定された名前のファイルが開けませんでした。
(S inplace) <>
ファイルハンドルによる暗黙的なファイルオープンまたは -n
か -p
コマンドラインスイッチによる暗黙的な、あるいは 明示的なファイルオープンが表示した理由によって失敗しました。 通常、これはコマンドラインで指定したファイルの読み込み権限が無いときに起こります。
(F) -e オプション付きで perl を呼び出そうとしましたが、/dev/null (またはあなたのオペレーティングシステムでの等価物) が開けませんでした。
(W io) 3 引数の open() の構文を使ってスカラリファレンスを読み込みまたは 書き込みのために開こうとしました:
open FH, '>', $ref;
しかしこのバージョンの perl は perlio なしでコンパイルされていて、 この形式の open は対応していません。
(W pipe) サポートされていない open(CMD, "|cmd|")
を行なおうとしました。 これを行なうためには、Perl ライブラリの IPC::Open2 のようないくつかの モジュールを使うことができます。 別の方法として、パイプされたものを ">" を使っていったんファイルに出力し、 あとで別のファイルハンドルで読み込みを行なうことも考えられます。
(F) VMS に固有のエラーです。 Perl は独自にコマンドラインのリダイレクトを扱っていて、 コマンドラインで書き込みのために '2>' や '2>>' の後に指定された ファイルを開けませんでした。
(F) VMS に固有のエラーです。 Perl は独自にコマンドラインのリダイレクトを扱っていて、 コマンドラインで読み込みのために '<' の後に指定された ファイルを開けませんでした。
(F) VMS に固有のエラーです。 Perl は独自にコマンドラインのリダイレクトを扱っていて、 コマンドラインで書き込みのために '>' や '>>' の後に指定された ファイルを開けませんでした。
(P) VMS に固有のエラーです。 Perl は独自にコマンドラインのリダイレクトを扱っていて、 標準出力としてデータを送るパイプを開けませんでした。
(F) 指定したスクリプトが、表示した理由によってオープンできませんでした。
#! を使うスクリプトをデバッグしていて、普通はシェルの $PATH 検索に 頼っている場合は、-S オプションを付けることで perl が検索するようになり、 パスや `which $scriptname`
をタイプする必要がなくなります。
(S) VMS に固有の警告です。 Perl は %ENV の要素を CRTL の内部環境配列から読み込もうとしましたが、 配列がないことを発見しました。 CRTL が環境をどこに間違えて置いたかを探し出すか、PERL_ENV_TABLE を 定義して(perlvms を参照してください)環境を検索しないようにする 必要があります。
(F) 現在のブロックの繰り返しをもう一度行なうために、 "redo" 文を実行しましたが、ブロックの中ではありませんでした。 "if" や "else" のブロックは、sort(), map(), grep() のブロックが違うのと 同様「ループ風」ブロックではないので、注意してください。 ただし、中かっこを二重にすれば、内側の中かっこが、1 度だけループする ブロックとみなされますから、同じ効果が得られます。 "redo" in perlfunc を参照してください。
(S inplace) バックアップを作成せずにその場編集することを要求しました。 Perl は変更したファイルで置き換えるために元のファイルを削除することが できませんでした。 ファイルは変更されずに残されます。
(S inplace) -i スイッチで行なわれた rename が何らかの理由によって、 うまく行きませんでした; ディレクトリに書き込み権がないことも考えられます。
(P) VMS に固有のエラーです。 Perl は標準入力がパイプであると考えて、バイナリデータを受け入れるために 再オープンしようとしました。 悲しいかな、それは失敗しました。
(F) reset('E')
のようなものを呼び出して、現在のパッケージで "E" で始まる 全ての変数を reset しようとしました。 main パッケージでは、これには %ENV が含まれます。 %ENV の reset は一部のシステム、特に VMS では対応していません。
(F)(P) (サブルーチンのリファレンスではなく)メソッド名で指定された オーバーロードの解決でのエラー: そのようなメソッドはパッケージ経由で 呼び出せません。 もしメソッド名が ???
なら、内部エラーです。
(F) Perl が、左辺値として使われるサブルーチンから(一時的や 読み込み専用のような)不正な左辺値が返されようとしているのを検出しました。 これは認められていません。
(F) return 文が、return で抜けるべきサブルーチンがない、 "main" コードで実行されました。 perlsub を参照してください。
(F) 左辺値サブルーチンから配列やハッシュ全体を返そうとしましたが、 一つだけの値を返そうとしていると Perl が考えるような方法でサブルーチンを 呼び出しました。 おそらく、Perl にこの呼び出しがリストコンテキストであると伝えるために、 サブルーチン呼び出しの周りにかっこを書いているのでしょう。
(P) 何らかの理由で、例え既にオープンしていたとしても、fstat() が 行なえません。困ったもんだ。
(F) 実数に対しては、負数や 0 に対する対数を取ることはできません。 しかし、もし本当に負数に対してそのようなことをしたいのなら、 Perl 標準になっている Math::Complex パッケージがあります。
(F) 通常の実数では、負数の平方根をとることはできません。 しかし、本当にその計算を行ないたいのであれば、Math::Complex パッケージが Perl に標準で用意されています。
(F) 実行中のルーティンを未定義にすることはできません。 しかし、実行中に再定義することはでき、古いルーティンを実行中に、 再定義したサブルーチンを undef することさえできます。 驚きです。
(P) 内部の sv_upgrade ルーティンは、SV に「メンバ」を加えて、 より特別な種類の SV にします。 しかし、上位のいくつかの SV 型は、 特殊化され過ぎて、内部変換することができません。 このメッセージは、そのような変更を行なおうとしたことを示しています。
(F) -m オプション付きで perl を呼び出そうとしましたが、モジュール名の後に "=" 以外のものを置きました。
(F) メソッド検索を行う内部ルーチンが、名前のないシンボルテーブルを 扱いました。 シンボルテーブルは、例えば undef %Some::Package::
のように未定義の stash によって無名となります。
(F) ハードリファレンスやシンボリックリファレンスとして使用する値は、 定義済みの値でなければなりません。 潜伏中のエラーを引きずり出す助けとなります。
(F) "strict refs" によって、ハードリファレンスのみが許可されます。 シンボリックリファレンスは許可されません。 perlref を参照してください。
(F) 最初に %!
ハッシュが使われるときに、 perl は自動的に Errno.pm モジュールを読み込みます。 Errno モジュールは $!
errno 値のシンボリック名を提供するために %! ハッシュと tie されることになります。
(F) 一つの型を同時にビッグエンディアンとリトルエンディアンの両方に 強制することはできないので、この修飾子の組み合わせは許可されません。 "pack" in perlfunc を参照してください。
(F) 単純スカラ変数だけが、foreach のループ変数として 使用することができます。
(F) マジカル変数を、字句スコープ変数として宣言しようとしました。 これが許されていないのは、マジカル変数は(グローバル変数という名前の) 1 か所だけに結び付けられているので、マジカル変数のように見えるけれども そうではない変数がプログラム中にあると、著しく混乱させるからです。
(F) 既にバイト順修飾子が付けられているグループの内側で異なったバイト順を 強制しようとしました。 例えば、ビッグエンディアングループの中にある型をリトルエンディアンに 強制することはできません。
(F) グローバル変数 $a と $b はソート比較のために予約されています。 $a か $b を <=> か cmp 演算子と同じ行に記述しましたが、その変数は その前にレキシカル変数として宣言されています。 ソート変数をパッケージ名で修飾するか、レキシカル変数の名前を変えてください。
(F) リファレンス型を混同しています。 必要な型のリファレンスを被参照しなければなりません。 必要ならば、リファレンスの型を調べるのに、ref() 関数を使うことができます。
(F) 文字列をデリファレンスするように Perl に指示しましたが、 use strict
ブロックがこれが偶然起きることを妨げました。 "Symbolic references" in perlref を参照してください。 これは、ダブルクォート文字列の中の変数展開の直前の @
または $
で 引き起こされます; 例えば "user @$twitter_id"
です; これは $twitter_id
の 内容を配列リファレンスとして扱うように指示しています; リテラルな @
の後に $twitter_id
の内容が引き続くようにするには \
を使ってください: "user \@$twitter_id"
。
(F) コンパイラが大かっこで囲われた式を添字として解釈しようとしました。 しかし、大かっこの左側はハッシュか配列のリファレンスやその他の 添字化できるもののようには見えない式です。
(W syntax) 通常の式では、バックスラッシュは引数へのリファレンスを作る 単項演算子です。 マッチした部分文字列への後方参照を示すためのバックスラッシュの使用は 正規表現パターンの一部の場合にのみ有効です。 通常の Perl コードの中でこれをしようとすると、SCALAR(0xdecaf) のように 表示される値を生成します。 代わりに $1 の形を使ってください。
(F) リファレンスではない何かを弱めようとしました。 リファレンスだけが弱めることができます。
(F) foreach
ブロックや given
ブロックの内側以外で when() ブロックを 使いました。 (このエラーは when
ブロックから終了したときに発生するので、マッチングに 失敗したときや、明示的な continue
を使った場合はこのエラーは 発生しません。)
(F) 定数値 (未定義値であることが多い) を、自らを書き換えることを意味する、 代入演算子で繰り返しを行なおうとしました。 テンポラリ変数に値を移してから、繰り返すと良いでしょう。
(F)(D deprecated, syntax) \cX
において、X は表示可能な ASCII 文字でなければなりません。 これは非 ASCII 文字については Perl v5.20 から致命的エラーになり、 Perl v5.22 からは全ての場合に致命的エラーになる予定です。 致命的エラーではない場合、これが評価される文字は、この文字の符号位置と 0x40 の排他的論理和をとったものです。
制御文字にマッピングされない ASCII 文字も非推奨であることに注意してください; そして (有効になっていれば) ""\c%c" is more clearly written simply as "%s"" 警告が出力されます。
(W pack) 以下のように書きましたが:
pack("C", $x)
$x は 0 より小さいか 255 より大きいです; "C"
フォーマットは ネイティブ OS 文字 (ASCII, EBCDIC など) のエンコーディングだけに 対応していて、Unicode 文字は対応していません; それで、Perl は以下のように意味しているかのように振舞います:
pack("C", $x & 255)
Unicode コードポイントを pack したい場合は、代わりに "U"
フォーマットを 使ってください。
(W pack) 以下のように書きましたが:
pack("c", $x)
$x は -128 より小さいか 127 より大きいです; "c"
フォーマットは ネイティブ OS 文字 (ASCII, EBCDIC など) のエンコーディングだけに 対応していて、Unicode 文字は対応していません; それで、Perl は以下のように意味しているかのように振舞います:
pack("c", $x & 255);
Unicode コードポイントを pack したい場合は、代わりに "U"
フォーマットを 使ってください。
(W unpack) 以下のようなことをしましたが:
unpack("H", "\x{2a1}")
ここでフォーマットはバイト(値が 256 より小さい文字)を想定していますが、 文字の中により大きな値のものがあります。 Perl は、あなたが以下のようにしたかのように、256 で割った余りを文字の 値として使います:
unpack("H", "\x{a1}")
(W pack) 以下のように書きましたが:
pack("U0W", $x)
$x が 0 より小さいか 255 より大きいです。 しかし、U0
-モードは全ての値が [0, 255] の範囲にあることを想定してるので、 Perl は以下のように振る舞います:
pack("U0W", $x & 255)
(W pack) 以下のようなことをしましたが:
pack("u", "\x{1f3}b")
ここでフォーマットはバイト(値が 256 より小さい文字)列を想定していますが、 文字の中により大きな値のものがあります。 Perl は、あなたが以下のようにしたかのように、256 で割った余りを文字の 値として使います:
pack("u", "\x{f3}b")
(W unpack) 以下のようなことをしましたが:
unpack("s", "\x{1f3}b")
ここでフォーマットはバイト(値が 256 より小さい文字)列を想定していますが、 文字の中により大きな値のものがあります。 Perl は、あなたが以下のようにしたかのように、256 で割った余りを文字の 値として使います:
unpack("s", "\x{f3}b")
(W syntax) \cX
構文は非表示文字を指定する方法を意図しています。 これを表示文字に使いました; おそらく(おそらく非単語文字のために 逆スラッシュを前に付けて)単にその文字自身を書くほうがよいです。
(F) s///
演算子の中での新しいスレッドの作成は非対応です。
(W io) 閉じようとしたディレクトリハンドルは既に閉じられているか、実際には ディレクトリハンドルではありません。 制御フローをチェックしてください。
(W unopened) オープンされていないファイルハンドルをクローズしようとしました。
(F) クロージャに属性があると、属性ハンドラに渡されるサブルーチンは、新しい クロージャが作成されたときにクローン化されたプロトタイプです。 このサブルーチンは呼び出すことができません。
(F) テンプレートが '/' で終わっています。 スラッシュの後には他のテンプレートコードが必須です。 "pack" in perlfunc を参照してください。
(S non_unicode) Unicode の最大である U+10FFFF を超えた符号位置です。
Perl は Unicode 符号位置のスーパーセットを含む文字列を受け入れます(最大値は システムで符号なし整数として保管可能な最大値です); しかし、これらは 他の言語やシステムでは受け入れないかも知れません。 同時に、一部の標準では 0x7FFF_FFFF までの符号位置は正当ですが、それ以上は そうではありません。 0xFFFF_FFFF より上の符号位置は 32 ビットワードより大きいものを要求します。
(A) スクリプトを perl ではなく csh またはその他のシェルで 実行しようとしました。 #! 行をチェックするか、スクリプトを直接 Perl で起動してください。 ファイルの先頭の #! 行は以下のようにします
#!/usr/bin/perl -w
(F) Perl は require
文で指定されたファイルをコンパイルできませんでした。 Perl は、コンパイルを直ちに停止させるほど厳しいエラーに遭遇しなかった ときに、この一般的なメッセージを使います。
(W regexp) 正規表現エンジンはバックトラックが要求される複雑な状況では 再帰を使用します。 再帰の深さは 32766、またはスタックを任意に増やせないアーキテクチャでは おそらくもっと小さい値に制限されています。 (「単純な」または「中くらいの」状況では再帰なしで扱われるので、制限は ありません。) 調べる文字列を短くしてみてください; 正規表現エンジンではなく (while
などの) Perl コードを使ってループするか、 あるいは正規表現をより単純にしたり、バックトラックが少なくなるように 書き換えてください。 (Mastering Regular Expressions の情報については perlfaq2 を 参照してください。)
(W closed) クローズされたソケットに connent を行なおうとしました。 socket() の呼び出し時に、返却値のチェックを忘れたのではありませんか。 "connect" in perlfunc を参照してください。
(F) 定数オーバーロード (overload 参照) を扱うために登録された サブルーチンや、カスタム文字名ハンドラ ("CUSTOM TRANSLATORS" in charnames 参照) が未定義値を返しました。
(F) パーサは、オーバーロード定数を定義しようとしたときに矛盾を発見しました。 おそらく対応する overload プラグマを読み込むのを忘れたのでは?
(F) (おそらく use constant
プラグマを使って宣言した) 定数値が デリファレンスされましたが、間違った型のリファレンスになりました。 このメッセージは想定されたリファレンスの型を示しています。 これは普通定数値をデリファレンスするときの文法エラーを示しています。 "Constant Functions" in perlsub と constant を参照してください。
(W redefine)(S) 以前にインライン化できる形であったサブルーチンを 再定義しました。 コメントと回避策については "Constant Functions" in perlsub を 参照してください。
(W misc)以前にインライン化できる形であったサブルーチンを 未定義化しました。 コメントと回避策については "Constant Functions" in perlsub を 参照してください。
(F) パーサは、オーバーロードされた定数を定義しようとしたときか、 \N{...}
エスケープで指定された文字名の検索中に矛盾を 発見しました。 おそらく対応する overload プラグマを読み込むのを忘れたのでは?
(F) "=" をオーバーロードしたメソッドはバグっています。 "Copy Constructor" in overload を参照してください。
(F) CORE::
名前空間のサブルーチンを &foo
文法またはリファレンス経由で 呼び出そうとしました。 このパッケージの一部のサブルーチンはまだこの方法では呼び出せず、裸の単語で 呼び出さなければなりません。 以下のようなものは動作します:
BEGIN { *shove = \&CORE::push; }
shove @array, 1,2,3; # pushes on to @array
(F) CORE:: 名前空間は Perl キーワードとして予約されています。
(P) これは Perl か、あるいは、使っているなら カスタム正規表現エンジン のエラーです。 後者でなければ、perlbug ユーティリティを使って問題を報告してください。
(P) 正規表現コンパイラが渡したもので、正規表現エンジンが 処理できなくなりました。
(P) 正規表現エンジンが、有効なマジックナンバーを持たない regexp プログラムを渡しました。
(P) Perl に付属の malloc ルーティンが内部エラーを起こしました。
(F) unpack のテンプレートとしてカウント長文字列を示していますが、 文字列の長さも明示的に指定しています。 "pack" in perlfunc を参照してください。
(W recursion) このサブルーチンは、(直接、間接に) 自分自身の呼び出しを、 return より 100 回多く行ないました。 変わったベンチマークプログラムを書いているのでなければ、無限再帰の 可能性があります; ベンチマークを書いている場合には、別のことを示しています。
この閾値は、C プリプロセッサマクロ PERL_SUB_DEPTH_WARN
を希望の値に 設定して perl バイナリを再コンパイルすることで、100 から変更できます。
(D deprecated) defined() は未定義の スカラ 値を調べるので、配列に使っても 普通は無意味です。 配列が空かどうかを調べたい場合は、例えば単に if (@array) { # not empty }
としてください。
(D deprecated) defined()
は普通はハッシュの右側ではないので、 5.004 から非推奨でした。
まだ使われていない普通のハッシュに対する defined %hash
は偽ですが、 いくつかの明白でない状況では新になります; これには反復し、弱い参照、 stash 名を含み、undef %hash
の後でも真になります。 これらにより、実践では defined %hash
はほとんど使えません。
空でないことをチェックしたいなら、単にこれを真偽値コンテキストに 置いてください ("Scalar values" in perldata を参照してください):
if (%hash) {
# not empty
}
パッケージ変数が存在するかどうかを調べるために defined %Foo::Bar::QUUX
のようなことをしていると、これは決して信頼性が なく、パッケージの機能や読み込まれているかどうかなどを問い合わせる 良い方法ではありません。
(F) 不正な形の (?(DEFINE)...|..)
のようなものを使いました。 このエラーの、もっともありそうな理由は、....
パートの中のかっこを そのままにしたことです。
<-- HERE で正規表現のどこに問題が発見されたかを示しています。
(F) "use Module 42" のようなことをしましたが、Module ファイルに パッケージ定義がないか、$VERSION
がありませんでした。
(F) インデックス/値配列スライス文法 (%array[...]
) を、delete
への 引数として使いました。 おそらく @ シンボルを使って @array[...]
としたかったのでしょう。
(F) キー/値ハッシュスライス文法 (%hash{...}
) を、delete
への 引数として使いました。 おそらく @ シンボルを使って @hash{...}
としたかったのでしょう。
(F) delete
の引数は以下のようにハッシュか配列の要素であるか:
$foo{$bar}
$ref->{"susie"}[12]
あるいは以下のようにハッシュか配列のスライスでなければなりません:
@foo[$bar, $baz, $xyzzy]
@{$ref->[12]}{"susie", "queue"}
(F) <<FOO
のようなヒアドキュメント構造で、ラベル FOO
が Perl が扱うには長すぎました。 このエラーを起こすようなコードを書くには相当ひねくれている必要があります。
(D deprecated) my $x if 0
のような定義を行いました。 これは、宣言に偽の条件を含んでいるとスコープから外れた際にレキシカル変数が クリアされないという、Perl に長い間存在したバグです。 ある種の静的変数を実現するためにこのバグを悪用する人々もいます。 私たちはこのバグを修正するつもりなので、人々がこの振る舞いに依存して ほしくありません。 関数外の別のブロックで変数を宣言することで似たような静的な効果を 達成できます; 例えば:
sub f { my $x if 0; return $x++ }
これは以下のようにします:
{ my $x; sub f { return $x++ } }
perl 5.10.0 から、一度だけ初期化されるレキシカルとして state
変数も 使えます (feature を参照してください):
sub f { state $x; return $x++ }
(F) DESTROY() メソッドが、DESTROY したばかりのオブジェクトへの 新しいリファレンスを作りました。 Perl は混乱して、不明瞭なリファレンスを作るよりは中断することを選びました。
"Server error" を参照してください。
(F) require (や use) されたファイルは、正常にコンパイルされ、 初期化コードを正しく実行したことを示すために、真を返さなければなりません。 こういったファイルは、"1;" で終わるようにするのが習慣ですが、 真となる値であれば、何でもかまいません。 "require" in perlfunc を参照してください。
(W misc) おそらく import したサブルーチン &FOO を $FOO として 参照したようなことでしょう。
(W misc) "our" 宣言されたグローバル変数を local 化しないことを 忘れないで下さい。 これをもう一度同じレキシカルスコープで宣言していますが、 不必要でしょう。
(W) おそらく $hash{$key} か @hash{@keys} としたいときに %hash{$key} と したのでしょう。 あるいは、単に %hash としたくてやりすぎたのでしょう。
(F) die() に空文字列を渡した(die ""
と等価です)か、引数なしで 呼び出して、$@
が空でした。
"Server error" を参照してください。
(F) "use Module 42" のようなことをしましたが、Module は $VERSION
を 定義していません。
(F) '/' の直後には繰り返し数を指定できません。 "pack" in perlfunc を参照してください。
(P) VMS 固有の perl 内部 I/O 関数である PerlIO_getname
がなぜか 他のプラットフォームで呼び出されました。 これは起きないはずです。
(P) マジカル変数の内部処理がおかしくなっています。
(P) これは、本来 safemalloc() で引っ掛かるはずのものです。
(S syntax) これは "%s found where operator expected" メッセージと共に 表示される教育的な推測です。 これはしばしばサブルーチンやモジュール名がまだ宣言される前に参照されている ことを意味します。 これはファイル内部での順番のためであったり、"sub", "package", "require", "use" 文がないためであったりします。 もしまだ定義されていないものを参照したい場合、現在位置より前に実際に サブルーチンやパッケージを定義する必要はありません。 空の "sub foo;" や "package FOO;" を「前方」宣言として使えます。
(W misc) 古いものである dump()
組み込み関数を、CORE::dump()
と いうように完全修飾せずに使いました。 おそらくこれはタイプミスです。 "dump" in perlfunc を参照してください。
(F) このマシンは dump/undump に対応していません。
(S malloc) 既に解放されているものに対して、内部ルーティンが free() を 行なおうとしました。
(W unpack) pack テンプレートで、一つの型の後に同じ修飾子を複数指定しました。 "pack" in perlfunc を参照してください。
(S experimental::autoderef) スカラ引数の each
は実験的で、将来の バージョンの Perl で変更されたり削除されたりするかもしれません。 この機能を使うリスクを取る場合は、単に警告を無効にして下さい:
no warnings "experimental::autoderef";
(S) Larry は "elseif" というのは醜いと考えたので、Perl にはこのキーワードは ありません。 このコードは引き続くブロックによって返されたクラスの "elseif" メソッドを 呼び出そうとしていると解釈されます。 これは望んでいることではないはずです。
(F) \p
と \P
は、perlunicode と perlre に記述されているように、 名前付き Unicode プロパティを導入するために使われます。 正規表現の中で、\p
や \P
をプロパティ名の指定なしに使いました。
(F) use filetest
プラグマを使っている間に、 実と実効の UID や GID の切り替えに失敗しました。
(F) 汚染モードで動作していて、%ENV
変数が他のハッシュへのエイリアスに なっているので、これ以上プログラムの環境の状態を反映しません。 これは潜在的にはセキュアではありません。
(F) VMS に固有のエラーです。 Perl はファイル仕様を VMS 式か Unix 式かどちらかで扱わなければならないので、 直接操作しなければならない場合は変換します。 不正なファイル仕様を Perl に渡したか、変換ルーチンが扱えないパターンを 発見したかです。 ちぇっ。
(D deprecated) 空白を無視するための /x
付きで正規表現をコンパイルし、 Perl が最終的に空白として扱う計画の文字の一つをリテラルとして使いました。 文字は何らかの方法でエスケープされなければならず、これを空白として扱う 将来の Perl では違った動作をします。 最も簡単な方法は直前に逆スラッシュは挿入するか、大かっこで囲むことです。 この変更は Perl を Unicode の勧告に準拠するようにするためのものです。 次の 5 文字がこの警告を発生させます: U+0085 NEXT LINE, U+200E LEFT-TO-RIGHT MARK, U+200F RIGHT-TO-LEFT MARK, U+2028 LINE SEPARATOR, U+2029 PARAGRAPH SEPARATOR。
(?{ ... })
ゼロ幅アサーションを含む正規表現をコンパイルしようと したときに、Perl は汚染されたデータを検出しました; これは安全ではありません。 "(?{ code })" in perlre と perlsec を参照してください。
(F) Perl が実行時に、変数展開された値を含んでいて、 (?{ ... })
ゼロ幅アサーションを含む正規表現をコンパイルしようとしました。 これはセキュリティ上の危険があるので、許可されていません。 どうしても実行したい場合は、re 'eval'
プラグマを使うか実行時に 変数展開された文字列からパターンを作成して、それを eval() の中で使うことで 実行できます。 "(?{ code })" in perlre を参照してください。
(F) 正規表現に (?{ ... })
ゼロ幅アサーションを含んでいますが、 この構造は use re 'eval'
プラグマが有効の場合にのみ許可されます。 "(?{ code })" in perlre を参照してください。
(F) テキストを一切読み込むことなく、EVAL 呼び出しのネストが多すぎる パターンを使いました。 テキストを読み込むようにパターンを再構築してください。
<-- HERE で正規表現のどこに問題が発見されたかを示しています。
(F) <> 演算子の内容は Perl 識別子の最大サイズを越えることはできません。 単にファイル名の長いリストをグロブしようとしただけなら、glob() 演算子を 使うか、ファイル名を変数に入れて、それをグロブしてください。
(F) exec
関数は Symbian OS のような一部のシステムには実装されていません。 perlport を参照してください。
(F) Perl のコンパイルが失敗したときの、最後のまとめメッセージです。
(F) exists
の引数は以下のように、ハッシュや配列の要素か、 アンパサンド付きのサブルーチンでなければなりません:
$foo{$bar}
$ref->{"susie"}[12]
&do_something
(F) exists &sub
での exists
への引数はサブルーチン名でなければならず、 サブルーチン呼び出しではありません。 exists &sub()
はこのエラーを生成します。
(W exiting) goto やループ制御文など、おかしな方法で eval を抜けました。
(W exiting) goto やループ制御文といった、異例な形でフォーマットを 終了しました。
(W exiting) (ソートブロックやサブルーチンのような) 特別なブロック構造を、 goto やループ制御文といった異例な方法で終了しました。 "sort" in perlfunc を参照してください。
(W exiting) goto やループ制御文など、おかしな方法でサブルーチンを 抜けました。
(W exit) return や goto やループ制御文など、おかしな方法で置換を 抜けました。
(F) 以下のようなものを書きました
(?13
to denote a capturing group of the form (?PARNO)
形式の 捕捉グループを示していますが ")"
が省略されています。
(F) (?[...])
拡張文字クラス正規表現構文には、(\d
のような 文字クラスエスケープを含む) 文字クラス、演算子、かっこのみが許されます。 一つの例外は正確に一つだけのフラグと一つだけの (?[...])
を含む (?flags:...)
です。 これにより (?[...])
だけを含む正規表現を変数展開できるようになります。 このエラーメッセージが表示された時は、おそらく文字クラスの中に他の (?...)
構文が含まれています。 "Extended Bracketed Character Classes" in perlrecharclass を参照してください。
(F) サブルーチンシグネチャを使うためには、まずそれを有効にしなければなりません:
no warnings "experimental::signatures";
use feature "signatures";
sub foo ($left, $right) { ... }
(F) レキシカルサブルーチンを使うためには、まずそれを有効にしなければなりません:
no warnings 'experimental::lexical_subs';
use feature 'lexical_subs';
my sub foo { ... }
(W misc) リファレンスを長さゼロの文字列に bless しました。 これはリファレンスをパッケージ main に bless する効果があります。 これは普通あなたが望んでいることではありません。 (bless($ref, $p || 'MyPackage'); のように) デフォルトターゲット パッケージを提供することを考慮してください;
(A) スクリプトを perl ではなく csh で実行しようとしました。 #! 行をチェックするか、スクリプトを直接 Perl で起動してください。
(F) UNITCHECK, CHECK, INIT, END サブルーチンを実行中にトラップされていない 例外が発生しました。 このようなルーチンのキューの残りの処理は途中で終了しました。
(W regexp)(F) 文字クラス範囲の先頭とと末尾は、\d
や [:alpha:]
のような 他の文字クラスではなく、リテラル文字でなければなりません。 間違った範囲の "-" はリテラルの "-" と解釈されます。 (?[...])
構文では、これは警告ではなくエラーです。 "-" を "\-" とクォートすることを考慮してください。 <-- HERE で正規表現のどこに問題が発見されたかを示しています。 perlre を参照してください。
(P) VMS に固有のエラーです。 何か都合の悪いことが VMS システムサービスか RTL ルーチンで起こりました; Perl の終了コードに詳細が示されています。 "at %s" のファイル名と "line %d" の行番号は、問題の起こった Perl ソースコードの位置を示しています。
(F) このマシンでは、fcntl() が実装されていないように見えます。 PDP-11 か何かでしょうか。
(F) tie された配列に対して負の番号の要素を要求されました; これは不可能です。
(W pack) uuencode された文字列の各行が、63 以上にエンコードできない 長さ識別子から始まっています。 それで、これより長い行の長さを問い合わせるところがありません。 Perl はフォーマットとして u63
が指定されたかのように振る舞います。
(W io) リードオンリーのファイルハンドルに対して、書込みを行なおうとしました。 読み書き両用ファイルハンドルにしたいのであれば、"<" を付けたり、 何も付けなかったりするのではなく、"+<" や "+>" や "+>>" を付けて open する必要があります。 ライトオンリーであれば、">" や ">>" を使ってください。 "open" in perlfunc を参照してください。
(W io) 書き込み専用のファイルハンドルから読み込もうとしました; 読み書きできるファイルハンドルにしたい場合は、ファイルのオープン時に ">" ではなく、"+<" か "+>" か "+>>" をつける必要があります。 読み込み専用にしたい場合は、"<" を使ってください。 "open" in perlfunc を参照してください。 他の可能性としては、ファイル記述子 0 (STDIN としても知られています) を 出力用に開こうとした場合(おそらくその前に STDIN を閉じたのでは?)です。
(W io) STDOUT または STDERR として使われていたのと同じファイルハンドル ID の ファイルハンドルを読み込み用に開こうとしました。 これは、以前 STDOUT または STDERR を閉じたときに起きます。
(W io) STDIN として使われていたのと同じファイルハンドル ID の ファイルハンドルを書き込み用に開こうとしました。 これは、以前 STDIN を閉じたときに起きます。
(F) 文字列の最後の $ が、リテラルのドル記号なのか、変数名を入れようとして 忘れたのかを、はっきりさせなければなりません。 バックスラッシュを付けるか、名前を入れてください。
(W closed) flock() しようとしたファイルハンドルはその前に既に 閉じられています。 制御フローをチェックしてください。 flock() はファイルハンドルを操作します。 同じ名前のディレクトリハンドルに flock() しようとしていませんか?
(F) フォーマットは、単独のドットだけからなる行で終わらなければなりません。 そのような行が見つからないまま、スクリプトの最後に行き当たってしまいました。
(W redefine) フォーマットを再定義しました。 この警告を止めるには以下のようにしてください:
{
no warnings 'redefine';
eval "format NAME =...";
}
(W) 以下のようにしています:
if ($foo = 123)
以下のようにすべきです:
if ($foo == 123)
(あるいは似たようなこと)。
(S syntax) Perl の字句解析部は、次に項が来るか、演算子が来るかを 知っています。 次に演算子が来ると思っているときに、項であるとわかるものが現れると、 この警告が出ることになります。 通常、演算子かセミコロンのような区切り文字が省略されたことをしめします。
(S) GDBM_File 拡張モジュールが、値の設定に失敗したという警告です。
(F) C ライブラリに gethostent() が実装されていないようです; おそらく、実装すると Internet 上のすべてのホスト名を 返さなければいけないと思っているのでしょう。
(W closed) 閉じたソケットに対してソケットやピアソケット名を取得しようと しました。 socket() の呼び出し時に、返却値のチェックを忘れたのではありませんか?
(S) VMS に固有の警告です。 getpwnam
演算子の基礎となる sys$getuai
呼び出しで 不正な UIC が返されました。
(W clockd) クローズされたソケットのソケットオプションを取得しようとしました。 socket() の呼び出し時に、返却値のチェックを忘れたのではありませんか。 "getsockopt" in perlfunc を参照してください。
(S experimental::smartmatch) given
はスマートマッチングのに依存していて、 これは実験的なので、その振る舞いは将来のリリースの perl で変更されたり 削除されたりするかもしれません。 "Experimental Details on given and when" in perlsyn の説明を参照してください。
(F) "use strict" か "use strict vars" が指定されていますので、すべての変数は ("my" か "state" を使った) レキシカルスコープの変数か、"our" を使って事前に 宣言するか、グローバル変数がどのパッケージのものかを ("::" を使って)、 明示的に修飾しなくてはなりません。
(S glob) glob
や <*.c>
のために使われる外部プログラムに何か問題が 発生しました。 通常、これは外部プログラムが失敗して非 0 のステータスで終了するような glob
パターンが渡されたことを意味します。 このメッセージがコアダンプを引きおこした異常終了を示している場合、 csh (C シェル) が壊れていることを意味しているかもしれません。 もしそうなら、config.sh の全ての csh 関連の変数を変更するべきです: もし tcsh があるなら、(full_csh='/usr/bin/tcsh'
のように) tcsh を 参照するように変数を設定します; さもなければ、関連する全ての変数を空にする(例外として d_csh
は 'undef'
に設定するべきです)ことで、Perl は csh がないものと考えます。 どちらの場合でも、config.sh を修正した後、./Configure -S
を実行して Perl を再ビルドしてください。
(F) 項が必要とされるところで、開き山かっこが見つけたため、 対応する閉じ山かっこを探しましたが、見つかりませんでした。 可能性としては、必要なかっこを省いてしまい、本当は、「小なり記号」を 表したかった場合が考えられます。
(W overflow) 扱えない数値で gmtime
を呼び出しました: 大きすぎたり 小さすぎたり NaN だったりです。 返り値は undef
です。
(W overflow) 確実に扱えるよりも大きい数値の引数で gmtime
を呼び出して、 おそらく間違った日付が返されました。 この警告は、NaN (特殊な非数) でも引き起こされます。
(W overflow) 確実に扱えるよりも大きい数値の引数で gmtime
を呼び出して、 おそらく間違った日付が返されました。
(P) OS/2 に固有のエラーです。 もっともありそうなのは廃止されたバージョンの Perl を使っていることで、 どちらにしてもこのエラーは起きないはずです。
(F) "next" や "last" とは違って、goto には必ず、飛び先を 指定しなくてはなりません。 "goto" in perlfunc を参照してください。
(F) goto &sub
文法でサブルーチンを呼び出そうとしましたが、示された サブルーチンは定義されていないか、定義されていましたが未定義化されました。
(F) グループ名は perl 識別子の規則に従う必要があり、非数値単語文字で 始まらなければなりません。 このエラーのよくある原因は (?0) ではなく (?&0) を使うことです。 perlre を参照してください。
(F) () グループが繰り返し数で始まっています。 繰り返し数は、テンプレート文字か () グループの後に続くことを想定しています。 "pack" in perlfunc を参照してください。
(F) perl -c
が失敗したときの最終まとめメッセージです。
(S internal) あるルーティンが、既に存在しているはずのシンボルを、 シンボルテーブルで探しましたが、何らかの理由で存在せず、 コアダンプを避けるために、緊急に生成しました。
(D deprecated) 本当に古い Perl では、ハッシュ名の % を省略できる場所が ありました。 これは廃止予定です。
(F) 構文解析部が、プログラム中に 10 個のエラーを見つけたため、 それ以上の解析を諦めました。 それ以上のエラーメッセージは、おそらく意味がないでしょう。
(W portable) 指定した 16 進数が 2**32-1 (4294967295) より大きいので、 システム間で移植性がありません。 移植性に関するさらなる考察については perlport を参照してください。
(F) Perl は識別子(変数名や関数名など)について、単純な名前については およそ 250 文字に、($A::B
のような)複合名についてはもう少し長い長さに 制限しています。 この Perl の制限を越えました。 将来のバージョンの Perl ではこれらの恣意的な制限はなくなるでしょう。
(W regexp) 名前付き Unicode 文字エスケープ (\N{...})
が長さ 0 の シーケンスを返しました。 文字クラスでこのようなエスケープが使われた場合、振る舞いは未定義です。 正しいエスケープを使っているか、および正しい文字名ハンドラがスコープ内に あるかをチェックしてください。
(F) 2 進数として 0 と 1 以外の数値を使っています。
(W digit) 2 進数として 0 と 1 以外の数値を使おうとしたのでしょう。 2 進数の解釈は問題のある数値の手前で停止しました。
(W illegalproto) プロトタイプ宣言に無効な文字が見つかりました。 プロトタイプの中の '_' は、残りの引数がオプションであることを示すために ';' が引き続くか、'@' か '%' の一つでなければなりません; これら二つは 0 以上の末尾の引数を受け付けるからです。
(F) Perl は普通プログラムテキスト中の復帰文字をその他の空白と同様に 扱いますので、Perl を標準のオプションでビルドした場合はこのエラーを 見ることは決してないはずです。 どういうわけか、お使いの Perl はこの機能なしでビルドされているようです。 Perl の管理者に問い合わせてください。
(W illegalproto) プロトタイプ宣言に無効な文字が見つかりました。 プロトタイプでの有効な文字は、$, @, %, *, ;, [, ], &, \, + です。 おそらくサブルーチンシグネチャを書こうとしたけれども、先にこの機能を有効に していなかった (use feature 'signatures'
) ので、シグネチャが間違った プロトタイプとして解釈されたのでしょう。
(F) 無名サブルーチンを作るために sub
を使ったときは、 常にコードのブロックを指定しなければなりません。 perlsub を参照してください。
(F) サブルーチンが正しく宣言されていません。 perlsub を参照してください。
(F) ゼロで割り算をしようとしました。 ロジックの誤りか、意味の無い入力を防ぐために、条件を付けることが 必要かのどちらかでしょう。
(W digit) 16 進数として 0 - 9, A - F, a - f 以外の文字を使おうとしました。 16 進数の解釈は不正な文字の手前で停止しました。
(F) 余りを求めるのに、ゼロで割り算をしようとしました。 これは、ほとんどの数体系で受け入れられません。
(F) vec() のビット数 (第三引数) は 1 から 32 (プラットフォームが 対応している場合は 64) までの、2 のべき乗でなければなりません。
(F) 8 進数で 8 か 9 を使いました。
(W digit) 8 進数で 8 か 9 を使おうとしたのでしょう。 8 進数の解釈は 8 か 9 の手前で停止しました。
(F) 以下のようなものを書きました
(?+foo)
"+"
は捕捉グループを示すために数値が引き続く場合にのみ正当です。 (?PARNO)
を 参照してください。
(X) PERL5OPT 環境変数で設定できるのは -[CDIMUdmtw] のオプションだけです。
(W internal) VMS に固有の警告です。 Perl は CRTL の内部環境配列を読み込もうとしましたが、キーを値と 分離するために使われている =
デリミタのない要素に遭遇しました。 この要素は無視しました。
(W internal) VMS に固有の警告です。 Perl は %ENV を反復する準備したときに論理名や CLI シンボル定義を 読み込もうとしましたが、キーと値の間のデリミタが見つからなかったので、 その行は無視しました。
(W misc) この接頭辞は普通、示されている例外が DESTROY() メソッドで 発生したことを示しています。 デストラクタは普通実行中の任意の時点で呼び出され、しばしば大量に 呼び出されるので、この警告は同じメッセージが繰り返されないように、 何回失敗しても一度だけ発生します。
G_KEEPERR
フラグを使って発行(dispatch)したユーザーコールバックに失敗した 場合にもこの警告が出ることがあります。 "G_KEEPERR" in perlcall を参照してください。
(F) これは (?[ ])
の中の文法エラーです。 これは、この構文の中の式が完全に空か、演算子の数に対してオペランドが多すぎたり 少なすぎたりする場合に起こります。 Perl は、何が悪いのかをより正確に示せるほど賢くはありませんでした。
(F) 与えられたクラスのメソッド解決順序 (MRO) が C3 に矛盾していますが、 このクラスの C3 MRO を有効にしました。 さらなる情報については mro 内の C3 に関する文書を参照してください。
(F) EBCDIC 特有のエラーです。 内部的に、v 文字列は Unicode 文字ポイントとして保管されていて、 EBCDIC では UTF-EBCDIC でとしてエンコードされています。 UTF-EBCDIC エンコーディングでは、コードポイントは 2147483647 (0x7FFFFFFF) 以下に制限されます。
(F) 入力テキストを読み込むことなく自分自身を参照するパターンを使いました。 再帰的なパターンが、テキストを読み込むか失敗するかを確実に行うように、 パターンをチェックするべきです。
(F) 現在のところ、"state" の実装は、スカラコンテキストでのスカラ変数の 初期化のみが許されています。 state ($a) = 42
を state $a = 42
のように、リストコンテキストから スカラコンテキストに書き換えてください。 state (@a) = foo()
のような構文は perl の将来のリリースで 対応されるでしょう。
(W syntax) スカラコンテキストで、配列の単一の要素を選択するために (% で示される)配列インデックス/値スライスを使いました。 一般的には($ で示される)スカラ値を取得した方がよいです。 違いは、$foo[&bar]
は返り値と引数を評価したときの両方で常にスカラのように 振る舞いますが、%foo[&bar]
は添え字にリストコンテキストを提供するので、 一つだけの添え字を想定していた場合、おかしなことになることがあります。 リストコンテキストで呼び出された場合、値に加えてインデックス (&bar
が返すもの) を返します。
(W syntax) スカラコンテキストで、ハッシュの単一の要素を選択するために (% で示される)ハッシュキー/値スライスを使いました。 一般的には($ で示される)スカラ値を取得した方がよいです。 違いは、$foo[&bar]
は返り値と引数を評価したときの両方で常にスカラのように 振る舞いますが、%foo[&bar]
は添え字にリストコンテキストを提供するので、 一つだけの添え字を想定していた場合、おかしなことになることがあります。 リストコンテキストで呼び出された場合、値に加えてインデックスを返します。
(F) 何か汚染チェックの機構が、望ましくないと判断することを 行なおうとしました。 setuid や setgid を実行したときや、明示的に -T で指定したときに、 汚染チェック機構が働きます。 汚染チェック機構は、信頼がおけないと仮定されるユーザが直接、間接を問わず、 指定したデータに印を付けます。 そのようなデータを「危険な」操作に用いると、このエラーが発生します。 詳しくは、perlsec を参照してください。
(F) $ENV{PATH}
の中に、誰にでも書き込みができるディレクトリが 含まれているとき、system()、exec()、パイプのオープンを 行なうことはできません。 また、PATH には相対早退ディレクトリを含んでいてはいけません。 perlsec を参照してください。
(F) $ENV{PATH}
, $ENV{IFS}
, $ENV{CDPATH}
, $ENV{ENV}
, $ENV{BASH_ENV}
, $ENV{TERM}
のいずれかがユーザーによって提供された (あるいは提供された可能性のある)データの場合、setuid や setgid された スクリプトでは system(), exec(), パイプされる open を 使うことはできません。 スクリプトはパスとして、信頼の置けるデータを使った、既知の値を セットしなければなりません。 perlsec を参照してください。
(F) Perl は、ユーザー定義文字特性関数 (\p{IsFoo}
や \p{InFoo}
) の 呼び出しを含む正規表現をコンパイルしようとしたときに汚染されたデータを 検出しました。 "User-Defined Character Properties" in perlunicode と perlsec を 参照してください。
(D regexp, deprecated) 正規表現中のこのコンテキストでの 2 文字並び "(?"
は分割できないトークンで、 "("
と "?"
の間には何も入らないはずですが、これを分割しました。 実装上の偶然により、この禁止事項は強制されていませんでしたが、将来の Perl バージョンでは禁止する計画です。 このメッセージは、この補注中の変更を警告するためのものです。
(F) printf()
や sprintf()
のフォーマット文字列で指定されたインデックスや 幅が大きすぎます。 数値はあなたのアーキテクチャの整数のサイズをオーバーフローしないように しなければなりません。
(S overflow) リテラルまたは hex() や oct() の引数として指定された 16 進、 8 進、2 進数は実行しているアーキテクチャには大きすぎるので、浮動小数点数に 変換されました。 32 ビットアーキテクチャでは、オーバーフローせずに表現できる 16 進、8 進 2 進数はそれぞれ 0xFFFFFFFF, 037777777777, 0b11111111111111111111111111111111 です。 Perl は全ての数値を内部では浮動小数点表現に透過的に変換することに 注意してください -- 引き続く操作によって精度が失われることがあります。
(S overflow) srand に渡した数値は、現在のアーキテクチャの整数表現に 適合させるには大きすぎます。 数値は対応している最大の整数(32 ビットアーキテクチャでは 0xFFFFFFFF) に 置き換えられました。 これは、最大数よりも大きな異なった乱数の種が同じ乱数の並びを返すので、 想定しているよりもランダム性が低くなることを意味します。
(W overflow) バージョン初期化の一部が、アーキテクチャの整数のサイズより 大きすぎます。 バージョンとして典型的には 2**32 を超える要素を使おうとするための合理的な 理由がないので、これは警告ではありません。 これは普通、100/9 のようなおかしな数値演算をバージョンとして 使おうとしたことによります。
(P) 正規表現解析部に何か悪いことが起こりました。 <-- HERE で正規表現のどこに問題が発見されたかを示しています。
(S) VMS に固有の警告です。 Perl は fork
と exec
を呼び出した回数を数えています; これは現在の exec
呼び出しが現在のスクリプトかサブプロセスかどちらに 影響を与えるかを決定するためです("exec LIST" in perlvms を 参照してください)。 どういうわけか、このカウントがおかしくなったので、Perl はこの exec
が Perl スクリプトを終了させて指定されたコマンドを実行する要求であると 仮定して、そのように扱いました。
(S internal) printf
と sprintf
のフォーマットを扱う Perl の 内部ルーチンは、C や XS コードから呼び出されたときは少し違う規則集合に 従います。 特に、数値に引き続いて "p" のあるフォーマット (例えば "%7p") は将来の 使用のために予約されています。 このメッセージが表示された場合、XS モジュールはこのような予約された フォーマットを使って呼び出そうとしました。
(P) 正規表現解析部に何か間違ったことが起こりました。 <-- HERE で正規表現のどこに問題が発見されたかを示しています。
(W syntax) リスト演算子の直後にかっこを置くと、かっこ内にある リスト演算子引数を持つ関数になる、という規則が適用されました。 "Terms and List Operators (Leftward)" in perlop を参照してください。
(F) 示されたサブルーチンや変数の属性は Perl やユーザー提供のハンドラで 認識されませんでした。 attributes を参照してください。
(F) 示されたサブルーチンや変数の属性は Perl やユーザー提供のハンドラで 認識されませんでした。 attributes を参照してください。
(F) use charnames
の :alias
オプションで文字名へのカスタム別名を 作ろうとしましたが、指定された名前のうち示された文字は正当ではありません。 "CUSTOM ALIASES" in charnames を参照してください。
(W syscalls) パス名やその他のシステムコール引数に埋め込まれた \0 文字は 5.20 から警告を出力するようになりました。 以前は \0 の後の部分はシステムコールによって無視されていました。
(F) 文字名としては一部の文字のみが正当です。 示されたものは違います。 "CUSTOM ALIASES" in charnames を参照してください。
(W printf) Perl は指定されたフォーマット変換が認識できませんでした。 "sprintf" in perlfunc を参照してください。
(W regexp)(F) (例えば \xHH
のような)数値エスケープの 256 より小さい値が、 エンコーディングプラグマで指定した変換によって 一つの文字に対応していません。 エスケープは代わりに REPLACEMENT CHARACTER (U+FFFD) に置き換えられます; ただし、(?[ ])
の内側の場合は致命的エラーになります。 <-- HERE で正規表現のどこにエスケープが発見されたかを示しています。
(F) ...
で表現された文字定数は妥当な 16 進数ではありません。 空か、16 進数の中に 0 - 9, A - F, a - f 以外の文字を使おうとしました。
(F) perl の -m と -M のコマンドラインオプションでのモジュール引数は、 モジュール名では単一のコロンを含むことが出来ず、"=" の後でのみ含むことが できます。 言い換えると、-MFoo::Bar=:baz は OK ですが、-MFoo:Bar=baz は そうではありません。
(F) mro::set_mro("classname", "foo")
または use mro 'foo'
を使おうと しましたが、foo
は有効なメソッド解決順序 (MRO) ではありません。 現在のところ、MRO プラグインモジュールを読み込まない限り、対応として 有効なものは dfs
と c3
だけです。 mro と perlmroapi を参照してください。
(W utf8) chr
に負数を渡しました。 負数は正当な文字番号ではないので、Unicode 代替文字 (U+FFFD) を返します。
(F) Perl は不正なデバッガフラグで呼び出されました。 受け付けられる値の一覧を見るには、フラグなしの -D オプションをつけて perl を呼び出してください。 "-Dletters" in perlrun も参照してください。
(F) 文字クラスに指定した範囲の最小値が、最大値よりも大きくなっています。 ひとつの可能性としては、末尾の \x{}
から {}
を 忘れているということです - 中かっこなしの \x
は ff
までにしか なりません。 <-- HERE で正規表現のどこに問題が発見されたかを示しています。 perlre を参照してください。
(F) tr/// や y/// の演算子での範囲指定で、最大の文字より最小の文字の方が 大きいです。 perlop を参照してください。
(F) 属性リストの要素の間にコロンと空白以外のものがあります。 直前の属性がかっこ付きのパラメータリストの場合、おそらくリストが 予定より早く終端されています。 attributes を参照してください。
(W layer) 層を Perl I/O システムに押し込むときに、層リストの要素の間に コロンと空白以外のものがありました。 直前の属性がかっこ付きのパラメータリストの場合、おそらくリストが 予定より早く終端されています。
(F) バージョン番号がバージョンの「厳密な」基準に一致しませんでした。 「厳密な」バージョン番号は、指数なしの正の 10 進数 (整数または 10 進小数)か、 さもなければどっと付き 10 進 v-文字列で先頭に 'v' の文字があり、少なくとも 三つの部分からなるものです。 かっこで囲まれたテキストは問題の基準を示しています。 許されるバージョンオブジェクトに関するさらなる詳細については version モジュールを参照してください。
(F) 与えられた文字は有効な pack や unpack の型ではありません。 "pack" in perlfunc を参照してください。
(W) 与えられた文字は有効な pack や unpack の型ではありませんが、暗黙に 無視されました。
(F) バージョン番号がバージョンの「緩い」基準に一致しませんでした。 「緩い」バージョン番号は指数なしの正の 10 進数(整数または 10 進小数)か、 あるいはどっと付き 10 進 v-文字列です。 v-文字列の要素が三つ未満の場合、先頭に 'v' 文字が必要です。 さもなければ、先頭の 'v' はオプションです。 10 進とドット付き 10 進の両方のバージョンは、小数またはドット付き 10 進 要素の後に下線で区切られた「α」要素が引き続くこともあります。 かっこで囲まれたテキストは問題の基準を示しています。 許されるバージョンオブジェクトに関するさらなる詳細については version モジュールを参照してください。
(F) バージョンオブジェクトの内部構造が不正です。 おそらく何らかの方法で内部が直接変更されたか、任意のリファレンスが "version" クラスとして bless されました。
(D regexp, deprecated) 正規表現中のこのコンテキストでの 2 文字並び "(*"
は分割できないトークンで、 "("
と "*"
の間には何も入らないはずですが、これを分割しました。 実装上の偶然により、この禁止事項は強制されていませんでしたが、将来の Perl バージョンでは禁止する計画です。 このメッセージは、この補注中の変更を警告するためのものです。
(F) C をサポートしているマシンではおかしなことだと思いますが、 このマシンでは ioctl() が実装されていないようです。
(W unopened) 開いていないファイルハンドルに ioctl() を使おうとしました。 制御フローと引数の数をチェックしてください。
(F) この Perl は PerlIO を使うように設定されていないので、IO 層は使えません。 PerlIO を使うには、'useperlio' 付きで設定する必要があります。
(F) 実行されているマシンでは、システムコールでも ioctl コール(SIOCATMARK) でも sockatmark() 機能が実装されていません。
(D deprecated, syntax) より古い perl で廃止予定とされた特殊変数 $*
は 5.10.0 で削除され、もはや対応していません。 以前のバージョンの perl では、$*
は文字列中の複数行マッチングを有効または 無効にするために使っていました。
$*
を使う代わりに、/m
(とおそらく /s
) 正規表現修飾子を 使うべきです。 use re '/m'
でレキシカルスコープで (ファイル全体でも) /m
を 有効にできます。 (より古いバージョンでは: $*
を真の値に設定すると全ての正規表現は /m
を使って書かれたかのように振る舞っていました。)
(D deprecated, syntax) より古い perl で廃止予定とされた特殊変数 $#
は 5.10.0 で削除され、もはや対応していません。 代わりに printf/sprintf 関数を使うべきです。
(W overload) overload::constant の 2 番目 (4 番目、6 番目, ...) の引数は コードリファレンスである必要があります。 無名サブルーチンか、サブルーチンへのリファレンスです。
(W overload) オーバーロードパッケージが知らない定数型を オーバーロードしようとしました。
(S inplace) The -i
オプションがコマンドラインで渡されました; これは スクリプトがファイルをその場で編集することを示していますが、ファイルが 指定されませんでした。 これは普通はミスです; STDIN をその場で編集するというのは無意味ですし、 本当に単に STDIN から読み込もうとしているだけのときに perl が ハングしているように見えることがあるので混乱を引き起こします。 編集するファイル名を指定するか、コマンドラインから -i
を 取り除いてください。 さらなる詳細については perlrun を参照してください。
(P) 正規表現の構文解析ができなくなりました。
(S experimental::autoderef) スカラ引数の keys
は実験的で、将来の バージョンの Perl で変更されたり削除されたりするかもしれません。 この機能を使うリスクを取る場合は、単に警告を無効にして下さい:
no warnings "experimental::autoderef";
(F) 脱出するループを指定しましたが、その名前のループの中にいません、 たとえ、呼び出された場所がそうであっても、今はそうではありません。 "last" in perlfunc を参照してください。
(F) 次の繰り返しを行なうループを指定しましたが、その名前のループの中に いません; たとえ、呼び出された場所がそうであっても、今はそうではありません。 "last" in perlfunc を参照してください。
(F) 繰り返しの再実行を行なうループを指定しましたが、その名前のループの中に いません; たとえ、呼び出された場所がそうであっても、今はそうではありません。 "last" in perlfunc を参照してください。
(F) use filetest
プラグマを使っている間に、 実と実効の UID や GID の切り替えに失敗しました。
(F) unpack する間、さらなるデータを取り出すために長さ/コードの組み合わせを unpack するときに文字列バッファが既に使い切っていました。 これにより、長さが未定義値となります。 "pack" in perlfunc を参照してください。
(W syntax) おそらくアイテムの数を知りたいときに配列やハッシュに対して length() を使いました。
配列の大きさは以下のようにして得られます:
scalar(@array);
ハッシュの要素数は以下のようにして得られます:
scalar(keys %hash);
(F) エクステンションが(lex_stuff_pvn や 同様なものを使って)現在のパースにテキストを挿入しようとしましたが、 現在の入力の一部となることができない文字を挿入しようとしました。 これは詰め物機構の生来の落とし穴で、これを避けるための理由の一つです。 詰め物が必要なところでは、プレーン ASCII のみを詰めることを推奨します。
(F) エクステンションによって供給された文法解析コードが、検出できる方法で 文法解析器の API に違反しています。
(W closed) クローズされたソケットに listen を行なおうとしました。 socket() の呼び出し時に、返却値のチェックを忘れたのではありませんか。 "listen" in perlfunc を参照してください。
(F) 一部のプラットフォーム、特に Windows では、 open($pipe, '|-', @args)
のような、3 以上の引数の形式の open
ではパイプに対応していません。 代わりに 2 引数 open($pipe, '|prog arg1 arg2...')
形式を使ってください。
(W overflow) 扱えない数値で localtime
を呼び出しました: 大きすぎたり 小さすぎたり NaN だったりです。 返り値は undef
です。
(W overflow) 信頼して扱えるよりも大きな数値で localtime
を呼び出したので localtime
はおそらく間違った日付を返します。 この警告は、NaN (特殊な非数) でも引き起こされます。
(W overflow) 信頼して扱えるよりも小さな数値で localtime
を呼び出したので localtime
はおそらく間違った日付を返します。
(F) 現在のところ前方参照が扱える文字列の長さには制限があります。 この制限は将来のリリースでは緩和されるでしょう。
(W imprecision) インクリメントまたはデクリメントしようとしている値は、 基礎となっている浮動小数点数表現にとって正確に保管するには大きすぎるので、 ++
や --
のターゲットは変更されません。 Perl は既に値が整数として大きすぎる時には整数から浮動小数点数に 切り替えていて、浮動小数点数でも不十分なときにこの警告を出力します。 明示的に Math::BigInt を使うように切り替えたいかもしれません。
(W io) ファイルハンドルに lstat を実行しようとしました。 これで何をしようとしたのですか? lstat() はファイル名に対してのみ意味があります。 (Perl はファイルハンドルには代わりに fstat() を行いました。)
(W misc) attributes.pm ではこれは許されていますが、既に 定義されている Perl サブルーチンに対して左辺値属性をオンまたはオフにするのは 常に適切に動作するわけではありません。 あなたの望むことが行われるかもしれませんし行われないかもしれません; サブルーチンの内側にどんなコードがあるかに依存し、正確な詳細は Perl バージョン間で変更されることがあります。 自分が何をしているのかが本当に分かっているときにだけこれを行ってください。
(W misc) サブルーチンが定義された後、Perl サブルーチンを左辺値サブルーチンに するために :lvalue
宣言文を使うことはできません。 サブルーチンを左辺値サブルーチンにするには定義時に左辺値属性を追加するか、 定義する前に sub foo :lvalue;
宣言を行います。
attributes.pm も参照してください。
(F) マジカルな配列をスタッシュ要素に代入し、それから同じスロットから サブルーチンを使おうとしました。 Perl のバージョンによって詳細が変わるかも知れないような、してはいけないことを Perl にさせようとしました。
(F) 中かっこで数値繰り返し数を囲む場合、数値のみが許されます。 "pack" in perlfunc を参照してください。
(F) 中かっこで数値繰り返し数を囲む場合、数値のみが許されます。 "pack" in perlfunc を参照してください。
(F) OS/2 固有のエラーです。 PERLLIB_PREFIX は以下のような形か:
prefix1;prefix2
または prefix1 prefix2
prefix1 と prefix2 が空でない形である必要があります。 prefix1
が組み込みライブラリ検索パスのプレフィックスなら、 prefix2 は置き換えられます。 このエラーは、コンポーネントが見つからないか、長すぎる時に起こります。 perlos2 の "PERLLIB_PREFIX" を参照してください。
(F) 不正な形式のプロトタイプをもつ関数を使おうとしました。 関数プロトタイプの構文は、不正な文字のようなありふれたエラーについては コンパイル時にチェックされます。 より厳密なチェックは、関数が呼び出された時に実行されます。 おそらく関数の作者はサブルーチンシグネチャを書こうとしたけれども、 先にこの機能を有効にしなかった (use feature 'signatures'
) ので、 シグネチャは間違ったプロトタイプとして解釈されました。
(S utf8)(F) Perl が、UTF8 フラグがオンにも関わらず UTF-8 エンコーディング ルールに従わない文字列を検出しました。
原因の可能性の一つは、UTF-8 だと思っていたけれでもそうではなかったデータ (例えばレガシーな 8 ビットデータ)にあなた自身で UTF8 フラグをセットした ことです。 これから守るためには、Encode::decode_utf8 を使えます。
入力に :encoding(UTF-8)
PerlIO 層を使うと、不正なバイトシーケンスは 寛容に扱われますが、:utf8
を使うと、フラグはデータを検証せずに設定され、 おそらく結果としてこのエラーメッセージが出力されます。
"Handling Malformed Data" in Encode も参照してください。
(F) use utf8
を指定しましたが、プログラムファイルは UTF-8 エンコーディング 規則に従っていません。 このメッセージは最初の間違った文字の直前の正しくエンコードされた文字を 表示します。 utf8
警告が有効なら、不正の種類に関するさらなる詳細が出力されます。
(F) charnames ハンドラが不正な UTF-8 を返しました。
(F) UTF-8 エンコーディング規則に従わない何かを unpack しようとしたので、 perl はどうやってさらに進捗させればいいかが推測できませんでした。
(F) UTF-8 エンコーディング規則に従わない何かを pack しようとしたので、 perl はどうやってさらに進捗させればいいかが推測できませんでした。
(F) UTF-8 エンコーディング規則に従わない何かを unpack しようとしたので、 perl はどうやってさらに進捗させればいいかが推測できませんでした。
(F) Perl は UTF-16 エンコード文字データを読み込んでいると考えましたが、 その間に Perl が不正な Unicode サロゲートに遭遇しました。
(F) サブルーチンシグネチャで、"$a = undef, $b" のような、先の引数が オプションで後の引数が必須のようなものを書きました。 引数は左から右に埋められるので、呼び出し側が先のものを省略して後のものに 渡すことは不可能です。 引数が右から左に埋められるかのように振る舞ってほしい場合は、一番右を オプションと宣言して、引数をサブルーチン本体で入れ替えてください。
(S non_unicode) Perl は文字列に Unicode 符号位置の上位集合を 含むことができます; それぞれの符号位置はシステムの符号なし整数に 格納できるだけの大きさを指定できますが、これらは他の言語/システムでは 受け付けられないかも知れません。 このメッセージは、このような符号位置を含む文字列をある正規表現パターンで マッチングし、符号位置が Unicode 特性 \p{...}
または \P{...}
と マッチングしたときに発生します。 Unicode 特性は Unicode 符号位置に対してのみ定義されているので、 Unicode によればこのマッチングの結果は未定義ですが、 Perl は (v5.20 から) 非 Unicode 符号位置を、典型的な未割り当て Unicode 符号位置として扱い、それぞれマッチングします。 指定された特性がこれらの符号位置にマッチングするかどうかは "Properties accessible through \p{} and \P{}" in perluniprops で 指定されています。
このメッセージは、符号位置が Unicode かどうかがマッチングの結果に関係ない 場合は、(致命的にしていない限り)抑制されます。 例えば、特性 \p{ASCII_Hex_Digit}
は 22 文字 [0-9A-Fa-f]
だけに マッチングするので、明らかに他の符号位置は、Unicode かどうかに関わらず、 マッチングしません。 (そして \P{ASCII_Hex_Digit}
はこれら 22 以外の全ての符号位置に マッチングします。)
このメッセージが出たということは、マッチングの結果はおそらく実際に起きた結果と 逆になっているはずだということを示しています。 これに当てはまっていると考えられる場合は、non_unicode
警告カテゴリを 致命的にした方がよいでしょう; Perl の結果に同意する場合は、このカテゴリを オフにした方がよいでしょう。
さらなる情報については "Beyond Unicode code points" in perlunicode を 参照してください。
(W) 指定したパターンは、もし、正規表現エンジンがチェックを 行なっていなければ、無限ループに陥るものです。 <-- HERE で正規表現のどこに問題が発見されたかを示しています。 perlre を参照してください。
(F) あまりにも多くのシグナルが保留中になったので Perl は中断しました。 これは普通 OS が速くシグナルを(とても高い優先順位で)配達しようとしすぎて、 perl のプロセスが安全にシグナルを処理できるところに到達するまでに必要な リソースが不足したことを示しています。 ("Deferred Signals (Safe Signals)" in perlipc を参照してください。)
(W) この警告は perl5 のスクリプトを perl4 インタプリタで実行しようとした ときに起きることが多いです; 特に警告された文字が "use" や "my" の場合は そうです。
(F) チェックサムを指定して pack を行なうことはできません; チェックサム処理では、情報が失われ、どうしようもなくなるからです。 "unpack" in perlfunc を参照してください。
(F) 多重定義テーブルで、有効なサブルーチンに解決できない エントリを指定しようとしました。 overload を参照してください。
"Server error" を参照してください。
(S) ようやく現在行になって、文字列やパターンの終わりが見つかったことから、 先のエラーが、文字列やパターンのデリミタが、見つからなかったことで 起ったかもしれないことを、補足的に示しています。
(W syntax) 数値定数の下線が、二つの値を分離していません。
(W uninitialized) printf 形式ののフォーマットが供給されたのよりも多くの引数を 要求しました。
(F) 示されたコマンドラインスイッチの引数は、 スイッチの直後にスペースを空けないで書く必要があります。
(F) ダブルクォートされたコンテキストの中で、文字名リテラル \N{charname}
の 文法が間違っています。 これはまた、/x
修飾子付きの正規表現の \N
と {
の間に空白(または コメント)がある場合にも起こります。 この修飾子は、\N
の直後に中かっこが必要であるという条件は変更しません。
(F) ダブルクォート風コンテキストでは \o
は直後に {
が 引き続かなければなりません。
(F) ある種の関数では、引数リストの前に、ファイルハンドルや 「間接オブジェクト」をおくことができますが、この関数は、 そういったものではありません。
(W pipe) open(FH, "| command")
か open(FH, "command |")
の構文を 使っていますが、コマンドが指定されていないか空白です。
(F) ダブルクォートされた文字列が "\c" で終わっています; 制御文字名が 必要です。
(W illegalproto) グループ化は [
で始まりましたが ]
で 閉じられませんでした。
(F) レキシカルスコープのサブルーチンの文法には探すことの出来る名前が必要です。
(F) csh を使いすぎた症状が現れているようです。 Perl では、変数は常に $ を付けて表わされます; その時によって違う、シェルとは 違っています。
(S syntax) これは "%s found where operator expected" メッセージと共に 表示される教育的な推測です。 しばしば不足している演算子はカンマです。
(F) \x{...}
, \p{...}
, \P{...}
, \N{...}
の右側のかっこが 抜けています。
(F) \N
には二つの意味があります。
伝統的なものは中かっこで囲まれた名前が引き続き、その名前を持つ文字 (または文字並び)を意味します。 従って \N{ASTERISK}
は *
を書くためのもう一つの方法であり、 ダブルクォート文字列と正規表現パターンの両方で妥当です。 パターンでは、これはエスケープされない *
の持つ意味はありません。
Perl 5.12.0 から、\N
はパターンでの中(のみ)では追加の意味を持ちます; 非改行文字にマッチングします。 (これは [^\n]
の短縮形で、.
と似ていますが /s
正規表現修飾子によって 影響を受けません。)
これによりいくつかの曖昧さを引き起こします。 \N
の直後に開き中かっこがなければ、Perl は [^\n]
の意味を仮定します。 また、中かっこが \N{3}
や \N{5,}
のような妥当な量指定子の形に なっているなら、Perl はこれを与えられた量の非改行 (この例では、それぞれ 3 と 5 以上) にマッチングするという意味を仮定します。 それ以外の場合、\N{
と対応する }
があれば、Perl は文字名が 求められていると仮定します。
しかし、対応する }
がなければ、それが間違って省略されたのか、 [^\n]{
が求められているものなのかが分からず、エラーを起こします。 前者を意味しているなら、閉じ中かっこを追加してください; 後者を 意味しているなら、\N\{
のように中かっこを逆スラッシュで エスケープしてください。
(F) 字句解析部が、閉じ中かっこ(または大かっこ)よりも 開き中かっこ(大かっこ)を多く発見しました。 一般的な規則として、最後に修正した場所の近くに間違いがあるといえます。
(S syntax) これは "%s found where operator expected" メッセージと共に 表示される教育的な推測です。 このメッセージが出たからといって、機械的に前の行にセミコロンを付けることは しないでください。
(F) 直接、間接に関らず、定数値を変更しようとしました。 もちろん、コンパイラが発見できる、"2 = 1" などといったことを したわけではありません。 しかし、同じことは以下のようにしても起こります。
sub mod { $_[0] = 1 }
mod(2);
substr() で、文字列の終わりよりも後ろに代入を行なうことでも起こります。
もう一つの可能性は、foreach
ループにおいて、VAR が LIST の中の 定数のエイリアスであるときに、VAR に代入した時です:
$x = 1;
foreach my $n ($x, 2) {
$n *= 2; # modifies the $x, but fails on attempt to
} # modify the 2
(F) 配列値を存在するようにしようとしました; おそらく、添字が負数で、配列の 終わりから逆に数えたとしても、おかしな位置を指しているようです。
(F) ハッシュ値を存在するようにしようとしましたが、何か特別な理由で、 できませんでした。
(F) "use" の最初の引数としてモジュール名を示すのに許されているのは、 裸の単語だけです。
-M
と -m
のオプションは Perl にモジュールを読み込ませることを 指示しますが、モジュール名がありませんでした。 -M
と -m
に関する完全な詳細については perlrun を参照してください。
(F) open
関数に、複数のファイルを開くように指定されました。 これは引数のリストを取るコマンドへのパイプを開こうとしたときに、パイプ オープンモードを指定するのを忘れた時に起きます。 詳細は "open" in perlfunc を参照してください。
(S) perl を -DPERL_DEBUG_READONLY_COW ("Copy on Write" in perlguts 参照) で コンパイルしましたが、共有文字列バッファを読み込み専用にできませんでした。
(S) perl が -DPERL_DEBUG_READONLY_OPS (perlhacktips 参照) で コンパイルされましたが、op 木を読み込み専用にできませんでした。
(S) perl を -DPERL_DEBUG_READONLY_COW ("Copy on Write" in perlguts 参照) で コンパイルしましたが、読み込み専用共有文字列バッファを変更可能に できませんでした。
(S) perl が -DPERL_DEBUG_READONLY_OPS (perlhacktips 参照) で コンパイルされましたが、読み込み専用の op 木を、op を解放する前に ミュータブルにできませんでした。
(F) このシステムでは、System V メッセージ IPC は使えません。
(W syntax) 多次元配列は、$foo[1,2,3]
のようには書けません。 これは、C のように $foo[1][2][3]
のように書きます。
(F) '/' を含む unpack テンプレートがありますが、これがなんらかの 数値を生成する unpack 指定に引き続いていません。 "pack" in perlfunc を参照してください。
(F) レキシカルスコープのサブルーチンはまだ実装されていません。 まだ試さないでください。
(W syntax) パッケージ変数 $a と $b はソート比較のために使われます。 $a または $b をソート比較ブロックの中の <=>
または cmp
演算子の オペランドとして使いましたが、この変数はその前にレキシカル変数として 宣言されています。 ソート変数をパッケージ名で修飾するか、レキシカル変数の名前を変えてください。
(F) 字句スコープの変数は、パッケージ内に置かれませんので、 頭にパッケージ名を付けて宣言することは、無意味です。 パッケージ変数をローカル化したい場合には、local() を使ってください。
(W once) しばしばタイプミスによってユニークな変数名として表示されます。 ユニークな名前をを使う理由があるのなら、もう一度どこかで参照することで このメッセージを抑制できます。 our
宣言もこの目的のために提供されています。
注意: この警告はパッケージシンボルが一度だけしか使われていないことを 検出します。 これは、レキシカル変数はこの警告を引き起こすことはないということです。 また、パッケージ変数 $c, @c, %c および、*c, &c, sub c{}, c(), c(ファイルハンドルかフォーマット)は全て同じ物として扱わるということです; もしプログラムで $c を一度しか使っていなくても その他のものが使われている場合、警告は発生しません。 下線で始まるシンボルと、特殊識別子 (perldata 参照) を使ったシンボルは この警告から免れます。
(F) (?[ ])
の中で、8 進数として解釈される全ての定数は正確に 3 桁である 必要があります。 これはある種の曖昧さを捕まえる助けになります。 定数が短い場合は、以下のように先頭に 0 を追加してください
(?[ [ \078 ] ]) # Syntax error!
(?[ [ \0078 ] ]) # Works
(?[ [ \007 8 ] ]) # Clearer
この構文が表現できる最大数は \777
です。 より大きな値が必要なときは、代わりに \o{} を 使う必要があります。 二つの別々のものを意味しているなら、分ける必要があります:
(?[ [ \7776 ] ]) # Syntax error!
(?[ [ \o{7776} ] ]) # One meaning
(?[ [ \777 6 ] ]) # Another meaning
(?[ [ \777 \006 ] ]) # Still another
(F) 長さ/コード unpack 操作で得られた長さカウントが負数でした。 "pack" in perlfunc を参照してください。
(F) ゼロより短い長さのバッファで、読み込み、書き込み、送信、受信を 行なおうとしました。 これは想像しにくいことです。
(F) 左辺値コンテキストで vec
が呼び出されたとき、 二つ目の引数は 0 以上でなければなりません。
(F) かっこを挟まないで、数量子を数量子で修飾することはできません。 つまり、** や +* や ?* といったものは、正しくありません。 <-- HERE で正規表現のどこに問題が発見されたかを示しています。
最短一致数量子の *?
、+?
、??
は、ネストした数量子のように 見えますが、そうではありません。 perlre を参照してください。
(S internal) 問題のシンボルは、宣言されましたが、使われる前にスコープから 外れてしまいました。
(F) next::method
は実パッケージの実メソッドのコンテキストの中で呼ばれる 必要がありますが、そのようなコンテキストが見つけられませんでした。 mro を参照してください。
(F) [^\n]
という新しい (5.12 からの) \N
の意味は大かっこ文字クラスでは 妥当ではありません; 文字クラス内の .
がその特殊性を失うのと同じ理由です: これはほとんど何にでもマッチングし、これはおそらくあなたの求めているものでは ないでしょう。
(F) 名前付き Unicode 文字エスケープ (\N{...})
は複数文字並びを 返すことがあります。 このようなエスケープは文字クラスの中では使えません; 文字クラスは常に 入力のうちの一文字にマッチングするからです。 正しいエスケープを使っているか、および正しい文字名ハンドラがスコープ内に あるかをチェックしてください。 <-- HERE で正規表現のどこに問題が発見されたかを示しています。
(F) 正規表現パターンをコンパイルするとき、解決されない名前付き文字や並びに 遭遇しました。 これはシングルクォート風コンテキストを使ったり、ダブルクォート風で 余分な逆スラッシュがあるような、字句解析器を回避する様々な方法のどれかで 起こります:
$re = '\N{SPACE}'; # Wrong!
$re = "\\N{SPACE}"; # Wrong!
/$re/;
代わりに、単一のバックスラッシュとダブルクォートを使ってください:
$re = "\N{SPACE}"; # ok
/$re/;
字句解析器はより小さい構造からパターンを作ることによっても回避できます:
$re = '\N';
/${re}{SPACE}/; # Wrong!
このように中間で構造を分割することはよい考えではなく、ここでは動作しません。 代わりに上述した解決法を使ってください。
最後に、このメッセージは /x
正規表現修飾子 が有効の時に \N
が {
と 空白で区切られているときにもでます; この場合、空白を削除します。
/\N {SPACE}/x; # Wrong!
/\N{SPACE}/x; # ok
(F) ある種の操作は、setuid や setgid スクリプトにとって、 やってみることはできても、とても安全なものとは考えられないものです。 一般に言って、安全ではなくても、安全にしうる、別の方法があるはずです。 perlsec を参照してください。
(F) Perl の -e と -E のコマンドラインオプションは引数が必要です。 空のプログラムを実行したい場合は、空文字列を別の引数として渡すか、単一の 0 または 1 からなるプログラムを実行してください:
perl -e ""
perl -e0
perl -e1
(F) ファイルハンドルや「間接オブジェクト」を伴うリスト演算子では、 それらとそれ以降の引数の間にコンマを入れることはできません。 そのようにした場合には、引数の一つとなってしまいます。
これの原因としてあり得るものの一つは、use や import を使って 名前空間にインポートしたつもりの定数が実際にはインポートされていなかった 場合です; 例えば OS が特定の定数に対応していない場合などです。 できればインポートしたい定数のリストを明示的に使ってください; "use" in perlfunc と "import" in perlfunc を参照して下さい。 明示的なインポートリストでおそらくこのエラーをより早く知ることができますが、 そもそも OS がその定数に対応していないという問題を解決はしません。 おそらく use や import のシンボルインポートリストの定数か、 エラーを引き起こした行の定数名をタイプミスしたのでは?
(F) VMS に固有のエラーです。 Perl は独自にコマンドラインのリダイレクトを扱っていて、 コマンドラインの最後にに '|' を発見しましたが、 このコマンドから出力をどこにパイプしたいのかがわかりませんでした。
(F) 現在実行中のコードは、-d スイッチを付けてコンパイルされましたが、 何らかの理由により、現在のデバッガ(perl5db.pl か Devel::
モジュール) が各実行文の頭で呼び出すルーティンを定義していません。
(P) これは、内部エラーとして扱われます; Perl に SDBM が付いてくるので、 どのマシンでも dbm が使えるはずだからです。 SDBM_File を参照してください。
(F) 現在実行中のコードは、-d スイッチを付けてコンパイルされましたが、 何らかの理由により、現在のデバッガ(perl5db.pl か Devel::
モジュール)が 各サブルーチン呼び出しの頭で呼び出す DB::sub
ルーティンを 定義していませんでした。
(F) -I コマンドラインオプションは 同じ 引数の一部としてディレクトリ名が 必要です。 例えば、-Ilib としてください。 -I lib は動作しません。
(F) VMS に固有のエラーです。 Perl は独自にコマンドラインのリダイレクトを扱っていて、 コマンドラインに '2>' や '2>>' を発見しましたが、 標準エラーとしてデータを書き込むファイル名が見つかりませんでした。
(F) pack や unpack のテンプレートに開きかっこの '(' や '[' がありますが、 対応する閉じかっこがありません。 "pack" in perlfunc を参照してください。
(F) VMS に固有のエラーです。 Perl は独自にコマンドラインのリダイレクトを扱っていて、コマンドラインに '<' を発見しましたが、標準入力として読み込むためのファイル名が 見つかりませんでした。
(F) next::method
で、このクラスの MRO で残っているパッケージの中で、この メソッド名のインスタンスがもうありません。 もし例外を投げたくないなら、maybe::next::method
か next::can
を 使ってください。 mro を参照してください。
(F) 正規表現で、次のように 16 進文字が想定されるところで非 16 進文字がありました
(?[ [ \xDG ] ])
(?[ [ \x{DEKA} ] ])
(F) 正規表現で、次のように 8 進文字が想定されるところで非 8 進文字がありました
(?[ [ \o{1278} ] ])
(W digit) 8 進数定数をパースするときに、8 進数でない文字に遭遇しました。 結果の値は示された通りになります。
(F) "no" キーワードは、コンパイル時に認識され、実行されるもので、 意味のある値を返しません。 perlmod を参照してください。
(W misc) select() のビットマスク引数として数値が渡されました。 select のためのファイル記述子のビットマスクを構成するには、 vec() 関数を使ってください。 "select" in perlfunc を参照してください。
(F) VMS に固有のエラーです。 Perl は独自にコマンドラインのリダイレクトを扱っていて、コマンドラインの 最後に単独の '>' を発見したので、stdout をどこにリダイレクトしたいのかが わかりませんでした。
(F) VMS に固有のエラーです。 Perl は独自にコマンドラインのリダイレクトを扱っていて、コマンドラインに '>' や '>>' を発見しましたが、stdout を書き込むためのファイル名が 見つかりませんでした。
(F) 完全修飾変数名は "our" 宣言では使えません; なぜなら現在の動作ではほとんど意味がないからです。 そのような文法は将来の拡張に予約されています。
(F) perl -x
を呼び出しましたが、そのファイルに #! で始まり、 "perl" という語を含む行が見つかりませんでした。
(F) Configure が、システム上に setregid() のような関数を 見つけられませんでした。
(F) Configure が、システム上に setreuid() のような関数を 見つけられませんでした。
(F) "my", "our", "state" の宣言でクラス修飾子が指定されましたが、指定された クラスは現時点では存在しません。
(F) 示されている型の変数を通してハッシュのキーにアクセスしようとしましたが、 そのキーは同じ型のパッケージによって許可されていません。 示されているパッケージは fields プラグマによって許可されるキーの集合が 制限されています。
(F) Perl が認識できないシグナルフックを指定しました。 現在のところ、Perl は有効なシグナルフックとして __DIE__
と __WARN__
を受け付けます。
(P) VMS に固有のエラーです。 内部ルーチンである my_pclose() が、開いていないパイプを閉じようとしました。 これは開いていないファイルハンドルを閉じようとしたとしてもっと早くに 捕捉されるべきものです。
(W signal) %SIG の添字として認識できないシグナル名を指定しました。 お使いのシステムで使用可能なシグナル名を調べるには、 シェル上で kill -l
などとしてください。
(F) Perl がコード値 (サブルーチン) へのリファレンスを 評価しようとしましたが、別のものへのリファレンスでした。 実際にどんな種類のリファレンスかを調べるには、ref() 関数を 使うことができます。 perlref も参照してください。
(F) Perl が「型グロブ」(これは、*foo
のような シンボルテーブルエントリです) へのリファレンスを評価しようとしましたが、 別のものへのリファレンスでした。 実際にどんな種類のリファレンスかを調べるには、ref() 関数を 使うことができます。 perlref を参照してください。
(F) Perl がハッシュ値へのリファレンスを評価しようとしましたが、 別のものへのリファレンスでした。 実際にどんな種類のリファレンスかを調べるには、ref() 関数を 使うことができます。 perlref を参照してください。
(F) Perl が配列値へのリファレンスを評価しようとしましたが、 別のものへのリファレンスでした。 実際にどんな種類のリファレンスかを調べるには、ref() 関数を 使うことができます。 perlref を参照してください。
(F) push
, shift
やその他の配列関数に bless された配列へのリファレンスを 渡しました。 これらは bless されていない配列リファレンスか明示的に @
で始まる 配列のみを受け付けます。
(F) Perl がスカラ値へのリファレンスを評価しようとしましたが、 別のものへのリファレンスでした。 実際にどんな種類のリファレンスかを調べるには、ref() 関数を 使うことができます。 perlref を参照してください。
(F) Perl がコード値 (サブルーチン) へのリファレンスを 評価しようとしましたが、別のものへのリファレンスでした。 実際にどんな種類のリファレンスかを調べるには、ref() 関数を 使うことができます。 perlref も参照してください。
(F) 多重定義テーブルで、有効なサブルーチンを指していないエントリを 指定しようとしました。 overload を参照してください。
(F) この関数は、指定したよりも多くの引数を必要とします。
(W syntax) 指定したフォーマットに、次の行で指定したより多くの ピクチャフィールドがあります。 perlform を参照してください。
(A) スクリプトを perl ではなく Bourne shell で実行しようとしました。 #! 行をチェックするか、スクリプトを直接 Perl で起動してください。
(F) (?[...])
は use locale
のスコープ内や /l
正規表現修飾子付きでは 使えません; これは何を評価するべきかを実行時の計算によりますが、 これは正規表現のコンパイル時のみだからです。
(S) VMS に固有の警告です。 Perl はローカルタイムゾーンオフセットを見つけることができなかったので、 ローカルシステムタイムは UTC と等価であると仮定します。 もし違うなら、論理名 SYS$TIMEZONE_DIFFERENTIAL に、UTC からローカル 時刻を得るために加える必要がある秒数を定義してください。
(F) 空のファイル名は require できません; 特に、多くのマシンでは カレントディレクトリを意味するからです! "require" in perlfunc を参照してください。
(S debugging) 内部ルーティンで、ヌル opcode ポインタで run() を 呼んだものがあります。
(F) formline の第 1 引数は有効なフォーマットピクチャー指定でなければ なりません。 これが空でした; おそらく初期化していない値を指定したのでしょう。 perlform を参照してください。
(P) realloc NULL を行なおうとしました。
(P) 内部パターンマッチルーティンが、大当たりです。
(P) 内部パターンマッチルーティンが、狂っています。
Perl はプログラム中での十進数の表現を 250 文字に制限しています。 この制限を越えました。 Perl の将来のバージョンではこの恣意的な制限は除去されるでしょう。 それまでの間は、科学的な記述法("1_000_000" ではなく "1e6")を 使用してください。
(F) Perl は数字を探していましたが数字に見えないものが見つかりました。 これは、例えば \o{}
では、中かっこの中に数字がないときに起こります。
(W portable) 指定した 8 進数が 2**32-1 (4294967295) より大きいので、 システム間で移植性がありません。 移植性に関するさらなる考察については perlport を参照してください。
(F) シグネチャで吸い込みハッシュ引数を使っているサブルーチンが、 ハッシュに展開するために奇数の数の引数を受け取りました。 引数は、同じ数のキーと値のペアになっていることが必要です。 サブルーチンの呼び出しものがおそらく間違えているのでしょう。 不便なことに、このエラーは呼び出し元ではなく、サブルーチンの位置で 報告されます。
(W overload) 奇数の数の引数で overload::constant を呼び出しました。 引数はペアになっている必要があります。
(W misc) ハッシュリストへの要素の数が奇数でした; ハッシュリストは、 key/value のペアで与えられますから、これは奇妙なことです。
(W misc) ハッシュリストへの要素の数が奇数でした; ハッシュリストは、 key/value のペアで与えられますから、これは奇妙なことです。
(F)(W layer) バッファの外を指すオフセットで read/write/send/recv/seek 操作を しようとしました。 これは想像しにくいことです。 唯一の例外は、ファイルを sysread()
するときに 文字列の最後を越えたか、 (将来の読み込みと実際のファイルの振る舞いを模倣することを期待して) I/O のためにオープンされているスカラの最後を越えてシークしたときに、 0 でパッディングされたときです。
(W unopened) 初期化していないファイルハンドルに I/O 操作をしようとしました。 open(), sysopen(), socket() を呼び出すか、FileHandle パッケージの コンストラクタを呼び出す必要があります。
(W unopened) 開いていないファイルハンドルに対してファイルテスト演算子を 使おうとしました。 制御フローをチェックしてください。 "-X" in perlfunc も参照してください。
(S internal) 文法がおかしくなったことを示す内部警告です。
(S internal) 文法がおかしくなったことを示す内部警告です。
(D io, deprecated) open() で、既にディレクトリハンドルを保持しているシンボル (グロブまたはスカラ)にファイルハンドルを関連付けようとしました。 これは不正ではありませんが、この用法はコードを間違えて解釈する可能性が あるので非推奨です。
(D io, deprecated) すでにファイルハンドルを保持しているシンボル (グロブまたはスカラ)にディレクトリハンドルを関連付けるために opendir() を使いました。 これは不正ではありませんが、この用法はコードを間違えて解釈する可能性が あるので非推奨です。
(F) 以下のようなものを書きました
(?[ \p{Digit} \p{Thai} ])
二つのオペランドがありますが、それをどのように結びつけたいかを指定する 演算子がありません。
(F) ハンドラが定義されていないオーバーロード操作が行われました。 一部のハンドラは他のハンドラから自動生成されますが、fallback
オーバーロードキーが真に指定されていない限り、どの動作にも デフォルトのハンドラはありません。 overload を参照してください。
(S non_unicode) Unicode ではない符号位置に対して、Unicode の意味論が 必要な操作を実行しました; 何をするべきかは未定義です。 Perl は何もしないことを選択し、警告を出します。
示された操作が "ToFold" なら、正規表現での大文字小文字を無視したマッチングが その符号位置に対して行われたということです。
自分で何をしているのかが分かっているなら、 no warnings 'non_unicode';
とすることでこの警告をオフにできます。
(S surrogate) Unicode サロゲートに対して Unicode の意味論が必要な 操作を実行しました。 Unicode は文字列を UTF-16 で保管する以外のことでサロゲートを使うことに 難色を示しますが、意味論は(渋々)サロゲートのために定義されていて、それは この操作に対して何もしないことです。 サロゲートの使用は危険かも知れないので、Perl は警告します。
示された操作が "ToFold" なら、正規表現での大文字小文字を無視したマッチングが その符号位置に対して行われたということです。
自分で何をしているのかが分かっているなら、 no warnings 'surrogate';
とすることでこの警告をオフにできます。
(S ambiguous) パーサーが演算子を装置している場所で変数やサブルーチン 呼び出しが使われました。 パーサーはあなたが本当に演算子を使おうとしていると仮定しますが、 これは大抵正しくありません。 例えば、"*foo *foo" とすると、"*foo * 'foo'" としたとして解釈されます。
(F) サブルーチンシグネチャで、"$a =" のような、デフォルト値のない名前付き オプション引数を書きました。 無名オプション引数はデフォルト値を持たないことを許されていますが、 名前付きのものはデフォルトを指定しなければなりません。 おそらく "$a = undef" としたかったのでしょう。
(W misc) 現在のレキシカルスコープで、既に同じ名前のグローバル変数を 宣言しているようです。
(X) 要求を満たすだけの、十分な残メモリ (または、仮想メモリ) が 取得できないことを示す、0 を malloc() 関数が返しました。 Perl は直ちに終了するしかありませんでした。
少なくとも Unix ではプロセスのデータサイズ制限を増やすことによって これを回避することが可能です: csh/tcsh では現在の制限を調べるのに limit
を、これを変更するには limit datasize n
(ここで n
はキロバイト単位) を使ってください; ksh/bash/zsh ではそれぞれ ulimit -a
と ulimit -d n
を使ってください。
(X) 確保可能な最大メモリを越えて配列、リスト、文字列を拡張しようとしました。
(F) malloc() 関数が 0 を返しました; これは要求を満たすメモリ (または仮想メモリ)が不十分であることを示しています。 しかし、要求が十分大きい(コンパイル時のデフォルトは 64K)ので、 このエラーをトラップすることでシャットダウンできる可能性があります。
(X)(F) malloc() 関数が 0 を返しました; これは要求を満たすメモリ (または仮想メモリ)が不十分であることを示しています。
要求は小さいものと判定されたので、これをトラップできる確率は perl が どのようにコンパイルされたかに依存します。 デフォルトではこれはトラップできません。 しかし、もしこのためにコンパイルすると、Perl はこのメッセージと共に die() した後の非常用エリアとして $^M
の内容を使います。 この場合エラーは 一度だけ トラップ可能で、エラーメッセージは失敗した 要求が起きたファイルと行番号を含んでいます。
(F) 2^31+「少量」バイト以上割り当てることはできません。 このエラーはほとんどの場合 Perl プログラムのタイプミスが原因です。 例えば、$arr[$time]
の代わりに $arr[time]
のような。
(F) yacc パーサーが解析を続けるために、スタックを広げようとしましたが、 realloc() が仮想やその他のメモリを確保できませんでした。
(F) テンプレートでの '.' の引数として、pack された文字列が構築されたよりも 前に作業位置を移動しようとしました。
(F) unpack される文字列の外に絶対位置指定している、 テンプレートを指定しました。 "pack" in perlfunc を参照してください。
(F) unpack される文字列の外に絶対位置指定している、 テンプレートを指定しました。 unpack された文字列は不正な UTF-8 でもあります。 "pack" in perlfunc を参照してください。
(W overload) overload プラグマに、認識できない引数が渡されました。 演算子をタイプミスしましたか?
(F) オーバーロードされたデリファレンス演算子のオブジェクトが デリファレンスされましたが、オーバーロード演算がリファレンスを 返しませんでした。 overload を参照してください。
(F) qr
をオーバーロードしたオブジェクトがマッチングの一部として 使われましたが、オーバーロード演算がコンパイルされた正規表現を 返しませんでした。 overload を参照してください。
(W reserved) パッケージ固有のハンドラが、小文字の属性名を使っています。 この名前は、たとえ今は使っていなくても、 Perl 自身がいつか使うかもしれません。 おそらく代わりに大文字小文字の混じった属性名を使うべきでしょう。 attributes を参照してください。
(F) 繰り返し回数として符号付き整数をオーバーフローするような 値は指定できません。 "pack" in perlfunc を参照してください。
(W io) write() の 1 度の呼び出しで、1 ページに収まるより多くの行が できました。 perlform を参照してください。
(P) 内部エラーです。
(P) ファイルテスト演算子の一つが ACL 関連関数を呼び出すコード分岐に 入りましたが、この関数はこのプラットフォームでは利用できません。 より早いチェックは、このプラットフォームのこの分岐に入ることがないように するべきことを意味します。
(P) Windowsでのiスレッド実装の子疑似プロセスが許された時間間隔の間に スケジューリングされなかったので、適切に初期化されなかった可能性があります。
(P) grep をコンパイルしようとして、内部の一貫性チェックに 引っ掛かりました。
(P) split をコンパイルしようとして、内部の一貫性チェックに 引っ掛かりました。
(P) セーブスタックにある以上のローカル化した値を元に戻す 要求がありました。
(P) 弱いリファレンスをリセットしようとしたときに内部の 一貫性チェックに引っ掛かりました。
(P) eval コンテキストへコンテキストスタックをポップしたあと、 eval コンテキストでないことがわかりました。
(P) 内部の pp_subst() ルーティンが、無効な省略可能データを 付けて呼ばれました。
(P) 内部の pp_trans ルーティンが、無効な省略可能データを 付けて呼ばれました。
(P) 定数の畳み込みを実行中に eval
失敗以外の例外が捕捉されました。
(P) ライブラリ関数 frexp() が失敗したので、printf("%f") ができません。
(P) 指定したラベルを伴うコンテキストへコンテキストスタックを ポップしたあと、どのように goto するかがわかっている コンテキストでないことがわかりました。
(P) 型グロブのエントリをクリアするために使われる内部ルーチンが複数回 試しましたが、毎回何かがグロブにエントリを再作成しました。 おそらくグロブにそのグロブへのリファレンスと、グロブへの新しいオブジェクトを 追加するデストラクタを持つオブジェクトが含まれています。
(P) 大文字小文字修飾子のところで、字句解析部がおかしな状態に陥りました。
(P) 中かっこを伴う文字列を解析中に、字句解析部がおかしな状態に陥りました。
(F) fork した子プロセスが errno に関して不完全なメッセージを返しました。
(P) block コンテキストへコンテキストスタックをポップしたあと、 block コンテキストでないことがわかりました。
(P) 書き込み可能な字句スコープ変数が、どういうわけか、スコープ内で リードオンリーになりました。
(P) おそらく、セーブスタックの同期がとれていません。 少なくとも、トップに不正な enum がありました。
(P) あるオブジェクトへの全ての弱い参照をリセットしようとした時に内部の 一貫性チェックに引っ掛かりました。
(P) malloc に負のバイト数で要求が行なわれました。
(P) 何かが、確保可能な量を超える、または負の量のメモリを確保しようとしました。
(P) コンパイラが、一時領域や字句形式を割り当て、解放している スクラッチパッドについて混乱しました。
(P) コンパイラが、一時領域や字句形式を割り当て、解放している スクラッチパッドについて混乱しました。
(P) 不正なスクラッチパッドのオフセットが、内部的に検出されました。
(P) コンパイラが、一時領域や字句形式を割り当て、解放している スクラッチパッドについて混乱しました。
(P) 不正なスクラッチパッドのオフセットが、内部的に検出されました。
(P) コンパイラが、一時領域や字句形式を割り当て、解放している スクラッチパッドについて混乱しました。
(P) 不正なスクラッチパッドのオフセットが、内部的に検出されました。
(P) foreach の繰返し子が、ループ文脈以外のところで呼ばれました。
(P) 内部の pp_match() ルーティンが、無効な省略可能データを 付けて呼ばれました。
(P) split の準備中に何かまずいことが起こってしまいました。
(P) 何か、realloc に負のバイト数を要求したものがあります。
(P) 内部の sv_replace() 関数は、参照カウントが 1 でない新しい SV を 扱いました。
(P) 内部ルーティンから goto (または、同じようなもの) が 要求されましたが、飛び先が与えれていません。
(P) サブルーチンコンテキストや eval コンテキストへ、 コンテキストスタックをポップしたあと、サブルーチンコンテキストや eval コンテキストでないことがわかりました。
(P) scan_num() が、何か数字でないものに対して呼ばれました。
(P) 組み込みの (?{}) や (??{}) コードブロックを持つパターンをコンパイル中に、 既に現れていて、正規表現コンパイラに制御を渡す前に perl によって コンパイルされているコードブロックを発見できませんでした。
(P) C 関数 strxfrm() のインタプリタの正気度チェックが失敗しました。 現在のロケールでは、文字列 "ab" の変換で返されたものは 文字列 "a" の 変換で返されたものよりも短いので、おかしいです。
(P) sv_chop() ルーチンは、スカラの文字列バッファ内でない位置を 渡されました。
(P) sv_insert() ルーティンが、存在する以上の文字列を削除するように 指示されました。
(P) コンパイラが、goto など妙なことを行なおうとしました。
(P) コンパイラがおかしくなって、実行時に許可されていない op を しようとしました。
(P) 何かが(偶数ではなく)奇数のバイト長で utf16_to_utf8 を 呼び出そうとしました。
(P) 何かが utf16_to_utf8_reversed を奇数バイト長で呼び出そうとしました。
(P) 大文字小文字修飾子を処理中に、字句解析部がおかしな状態に陥りました。
(W parenthesis) おそらく以下のようにしたのでしょう:
my $foo, $bar = @_;
以下のようにすべきです:
my ($foo, $bar) = @_;
"my", "our", "local", "state" は、コンマよりも強く結合することを 忘れないでください。
(F) エクステンションによって供給されたパースコードが、検出できる形で パーサの API に違反しています。
(D deprecated, utf8) このメッセージは、Perl コアまたは XS コードにバグが あることを示しています。 このコードは、内部で UTF-8 にエンコードしているとされている文字が、 句読点や数字といった特定の種類かどうかを調べようとしました。 しかしその文字は正当な UTF-8 としてエンコードされていませんでした。 %s
は、知識のある人々がチェックするべき型を決定するために使われる文字列で 置き換えられます。 utf8
警告が有効なら、不正な形の詳細が記されたさらなるメッセージが 出力されます。
(F) テキストを全く消費することなく、あまりに多くネストした副パターンを使う パターンを使いました。 ネストの制限を越える前にテキストを消費するようにパターンを 再構成してください。
-p
destination: %s(F) -p
コマンドラインオプションで起動された 暗黙の出力中にエラーが発生しました。 (この出力は select() でリダイレクトしていない限り STDOUT に出力されます。)
(F) これは "Can't locate object method \"%s\" via package \"%s\"" の メッセージと共に出る教育的な推測です。 これはしばしばメソッドがまだロードされていないパッケージを 要求していることを意味します。
(S regexp) 大文字小文字を無視するマッチングを行う正規表現を使いました; そして 組み込みの正規表現畳み込み規則が正確でないという Perl のバグがありました。 これは間違った結果を引き起こします。 どうか perlbug ユーティリティを使ってバグとして報告してください。
(F) あなたのプラットフォームはとても珍しいバイト順と整数サイズを 使っているので、固定長バイト順変換関数の一部または全部を使うことができません。 これは (un)pack テンプレートの中で '<' か '>' の修飾子を使った場合にのみ問題となります。 "pack" in perlfunc を参照してください。
(F) 実行しようとしたコードは、実行している Perl のバージョンよりも高いものを 尋ねました。 おそらく use 5.010
or use v5.10
ではなく use 5.10
と 書かれているのでしょう。 先頭の v
がないと、数値は 10 進数で、小数点の後の 3 桁毎にバージョン番号の 部分を表現していると解釈されます。 それで、5.10 は v5.100 と等価です。
(F) 問題のモジュールは、現在実行中の Perl よりも最近のバージョンの 機能を使っています。 ところで、いつからアップグレードしていないのですか? "require" in perlfunc を参照してください。
(F) OS/2 固有のエラーです。 PERL_SH_DIR は sh
-shell を見つけるためのディレクトリです。 perlos2 の "PERL_SH_DIR" を参照してください。
(X) 有効な値については "PERL_SIGNALS" in perlrun を参照してください。
(F) 実行しようとしているコードは、使っている Perl のバージョンが新しすぎると 主張しています。 コードを更新する必要があるかもしれませんし、単に間違っていて単純に バージョンチェックを削除するべきかもしれません。
(S) PERL_HASH_SEED は /^\s*(?:0x)?[0-9a-fA-F]+\s*\z/ にマッチングするけれども 非 16 進数文字を含む必要があります。 これは、考えているようなハッシュの種が使われないことを 意味しているかもしれません。
(S) 警告全体は以下のような形になります:
perl: warning: Setting locale failed.
perl: warning: Please check that your locale settings:
LC_ALL = "En_US",
LANG = (unset)
are supported and installed on your system.
perl: warning: Falling back to the standard locale ("C").
正確にどのロケール設定が失敗したのかは様々です。 上記では設定は LC_ALL は "En_US" で、LANG は空でした。 このエラーは、あなたや OS 供給者やシステム管理者がロケールシステムと呼ばれる ものをセットアップしましたが、Perl がこれらの設定を使えないことを 検出したことを意味します。 これは幸いにして致命的ではありません; Perl が使用できる "C" と呼ばれる 「デフォルトロケール」が存在するので、スクリプトは実行されます。 しかし、本当にこの問題を解決するまでは、Perl を実行する毎に同じエラー メッセージが表示されます。 本当にこの問題を修正する方法は perllocale の LOCALE PROBLEMS の 章にあります。
(S) 環境変数 PERL_PERTURB_KEYS が定義されている環境で Perl が実行されましたが 想定外の値でした。 この設定の正当な値は以下のものです。
Numeric | String | Result
--------+---------------+-----------------------------------------
0 | NO | Disables key traversal randomization
1 | RANDOM | Enables full key traversal randomization
2 | DETERMINISTIC | Enables repeatable key traversal
| | randomization
数値と文字列の値の両方が受け入れられますが、文字列の値は大文字小文字を 区別することに注意してください。 この設定のデフォルトは "RANDOM"、つまり 1 です。
(W exec) VMS に固有の警告です。 現在のプロセスのサブプロセスでないプロセスに Waitpid() を使いました。 これは VMS の観点からは問題ありませんが、おそらくあなたの望んでいることでは ないでしょう。
(F) unpack フォーマット P は "*" ではなく、明示的なサイズを 指定しなければなりません。
(S experimental::autoderef) スカラ引数の pop
は実験的で、将来の バージョンの Perl で変更されたり削除されたりするかもしれません。 この機能を使うリスクを取る場合は、単に警告を無効にして下さい:
no warnings "experimental::autoderef";
(F) 文字クラス [: :] 文法の中のクラスは不明です。 <-- HERE で正規表現のどこに問題が発見されたかを示しています。 POSIX 文字クラスは、対応する C インターフェースが持っている is
接頭辞が 付かない ことに注意してください: 言い換えると、[[:print:]]
であり、 isprint
ではありません。 perlre を参照してください。
(F) お使いのシステムは、引数に pid をとる BSD バージョンの getpgrp() と違って、引数をとらない POSIX のものを使っています。
(W regexp) 例えば /[012[:alpha:]345]/ のように、文字クラス構造 [: :], [= =], [. .] が文字クラスの 内側 にあり、[] は構造の一部です。 [= =] と [. .] は現在のところ実装されていないことに注意してください; これらは単に将来の拡張のためのプレースホルダであり、致命的エラーを 生成します。 <-- HERE で正規表現のどこに問題が発見されたかを示しています。 perlre を参照してください。
(F) 正規表現文字クラス ([]) の中では、"[." で始まる文法と ".]" で 終わる文法は将来の拡張のために予約されます。 正規表現文字クラスの中でこのような文字シーケンスを表現する必要がある 場合には、"\[." と ".\]" のように、大かっこをバックスラッシュで クォートしてください。 <-- HERE で正規表現のどこに問題が発見されたかを示しています。 perlre を参照してください。
(F) 正規表現文字クラス ([]) の中では、"[=" で始まる文法と "=]" で 終わる文法は将来の拡張のために予約されます。 正規表現文字クラスの中でこのような文字シーケンスを表現する必要がある 場合には、"\[=" と "=\]" のように、大かっこをバックスラッシュで クォートしてください。 <-- HERE で正規表現のどこに問題が発見されたかを示しています。 perlre を参照してください。
(W qw) qw() リストは空白で分割されたアイテムを含んでいます; リテラル文字列では、コメント文字無視されず、リテラルデータとして扱われます。 (ここで使われているのと違うデリミタを用いているかもしれません; 大かっこもよく使われます。)
おそらく以下のように書いたのでしょう:
@list = qw(
a # a comment
b # another comment
);
以下のように書くべきです:
@list = qw(
a
b
);
本当にコメントをつけたいのなら、 リストを昔のクォートとカンマの形で書いてください。
@list = (
'a', # a comment
'b', # another comment
);
(W qw) qw() リストに空白で分割された項目があります; そのため、カンマは項目を分割する必要がありません。 (ここで使われているのと違うデリミタを用いているかもしれません; 大かっこもよく使われます。)
おそらく以下のように書いたのでしょう:
qw! a, b, c !;
リスト要素の中にリテラルのカンマを書いています。 データの中にカンマを出したくないなら、カンマなしで書きます:
qw! a b c !;
(F) ioctl() や fcntl() が、Perl が求めていた以上のものを返してきました。 Perl は、適量のバッファサイズを見積もりますが、念のためにバッファの 最後に目印を付けています。 この目印が壊されたため、Perl はメモリの破壊が起こったと判断しました。 "ioctl" in perlfunc を参照してください。
(W syntax) フロー制御演算子 (例えば return
) と、or
のような 低優先順位演算子を混ぜると問題が起きることがあります。 次を考えると:
sub { return $a or $b; }
これは次のようにパースされます:
sub { (return $a) or $b; }
これは事実上次のものです:
sub { return $a; }
かっこか、高優先順位版の演算子を使ってください。
これは次のような構文でも引き起こされることに注意してください:
sub { 1 if die; }
(W precedence) 以下のように、ビット単位の論理演算子を数値比較演算子と 結合して使用しています:
if ($x & $y == 0) { ... }
この式は、==
の優先順位の方が高いので、$x & ($y == 0)
と 等価になります。 これはおそらく望んでいるものではないでしょう。 (もし本当にこのように書きたいのなら、警告を無効にするか、あるいは よりよいのはかっこを明示的に使って $x & ($y == 0)
と書きます)。
(W ambiguous) 正規表現で m/$\/
のようなことをしました。 正規表現 m/foo$\s+bar/m
は以下のように翻訳されます: 単語 'foo'、出力 レコードセパレータ ("$\" in perlvar 参照)、文字 's' (1 回以上)、単語 'bar' にマッチングします。
これがあなたのしたいことなら、m/${\}/
を使うことで警告を抑制できます (例えば: m/foo${\}s+bar/
)。
そうではなく、行末の単語 'foo' に引き続いて、次の行で空白と単語 'bar' に マッチングしたいなら、m/$(?)\/
を使ってください (例えば: m/foo$(?)\s+bar/
)。
(W ambiguous) 「@foo」のようなものをダブルクォート文字列の中に書きましたが、 現在のスコープ内に @foo
という配列はありません。 リテラルな @foo を指定したい場合は、\@foo と書いてください; そうでなければ、どうやら見失ってしまったらしい配列に何が起こったを 調べてください。
(S experimental::postderef) この警告は、実験的な接尾辞デリファレンス文法を 使ったときに出力されます。 この機能を使いたいけれども、そうすることで将来の Perl バージョンで 変更されるかもしれない実験的機能を使うリスクを取ることを分かっている場合は、 単に警告を抑制してください:
no warnings "experimental::postderef";
use feature "postderef", "postderef_qq";
$ref->$*;
$aref->@*;
$aref->@[@indices];
... etc ...
(S precedence) 古い変則的な構文
open FOO || die;
は現在は、Perl 5 の文法の厳しい正規化の結果、単項演算子か リスト演算子と解釈されますので、
open(FOO || die);
という風に誤った解釈がなされます。 (古い open は、単項演算子とリスト演算子の中間のようなものでした。) ファイルハンドルの前後をかっこで囲むか、"||" 演算子の代わりに "or" 演算子を使わなくてはなりません。
"Server error" を参照してください。
(W closed) 書き込みを行なおうとしたファイルハンドルは、既に閉じられています。 制御フローをチェックしてください。
(W closed) print を行なおうとしたファイルハンドルは、既に閉じられています。 制御フローをチェックしてください。
(W) *nix アプリケーションは何も出力せずに終了しますが、 OS/2 アプリケーションはこれを標準メッセージとして出力します。 これは OS/2 版の仕様とみなされています。 適切なシグナルハンドラによって簡単に無効にできます; "Signals" in perlipc を参照してください。 perlos2 の "Process terminated by SIGTERM/SIGINT" も参照してください。
(F) \p
や \P
で指定した名前付き特性は Perl が知らないものです。 おそらく名前をタイプミスしたのでは? 公式に利用可能な特性の完全な一覧については "Properties accessible through \p{} and \P{}" in perluniprops を 参照してください。 これが ユーザー定義特性 の 場合は、正規表現がコンパイルされる時点で定義されていなければなりません。
(W illegalproto) プロトタイプで % または @ に文字が引き続いています。 これは無意味です; % と @ は残りのサブルーチン引数を全て飲み込むからです。
(S prototype) 以前異なる関数プロトタイプで宣言または定義された サブルーチンが宣言または定義されました。
(F) 関数プロトタイプ宣言で、閉じかっこがありませんでした。
(W prototype) サブルーチン名の後のかっことプロトタイプ属性の両方で プロトタイプが宣言されました。 先に宣言されていたプロトタイプは属性で置き換えられるので、かっこ内の プロトタイプは無駄です。
(W) Unicode 特性マッチング(\p
または \P
)を含む正規表現を コンパイルしましたが、その正規表現は Unicode ではなく実行時ロケールを使うとも 設定されています。 代わりに、ロケールの規則を知っているはずの POSIX 文字クラスを使ってください。 ("POSIX Character Classes" in perlrecharclass を参照してください。)
たとえ実行時ロケールが Unicode のサブセットである ISO 8859-1 (Latin1) でも、 一部の特性はサブセットに対しては不正であるという結果を返します。
以下に、何が起きているかを知る助けになる例を二つ挙げます。 ロケールが ISO 8859-7 なら、符号位置 0xD7 の文字は "GREEK CAPITAL LETTER CHI" です。 しかし Unicode ではこの符号位置は "MULTIPLICATION SIGN" を意味し、 \p
は常に Unicode の意味を使います。 これは、\p{Alpha}
にはマッチングしませんが、[[:alpha:]]
には マッチングするということです。 Latin1 ロケールのみが、全ての文字について Unicode と同じ位置を持ちます。 しかし、それでも、一部の特性は正しくない結果となります。 例えば、\p{Changes_When_Uppercased}
は "LATIN SMALL LETTER Y WITH DIAERESIS" では真ですが、この文字の大文字は Latin1 にはないので、 大文字にしたときにこの文字は変更されません。
(S experimental::autoderef) スカラ引数の push
は実験的で、将来の バージョンの Perl で変更されたり削除されたりするかもしれません。 この機能を使うリスクを取る場合は、単に警告を無効にして下さい:
no warnings "experimental::autoderef";
(F) 正規表現を量指定子で開始しています。 もしそれをリテラルに使いたいなら、バックスラッシュでクォートしてください。 <-- HERE で正規表現のどこに問題が発見されたかを示しています。 perlre を参照してください。
現在のところ、{min,max} 構造の最大値と最小値には制限があります。 <-- HERE で正規表現のどこに問題が発見されたかを示しています。 perlre を参照してください。
(W regexp) 最小値は最大値以下である必要があります。 本当に 0 回マッチングする正規表現がほしいなら、単に {0} を指定してください。
(W regexp) 正規表現量指定子をゼロ幅アサーションのような意味のない場所に 適用しました。 代わりにアサーションの中に量指定子を置いてください。 例えば、"xyz" を 3 回繰り返した後の "abc" にマッチングさせるには、 /abc(?=xyz){3}/
ではなく /abc(?=(?:xyz){3})/
としてください。
<-- HERE で正規表現のどこに問題が発見されたかを示しています。
(F) 範囲演算子 ".." の一つ(または両方)の数値引数が、内部で整数として 表現できる範囲を越えています。 回避方法のひとつとしては、数値の頭に "0" を付けることで Perl に マジカル文字列インクリメントの使用を強制させることです。
(W io) 読み込もうとしたディレクトリハンドルは既に閉じられているか、 実際にはディレクトリハンドルではありません。 制御フローをチェックしてください。
(W closed) 読み込もうとしたファイルハンドルは、既に閉じられています。 制御フローをチェックしてください。
(W closed) 閉じたファイルハンドルから読み込もうとしました。
(W unopened) 開いていないファイルハンドルから読み込もうとしました。
(F) MS-DOS マシンでは、64K を越えるメモリを割り当てることはできません。
内部ルーチンが、何か既に解放されているものに対して realloc() を 呼び出しました。
(S debugging) Perl のコンパイル時に、適切な出力ルーティンが 組み込まれていなければ、-D スイッチを使うことはできません; これは、多少のオーバヘッドがかかるもので、それが現在使っている Perl に組み込んでない理由でしょう。
(P) %INC フックの内側でファイルハンドルを作る時にモジュールを読み込むのは 現在のところ許されていません。 これは、open my $fh, '<', \$scalar
で暗黙に PerlIO::scalar を読み込むときに 起こることがあります。 最初に PerlIO::scalar を明示的に読み込むことを試してください。
(F) パッケージのメソッド解決順序 (MRO) の計算中に、@ISA
構造に 無限ループがあると判断しました。 これは、@ISA
を 100 階層探索した後に起きる荒いチェックです。
(P) Perl の I/O 実装は内部の一貫性チェックに失敗しました。 このメッセージを見たなら、何かがすごく悪いです。
(W misc) Perl が(ハッシュへの代入のために)偶数の数の要素のリストを 想定しているところに 一つのリファレンスを渡しました。 これは普通かっこを使うべきところで無名ハッシュコンストラクタを使ったことを 意味します。 とにかく、ハッシュはキー/値の 組 を要求します。
%hash = { one => 1, two => 2, }; # WRONG
%hash = [ qw/ an anon array / ]; # WRONG
%hash = ( one => 1, two => 2, ); # right
%hash = qw( one 1 two 2 ); # also fine
(W misc) 既に弱いリファレンスを弱めようとしました。 そうしても何の効果もありません。
(F) 正規表現で \g0
のようなものを使いました。 捕捉用のかっこへの参照は、正数(通常の後方参照)か、負数(相対後方参照) のみです。 0 は意味を成しません。
正規表現の中で \7
のような記述がありますが、 正規表現の中に値を捕らえるかっこが 7 つありません。 正規表現の中に値 7 を持つ文字を挿入したい場合、 ゼロをつけて最低 3 桁の数値にする必要があります: \007
<-- HERE で正規表現のどこに問題が発見されたかを示しています。
(F) 正規表現中に \k'NAME'
や \k<NAME>
のようなものを使いましたが、 (?'NAME'...)
や (?<NAME>...)
のような、対応する名前付き捕捉かっこが ありません。 前方参照と定義の両方において、名前のスペルが正しいかどうか チェックしてください。
<-- HERE で正規表現のどこに問題が発見されたかを示しています。
(F) 正規表現で \g{-7}
のようなものを使いましたが、式中で \g{-7}
の 位置より前に少なくとも 7 組の捕捉用のかっこの組がありません。
<-- HERE で正規表現のどこに問題が発見されたかを示しています。
(P) 正規表現コンパイラが渡したもので、正規表現エンジンが 処理できなくなりました。
(F) 正規表現パターンに指定された修飾子が多すぎます。 余分なものを削除してください。
(F regexp) 指定された修飾子をオフにするのは他の修飾子をオンにするという 副作用があります。 Perl は現在のところこれを受け入れません。 オフにしたいものではなく、オンにしたい修飾子を使う(そしてマイナスの 前に置く)ように正規表現を書き直してください。
(F) 正規表現パターンに指定された修飾子が多すぎます。 余分なものを削除してください。
(F) 正規表現パターンに相互に排他的な修飾子が複数あります。 ここで使うであろう修飾子のみを保持します。
(P) safemalloc() が見つけるはずなので、「起こるはずのない」エラーです。
(F) フォーマットに ~~ (空白まで繰り返し)シーケンスと決して空白にならない スウチフィールドが含まれているので、無限ループになります。 代わりに ^# を使うべきでしょう。 perlform を参照してください。
(W misc) 検索リストよりも長い置換リストを使いました。 長い分の置換リストは無意味です。
(W misc, regexp) ダブルクォート風の文字列の中で \08
や \179
のような ものを書きました。 最後以外の数字は、8 進数で指定された単一の文字として扱われます。 最後の数字は文字列中の次の文字です。 これがまさしく望んでいるものであることを Perl に伝えるには、 \o{ }
構文を使うか、文字を 8 進数で指定するために正確に 3 桁を 使ってください。
(W syntax) 代入演算子を逆順に書いています。 等号の後に単項演算子が続くときに、曖昧になるのを避けるため、 代入演算子では、等号 = が、最後にこないといけません。
(W io) rewinddir() しようとしたディレクトリハンドルは既に閉じられているか、 実際にはディレクトリハンドルではありません。 制御フローをチェックしてください。
(P) Perl 内部のスカラ管理で何かがおかしくなりました: Perl 終了時に全てのスカラ変数が解放されませんでした。 これは普通メモリリークを示していて、これはもちろん悪いことですが、 Perl プログラムが長い間動作する場合には特にそうです。
(W syntax) 配列の一つの要素を選ぶのに、(@ で示される) 配列 スライスを用いました。 一般には、($ で示される) スカラ値を使った方が良いと思われます。 違いは、$foo[&bar]
とした場合、代入の対象としたときにも、 添字を評価するときにも、常にスカラとして振る舞うのに対し、 @foo[&bar]
の場合には、代入の対象としてもリストとして振る舞い、 添字にもリストコンテキストを与えることになります; これは、一つの添字だけを期待するときには、おかしなこととなるでしょう。
一方、もし本当に配列要素をリストとして扱いたい場合、リファレンスが どのように働くかについて詳しく知る必要があります; なぜなら Perl はスカラとリストを自動的に変換したりはしないからです。 perlref を参照してください。
(W syntax) ハッシュの一つの要素を選ぶのに、(@ で示される) ハッシュ スライスを用いました。 一般には、($ で示される) スカラ値を使った方が良いと思われます。 違いは、$foo{&bar}
とした場合、代入の対象としたときにも、 添字を評価するときにも、常にスカラとして振る舞うのに対し、 @foo{&bar}
の場合には、代入の対象としてもリストとして振る舞い、 添字にもリストコンテキストを与えることになります; これは、一つの添字だけを期待するときには、おかしなこととなるでしょう。
一方、もし本当にハッシュ要素をリストとして扱いたい場合、リファレンスが どのように働くかについて詳しく知る必要があります; なぜなら Perl はスカラとリストを自動的に変換したりはしないからです。 perlref を参照してください。
(F) // もしくは m{} 構文の最後の区切り文字が見つかりませんでした。 かっこ類の区切り文字では、ネストを数えることを忘れないでください。 $m
変数の前に $
をつけるのを忘れるとこのエラーが出ることがあります。
Perl 5.10.0 から、// は defined-or 構文として扱われ、単なる 空検索パターンではありません。 従って、Perl 5.10.0 以降で書かれた、// を defined-or として使っている コードは、5.10.0 以前の Perl では、終端していない検索パターンとして 誤パースされるかもしれません。
(F) 構文解析器が ?PATTERN?
構造の最後のデリミタを見つけられませんでした。
クエスチョンマークは (foo ? 0 : 1
のような) 3 項演算子の一部としても 使われるので、紛らわしい構造の場合は間違ってパースされることがあります。 パースのあいまいさをなくすための一つの方法は、(foo) ? 0 : 1
のように 条件式をかっこで括ることです。
(W io) seekdir() しようとしたディレクトリハンドルは閉じられているか、 実際にはディレクトリハンドルではありません。 制御フローをチェックしてください。
(W unopened) オープンされていないファイルハンドルか、既にクローズされた ファイルハンドルに対して、seek() 関数や sysseek() 関数を使おうとしました。
(F) このマシンでは、select() システムコールは実装されていません。
(F) 配列やハッシュの自己 tie は現在の実装では対応していません。
(W semicolon) この付近の構文エラーは、おそらくセミコロンか、コンマなどの 演算子がなかったために起こったものと考えられます。
(S internal) 既に解放と印を付けたスカラを複製するために、内部の newSVsv() ルーティンが呼ばれました。
(F) このシステムでは、System V セマフォ IPC は使えません。
(W closed) 送信を行なおうとしたソケットは、既に閉じられています。 制御フローをチェックしてください。
(F) 正規表現が不完全な拡張 (? で終わっています。 <-- HERE で正規表現のどこに問題が発見されたかを示しています。 perlre を参照してください。
(F) 使おうとした正規表現の拡張は、予約された文字ですが、 まだ実装されていません。 <-- HERE で正規表現のどこに問題が発見されたかを示しています。 perlre を参照してください。
(F) お使いになった正規表現の拡張は、意味をなしません。 <-- HERE で正規表現のどこに問題が発見されたかを示しています。 これは、 Perl にデフォルトの正規表現修飾子を使うように知らせるために (?^...)
構文を使ったときや、デフォルトの演算子を冗長に指定しています。 その他の理由については、perlre を参照してください。
(F) 正規表現のコメントは閉じかっこで終わらなければなりません。 組み込みのかっこは許可されません。 perlre を参照してください。
(F) (?&...)
の形式の名前付きリファレンスで、名前の後の最後の閉じかっこが ありません。 <-- HERE で正規表現のどこに問題が発見されたかを示しています。
(F) (?'...')
または (?<...>)
の形式の名前付きグループで、名前の後の 最後の閉じクォートまたは山かっこがありません。 <-- HERE で正規表現のどこに問題が発見されたかを示しています。
(F) (?('...')...)
または (?(<...>)...)
の形式の名前付き リファレンスで、名前の後の最後の閉じクォートまたは山かっこがありません。 <-- HERE で正規表現のどこに問題が発見されたかを示しています。
(F) 正規表現でエスケープシーケンスの後に必須の引き数を想定しましたが、 それが省略されているか適切に書かれていません。
(F) {} の中に含まれている perl コードの末尾は直後に ')' が 引き続かなければなりません。
(F) (?P=...)
の形式の名前付きリファレンスで、名前の後の最後の 閉じかっこがありません。 <-- HERE で正規表現のどこに問題が発見されたかを示しています。
(F) 正規表現中の (?R)
または (?0)
で最後のかっこがありません。
(A) これは、一般的には CGI (SSI を含みます)プログラムを WWW 越しに 実行しようとしたときにブラウザのウィンドウに表示されるメッセージです。 実際のエラーテキストはサーバーによって大きく異なります。 もっともよく見られるものとしては、"500 Server error", "Method (something) not permitted", "Document contains no data", "Premature end of script headers", "Did not produce a valid header" が あります。
これは CGI のエラーであり、Perl のエラーではありません.
まずはあなたのスクリプトが実行可能か、CGI を実行するユーザー(これはおそらく あなたがテストしたユーザーではありません)で読み込み可能か、実行しているのとは 異なるユーザーの環境変数(PATH など)に依存していないか、CGI サーバーが 見つけられない場所に置いていないか、といったことを確認する必要があるでしょう。 さらなる情報については以下を参照してください。
http://www.perl.org/CGI_MetaFAQ.html
http://www.htmlhelp.org/faq/cgifaq.html
http://www.w3.org/Security/Faq/
perlfaq9 も見るべきでしょう。
(F) $)
へ代入を行なおうとしましたが、この OS では、setegid() システムコール (または、同等のもの) がサポートされていません; 少なくとも Configure では、そう判断されました。
(F) $>
へ代入を行なおうとしましたが、この OS では、seteuid() システムコール (または、同等のもの) がサポートされていません; 少なくとも Configure では、そう判断されました。
(F) このシステムの setpgrp() は BSD 4.2 由来のもので、引数がありません; POSIX setpgid() はプロセス ID とプロセスグループ ID を引数にとります。
(F) $(
へ代入を行なおうとしましたが、この OS では、setrgid() システムコール (または、同等のもの) がサポートされていません; 少なくとも Configure では、そう判断されました。
(F) $<
へ代入を行なおうとしましたが、この OS では、setruid() システムコール (または、同等のもの) がサポートされていません; 少なくとも Configure では、そう判断されました。
(W closed) 閉じているソケットにソケットオプションを設定しようとしました。 socket() の呼び出し時に、返却値のチェックを忘れたのではありませんか? "setsockopt" in perlfunc を参照してください。
(W deprecated) リファレンス先のアイテムが正の整数でないときに、 $/
にスカラへの整数を代入しました。 以前の perl ではこれは undef
を設定するのと同じように 見えました が、 内部的には異なっていて、より非効率で、とても運が悪い場合はファイルが このリファレンスの文字列化形式で split されることになっていました。
Perl 5.20.0 でこれは変更され、これはこの警告が投げられることを除いては $/
に undef を設定するのと 正確に 同じになりました。
ファイル全体を読み込みたい場合は、明示的に $/
に undef
を 設定するようにコードを変更することを勧めます。 将来のバージョンの Perl では、リファレンスの代入は致命的エラーになります。
(F) 非整数へのリファレンスを $/
に代入しようとしました。 以前の Perl ではこれは正の整数(リファレンスのアドレス)へのリファレンスを 設定するのと似たように振る舞っていました。 将来のバージョンの Perl で非整数リファレンスをより興味深い目的に使えるように Perl 5.20.0 から、これは致命的エラーになりました。
(S experimental::autoderef) スカラ引数の shift
は実験的で、将来の バージョンの Perl で変更されたり削除されたりするかもしれません。 この機能を使うリスクを取る場合は、単に警告を無効にして下さい:
no warnings "experimental::autoderef";
(F) このシステムでは、System V 共有メモリ IPC は使えません。
(W syntax) 非マッチ演算子は !=~ ではなく !~ です。 !=~ は != (数値の不一致) と ~ (1 の補数) 演算子と解釈されます: おそらくあなたの意図していることではないでしょう。
(F) require 'file'
と書くべきところで require <file>
と 書いています。
(W syntax) join
の最初の引数として、Perl が文字列を想定しているところに パターンを使いました。 Perl は $_ をパターンマッチングした結果の真か偽の値を文字列として 扱いますが、これはおそらく望んでいることではないでしょう。
(W closed) クローズされたソケットに shutdown を行なおうとしました。 多少、無駄のように思われます。
(W signal) %SIG 内で指定したシグナルハンドラが、存在しません。 間違ったパッケージで、設定を行なっているのかもしれません。
(S) このメッセージが出た場合、構文木の内部管理で何かひどく 悪いことになっています。 ある構文木がコンパイルエラーの後で解放される必要がありますが、 見つからないので、リークしています。
(W overflow) 確実に扱えるよりも大きな値で sleep
を呼び出したので、 sleep
はおそらく指定されたより短い時間だけスリープします。
(F) サブルーチンシグネチャの中で、吸い込み(配列またはハッシュ)パラメータの後に 何かを起きました。 吸い込みパラメータは利用可能な全ての引数を取るので、その後のパラメータに 対応するものを残しません。
(F) オーバーロードしていないオブジェクトに対して ~~
演算子を 使うべきではありません: Perl はスマートマッチング時にオブジェクトの 基礎となる構造を使うことを拒否します。
(S experimental::smartmatch) この警告は、スマートマッチング (~~
) 演算子を 使ったときに出力されます。 これは現在のところ実験的な機能で、Perl の将来のリリースでは変更される 可能性があります。 特に、現在の実装は不必要に複雑かつ直感的でないとされており、ほぼ確実に 見直されます。
(F) もはや、誰もお目にかかることのない、旧世代のエラーメッセージです。 ただ、sort がキーワードとなる前には、これをファイルハンドルとして 使う方がいました。
(F) XS で書かれたソート比較サブルーチンは正確に一つのアイテムを 返さなければなりません。 "sort" in perlfunc を参照してください。
(F) eval
に渡された文字列の中で(通常はソースフィルタモジュールを 読み込むことで)ソースフィルタを有効にしようとしました。 これは unicode_eval
機能が有効の場合は許されていません。 代わりに evalbytes
を使うことを検討してください。 feature を参照してください。
(W misc) splice() で渡された配列の末尾より後ろのオフセットを指定しました。 splice は配列の末尾ではなく、配列の最後の位置に対して実行されます。 これが望んでいることではないなら、$#array = $offset と代入することで 明示的に事前に配列を拡張してください。 "splice" in perlfunc を参照してください。
(S experimental::autoderef) スカラ引数の splice
は実験的で、将来の バージョンの Perl で変更されたり削除されたりするかもしれません。 この機能を使うリスクを取る場合は、単に警告を無効にして下さい:
no warnings "experimental::autoderef";
(P) split が無限ループに陥りました。 (明らかに、split は、入力文字数以上にはできないはずですが、 そうなってしまいました。) "split" in perlfunc を参照してください。
(W exec) exec() の後に、die() 以外の実行文があります。 失敗したとき以外は、exec() から戻ってくることはありませんから、 ほとんどの場合には誤りでしょう。 戻ってくるsystem() に置き換える必要があるかもしれません。 この警告を止めるには、ブロック内に exec() だけを記述してください。
(W syntax) パッケージ変数 $a と $b はソート比較のために使われます。 $a または $b をソート比較ブロックの中の <=>
または cmp
演算子の オペランドとして使いましたが、この変数はその前にレキシカル変数として 宣言されています。 ソート変数をパッケージ名で修飾するか、レキシカル変数の名前を変えてください。
(F) 字句スコープの変数は、パッケージ内に置かれませんので、 頭にパッケージ名を付けて宣言することは、無意味です。 パッケージ変数をローカル化したい場合には、local() を使ってください。
(W unopened) オープンされていないファイルハンドルか、既にクローズされた ファイルハンドルに対して、stat() 関数を使おうとしました。
(W utf8) 0xFF を超える符号位置を含むスカラに対して、読み込みや追加で スカラへのリファレンスを開こうとしました。 インメモリファイルはディスクのファイルをモデル化していて、バイトのみが 使えます。
(P) @ISA ツリーでのオーバーロードの解決がインポートのスタブで壊されました。 スタブは暗黙に作られることはありませんが、明示的に can
を呼び出すと これを破壊することがあります。
(W closure) コンパイル時に、内部の名前付きサブルーチンや eval が、現在 利用できない外側のレキシカルサブルーチンを捕捉しようとしました。 これは二つの理由で起こります。 まず、レキシカルサブルーチンが、まだ作成されていない外側の無名サブルーチンで 宣言されたときです。 (名前付きサブルーチンはコンパイル時に作成されますが、無名サブルーチンは 実行時に作成されることを思い出してください。) 例えば、
sub { my sub a {...} sub f { \&a } }
f が作成された時点で、現在の "a" サブルーチンは捕捉できません; なぜなら 無名サブルーチンはまだ作成されていないからです。 逆に、以下のものは警告されません; 無名サブルーチンはこの時点で作成されていて 生きているからです:
sub { my sub a {...} eval 'sub f { \&a }' }->();
2 番目の状況は eval がスコープ外となったレキシカルサブルーチンに アクセスすることで起こります; 例えば:
sub f {
my sub a {...}
sub { eval '\&a' }
}
f()->();
ここで、eval の中の '\&a' がコンパイルされるとき、f() はこの時点では 実行されていないので、&a は捕捉として利用できません。
(W misc) "my" または "state" サブルーチンは現在のスコープまたは文で 再定義されたため、事実上以前の実体への全てのアクセスが取り除かれます。 これはほとんど常にタイプミスです。 最初のサブルーチンはスコープの末尾に到達するか、これを参照している 全てのクロージャが破壊されるまで存在したままであることに注意してください。
(W redefine) サブルーチンを再定義しました。 この警告を止めるには以下のようにしてください:
{
no warnings 'redefine';
eval "sub name { ... }";
}
(P) 置換が無限ループに陥りました。 (明らかに、置換は入力文字数以上には起こらないはずですが、 それが起こってしまいました。) "Quote and Quote-Like Operators" in perlop を参照してください。
(F) s/// もしくは s{}{} 構文の真ん中の区切り文字が見つかりませんでした。 かっこ類の区切り文字では、ネストを数えることを忘れないでください。 $s
変数の前に $
をつけるのを忘れるとこのエラーが出ることがあります。
(F) s/// もしくは s{}{} 構文の最後の区切り文字が見つかりませんでした。 かっこ類の区切り文字では、ネストを数えることを忘れないでください。 $s
変数の前に $
をつけるのを忘れるとこのエラーが出ることがあります。
(W substr)(F) 文字列の外を指す substr() を参照しようとしました。 つまり、オフセットの絶対値が、文字列の長さより大きくなっています。 "substr" in perlfunc を参照してください。 この警告は、substr が(代入の左側やサブルーチンの引数といった) 左辺値として使われた場合は致命的となります。
(P) Perl は SV を、実際には現在の型より下位の型への昇格を 強制しようとしました。
(P) Perl が Unicode 文字を探そうとしたときに、内部で何かがおかしくなりました。
(F) (?(condition)if-clause|else-clause) 構造は最大で二つの分岐 (if-clause と else-clause) を持つことができます。 片方、または両方に選択肢を含めたいときは、それをかっこで囲んでください:
(?(condition)(?:this|that|other)|else-clause)
<-- HERE で正規表現のどこに問題が発見されたかを示しています。 perlre を参照してください。
(?(...)if-clause|else-clause) 構造の条件部が不明です。 条件は以下のいずれかでなければなりません。
(1) (2) ... true if 1st, 2nd, etc., capture matched
(<NAME>) ('NAME') true if named capture matched
(?=...) (?<=...) true if subpattern matches
(?!...) (?<!...) true if subpattern fails to match
(?{ CODE }) true if code returns a true value
(R) true if evaluating inside recursion
(R1) (R2) ... true if directly inside capture group 1, 2, etc.
(R&NAME) true if directly inside named capture
(DEFINE) always false; for defining named subpatterns
<-- HERE で正規表現のどこに問題が発見されたかを示しています。 perlre を参照してください。
(F) use filetest
プラグマを使っている間に、 実と実効の UID や GID の切り替えに失敗しました。
(F) おそらく、構文エラーが起こっています。 よくある原因としては以下のことが考えられます:
キーワードのスペルミス。
セミコロンを忘れた。
コンマを忘れた。
開きかっこ、閉じかっこを忘れた。
開き中かっこ、閉じ中かっこを忘れた。
クォートの閉じ忘れ。
多くの場合、構文エラーと一緒に、別のエラーメッセージが出て、 情報を与えてくれます。(-w を付けることが、助けになることもあります。) エラーメッセージ自身には、何行目まで行って、諦めたのかということも 含まれています。 Perl はでたらめな入力を理解するのが得意なので、実際のエラーはもう少し前に 在ることもあります。 ときには、行番号が全く役に立たないこともあり、はまってしまったなら、 エラーのきっかけが何かを見つける唯一の手段は、プログラムを寸断して、 エラーがなくなるまで、perl -c を繰り返すしかありません。 頭の体操 20 問だと思ってください。
(A) スクリプトを perl ではなく Bourne shell で実行しようとしました。 #! 行をチェックするか、スクリプトを直接 Perl で起動してください。
(F) このエラーは、perl5 のスクリプトを perl4 インタプリタで実行したときに おきそうなものです; 特に次の二つのトークンが "use strict" か "my $var" か "our $var" の場合はそうです。
(F) Perl はこの構文の中で何を意味しようとしているのかが分かりませんでした; これは試すのを諦めたことを知らせます。
(F) perl -c
が成功したときの最終まとめメッセージです。
(W closed) 閉じたファイルハンドルから読み込もうとしました。
(W unopened) 開いていないファイルハンドルから読み込もうとしました。
(F) 何か、名前が "sem"、"shm"、"msg" で始まる関数を実行しようとしましたが、 あなたのマシンには System V IPC が実装されていません。 機能はあっても設定されていない場合もあります。 システムサポートに相談してください。
(W closed) 書き込みを行なおうとしたファイルハンドルは、既に閉じられています。 制御フローをチェックしてください。
-T
and -B
not implemented on filehandles(F) Perl が、お使いの stdio のことをよく知らないとき、 ファイルハンドルの stdio バッファを覗くことはできません。 代わりにファイル名を使わなければなりません。
(F) goto
で、Perl が届かないほど深くネストしたラベルに移動しようとしました。 Perl は親切にもこれを拒否します。
(W io) telldir() しようとしたディレクトリハンドルは既に閉じられているか、 実際にはディレクトリハンドルではありません。 制御フローをチェックしてください。
(W unopened) オープンされていないファイルハンドルか、既にクローズされた ファイルハンドルに対して、tell() 関数を使おうとしました。
(F) 現在、$[
への代入は、厳しく制限され、コンパイラ指示子と解釈されます。 使えるのは以下の形だけです:
$[ = 0;
$[ = 1;
...
local $[ = 0;
local $[ = 1;
...
これは、一つのモジュールで、他のモジュールが意図しないような、 配列のベースを変更する問題を回避するためのものです。 "$[" in perlvar と arybase を参照してください。
(F) Configure は、マシン上で crypt() 関数を見つけられませんでした; おそらく、ベンダからの供給がなかったからで、おそらく、ベンダは アメリカ政府がそれを秘密だとしていると思っているか、 少なくとも思っているというふりをしているのでしょう。 私を引き合いに出したところで、それは否定されることでしょう。
(F) この関数は、Configure の調査によると、このアーキテクチャでは、 実装されていないようです。
(S experimental::lexical_subs) この警告は、サブルーチンを my
または state
で宣言すると出力されます。 この機能を使いたいけれども、そうすることで将来の Perl バージョンで 変更されるかもしれない実験的機能を使うリスクを取ることを分かっている場合は、 単に警告を抑制してください:
no warnings "experimental::lexical_subs";
use feature "lexical_subs";
my sub foo { ... }
(S experimental::regex_sets) この警告は、正規表現で (?[ ])
構文を 使うと出力されます。 この機能の詳細は変更されることがあります。 この機能を使いたいけれども、そうすることで将来の Perl バージョンで 変更されるかもしれない実験的機能を使うリスクを取ることを分かっている場合は、 以下のようにして警告を黙らせられます:
no warnings "experimental::regex_sets";
(S experimental::signatures) この警告は、シグネチャを使ったサブルーチンの 引数を展開するときに出力されます。 この機能を使いたいけれども、そうすることで将来の Perl バージョンで 変更されるかもしれない実験的機能を使うリスクを取ることを分かっている場合は、 単に警告を抑制してください:
no warnings "experimental::signatures";
use feature "signatures";
sub foo ($left, $right) { ... }
(F) 過去の stat がシンボリックリンクを通り過ぎた、実際のファイルの 情報を取って、stat バッファに入れているときに、シンボリックタイプの stat をカレント stat バッファに対して行なっても意味がありません。 実際のファイル名を使ってください。
(F) この属性は my
や sub
の宣言では対応していません。
(W internal) VMS に固有の警告です。 CRTL の内部環境配列を変更または削除しようとしましたが、この Perl は setenv() 関数を含んだ CRTL でビルドされていません。 これを含む CRTL を使って Perl を再ビルドするか、環境配列がこの警告を 出力している %ENV を変更するターゲットとならないように PERL_ENV_TABLES (perlvms を参照してください) を再定義してください。
(F) 何かが、Perl がデフォルトで対応しているランダム化されたハッシュキー検索に 依存した 内部 API 呼び出しを使おうとしましたが、この Perl はそれなしで コンパイルされていました。 この警告を関係する上流グループに報告するか、デフォルトオプションで perl を 再コンパイルしてください。
(F) お使いの C ライブラリでは、times() を行わないようです。 UNIX ではない環境でしょうか。
(X) Perl スクリプトの #! 行(あるいはローカルで等価なもの)に -T オプション (または -t オプション) が含まれていますが、Perl は コマンドラインで -T 付きで起動されていません。 Perl がスクリプトの中で -T を発見した時点では、環境からの全てを 汚染チェックするには遅すぎるので、これはエラーになります。 それで Perl は諦めます。
perl スクリプトが #! 機構(またはローカルな等価な機構)を使ってコマンドとして 実行される場合、このエラーは普通 -%c オプションを Perl の最初の引数に 変更する(perl -n -%c
を perl -%c -n
に変更する)ことで修正されます。
Perl スクリプトが perl scriptname
として起動される場合、-T オプションは コマンドラインに書かなければなりません: perl -%c scriptname
(F) lc(), lcfirst, uc(), or ucfirst() (またはこれらの文字列組み込み版)の ためのカスタマイズされた変換先マッピングを定義しようとしましたが、 不正なマッピングを指定しました。 "User-Defined Character Properties" in perlunicode を参照してください。
(F) テンプレートに、おかしいぐらいネストした () グループがあります。
(F) syscall() には、最低限でも呼び出すシステムコールを示す、 引数が一つ必要です。
(F) シグネチャを使っているサブルーチンが、シグネチャが要求しているよりも 少ない引数を受け取りました。 おそらくサブルーチンの呼び出し元が間違っています。 不便なことに、このエラーは呼び出し元ではなく、サブルーチンの位置で 報告されます。
(X) Perl スクリプトの #! 行(またはローカルな等価な機構)に -M, -m, -C オプションが含まれています。
-M と -m に関しては、スクリプト内部で使うためのものではないので、 これはエラーになります。 代わりに use
プラグマを使ってください。
-C オプションは、コマンドラインも (以下と同じ文字と数値の並びで) 指定されたときにのみ動作します。 このオプションをコマンドラインで指定するか、もしシステムが対応しているなら、 スクリプトを perl に渡すのではなく、スクリプトを実行可能にして 直接実行してください。
(W void) CHECK か INIT のブロックが、それが実行される機会が過ぎてから 実行時に定義されました。 おそらく use
を使うべきときに require
か do
を使ってファイルを 読み込んでいます。 あるいはおそらく BEGIN ブロックの中に require
か do
を 書いたのでしょう。
(F) Perl では、syscall() に最大 14 までしか、引数を渡すことができません。
(F) 関数が要求する以上の引数を指定しました。
(F) シグネチャを使っているサブルーチンが、シグネチャが要求しているよりも 多い引数を受け取りました。 おそらくサブルーチンの呼び出し元が間違っています。 不便なことに、このエラーは呼び出し元ではなく、サブルーチンの位置で 報告されます。
(A) スクリプトを perl ではなく csh で実行しようとしました。 #! 行をチェックするか、スクリプトを直接 Perl で起動してください。
(A) スクリプトを perl ではなく csh で実行しようとしました。 #! 行をチェックするか、スクリプトを直接 Perl で起動してください。
(F) 正規表現が、バックスラッシュを付けていないバックスラッシュで 終了しました。バックスラッシュを付けてください。 perlre を参照してください。
(D) スペース文字で終わる文字名を定義しました。 末尾のスペースを取り除いてください。 普通はこれらの名前は use charnames
の :alias
インポート引数で 定義されますが、$^H{charnames}
にインストールされた変換器で 定義されているかも知れません。 "CUSTOM ALIASES" in charnames を参照してください。
(F) tr///, tr[][], y///, y[][] 構文の真ん中の区切り文字が 見つかりませんでした。 $tr
変数 や $y
変数の前に $
をつけるのを忘れると このエラーが出ることがあります。
(F) tr///, tr[][], y///, y[][] 構文の最後の区切り文字が 見つかりませんでした。
(F) Safe 区画の中で、許されていない演算子を使おうとしました。 Safe を参照してください。
(F) このマシンでは、Configure が知りうる、ファイルの切り詰めの機能が 実装されていません。
(F) CORE パッケージにある問題のサブルーチンは、引数に特定の型のデータへの ハードリファレンスを要求しています。 オーバーロードは無視されるので、指定された型ではないけれども、それを 扱えるようにオーバーロードされたオブジェクトへのリファレンスでも 受け付けられません。
(F) この関数は、その位置に決まった型の引数を必要とします。 配列は、@NAME もしくは @{EXPR}
でなりません。 ハッシュは、%NAME もしくは %{EXPR}
でなければなりません。 暗黙の被参照は許されませんので、明示的な被参照として、 {EXPR} 形式を使ってください。 perlref を参照してください。
(F) bless されていないハッシュや配列へのリファレンスでないスカラ引数を使って keys
, values
, each
を呼び出しました。
(F) umask 関数が実装されていないマシンで、自分自身の権限を制限する (EXPR & 0700) ためにこれを使おうとしました。
(S internal) いくつの実行コンテキストに入って、出たかということの 内部矛盾が exit コードで発見されました。
(S internal) いくつの値が、一時的にローカル化されたかということの 内部矛盾が exit コードで発見されました。
(S internal) いくつのブロックに入って、出たかということの 内部矛盾が exit コードで発見されました。
(S internal) 終了時に、ハッシュキーのためのコピーオンライトのための 共有文字列テーブルに文字列が残っていることを Perl が発見しました。 エントリは開放されている必要があるので、これはどこかにバグがあることを 示しています。
(S internal) いくつの揮発性スカラの割り当てを行ない、解放したかと いうことの内部矛盾が exit コードで発見されました。
(F) 示されたフォーマットが存在しないようです。 おそらく本当は他のパッケージにあるのでは? perlform を参照してください。
(F) 指定された sort の比較ルーティンは存在していないように思われます。 おそらく、別のパッケージに存在するのではないでしょうか。 "sort" in perlfunc を参照してください。
(F) 指定されたサブルーチンが定義されていません; 定義されていたとしても、 既に未定義になっています。
(F) 呼びだそうとしている無名のサブルーチンは、定義されていません; 定義されていたとしても、既に未定義になっています。
(F) 指定された sort の比較ルーティンは宣言されましたが、 定義されていないようです。 "sort" in perlfunc を参照してください。
(F) 示されたフォーマットが存在しないようです。 おそらく本当は他のパッケージにあるのでは? perlform を参照してください。
(W misc) *foo = undef
のように、未定義値を型グロブに代入しました。 これは何もしません。 本当は undef *foo
としたかったのかもしれません。
(A) スクリプトを perl ではなく csh で実行しようとしました。 #! 行をチェックするか、スクリプトを直接 Perl で起動してください。
(F) unexec() ルーティンが何らかの理由によって失敗しました。 最初にインストールしたであろう、サイトの FSF 代表者にたずねてみてください。
(F) 以下のようなものを書きました:
(?[ | \p{Digit} ])
ここで "|"
は右側にはオペランドがありますが、左側にはオペランドがない 2 項演算子です。
(F) 以下のようなものを書きました:
(?[ z ])
(?[ ])
の中では、次のようにさらに内側の大かっこの内側でない限り リテラル文字は許されません
(?[ [ z ] ])
もう一つの可能性は、逆スラッシュを忘れたことです。 Perl はあなたが何を意味しているのかを見つけ出せるほど賢くはありませんでした。
(P) 左辺値コンテキストでのサブルーチン呼び出しをコンパイルするときに、Perl は 内部一貫性チェックに失敗しました。 不正な構文木に遭遇しました。
(S) PL_exit_flags
に PERL_EXIT_WARN
が設定されているときに exit() が 呼び出されたりその他の理由で通常終了しました。
(S) PL_exit_flags
に PERL_EXIT_WARN
が設定されているときに 捕らえられていない die() が呼び出されました。
(F) 以下のようなものを書きました:
(?[ ( \p{Digit} + ) ])
")"
の場所がおかしいです。 何かを数値と結合しようとしていたのか、"+"
があるべきでないのか、あるいは 似たような何かです。 Perl は何を意図しているのかが分かりませんでした。
(F) 以下のようなものを書きました:
(?[ \p{Digit} ( \p{Lao} + \p{Thai} ) ])
これらは "("
の前の演算子であるべきです; ラオ語やタイ語で数字とこれらの 文字がどのように結びつくかの指示がないからです。
(S nonchar) U+FFFE や U+FFFF のようないくつかの符号位置は Unicode 標準によって非文字として指定されています。 これらは有効な符号位置ですが、内部使用のために予約されています; 従って、 アプリケーションはこれを交換しようとするべきではありません。 アプリケーションは、これらの文字を想定するべきではなく、これらを 受け取るとバグを引き起こすことがあります。 もし自分が何をしているかを理解しているなら、no warnings 'nonchar';
で 警告を無効にできます。
これは実際には「重大な」エラーではありませんが、例え警告が有効でなくても デフォルトで発生させることになっていて、今のところ Perl で出来る唯一のことは これを重大なものとして扱うことです。
(S surrogate) 受け付けられないと考えられる場所に UTF-16 サロゲートを 使いました。 これらの符号位置、U+D800 から U+DFFF (両端含む) は UTF-16 のためだけに Unicode によって使われます。 しかし Perl は、サロゲートを含む、内部で全ての符号なし整数の符号位置(最大値は プラットフォームで利用可能なサイズ上限)を受け付けます。 しかし、これらは入力や出力になるときに問題を引き起こします; それは おそらくこのメッセージが出た場所です。 自分で何をしているのかが本当に本当に分かっているなら、 no warnings 'surrogate';
とすることでこの警告をオフにできます。
(F) \N{}
の内側で使った名前は Perl が知らないものでした。 綴りをチェックしてください。 use charnames ":loose"
と指定することで、標準 Unicode 名の空白、ハイフン、 大文字小文字についてはそれほど正確でなくてもいいようになります。 (作成されたカスタム別名は、:loose
のありなしに関わらず正確に 指定されなければなりません。) このエラーは、\N{}
が、対応する use charnames
のスコープ内に ないときにも起こることがあります。
(P) Perl は $@
のエラーメッセージを表示しようとしましたが、$@
変数が (たとえ作ろうとした後でも) 存在しませんでした。
(F) 3 引数 open() の 第 2 引数が以下の有効なモードの どれでもありませんでした: <
, >
, >>
, +<
, +>
, +>>
, -|
, |-
, <&
, >&
(W layer) 不明な層をPerl I/O システムに追加しようとしました。 (層はデータの外部表現と内部表現の変換を扱います。) mmap
のような層は、全ての環境で対応しているわけではないことに 注意してください。 明示的に失敗する操作を要求していないのであれば、これは環境変数 PERLIO の 値が原因かもしれません。
(P) VMS に固有のエラーです。 Perl は %ENV を反復する前に %ENV から値を読み込み、Perl が想定している データストリームの中に誰かがメッセージを差し込みました。 誰かはとても混乱しているか、邪悪な目的のために %ENV の Perl の集団を 滅亡させようとしています。
(F) 正規表現で、閉じデリミタの直後の英数字は Perl によって正規表現への 修飾子フラグと解釈されます。 その一つが不正でした。 これが起きる一つの可能性は、正規表現の終わりと引き続く英数字演算子の間に 空白を置いていない場合です:
if ($a =~ /foo/and $bar == 3) { ... }
"a"
は正当な修飾子フラグですが、"n"
は違うので、このエラーが起こります。 おそらくしたかったのは以下のようなことでしょう:
if ($a =~ /foo/ and $bar == 3) { ... }
(W) "re" プラグマの、不明なサブプラグマを使おうとしました。
(?(...)if-clause|else-clause) 構造の条件部が不明です。 条件は以下のいずれかでなければなりません。
(1) (2) ... true if 1st, 2nd, etc., capture matched
(<NAME>) ('NAME') true if named capture matched
(?=...) (?<=...) true if subpattern matches
(?!...) (?<!...) true if subpattern fails to match
(?{ CODE }) true if code returns a true value
(R) true if evaluating inside recursion
(R1) (R2) ... true if directly inside capture group 1, 2, etc.
(R&NAME) true if directly inside named capture
(DEFINE) always false; for defining named subpatterns
<-- HERE で正規表現のどこに問題が発見されたかを示しています。 perlre を参照してください。
(F) 不明な Unicode オプションを指定しました。 オプションの一覧については、perlrun ドキュメントの -C
オプションを 参照してください。
(F) 不明な Unicode オプションを指定しました。 オプションの一覧については、perlrun ドキュメントの -C
オプションを 参照してください。
(F) タイプミスをしたか、間違ってパターン中の開き大かっこの後に *
量指定子を書いたかどちらかです。 パターンをチェックして、有効な動詞パターンの詳細については perlre を再チェックしてください。
(F) warnings
プラグマによるエラーです。 現在のところ perl が知らない警告カテゴリを指定しました。
(use warnings 'File::Find'
のように)モジュールによって登録される 警告カテゴリを有効にしたい場合、このモジュールを先に読み込む必要が あることに注意してください。
(F) 以下のようなものを書きました:
(?[ [:digit: ])
次のように書くべきです:
(?[ [:digit:] ])
(F) 以下のようなものを書きました:
(?[ [:alnum] ])
次のように、二つ目の ":"
が必要です:
(?[ [:alnum:] ])
(F) 文字クラスの周りの大かっこが一致していません。 文字クラスに閉じ大かっこを含めたい場合は、バックスラッシュをつけるか 先頭に置いてください。 <-- HERE で正規表現のどこに問題が発見されたかを示しています。 perlre を参照してください。
(F) 正規表現の中ではバックスラッシュのついていないかっこは常に 対応していなければなりません。 vi ユーザーであれば、% キーが対応するかっこの発見に有用です。 <-- HERE で正規表現のどこに問題が発見されたかを示しています。 perlre を参照してください。
(F) 文法解析器が、閉じ中かっこや大かっこが開きかっこよりも多いことを 見つけました; おそらく対応する開きかっこを忘れたのでしょう。 一般的な規則として、忘れたかっこ(そう呼ぶなら)はあなたが最後に編集した 場所の近くにあります。
(W) いつの日にか、予約語とかち合うかもしれない、裸の単語を使用しています。 そのような単語は、クォートするか、大文字を入れるか、アンダーバー (_) を いれるかしてください。 その裸の単語は、サブルーチンとして宣言することも可能です。
(F) Perl パーサーは、Perl スクリプト(または eval) で指定された桁数あたりに 出てきた文字に対してどうすればよいか分かりませんでした。 おそらく圧縮したスクリプト、バイナリプログラム、ディレクトリといったものを Perl プログラムとして実行しようとしたのでしょう。
(F) Perl の内部文字クラスとして認識されない逆スラッシュ文字並びを使いました。 これは文字クラスが (?[ ])
の中で使われた時は致命的エラーです。
(W regexp) Perl 内部文字クラスで認識できない、バックスラッシュ-文字の 組み合わせを使いました。 文字はリテラルに処理されますが、将来のバージョンの Perl では 変更されるかもしれません。 <-- HERE で正規表現のどこにエスケープが発見されたかを示しています。
(W misc) Perl が理解できないバックスラッシュ-文字の組み合わせが 使われています。 文字はリテラルに処理されますが、将来のバージョンの Perl では 変更されるかもしれません。
(W regexp) Perl が認識できない、バックスラッシュ-文字の組み合わせが 使われています。 文字はリテラルに処理されますが、将来のバージョンの Perl では 変更されるかもしれません。 <-- HERE で正規表現のどこにエスケープが発見されたかを示しています。
(F) kill() 関数に、認識できないシグナル名を指定しました。 お使いのシステムで使用可能なシグナル名を調べるには、 シェル上で kill -l
などとしてください。
(F) Perl に間違ったオプションを指定しました。 これを行なってはいけません。 (指定したつもりがないのであれば、#! 行に間違ったオプションが スイッチが指定されていないかをチェックしてください。)
(S experimental::autoderef) スカラ引数の unshift
は実験的で、将来の バージョンの Perl で変更されたり削除されたりするかもしれません。 この機能を使うリスクを取る場合は、単に警告を無効にして下さい:
no warnings "experimental::autoderef";
(W newline) あるファイル名に対して、ファイル操作を行ないましたが、 失敗しました; 「おそらく」ファイル名に改行文字がついていたからで、 「おそらく」 chomp() するのを忘れたのでしょう。 "chomp" in perlfunc を参照してください。
(F) このマシンでは、opendir() や readdir() がサポートされていません。
(F) このマシンでは、表示した関数は実装されていません。 少なくとも、Configure はそう判断しました。
(F) この実行ファイルは fork に対応していません。
OS/2 のようなシステムには、Perl 実行ファイルにいくつかの種類があり、 fork に対応しているものとしていないものがあります。 Perl を呼び出す時の名前を perl_
, perl__
のように 変えてみてください。
(F) プログラムファイルが、Perl が読み込めない Unicode エンコーディングを 宣言する Unicode Byte Order Mark (BOM) で始まっています。
(F) このマシンでは、Berkeley ソケット機構がサポートされていないか、 少なくとも Configure がそう判断しました。
(F) 字句解析器が、属性の先頭として単純な識別子やセミコロンやブロックの 開始でないものを発見しました。 おそらく以前の属性のパラメータリストを早く終端しすぎたのでしょう。 attributes を参照してください。
(F) 字句解析器が、属性リストをパースしているときに開き(左)かっこを 発見しましたが、対応する閉じ(右)かっこが見つかりませんでした。 かっこのバランスを取るために、バックスラッシュを追加(または削除)する 必要があるでしょう。 attributes を参照してください。
(F) unpack("w",...) の引数が BER 圧縮整数フォーマットと互換性がなく、 整数に変換できませんでした。 "pack" in perlfunc を参照してください。
(F) このメッセージは、ヒヤドキュメントのラベルがクォートで始まっているけれども 末尾のクォートがありません。 おそらく以下のように書いたのでしょう:
<<"foo
次のように書いてください:
<<"foo"
(F) 正規表現の中で、適切なグループ参照が引き続かない \g
を使いました。 \g{
の場合、閉じ中かっこがありません; さもなければ、\g
には整数が 引き続かなければ鳴りません。 パターンを修正して再挑戦してください。
(F) 項が必要とされるところで、開き山かっこが見つけたため、 対応する閉じ山かっこを探しましたが、見つかりませんでした。 可能性としては、必要なかっこを省いてしまい、本当は、「小なり記号」を 表したかった場合が考えられます。
(F) (*VERB:ARG)
の形のパターンを使いましたが、パターンが )
で 終わっていません。 パターンを修正して再挑戦してください。
(F) (*VERB)
の形のパターンを使いましたが、パターンが )
で 終わっていません。 パターンを修正して再挑戦してください。
(W untie) tie
(または tied
) から返されたオブジェクトが、 untie
が呼び出されたときにまだ有効でした。
(F) POSIX 関数を間違った引数で呼び出しました。 さらなる情報については "FUNCTIONS" in POSIX を参照してください。
(F) Win32 関数を間違った引数で呼び出しました。 更なる情報については Win32 を参照してください。
(W syntax) 以下のように、比較で $[
を使いました:
if ($[ > 5.006) {
...
}
おそらく $]
を使いたかったのでしょう。 $[
は配列の基数です。 $]
は Perl のバージョン番号の 10 進数です。
(F) 2 番目に挙げられた構文はもはや有効ではありません。 代わりに 1 番目のものを使ってください。
(W misc) 左辺値サブルーチンに代入しましたが、サブルーチンが返したものは 捨てられようとする一時的なスカラなので、代入は向こうです。
(W regexp) (?-o) のような内部修飾子は、正規表現全体から除去されなければ 意味がありません:
if ($string =~ /(?-o)$pattern/o) { ... }
これは以下のように書かなければなりません:
if ($string =~ /$pattern/) { ... }
<-- HERE で正規表現のどこに問題が発見されたかを示しています。 perlre を参照してください。
(W syntax) local($x=10)
のような左辺値のローカル化は有効ですが、 実際のところ local() は現在のところ何の効果もありません。 これは将来変更されるかもしれませんが、今のところはこのようなコードは 勧められません。
(W regexp) (?o) のような内部修飾子は、正規表現全体に適用されなければ 意味がありません:
if ($string =~ /(?o)$pattern/) { ... }
これは以下のように書かなければなりません:
if ($string =~ /$pattern/o) { ... }
<-- HERE で正規表現のどこに問題が発見されたかを示しています。 perlre を参照してください。
(W misc) 検索リストが置換リストと同じ長さの時に /d 修飾子を使いました。 /d 修飾子に関するさらなる情報については perlop を参照してください。
(D deprecated) 以下のどれかのような正規表現を書きました:
m{ \x\{FF\} }x
m{foo\{1,3\}}
qr(foo\(bar\))
s[foo\[a-z\]bar][baz]
内側の小かっこ、中かっこ、大かっこは、逆スラッシュが付けられてもメタ文字として 扱われます; 代わりに以下のように書いてください:
m{ \x{FF} }x
m{foo{1,3}}
qr(foo(bar))
s[foo[a-z]bar][baz]
正規表現パターンが、普通はメタ文字である {}
, []
, ()
で区切られていて、 そのパターンの中でも使われて組になっている場合、逆スラッシュは無効です。 将来の Perl リリースではこのような構文では逆スラッシュが効力を持つように 意味を変更することが計画されているので、コードからは取り除いてください。
(W misc) ダブルクォート風文字列の中で \U
, \L
, \Q
を前置することなく \E を書きました。
(W regexp) 次のようなものを指定しました:
qr/a{3}?/
qr/b{1,1}+/
"?"
と "+"
は何の効果もありません; これはマッチングする数に幅がある時に より多くまたは少なく変更します。 そして指定された数に正確にマッチングすることを指定されているので、 選択の余地はありません。
(W void) ブロックの値を返さない文や、スカラのコンマ演算子の左側のように 返却値の無い文脈で、副作用のないことを行ないました。 多くは、みなさんの間違いを指摘するものではなく、Perl がみなさんの 意向を汲み取った解釈ができないことで起こります。 たとえば、みなさんが C の優先順位を Python の優先順位と混同して 以下のようにした場合です:
$one, $two = 1, 2;
以下のようにするべきです。
($one, $two) = (1, 2);
その他の良くあるエラーとしては、リストを作るのに中かっこや大かっこを 使うべきところで普通のかっこを使うことです; 例えば、以下のように書いた 場合です:
$array = (1,2);
以下のように書くべきです:
$array = [1,2];
角かっこはリスト値を明示的にスカラ値に変換しますが、かっこは変換しません。 そのため、かっこで括られたリストをスカラコンテキストで評価すると、 カンマは C のカンマ演算子のように扱われ、左側の引数は捨てられます; これは望んでいることではないでしょう。 これに関するさらなる情報については perlref を参照してください。
この警告は、0 か 1 と等しい数値定数では起きません; なぜなら、 しばしば以下のような文で使われるからです:
1 while sub_with_side_effects();
通常 0 か 1 に評価される文字列定数は警告されます。
(W regexp) p
修飾子は、一度設定したものをオフにはできません。 そうしようとしても無効です。
(W) use re;
プラグマを引数なしで指定しました。これは無意味です。
(W void) こんな風に、ソートをスカラコンテキストで使いました:
my $x = sort @y;
これは全く便利ではないので、perl は現在のところ最適化して取り除きます。
(W syntax) push(@x)
や unshift(@foo)
のようにして、push() 関数や unshift() 関数を、配列以外の引数なしで使いました。 これは普通は配列に何の影響も与えないので、完全に無意味です。 理論的には、配列が tie されているクラスの PUSH メソッドの実装によっては push(@tied_array) が何らかの効果を持つ可能性はあります。 もしそうなら、これを push(@tied_array,())
のように書くことで警告を 回避できます。
(F) "use" キーワードは、コンパイル時に認識され、実行されるもので、 意味のある値を返しません。 perlmod を参照してください。
(D deprecated) $[
変数 (配列の最初の要素のインデックス) は廃止予定です。 "$[" in perlvar を参照してください。
(D deprecated) ヒアドキュメントの終端子として空行を 使いたいときには、明示的にクォートされた形を使うことを推奨しています。
(D deprecated) 引数なしの chdir() は、$ENV{HOME} か $ENV{LOGDIR} に 変更すると文書化されています。 chdir(undef) と chdir('') も同じふるまいをしますが、これは非推奨です。 将来のバージョンでは単に失敗するでしょう。
chdir() に渡すものが定義されていて、空白ではないことをチェックするように 注意してください; さもないとホームディレクトリに 移動してしまうかもしれません。
(W regexp) 置換で /c 修飾子を使いました。 /c は置換では現在のところ無意味です。
(W regexp) 正規表現オペランドに /c 修飾子を使いましたが、/g 修飾子は 使いませんでした。 現在のところ、/c は /g が使われたときにのみ有効です。 (これは将来変更されるかもしれません。)
(D deprecated) フォーマットに与えた値は単に行で 並べるのではなくて、カンマで区切るべきです。
(S internal) 挿入の後の each()
の振る舞いは未定義です; アイテムを 読み飛ばしたり、複数回読んだりします。 each()
の代わりに keys()
を使うことを検討してください。
(F) 構文 my $x := 42
は my $x : = 42
と等価にパースされていました ($x
に空の属性リストを適用する)。 この構文は 5.12.0 に廃止予定となり、今回文法エラーとなったので、 :=
は将来新しい演算子として再利用できます。
例えばコードジェネレータのために、空属性リストが必要なら、=
の前に スペースを加えてください。
(F) おそらくループの中で反復される配列を変更したのでは? このエラーは典型的には以下のようなコードで発生します:
@a = (3,4);
@a = () for (1,2,@a);
反復中の配列は変更してはいけないことになっています。 速度と効率上の理由から、Perl 内部では反復されたアイテムの参照カウントを 完全には数えていません; 従って反復中のアイテムのを削除すると Perl は 解放された値を見ることになります。
(D deprecated) 型グロブの中のファイルハンドルスロットにアクセスするには、 より短い *glob{IO} の形を使うことを推奨されています。
(W regexp) split
演算子のパターンで /g 修飾子を使いました。 split
は常にパターンを繰り返しマッチングしようとするので、 /g
は効果がありません。
(D deprecated) 外側のスコープから内側のスコープに飛び込むために goto
を 使うことは廃止予定であり、避けるべきです。
(D deprecated) (エヘン)偶発的な仕様によって、AUTOLOAD
サブルーチンは、 autoload されるサブルーチンがメソッド (Foo->bar()
や $obj->bar()
) ではなく、普通の関数 (Foo::bar()
) として 呼び出された場合にも、(@ISA
階層を使って) メソッドとして検索します。
このバグは、メソッドの検索をメソッドの AUTOLOAD
のみで使うことによって 将来修正される予定です。 しかし、現在のコードの大部分は古い振る舞いを使っています。 それで、暫定的なステップとして、Perl は現在のところは、 メソッド以外が継承されたAUTOLOAD
を使うときにオプションの警告を 発生させます。
単純な規則は: 継承は autoload された非メソッドには動作しません。 古いコードを修正する簡単な方法は: BaseClass
という名前の基底クラスから 非メソッドのための継承した AUTOLOAD
に依存しているモジュールに対して、 開始時に *AUTOLOAD = \&BaseClass::AUTOLOAD
を実行してください。
use AutoLoader; @ISA = qw(AutoLoader);
としているコードでは、 @ISA から AutoLoader を取り除いて、use AutoLoader;
を use AutoLoader 'AUTOLOAD';
に変更するべきです。
(F) C でのみアクセス可能な printf の機能を使おうとしました。 これは普通 Perl で行うより良い方法があります。
(D deprecated) 示した構文は、もはや使うことが推奨されません; 一般には もっと良い方法があるからであり、また古い方法は、悪い副作用があるからです。
(D deprecated) $^X
and ${^GLOBAL_PHASE}
のような ^FOO 変数を 参照するためにソース中にリテラル名制御文字を使うのは、廃止予定になりました。 これは $\cT
のようなコード (ここで \cT はソースコード中の制御文字) にのみ 影響します: ${"\cT"}
や $^T
は有効なままです。
(F) ファイルはオープンされたファイルを表わすものであり、 ファイルをオープンしたときには、探しているシンボリックリンクは、 既に通り過ぎた後です。 この操作は undef
を返します。 代わりにファイル名を使ってください。
(S experimental::lexical_topic) レキシカルな $_ は実験的機能で、その振る舞いは 将来のリリースの perl で変更されたり削除されたりするかもしれません。 "$_" in perlvar の説明を参照してください。
(D deprecated) スカラに対して tie
, tied
, untie
を使いましたが、 スカラは型グロブを保持していて、そのファイルハンドルが tie されていることを 意味します。 ハンドルを tie することを意味しているなら、tie *$handle
のように 明示的に * を使ってください。
これは Perl 5.16 で取り除かれた長年残っていたバグで、 型グロブを保持しているスカラ自身を tie する方法がなく、また型グロブが 代入されているスカラを untie する方法がないというものでした。 このメッセージを見たなら、古いバージョンを使わなければなりません。
(D deprecated) 一度だけマッチングする正規表現として ?\w?
のようなものを 書きました。 疑問符を将来新しい演算子として利用可能とするために、この単語を直接疑問符 デリミタで始めることは非推奨となりました。 代わりに、明示的に m
演算子を使って m?\w?
と書いてください: これも 疑問符デリミタは一度だけマッチングする振る舞いを起動します。
(W misc) リファレンスを配列の添え字として使おうとしました; これはおそらく 望んでいることではないでしょう; なぜなら数値コンテキストでの リファレンスはとても大きな数になることが多いので、普通はプログラマの ミスを意味しています。
本当にそうしたい場合は、$array[0+$ref]
のように、リファレンスを明示的に 数値化してください。 しかし、この警告はオーバーロードされたオブジェクトでは発生しません; 数値化と文字列化の演算子をオーバーロードして、何をしているかをわかっていると 仮定できるからです。
(S experimental::lexical_topic) レキシカルな $_ は実験的機能で、その振る舞いは 将来のリリースの perl で変更されたり削除されたりするかもしれません。 "$_" in perlvar の説明を参照してください。
(W taint, deprecated) system()
や exec()
に複数の引数を与えましたが、 そのうち少なくとも一つが汚染されています。 これは許されていましたが、将来のバージョンの perl では致命的エラーに なるでしょう。 引数を浄化してください。 perlsec を参照してください。
(W uninitialized) 未定義値を、あたかも既に定義されているかのように 使用しました。 これは、"" か 0 と解釈されますが、間違いの可能性があります。 この警告を止めるには、変数に定義された値を代入してください。
何が未定義なのかを見つけ出す助けにするために、perl は(あれば)未定義である 変数名を示します。 それができないような場合では、未定義値を使った操作を示します。 しかし、perl がプログラムを最適化するので、文字通りにはプログラム中に 現れない操作についての警告が表示されるかもしれないことに注意してください。 例えば、"that $foo"
は "that " . $foo
に最適化されるので、 たとえプログラム中に 連結 (.)
演算子がなくても .
に関する警告が 出ます。
(F) 正規表現で、以下のようなことをしました
(?[ [ \xBEEF ] ])
Perl は、これが以下のものを意味しているのか
(?[ [ \x{BEEF} ] ])
それとも次のものかがわかりません。
(?[ [ \x{BE} E F ] ])
明確にするために大かっこか空白を追加する必要があります。
(D deprecated) %foo->{"bar"}
や %$ref->{"hello"}
の形で、 ハッシュをリファレンスとして使おうとしました。 5.6.1 以前のバージョンの perl ではこの構文を許していましたが、 そうするべきではありません。 これは今では非推奨であり、将来のバージョンでは削除されるでしょう。
(D deprecated) @foo->[23]
や @$ref->[99]
の形で、 配列をリファレンスとして使おうとしました。 5.6.1 以前のバージョンの perl ではこの構文を許していましたが、 そうするべきではありません。 これは今では非推奨であり、将来のバージョンでは削除されるでしょう。
(W) charnames ハンドラが複数の文字の並びを返すことがあります。 正規表現パターン大かっこ文字クラスで使われるときには、現在のところ 最初のもの以外は捨てられます。
(F) s///r
, tr///r
, y///r
での !~
演算子の使用は、正確な振る舞いが まだ決定されていないので、将来の使用のために予約されています。 (単に修正された文字列の真偽値としての逆を返すのは普通特に 有用ではありません。)
(S surrogate) 受け付けられないと考えられる場所に UTF-16 サロゲートを 使いました。 これらの符号位置、U+D800 から U+DFFF (両端含む) は UTF-16 のためだけに Unicode によって使われます。 しかし Perl は、サロゲートを含む、内部で全ての符号なし整数の符号位置(最大値は プラットフォームで利用可能なサイズ上限)を受け付けます。 しかし、これらは入力や出力になるときに問題を引き起こします; それは おそらくこのメッセージが出た場所です。 自分で何をしているのかが本当に本当に分かっているなら、 no warnings 'surrogate';
とすることでこの警告をオフにできます。
(W misc) 条件式の中で、<HANDLE>, <*> (グロブ), each()
, readdir()
を 真偽値として使いました。 これらの構文は値 "0" を返すことがあります; これは条件式では偽を示しますが、 これはおそらく望んでいることではないでしょう。 これらの構文を条件式の中で使うときは、その値を defined
演算子で テストしてください。
(W misc) VMS に固有の警告です。 Perl は CLI シンボルテーブルから %ENV 要素の値を読み込もうとしましたが、 結果の文字列が 1024 文字を越えました。 返り値は 1024 文字に切り詰められます。
(S experimental::autoderef) スカラ引数の values
は実験的で、将来の バージョンの Perl で変更されたり削除されたりするかもしれません。 この機能を使うリスクを取る場合は、単に警告を無効にして下さい:
no warnings "experimental::autoderef";
(W closure) コンパイル中に、内側の名前付きサブルーチンや eval が まだ利用可能でない外側のレキシカルを捕捉しようとしました。 これは二つの理由で起こります。 まず、外側のレキシカルが、まだ作成されていない外側の無名サブルーチンで 定義されている場合です。 (名前付きサブルーチンはコンパイル時に作成されますが、無名サブルーチンは 実行時に作成されることを思い出してください。) 例えば、
sub { my $a; sub f { $a } }
f が作成された時点で、$a の現在の値を捕捉できません; なぜなら無名サブルーチンはまだ作成されていないからです。 逆に、以下のものは警告されません; 無名サブルーチンはこの時点で作成されていて 生きているからです:
sub { my $a; eval 'sub f { $a }' }->();
2 番目の状況は eval がスコープ外となった変数にアクセスすることで起こります; 例えば:
sub f {
my $a;
sub { eval '$a' }
}
f()->();
ここで、eval の中の '$a' がコンパイルされるとき、f() はまだ 実行されていないので、この $a は捕捉出来ません。
(S misc) "use strict" が有効のときに、見たところ他のモジュールから インポートされたとあなたが考えたグローバル変数を参照しました; なぜなら同じ名前の何か他のもの(通常はサブルーチン)がそのモジュールから エクスポートされています。 これは普通は変数の前に間違ったおかしな文字を置いたことを意味します。
(F) 後方参照は長さが固定で、コンパイル時に確定している副式に対してのみ 可能です。 正の後方参照では、等価な機能を得るために \K
正規表現構文が使えます。 "(?<=pattern) \K" in perlre を参照してください。
/i
の基では、おそらくあなたが考えていないような種類のものに マッチングするという、明確でない Unicode の規則があります。 例えば、部分文字列 "ss"
は単一文字 LATIN SMALL LETTER SHARP S に マッチングします。 ASCII 文字並びが単一の合字にマッチングするパターンとしては、 LATIN SMALL LIGATURE FFI が qr/ffi/i
にマッチングするといったものが あります。 Perl v5.16 から、もし ASCII のマッチングにだけ関心があるのなら、 正規表現に /aa
を追加することでこれらの明確でないマッチングを全て 除くことができるので、このメッセージを避けられます。 また、use re qw(/aa)
とすることで、スコープ内でコンパイルされた全ての 正規表現に対して /aa
を適用します。 re を参照してください。
(W misc) 現在のスコープや文で "my", "our", "state" 変数が再宣言されたので、 以前の実体への全てのアクセスができなくなりました。 これはほとんど常にタイプミスです。 以前の変数は、スコープが終わるか、それを参照している全てのクロージャが 破壊されるまでは存在し続けることに注意してください。
(A) スクリプトを perl ではなく csh で実行しようとしました。 #! 行をチェックするか、スクリプトを直接 Perl で起動してください。
(W closure) 内部の(ネストした) 名前付き サブルーチンが、 外側の名前付きサブルーチンで定義したレキシカル変数を参照しています。
内側のサブルーチンが呼び出された時、外側のサブルーチンの値は、最初の外側の サブルーチンへの呼び出し前および呼び出し中のものになります; この場合、外側のサブルーチンへの最初の呼び出しが終了した後、内側と 外側のサブルーチンは変数に関して同じ値を共有しなくなります。 言い換えると、変数はもはや共有されません。
この問題は普通、sub {}
構文を使って内側のサブルーチンを無名にすることで 解決します。 外側のサブルーチンの変数を参照している内側の無名サブルーチンが 作成されたとき、これらはそのような変数の現在の値に自動的に回復します。
(S printf) %vd (s)printf フォーマットはアルファ部分のある バージョンオブジェクトに対応していません。
(F) 引き数が必要な動詞パターンを使いました。 引き数を追加するか、正しい動詞を使ってください。
(F) 引き数が認められていない動詞パターンを使いました。 引き数を削除するか、正しい動詞を使ってください。
(P) use Module n.n LIST
文を等価な BEGIN
ブロックに変換しようと したときに、バージョン番号について内部の不整合を発見しました。
(W misc) バージョン文字列の末尾に不正な文字が含まれていたので、その文字は 無視されます。
(W) warn() に空文字列を渡した (warn ""
と透過です) か、 引数なしで呼び出され、$@
も空でした。
(S) open() によって暗黙のうちに行なわれる close() が、 close() のエラーとなりました。 通常、ファイルシステムがいっぱいであることを示します。
(S ambiguous) 単項演算子の後に、何か項にも単項演算子にも解釈できる、 二項演算子のようなものが置かれました。 たとえば、rand 関数がデフォルトの引数として、1.0 をとることを知って いれば、以下のように書いて:
rand + 5;
以下の同じことと思うかもしれませんが:
rand() + 5;
実際には以下のようになります:
rand(+5);
したがって、思うように解釈させるには、かっこが必要になります。
(S experimental::smartmatch) when
は、実験的であるスマートマッチングに 依存しています。 さらに、完全に明らかとは言えないいくつかの特殊なケースがあるので、その 振る舞いは将来のリリースの perl で変更されたり削除されたりするかもしれません。 "Experimental Details on given and when" in perlsyn の説明を参照してください。
(S utf8) Perl が(想定していないところで)ワイド文字(>255)に遭遇しました。 この警告は、(print のような) I/O に対してはデフォルトでオンです。 この警告を黙らせる最も簡単な方法は、binmode STDOUT, ':utf8'
のように 出力に単に :utf8
層を追加することです。 もう一つの方法は no warnings 'utf8';
を追加することですが、これは しばしばいかさまに近い方法です。 一般的に、ファイルハンドルにはエンコーディングを明示的に指定することに なっています; open と "binmode" in perlfunc を参照してください。
(F) (un)pack テンプレートの繰り返し数は、TEMPLATE
が常に テンプレートだけから決定される同じサイズの pack されたバイト列と一致する 場合にのみ [TEMPLATE]
によって置き換えられます。 これは、コード @, /, U, u, w や、長さ * が含まれていると不可能です。 テンプレートを再設計してください。
(W closed) 書き込みを行なおうとしたファイルハンドルは、既に閉じられています。 制御フローをチェックしてください。
(S utf8) 異なったエンコーディングを読み込むとき、Perl は全てを Unicode 文字に マッピングしようとします。 読み込んだバイトはこのエンコーディングでは不正でした。 例えば:
utf8 "\xE4" does not map to Unicode
というのは、Latin-1 の a 分節を UTF-8 として読み込もうとした場合です。
(F) (un)pack している文字列の最後より後の相対位置を示している (un)pack テンプレートを指定しました。 "pack" in perlfunc を参照してください。
(F) unpack している文字列の最後より後の相対位置を示している pack テンプレートを指定しました。 "pack" in perlfunc を参照してください。
(F) そして、そうすることはできないでしょう; カーネルのソースは お持ちではないでしょうし、ベンダも欲しいものを提供しては くれないでしょうから。 もっとも良いのは、スクリプトに setuid C ラッパーを被せることです。
(W syntax) シグナルハンドラ名に、裸の単語を代入しました。 残念ながら、そのサブルーチンは既に宣言されていて、Perl 5 では、 おそらく思惑とは違って、代入の実行時にサブルーチンの呼び出しが起こります。 (もし、本当にそうしたいのであれば、サブルーチン名に & を付けてください。)
(F) ハッシュのための乱数の種を初期化しようとしたとき、Perl はシステムから 何の乱数性も得られませんでした。 これは普通「何かとても具合が悪い」ことを示しています。
(F) 名前付き Unicode 文字エスケープ (\N{...})
はゼロ幅並びを 返すことがあります。 このようなエスケープが拡張文字クラス、つまり (?[...])
の中で使われました; これは認められていません。 正しいエスケープを使っているか、および正しい文字名ハンドラがスコープ内に あるかをチェックしてください。 <-- HERE で正規表現のどこに問題が発見されたかを示しています。