aboutsummaryrefslogtreecommitdiff
path: root/src/Compiler
diff options
context:
space:
mode:
authorАлександр Кирюхин <alexander@kiryukhin.su>2018-01-19 19:03:26 +0300
committerАлександр Кирюхин <alexander@kiryukhin.su>2018-01-19 19:03:26 +0300
commit8ea647570b87adda400e5a3ce6c91f4b51327a0d (patch)
tree7c5d328b41e64c3e78ac89c9674747346233c87a /src/Compiler
parent47c9d580c6e799e72b6a70b22dd5107790b1d3e9 (diff)
Remove KeyValue objectHEADmaster
Diffstat (limited to 'src/Compiler')
-rw-r--r--src/Compiler/Compiler.php42
-rw-r--r--src/Compiler/CompilerInterface.php10
2 files changed, 26 insertions, 26 deletions
diff --git a/src/Compiler/Compiler.php b/src/Compiler/Compiler.php
index 6a587d2..28b60e4 100644
--- a/src/Compiler/Compiler.php
+++ b/src/Compiler/Compiler.php
@@ -9,7 +9,6 @@ declare(strict_types=1);
namespace NeonXP\Dotenv\Compiler;
use NeonXP\Dotenv\Exception\RuntimeException;
-use NeonXP\Dotenv\Types\KeyValue;
/**
* Class Compiler
@@ -20,61 +19,64 @@ class Compiler implements CompilerInterface
const REGEX_VARIABLE = '/\$\{(.+?)\}/';
/**
- * @var KeyValue[]
+ * @var array[]
*/
protected $collection = [];
/**
- * @var KeyValue[]
+ * @var array[]
*/
protected $cache = [];
/**
* @inheritdoc
- * @param KeyValue[] $collection
+ * @param array[] $collection
*/
public function setRawCollection(array $collection): void
{
$this->collection = [];
$this->cache = [];
- foreach ($collection as $keyValue) {
- $this->collection[$keyValue->getKey()] = $keyValue;
+ foreach ($collection as $array) {
+ $this->collection[$array['key']] = $array;
}
}
/**
* @inheritdoc
- * @param KeyValue $keyValue
- * @return KeyValue
+ * @param array $array
+ * @return array
*/
- public function compileKeyValue(KeyValue $keyValue): KeyValue
+ public function compile(array $array): array
{
- $newValue = preg_replace_callback(self::REGEX_VARIABLE, function ($variable) use ($keyValue) {
+ $newValue = preg_replace_callback(self::REGEX_VARIABLE, function ($variable) use ($array) {
$variable = $variable[1];
- if ($variable === $keyValue->getKey()) {
+ if ($variable === $array['key']) {
throw new RuntimeException('Self referencing');
}
if (isset($this->cache[$variable])) {
- return $this->cache[$variable]->getValue();
+ return $this->cache[$variable]['value'];
} elseif (isset($this->collection[$variable]) && !$this->needToCompile($this->collection[$variable])) {
- return $this->collection[$variable]->getValue();
+ return $this->collection[$variable]['value'];
} elseif (isset($this->collection[$variable]) && $this->needToCompile($this->collection[$variable])) {
- return $this->compileKeyValue($this->collection[$variable])->getValue();
+ return $this->compile($this->collection[$variable])['value'];
}
return "UNKNOWN VARIABLE {$variable}";
- }, $keyValue->getValue());
- $result = new KeyValue($keyValue->getKey(), $newValue);
- $this->cache[$result->getKey()] = $result;
+ }, $array['value']);
+ $result = [
+ 'key' => $array['key'],
+ 'value' => $newValue
+ ];
+ $this->cache[$result['key']] = $result;
return $result;
}
/**
- * @param KeyValue $keyValue
+ * @param array $array
* @return bool
*/
- protected function needToCompile(KeyValue $keyValue): bool
+ protected function needToCompile(array $array): bool
{
- return !!preg_match(self::REGEX_VARIABLE, $keyValue->getValue());
+ return !!preg_match(self::REGEX_VARIABLE, $array['value']);
}
} \ No newline at end of file
diff --git a/src/Compiler/CompilerInterface.php b/src/Compiler/CompilerInterface.php
index 15b6823..22daad7 100644
--- a/src/Compiler/CompilerInterface.php
+++ b/src/Compiler/CompilerInterface.php
@@ -8,8 +8,6 @@ declare(strict_types=1);
namespace NeonXP\Dotenv\Compiler;
-use NeonXP\Dotenv\Types\KeyValue;
-
/**
* Interface CompilerInterface
* @package NeonXP\Dotenv\Compiler
@@ -17,13 +15,13 @@ use NeonXP\Dotenv\Types\KeyValue;
interface CompilerInterface
{
/**
- * @param KeyValue[] $collection
+ * @param array[] $collection
*/
public function setRawCollection(array $collection): void;
/**
- * @param KeyValue $keyValue
- * @return KeyValue
+ * @param array $array
+ * @return array
*/
- public function compileKeyValue(KeyValue $keyValue): KeyValue;
+ public function compile(array $array): array;
} \ No newline at end of file