From 5a9a8182c81f576fe8955620cfec5bfca9760f9c Mon Sep 17 00:00:00 2001 From: Jaapio Date: Sun, 9 Aug 2015 20:14:06 +0200 Subject: [PATCH] extracted file interaction to adapter appraoch --- .../Reflection/Php/Factory/File.php | 24 +++++-- .../Reflection/Php/Factory/File/Adapter.php | 51 +++++++++++++++ .../Php/Factory/File/LocalAdapter.php | 63 +++++++++++++++++++ 3 files changed, 133 insertions(+), 5 deletions(-) create mode 100644 src/phpDocumentor/Reflection/Php/Factory/File/Adapter.php create mode 100644 src/phpDocumentor/Reflection/Php/Factory/File/LocalAdapter.php diff --git a/src/phpDocumentor/Reflection/Php/Factory/File.php b/src/phpDocumentor/Reflection/Php/Factory/File.php index 4638cb3c..116d6a29 100644 --- a/src/phpDocumentor/Reflection/Php/Factory/File.php +++ b/src/phpDocumentor/Reflection/Php/Factory/File.php @@ -15,6 +15,8 @@ use InvalidArgumentException; use phpDocumentor\Reflection\Fqsen; +use phpDocumentor\Reflection\Php\Factory\File\Adapter; +use phpDocumentor\Reflection\Php\Factory\File\LocalAdapter; use phpDocumentor\Reflection\Php\File as FileElement; use phpDocumentor\Reflection\Php\NodesFactory; use phpDocumentor\Reflection\Php\ProjectFactoryStrategy; @@ -41,12 +43,24 @@ final class File implements ProjectFactoryStrategy private $nodesFactory; /** - * Initializes the object + * @var Adapter + */ + private $adapter; + + /** + * Initializes the object. + * * @param NodesFactory $nodesFactory + * @param Adapter $adapter */ - public function __construct(NodesFactory $nodesFactory) + public function __construct(NodesFactory $nodesFactory, Adapter $adapter = null) { + if($adapter === null) { + $adapter = new LocalAdapter(); + } + $this->nodesFactory = $nodesFactory; + $this->adapter = $adapter; } /** @@ -57,7 +71,7 @@ public function __construct(NodesFactory $nodesFactory) */ public function matches($filePath) { - return is_string($filePath) && file_exists($filePath); + return is_string($filePath) && $this->adapter->fileExists($filePath); } /** @@ -80,11 +94,11 @@ public function create($object, StrategyContainer $strategies, Context $context ) ); } - $code = file_get_contents($object); + $code = $this->adapter->getContents($object); $nodes = $this->nodesFactory->create($code); $docBlock = $this->createDocBlock($strategies, $code, $nodes); - $file = new FileElement(md5_file($object), $object, $code, $docBlock); + $file = new FileElement($this->adapter->md5($object), $this->adapter->path($object), $code, $docBlock); $this->createElements(new Fqsen('\\'), $nodes, $file, $strategies); diff --git a/src/phpDocumentor/Reflection/Php/Factory/File/Adapter.php b/src/phpDocumentor/Reflection/Php/Factory/File/Adapter.php new file mode 100644 index 00000000..c7f5c3f7 --- /dev/null +++ b/src/phpDocumentor/Reflection/Php/Factory/File/Adapter.php @@ -0,0 +1,51 @@ +