Add prettyPrintFile() method

This commit is contained in:
nikic 2013-04-15 20:53:23 +02:00
parent 5fca55702b
commit 08f0cde6f9
7 changed files with 127 additions and 16 deletions

View File

@ -17,6 +17,10 @@ Version 0.9.4-dev
* The pretty printer now prints namespaces in semicolon-style if possible (i.e. if the file does not contain a global * The pretty printer now prints namespaces in semicolon-style if possible (i.e. if the file does not contain a global
namespace declaration). namespace declaration).
* Added `prettyPrintFile(array $stmts)` method which will pretty print a file of statements including the opening
`<?php` tag if it is required. Use of this method will also eliminate the unnecessary `<?php ?>` at the start and end
of files using inline HTML.
Version 0.9.3 (22.11.2012) Version 0.9.3 (22.11.2012)
-------------------------- --------------------------

View File

@ -676,10 +676,7 @@ class PHPParser_PrettyPrinter_Default extends PHPParser_PrettyPrinterAbstract
} }
public function pStmt_InlineHTML(PHPParser_Node_Stmt_InlineHTML $node) { public function pStmt_InlineHTML(PHPParser_Node_Stmt_InlineHTML $node) {
return '?>' . $this->pNoIndent( return '?>' . $this->pNoIndent("\n" . $node->value) . '<?php ';
("\n" === $node->value[0] || "\r" === $node->value[0] ? "\n" : '')
. $node->value
) . '<?php ';
} }
public function pStmt_HaltCompiler(PHPParser_Node_Stmt_HaltCompiler $node) { public function pStmt_HaltCompiler(PHPParser_Node_Stmt_HaltCompiler $node) {

View File

@ -70,16 +70,16 @@ abstract class PHPParser_PrettyPrinterAbstract
} }
/** /**
* Pretty prints an array of nodes (statements). * Pretty prints an array of statements.
* *
* @param PHPParser_Node[] $nodes Array of nodes * @param PHPParser_Node[] $stmts Array of statements
* *
* @return string Pretty printed nodes * @return string Pretty printed statements
*/ */
public function prettyPrint(array $nodes) { public function prettyPrint(array $stmts) {
$this->preprocessNodes($nodes); $this->preprocessNodes($stmts);
return str_replace("\n" . $this->noIndentToken, "\n", $this->pStmts($nodes, false)); return str_replace("\n" . $this->noIndentToken, "\n", $this->pStmts($stmts, false));
} }
/** /**
@ -93,6 +93,26 @@ abstract class PHPParser_PrettyPrinterAbstract
return str_replace("\n" . $this->noIndentToken, "\n", $this->p($node)); return str_replace("\n" . $this->noIndentToken, "\n", $this->p($node));
} }
/**
* Pretty prints a file of statements (includes the opening <?php tag if it is required).
*
* @param PHPParser_Node[] $stmts Array of statements
*
* @return string Pretty printed statements
*/
public function prettyPrintFile(array $stmts) {
$p = trim($this->prettyPrint($stmts));
$p = preg_replace('/^\?>\n?/', '', $p, -1, $count);
$p = preg_replace('/<\?php$/', '', $p);
if (!$count) {
$p = "<?php\n\n" . $p;
}
return $p;
}
/** /**
* Preprocesses the top-level nodes to initialize pretty printer state. * Preprocesses the top-level nodes to initialize pretty printer state.
* *

View File

@ -4,23 +4,39 @@ require_once dirname(__FILE__) . '/CodeTestAbstract.php';
class PHPParser_Tests_PrettyPrinterTest extends PHPParser_Tests_CodeTestAbstract class PHPParser_Tests_PrettyPrinterTest extends PHPParser_Tests_CodeTestAbstract
{ {
/** protected function doTestPrettyPrintMethod($method, $name, $code, $dump) {
* @dataProvider provideTestPrettyPrint
* @covers PHPParser_PrettyPrinter_Zend<extended>
*/
public function testPrettyPrint($name, $code, $dump) {
$parser = new PHPParser_Parser(new PHPParser_Lexer_Emulative); $parser = new PHPParser_Parser(new PHPParser_Lexer_Emulative);
$prettyPrinter = new PHPParser_PrettyPrinter_Default; $prettyPrinter = new PHPParser_PrettyPrinter_Default;
$stmts = $parser->parse($code); $stmts = $parser->parse($code);
$this->assertEquals( $this->assertEquals(
$this->canonicalize($dump), $this->canonicalize($dump),
$this->canonicalize($prettyPrinter->prettyPrint($stmts)), $this->canonicalize($prettyPrinter->$method($stmts)),
$name $name
); );
} }
/**
* @dataProvider provideTestPrettyPrint
* @covers PHPParser_PrettyPrinter_Default<extended>
*/
public function testPrettyPrint($name, $code, $dump) {
$this->doTestPrettyPrintMethod('prettyPrint', $name, $code, $dump);
}
/**
* @dataProvider provideTestPrettyPrintFile
* @covers PHPParser_PrettyPrinter_Default<extended>
*/
public function testPrettyPrintFile($name, $code, $dump) {
$this->doTestPrettyPrintMethod('prettyPrintFile', $name, $code, $dump);
}
public function provideTestPrettyPrint() { public function provideTestPrettyPrint() {
return $this->getTests(dirname(__FILE__) . '/../../code/prettyPrinter', 'test'); return $this->getTests(dirname(__FILE__) . '/../../code/prettyPrinter', 'test');
} }
public function provideTestPrettyPrintFile() {
return $this->getTests(dirname(__FILE__) . '/../../code/prettyPrinter', 'file-test');
}
} }

View File

@ -0,0 +1,52 @@
File containing both inline HTML and PHP
-----
HTML
<?php
echo 'PHP';
-----
HTML
<?php
echo 'PHP';
-----
<?php
echo 'PHP';
?>
HTML
-----
<?php
echo 'PHP';
?>
HTML
-----
HTML
<?php
echo 'PHP';
?>
HTML
-----
HTML
<?php
echo 'PHP';
?>
HTML
-----
HTML
<?php
echo 'PHP';
?>
HTML
<?php
echo 'PHP';
?>
HTML
-----
HTML
<?php
echo 'PHP';
?>
HTML
<?php
echo 'PHP';
?>
HTML

View File

@ -0,0 +1,11 @@
File containing only inline HTML
-----
Hallo World
Foo Bar
Bar Foo
World Hallo
-----
Hallo World
Foo Bar
Bar Foo
World Hallo

View File

@ -0,0 +1,11 @@
File containing only PHP
-----
<?php
echo 'Foo Bar';
echo 'Bar Foo';
-----
<?php
echo 'Foo Bar';
echo 'Bar Foo';