乱雑なphpコードをうまくフォーマットするための優れたツールを知っていますか? Aptana/Eclipse用のスクリプトが望ましいですが、スタンドアロンツールでもできます。
PHP Code Beautifier は便利な無料ツールですが、 download page ではアカウントを作成する必要があります。
ツールは3つのバージョンに拒否されました。
- ファイルを視覚的に処理できるGUIバージョン。
- 他のツール(CVS、Subversion、IDE ...)とのバッチ処理または統合を可能にするコマンドラインバージョン。
- PHPEditの統合ツールとして。
基本的には、次のようになります。
if($code == BAD){$action = REWRITE;}else{$action = KEEP;}
for($i=0; $i<10;$i++){while($j>0){$j++;doCall($i+$j);if($k){$k/=10;}}}
に
if ($code == BAD) {
$action = REWRITE;
} else {
$action = KEEP;
}
for($i = 0; $i < 10;$i++) {
while ($j > 0) {
$j++;
doCall($i + $j);
if ($k) {
$k /= 10;
}
}
}
さて、これが私の非常に基本的で大まかなスクリプトです。
#!/usr/bin/php
<?php
class Token {
public $type;
public $contents;
public function __construct($rawToken) {
if (is_array($rawToken)) {
$this->type = $rawToken[0];
$this->contents = $rawToken[1];
} else {
$this->type = -1;
$this->contents = $rawToken;
}
}
}
$file = $argv[1];
$code = file_get_contents($file);
$rawTokens = token_get_all($code);
$tokens = array();
foreach ($rawTokens as $rawToken) {
$tokens[] = new Token($rawToken);
}
function skipWhitespace(&$tokens, &$i) {
global $lineNo;
$i++;
$token = $tokens[$i];
while ($token->type == T_WHITESPACE) {
$lineNo += substr($token->contents, "\n");
$i++;
$token = $tokens[$i];
}
}
function nextToken(&$j) {
global $tokens, $i;
$j = $i;
do {
$j++;
$token = $tokens[$j];
} while ($token->type == T_WHITESPACE);
return $token;
}
$OPERATORS = array('=', '.', '+', '-', '*', '/', '%', '||', '&&', '+=', '-=', '*=', '/=', '.=', '%=', '==', '!=', '<=', '>=', '<', '>', '===', '!==');
$IMPORT_STATEMENTS = array(T_REQUIRE, T_REQUIRE_ONCE, T_INCLUDE, T_INCLUDE_ONCE);
$CONTROL_STRUCTURES = array(T_IF, T_ELSEIF, T_FOREACH, T_FOR, T_WHILE, T_SWITCH, T_ELSE);
$WHITESPACE_BEFORE = array('?', '{', '=>');
$WHITESPACE_AFTER = array(',', '?', '=>');
foreach ($OPERATORS as $op) {
$WHITESPACE_BEFORE[] = $op;
$WHITESPACE_AFTER[] = $op;
}
$matchingTernary = false;
// First pass - filter out unwanted tokens
$filteredTokens = array();
for ($i = 0, $n = count($tokens); $i < $n; $i++) {
$token = $tokens[$i];
if ($token->contents == '?') {
$matchingTernary = true;
}
if (in_array($token->type, $IMPORT_STATEMENTS) && nextToken($j)->contents == '(') {
$filteredTokens[] = $token;
if ($tokens[$i + 1]->type != T_WHITESPACE) {
$filteredTokens[] = new Token(array(T_WHITESPACE, ' '));
}
$i = $j;
do {
$i++;
$token = $tokens[$i];
if ($token->contents != ')') {
$filteredTokens[] = $token;
}
} while ($token->contents != ')');
} elseif ($token->type == T_ELSE && nextToken($j)->type == T_IF) {
$i = $j;
$filteredTokens[] = new Token(array(T_ELSEIF, 'elseif'));
} elseif ($token->contents == ':') {
if ($matchingTernary) {
$matchingTernary = false;
} elseif ($tokens[$i - 1]->type == T_WHITESPACE) {
array_pop($filteredTokens); // Remove whitespace before
}
$filteredTokens[] = $token;
} else {
$filteredTokens[] = $token;
}
}
$tokens = $filteredTokens;
function isAssocArrayVariable($offset = 0) {
global $tokens, $i;
$j = $i + $offset;
return $tokens[$j]->type == T_VARIABLE &&
$tokens[$j + 1]->contents == '[' &&
$tokens[$j + 2]->type == T_STRING &&
preg_match('/[a-z_]+/', $tokens[$j + 2]->contents) &&
$tokens[$j + 3]->contents == ']';
}
// Second pass - add whitespace
$matchingTernary = false;
$doubleQuote = false;
for ($i = 0, $n = count($tokens); $i < $n; $i++) {
$token = $tokens[$i];
if ($token->contents == '?') {
$matchingTernary = true;
}
if ($token->contents == '"' && isAssocArrayVariable(1) && $tokens[$i + 5]->contents == '"') {
/*
* Handle case where the only thing quoted is the assoc array variable.
* Eg. "$value[key]"
*/
$quote = $tokens[$i++]->contents;
$var = $tokens[$i++]->contents;
$openSquareBracket = $tokens[$i++]->contents;
$str = $tokens[$i++]->contents;
$closeSquareBracket = $tokens[$i++]->contents;
$quote = $tokens[$i]->contents;
echo $var . "['" . $str . "']";
$doubleQuote = false;
continue;
}
if ($token->contents == '"') {
$doubleQuote = !$doubleQuote;
}
if ($doubleQuote && $token->contents == '"' && isAssocArrayVariable(1)) {
// don't echo "
} elseif ($doubleQuote && isAssocArrayVariable()) {
if ($tokens[$i - 1]->contents != '"') {
echo '" . ';
}
$var = $token->contents;
$openSquareBracket = $tokens[++$i]->contents;
$str = $tokens[++$i]->contents;
$closeSquareBracket = $tokens[++$i]->contents;
echo $var . "['" . $str . "']";
if ($tokens[$i + 1]->contents != '"') {
echo ' . "';
} else {
$i++; // process "
$doubleQuote = false;
}
} elseif ($token->type == T_STRING && $tokens[$i - 1]->contents == '[' && $tokens[$i + 1]->contents == ']') {
if (preg_match('/[a-z_]+/', $token->contents)) {
echo "'" . $token->contents . "'";
} else {
echo $token->contents;
}
} elseif ($token->type == T_ENCAPSED_AND_WHITESPACE || $token->type == T_STRING) {
echo $token->contents;
} elseif ($token->contents == '-' && in_array($tokens[$i + 1]->type, array(T_LNUMBER, T_DNUMBER))) {
echo '-';
} elseif (in_array($token->type, $CONTROL_STRUCTURES)) {
echo $token->contents;
if ($tokens[$i + 1]->type != T_WHITESPACE) {
echo ' ';
}
} elseif ($token->contents == '}' && in_array($tokens[$i + 1]->type, $CONTROL_STRUCTURES)) {
echo '} ';
} elseif ($token->contents == '=' && $tokens[$i + 1]->contents == '&') {
if ($tokens[$i - 1]->type != T_WHITESPACE) {
echo ' ';
}
$i++; // match &
echo '=&';
if ($tokens[$i + 1]->type != T_WHITESPACE) {
echo ' ';
}
} elseif ($token->contents == ':' && $matchingTernary) {
$matchingTernary = false;
if ($tokens[$i - 1]->type != T_WHITESPACE) {
echo ' ';
}
echo ':';
if ($tokens[$i + 1]->type != T_WHITESPACE) {
echo ' ';
}
} elseif (in_array($token->contents, $WHITESPACE_BEFORE) && $tokens[$i - 1]->type != T_WHITESPACE &&
in_array($token->contents, $WHITESPACE_AFTER) && $tokens[$i + 1]->type != T_WHITESPACE) {
echo ' ' . $token->contents . ' ';
} elseif (in_array($token->contents, $WHITESPACE_BEFORE) && $tokens[$i - 1]->type != T_WHITESPACE) {
echo ' ' . $token->contents;
} elseif (in_array($token->contents, $WHITESPACE_AFTER) && $tokens[$i + 1]->type != T_WHITESPACE) {
echo $token->contents . ' ';
} else {
echo $token->contents;
}
}
http://en.sourceforge.jp/projects/pdt-tools/
^^^は、適切なCTRL + SHIFT + F Eclipse/Aptana PHP Javaのようなフォーマッターを提供します。
インストールのヘルプについては ここ を参照してください。
コードをフォーマットするpearモジュールがあります。 PHPビューティファイアー
Zend開発環境を使用している場合は、インデントコード機能(Ctrl + Shift + F)を使用できます。
これがphpコード美容ツール(もちろんPHP)クラスです。
http://www.codeassembly.com/A-php-code-beautifier-that-works/
そして
オンラインデモ:
NetBeans PHPを使用し、alt + shift + Fを押します。
Zend開発環境はEclipseプラグインになりました。Aptanaと一緒に実行して、インデントコード機能を使用することができる場合があります。
私はまだEclipseプラグインにアップグレードしていません。以前のZDEが大好きです。私は実際に他の言語でEclipseを使い始めたのですが、ほとんど飛躍する準備ができています。
最も簡単な解決策は、IDEを使用することです。定期的にPHPでコードを記述する場合は、 、PHPStormの$ 60をドロップするだけです。後悔はしません。
http://www.jetbrains.com/phpstorm/
ファイルレベルまたはディレクトリレベルで簡単なキーボードショートカットを使用して好きな方法でコードをフォーマットでき、他にも膨大な数の優れた機能があります。
これはどうですか:
http://universalindent.sourceforge.net/
それはそこにたくさんのフォーマッターを組み合わせて、必要なスクリプトを生成し、それらを渡してチームメンバーが次回コミットする前にそれらを使用できるようにします...しかし...フォーマッターはコードをめちゃくちゃにしてレンダリングする可能性があります使用できません...
phpformatter.com が最適に機能します
「この無料のオンラインPHPフォーマッタは、すべてのPHPスクリプトを好みのスタイルで美化できるように設計されています。 "
私たちの PHP Formatter は、コードを確実にフォーマットします。コンパイラベースのフロントエンドを使用してコードを解析するため、コードを誤って解釈して損傷することはありません。その結果、フォーマットされた出力は常に機能します。
これは素晴らしい質問です。私はjsonを読み取り、phpとhtmlおよびcssを出力するアプリケーションを持っています。プログラムを実行して、数十(数百?)のファイルを生成します。ここでの回答がお役に立てば幸いです。
ヒアドキュメント、特別なインクルードファイル、メタ文字などを使用してプロジェクトを開始しましたが、すぐに混乱しました。フレームワークやIDEを必要としないスタンドアロンのソリューションが必要でした。そこで、ヒアドキュメントやその他のジャンクをすべて削除し、フォーマットに関係のない汎用テキストバッファリングクラスを作成しました。それはすべて私が気にするすべての1行になる場合があります。 htmlの場合、組み込みのtidy()を行います。 PHPの場合、私は phpstylist を使用します。 phpstylistは古くなっていますが、php形式ではまだうまく機能します。
Phpstylistオプションを設定するために、Windows GUIで niversalIndent (2012年1月更新)を使用しました。
UniversalStylistには、24(!)のフォーマッタープログラム(c、php、Ruby、htmlなど)がリストされています。特にphpstylistのオプションを認識しており、オプションのオン/オフを切り替えると、ファイルをライブで更新できます。とてもいいです。次に、スタイルがある場合、コマンドラインオプションを保存してスクリプトを生成するオプションがあります。一部の書式設定オプションでは、Perl、Pythonなどへのパスを追加する必要があります。
Windowsを使用していて、UniversalIndentでphpstylistを試したい場合は、php.exeのディレクトリを環境パスに追加するだけです。私は ampps を使用しているので、私のものはc:\ ampps\phpに設定されています。
良い固溶体を見つけるのは簡単ではありませんでした。また、コードのレビューとアーカイブの目的で、自動生成されたphp/htmlファイルをできるだけ簡単にバッチ形式でフォーマットするために、他の人が何をしているのか聞きたいと思っています。