Perl-コーディング標準
もちろん、各プログラマーはフォーマットに関して独自の好みを持っていますが、プログラムを読み、理解し、保守しやすくするための一般的なガイドラインがいくつかあります。
最も重要なことは、常に-wフラグの下でプログラムを実行することです。必要に応じて、警告なしプラグマまたは$ ^ W変数を使用して、コードの特定の部分に対して明示的にオフにすることができます。また、常に厳密な使用の下で実行するか、その理由を知っておく必要があります。sigtrapを使用し、診断プラグマを使用することも役立つ場合があります。
コードレイアウトの美学に関して、ラリーが強く気にかけているのは、複数行のBLOCKの閉じ中括弧が、構成を開始したキーワードと一致していることだけです。それを超えて、彼はそれほど強くない他の好みを持っています-
- 4列のインデント。
- 可能であればキーワードと同じ行でカーリーを開き、それ以外の場合は並べます。
- 複数行のブロックのカーリーを開く前のスペース。
- カーリーを含め、1行のブロックを1行に配置できます。
- セミコロンの前にスペースはありません。
- 「短い」1行のブロックではセミコロンが省略されています。
- ほとんどのオペレーターの周りのスペース。
- 「複雑な」添え字の周りのスペース(角かっこ内)。
- 異なることを行うチャンク間の空白行。
- 抱きしめられていない他の人。
- 関数名とその開き括弧の間にスペースはありません。
- 各コンマの後にスペースを入れます。
- 演算子の後に長い行が壊れています(andおよびorを除く)。
- 現在の行で最後の括弧が一致した後のスペース。
- 対応するアイテムを縦に並べます。
- 明瞭さが損なわれない限り、冗長な句読点は省略してください。
考えるべき他のより実質的なスタイルの問題がいくつかあります。特定の方法で何かを実行できるからといって、その方法で実行する必要があるとは限りません。Perlは、何かを行うためのいくつかの方法を提供するように設計されているため、最も読みやすい方法を選択することを検討してください。たとえば-
open(FOO,$foo) || die "Can't open $foo: $!";
−よりも優れている
die "Can't open $foo: $!" unless open(FOO,$foo);
2番目の方法は、ステートメントの要点を修飾子で隠すためです。一方、
print "Starting analysis\n" if $verbose;
−よりも優れている
$verbose && print "Starting analysis\n";
重要なのは、ユーザーが-vを入力したかどうかではないからです。
Perlが最後の演算子を提供しているので、途中で終了できる場合は、愚かなゆがみを経て上部または下部のループを終了しないでください。少しだけ「インデント」して、見やすくします-
LINE:
for (;;) {
statements;
last LINE if $foo;
next LINE if /^#/;
statements;
}
さらにいくつかの重要なポイントを見てみましょう-
ループラベルを使用することを恐れないでください。ループラベルは、読みやすさを向上させ、マルチレベルのループブレークを可能にするためにあります。前の例を参照してください。
無効なコンテキストで、つまり戻り値を破棄する場合は、grep()(またはmap())または `backticks`を使用しないでください。これらの関数はすべて戻り値を持っているので、それらを使用してください。それ以外の場合は、代わりにforeach()ループまたはsystem()関数を使用してください。
移植性のために、すべてのマシンに実装されていない可能性のある機能を使用する場合は、evalで構成をテストして、失敗するかどうかを確認してください。特定の機能が実装されたバージョンまたはパッチレベルがわかっている場合は、$](英語では$ PERL_VERSION)をテストして、そこにあるかどうかを確認できます。Configモジュールを使用すると、Perlのインストール時にConfigureプログラムによって決定された値を調べることもできます。
ニーモニック識別子を選択します。ニーモニックの意味を思い出せない場合は、問題があります。
$ gotitのような短い識別子はおそらく問題ありませんが、長い識別子の単語を区切るにはアンダースコアを使用してください。特に英語を母国語としない人にとっては、$ VarNamesLikeThisよりも$ var_names_like_thisを読む方が一般的に簡単です。これは、VAR_NAMES_LIKE_THISと一貫して機能する単純なルールでもあります。
パッケージ名は、この規則の例外である場合があります。Perlは、integerやstrictなどの「プラグマ」モジュール用に小文字のモジュール名を非公式に予約しています。他のモジュールは大文字で始まり、大文字と小文字を混在させる必要がありますが、プリミティブファイルシステムのモジュール名の数個のスパースバイトに収まらなければならないファイルとしての表現に制限があるため、おそらくアンダースコアはありません。
非常に毛深い正規表現がある場合は、/ x修飾子を使用し、空白を入れて、ラインノイズのように見えないようにします。正規表現にスラッシュまたはバックスラッシュがある場合は、区切り文字としてスラッシュを使用しないでください。
システムコールの戻りコードを常に確認してください。適切なエラーメッセージはSTDERRに送信され、問題の原因となったプログラム、失敗したシステムコールと引数が含まれ、(非常に重要)問題の原因に関する標準のシステムエラーメッセージが含まれている必要があります。これは単純ですが十分な例です-
opendir(D, $dir) or die "can't opendir $dir: $!";
再利用性について考えてください。もう一度そのようなことをしたいと思うかもしれないのに、なぜワンショットで頭脳を無駄にするのですか?コードを一般化することを検討してください。モジュールまたはオブジェクトクラスの作成を検討してください。厳密に使用し、警告(または-w)を有効にして、コードをクリーンに実行することを検討してください。コードを配布することを検討してください。全世界観を変えることを検討してください。考えてみてください...ああ、気にしないでください。
一貫性を保つ。
優しくしてください。