Compare commits
12 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
c975de0557 | ||
|
|
0c0ba39072 | ||
|
|
ef95576d74 | ||
|
|
e737e82d7e | ||
| 830a643a56 | |||
|
|
b24bbbc150 | ||
|
|
3ffb69342b | ||
| fa815a506e | |||
|
|
35a7bd4cf7 | ||
|
|
7970679894 | ||
| d22d26c9c8 | |||
|
|
934643214e |
@ -96,9 +96,9 @@ You can do so by using `define` and `slot`.
|
|||||||
```html
|
```html
|
||||||
{% arguments string $name, string $anchor, int $index = 0 %}
|
{% arguments string $name, string $anchor, int $index = 0 %}
|
||||||
|
|
||||||
{% define slot %}
|
{% define "attributes" %}
|
||||||
|
|
||||||
<a {% slot "attributes" %}href="{{ $anchor }}" tabindex="{{ $index }}"{% endslot %}>{{ $name }}"</a>
|
<a {% slot "attributes" %}{% endslot %} href="{{ $anchor }}" tabindex="{{ $index }}"{% endslot %}>{{ $name }}"</a>
|
||||||
```
|
```
|
||||||
|
|
||||||
**[HTML]** Would render the same as the `view` example :
|
**[HTML]** Would render the same as the `view` example :
|
||||||
|
|||||||
@ -21,7 +21,7 @@ class Builder
|
|||||||
|
|
||||||
$replace = [
|
$replace = [
|
||||||
'%NAMESPACE%' => $context->namespace,
|
'%NAMESPACE%' => $context->namespace,
|
||||||
'%USE%' => ( $uses = $context->renderUses() ) ? "use $uses;" : false,
|
'%USE%' => ( $uses = $context->renderUses() ) ? $uses : false,
|
||||||
'%CLASSNAME%' => $context->className,
|
'%CLASSNAME%' => $context->className,
|
||||||
'%PATHNAME%' => $path($context->viewPath),
|
'%PATHNAME%' => $path($context->viewPath),
|
||||||
'%FULLPATH%' => $path($context->filePath),
|
'%FULLPATH%' => $path($context->filePath),
|
||||||
|
|||||||
@ -57,7 +57,7 @@ abstract class Context {
|
|||||||
|
|
||||||
public function renderUses() : string
|
public function renderUses() : string
|
||||||
{
|
{
|
||||||
return implode(",", $this->useStack ?? []);
|
return implode(PHP_EOL, array_map(fn($use) => "use $use;", $this->useStack ?? []));
|
||||||
}
|
}
|
||||||
|
|
||||||
public function renderFunctions() : string
|
public function renderFunctions() : string
|
||||||
|
|||||||
@ -4,45 +4,43 @@ namespace Picea\ControlStructure;
|
|||||||
|
|
||||||
abstract class AbstractLoop implements ControlStructure {
|
abstract class AbstractLoop implements ControlStructure {
|
||||||
|
|
||||||
public function parse(\Picea\Compiler\Context &$context, ?string $arguments, string $token, array $options = []) : string
|
protected function openLoop(\Picea\Compiler\Context &$context, ?string $arguments, string $token,) : string
|
||||||
{
|
{
|
||||||
switch($token) {
|
$name = "$".uniqid("{$token}_");
|
||||||
case "while":
|
|
||||||
case "foreach":
|
|
||||||
$name = "$".uniqid("{$token}_");
|
|
||||||
|
|
||||||
$stack = array_filter($context->iterationStack ?? [], function($item) {
|
$stack = array_filter($context->iterationStack ?? [], function($item) {
|
||||||
return ! $item['or'];
|
return ! $item['or'];
|
||||||
});
|
});
|
||||||
|
|
||||||
$count = count($stack);
|
$count = count($stack);
|
||||||
|
|
||||||
if ( $count > 0 ) {
|
if ( $count > 0 ) {
|
||||||
$name .= "[" . end($stack)['uid'] . "]";
|
$name .= "[" . end($stack)['uid'] . "]";
|
||||||
}
|
|
||||||
|
|
||||||
$context->iterationStack[] = [
|
|
||||||
'or' => false,
|
|
||||||
'uid' => $name,
|
|
||||||
'token' => "end{$token}",
|
|
||||||
];
|
|
||||||
|
|
||||||
return "<?php $token ($arguments): $name = ( $name ?? 0 ) + 1; ?>";
|
|
||||||
|
|
||||||
case "endwhile":
|
|
||||||
case "endforeach":
|
|
||||||
$last = end($context->iterationStack);
|
|
||||||
|
|
||||||
if ( $last['or'] === false ) {
|
|
||||||
$output = "<?php $token; ?>";
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
$output = "<?php endif; if ( isset({$last['uid']}) ) unset({$last['uid']}); ?>";
|
|
||||||
}
|
|
||||||
|
|
||||||
array_pop($context->iterationStack);
|
|
||||||
|
|
||||||
return $output;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$context->iterationStack[] = [
|
||||||
|
'or' => false,
|
||||||
|
'uid' => $name,
|
||||||
|
'token' => "end{$token}",
|
||||||
|
];
|
||||||
|
|
||||||
|
return "<?php $token ($arguments): \$__loop_index = $name = ( $name ?? 0 ) + 1; ?>";
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function closeLoop(\Picea\Compiler\Context &$context, ?string $arguments, string $token,) : string
|
||||||
|
{
|
||||||
|
$last = end($context->iterationStack);
|
||||||
|
|
||||||
|
if ( $last['or'] === false ) {
|
||||||
|
$output = "<?php $token; ?>";
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
$output = "<?php endif; if ( isset({$last['uid']}) ) unset({$last['uid']}); ?>";
|
||||||
|
}
|
||||||
|
|
||||||
|
array_pop($context->iterationStack);
|
||||||
|
|
||||||
|
return $output;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -4,19 +4,25 @@ namespace Picea\ControlStructure;
|
|||||||
|
|
||||||
class BlockToken implements ControlStructure {
|
class BlockToken implements ControlStructure {
|
||||||
|
|
||||||
public array $token = [ "arguments", "block", "endblock", "define", "slot", "endslot", "using" ];
|
public array $token = [ "arguments", "block", "endblock", "/block", "define", "slot", "endslot", "/slot", "using" ];
|
||||||
|
|
||||||
public function parse(\Picea\Compiler\Context &$context, ?string $arguments, string $token, array $options = []) : string
|
public function parse(\Picea\Compiler\Context &$context, ?string $arguments, string $token, array $options = []) : string
|
||||||
{
|
{
|
||||||
|
static $depth = 0;
|
||||||
static $slotDefinitions = [];
|
static $slotDefinitions = [];
|
||||||
|
|
||||||
|
# dump($depth, $token, $arguments, $slotDefinitions);
|
||||||
|
|
||||||
switch($token) {
|
switch($token) {
|
||||||
case "block":
|
case "block":
|
||||||
$slotDefinitions[] = $this->slotDefinitions();
|
$slotDefinitions[] = $this->slotDefinitions();
|
||||||
|
$depth++;
|
||||||
|
|
||||||
return "<?php \$___block = \Picea\ControlStructure\BlockToken::instanciateBlock($arguments); ?>";
|
return "<?php \$___block = \Picea\ControlStructure\BlockToken::instanciateBlock($arguments); ?>";
|
||||||
|
|
||||||
|
case "/block":
|
||||||
case "endblock":
|
case "endblock":
|
||||||
|
$depth--;
|
||||||
return "<?php echo \$___block->render(\$___class__template); unset(\$___block); ?>";
|
return "<?php echo \$___block->render(\$___class__template); unset(\$___block); ?>";
|
||||||
|
|
||||||
case "arguments":
|
case "arguments":
|
||||||
@ -40,14 +46,14 @@ class BlockToken implements ControlStructure {
|
|||||||
case "define":
|
case "define":
|
||||||
list($name, $definition) = array_pad(explode(',', $arguments, 2), 2, "");
|
list($name, $definition) = array_pad(explode(',', $arguments, 2), 2, "");
|
||||||
|
|
||||||
end($slotDefinitions)->setDefinition(eval("return $name;"), $definition);
|
( $slotDefinitions[$depth] ?? end($slotDefinitions) )->setDefinition(eval("return $name;"), $definition);
|
||||||
|
|
||||||
return <<<PHP
|
return <<<PHP
|
||||||
<?php \$this->defineSlot($name, function($definition) {}); ?>
|
<?php \$this->defineSlot($name, function($definition) {}); ?>
|
||||||
PHP;
|
PHP;
|
||||||
|
|
||||||
case "slot":
|
case "slot":
|
||||||
$def = end($slotDefinitions);
|
$def = ( $slotDefinitions[$depth] ?? end($slotDefinitions) );
|
||||||
|
|
||||||
list($name, $definition) = array_pad(explode(',', $arguments, 2), 2, "");
|
list($name, $definition) = array_pad(explode(',', $arguments, 2), 2, "");
|
||||||
|
|
||||||
@ -65,7 +71,7 @@ class BlockToken implements ControlStructure {
|
|||||||
}
|
}
|
||||||
|
|
||||||
return <<<PHP
|
return <<<PHP
|
||||||
<?php \$this->printSlot($name, function($definition array \$___using = []) use (\$picea $loops) { extract(\$___using, \EXTR_SKIP); ?>
|
<?php \$this->printSlot($name, function($definition array \$___using = []) use (\$picea $loops) { extract(\$___using, \EXTR_SKIP); ?>
|
||||||
PHP;
|
PHP;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
@ -74,12 +80,13 @@ class BlockToken implements ControlStructure {
|
|||||||
}
|
}
|
||||||
|
|
||||||
return <<<PHP
|
return <<<PHP
|
||||||
<?php (\$___block ?? \$this)->slotIsSet($name) || \$___block->setSlot($name, function($definition array \$___using = []) use (\$picea $loops) { extract(\$___using, \EXTR_SKIP); ?>
|
<?php (\$___block ?? \$this)->slotIsSet($name) || (\$___block ?? \$this)->setSlot($name, function($definition array \$___using = []) use (\$picea $loops) { extract(\$___using, \EXTR_SKIP); ?>
|
||||||
PHP;
|
PHP;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
case "/slot":
|
||||||
case "endslot":
|
case "endslot":
|
||||||
$def =end($slotDefinitions);
|
$def = ( $slotDefinitions[$depth] ?? end($slotDefinitions) );
|
||||||
|
|
||||||
if ($def->hasDefinitions() ) {
|
if ($def->hasDefinitions() ) {
|
||||||
$definition = $def->getCurrentSlotDefinitionVars();
|
$definition = $def->getCurrentSlotDefinitionVars();
|
||||||
@ -89,7 +96,7 @@ class BlockToken implements ControlStructure {
|
|||||||
}
|
}
|
||||||
|
|
||||||
return <<<PHP
|
return <<<PHP
|
||||||
<?php })->call(\$this, $definition array_merge(get_defined_vars(), \$this->using)); ?>
|
<?php })->call(\$this, $definition array_merge(get_defined_vars(), \$this->using)); ?>
|
||||||
PHP;
|
PHP;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
@ -101,7 +108,6 @@ class BlockToken implements ControlStructure {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public function inlineHtml(? object $proxy, string $viewPath, ... $variables) {
|
public function inlineHtml(? object $proxy, string $viewPath, ... $variables) {
|
||||||
return $this->renderHtml($viewPath, [ 'inlineVariables' => $variables ], $proxy);
|
return $this->renderHtml($viewPath, [ 'inlineVariables' => $variables ], $proxy);
|
||||||
}
|
}
|
||||||
@ -184,7 +190,7 @@ class BlockToken implements ControlStructure {
|
|||||||
public function printDefinition(string $name) : string
|
public function printDefinition(string $name) : string
|
||||||
{
|
{
|
||||||
if ( ! isset($this->definitions[$name]) ) {
|
if ( ! isset($this->definitions[$name]) ) {
|
||||||
throw new \Exception("Slot definition for `$name` was not found. Have you defined it in your block header ?");
|
throw new \Exception("Slot definition for `$name` was not found. Have you defined it in your block header using something like '{% define \"$name\", ...\$arguments %}' ?");
|
||||||
}
|
}
|
||||||
|
|
||||||
return $this->definitions[$name];
|
return $this->definitions[$name];
|
||||||
@ -194,7 +200,6 @@ class BlockToken implements ControlStructure {
|
|||||||
{
|
{
|
||||||
$this->rendering = true;
|
$this->rendering = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -223,7 +228,11 @@ class BlockToken implements ControlStructure {
|
|||||||
{
|
{
|
||||||
$this->rendering = true;
|
$this->rendering = true;
|
||||||
|
|
||||||
return $classTemplate->picea->inlineBlock($this, $this->viewPath, ...$this->arguments);
|
if ($this->using['this'] ?? false) {
|
||||||
|
throw new \InvalidArgumentException("Block '{$this->viewPath}' cannot overwrite 'this' variable.");
|
||||||
|
}
|
||||||
|
|
||||||
|
return $classTemplate->picea->inlineBlock($thisProxy ?? $this, $this->viewPath, ...$this->arguments);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function setSlot(string $name, Callable $method) : void
|
public function setSlot(string $name, Callable $method) : void
|
||||||
|
|||||||
@ -4,7 +4,7 @@ namespace Picea\ControlStructure;
|
|||||||
|
|
||||||
class ForToken implements ControlStructure {
|
class ForToken implements ControlStructure {
|
||||||
|
|
||||||
public array $token = [ "for", "endfor" ];
|
public array $token = [ "for", "endfor", "/for" ];
|
||||||
|
|
||||||
public function parse(\Picea\Compiler\Context &$context, ?string $arguments, string $token, array $options = []) : string {
|
public function parse(\Picea\Compiler\Context &$context, ?string $arguments, string $token, array $options = []) : string {
|
||||||
switch($token) {
|
switch($token) {
|
||||||
@ -19,6 +19,7 @@ class ForToken implements ControlStructure {
|
|||||||
|
|
||||||
return "<?php for ($arguments): {$uid} = 1; ?>";
|
return "<?php for ($arguments): {$uid} = 1; ?>";
|
||||||
|
|
||||||
|
case "/for":
|
||||||
case "endfor":
|
case "endfor":
|
||||||
$last = end($context->iterationStack);
|
$last = end($context->iterationStack);
|
||||||
|
|
||||||
|
|||||||
@ -5,5 +5,17 @@ namespace Picea\ControlStructure;
|
|||||||
use DI\Definition\Source\AnnotationBasedAutowiring;
|
use DI\Definition\Source\AnnotationBasedAutowiring;
|
||||||
|
|
||||||
class ForeachToken extends AbstractLoop {
|
class ForeachToken extends AbstractLoop {
|
||||||
public array $token = [ "foreach", "endforeach" ];
|
public array $token = [ "foreach", "endforeach", "/foreach" ];
|
||||||
|
|
||||||
|
public function parse(\Picea\Compiler\Context &$context, ?string $arguments, string $token, array $options = []) : string
|
||||||
|
{
|
||||||
|
switch($token) {
|
||||||
|
case "foreach":
|
||||||
|
return $this->openLoop($context, $arguments, $token);
|
||||||
|
|
||||||
|
case "endforeach":
|
||||||
|
case "/foreach":
|
||||||
|
return $this->closeLoop($context, $arguments, $token);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -33,7 +33,9 @@ class FunctionToken implements ControlStructure {
|
|||||||
|
|
||||||
protected function printFunction($context, ?string $arguments) : string
|
protected function printFunction($context, ?string $arguments) : string
|
||||||
{
|
{
|
||||||
return "<?php function $arguments { ?>";
|
$name = trim(explode('(', $arguments, 2)[0]);
|
||||||
|
|
||||||
|
return "<?php if (! function_exists(__NAMESPACE__ . '\\$name')) { function $arguments { ?>";
|
||||||
}
|
}
|
||||||
|
|
||||||
protected function printReturn($context, ?string $arguments) : string
|
protected function printReturn($context, ?string $arguments) : string
|
||||||
@ -43,6 +45,6 @@ class FunctionToken implements ControlStructure {
|
|||||||
|
|
||||||
protected function printEndFunction($context) : string
|
protected function printEndFunction($context) : string
|
||||||
{
|
{
|
||||||
return "<?php } ?>";
|
return "<?php } } ?>";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -4,7 +4,7 @@ namespace Picea\ControlStructure;
|
|||||||
|
|
||||||
class IfToken implements ControlStructure {
|
class IfToken implements ControlStructure {
|
||||||
|
|
||||||
public array $token = [ "if", "else", "elseif", "endif" ];
|
public array $token = [ "if", "else", "elseif", "endif", "/if" ];
|
||||||
|
|
||||||
public function parse(\Picea\Compiler\Context &$context, ?string $arguments, string $token, array $options = []) : string {
|
public function parse(\Picea\Compiler\Context &$context, ?string $arguments, string $token, array $options = []) : string {
|
||||||
switch($token) {
|
switch($token) {
|
||||||
@ -17,6 +17,7 @@ class IfToken implements ControlStructure {
|
|||||||
case "elseif":
|
case "elseif":
|
||||||
return "<?php elseif ($arguments): ?>";
|
return "<?php elseif ($arguments): ?>";
|
||||||
|
|
||||||
|
case "/if":
|
||||||
case "endif":
|
case "endif":
|
||||||
return "<?php endif ?>";
|
return "<?php endif ?>";
|
||||||
}
|
}
|
||||||
|
|||||||
@ -11,7 +11,7 @@ enum PrintActionEnum : string {
|
|||||||
|
|
||||||
class SectionToken implements ControlStructure {
|
class SectionToken implements ControlStructure {
|
||||||
|
|
||||||
public array $token = [ "section", "endsection" ];
|
public array $token = [ "section", "endsection", "/section" ];
|
||||||
|
|
||||||
protected PrintActionEnum $action = PrintActionEnum::default;
|
protected PrintActionEnum $action = PrintActionEnum::default;
|
||||||
|
|
||||||
@ -29,6 +29,7 @@ class SectionToken implements ControlStructure {
|
|||||||
return $this->printSection($context, $arguments);
|
return $this->printSection($context, $arguments);
|
||||||
|
|
||||||
case "endsection":
|
case "endsection":
|
||||||
|
case "/endsection":
|
||||||
if ( empty($context->sections) ) {
|
if ( empty($context->sections) ) {
|
||||||
throw new \RuntimeException("A section closing tag {% endsection %} was found without an opening {% section %} tag");
|
throw new \RuntimeException("A section closing tag {% endsection %} was found without an opening {% section %} tag");
|
||||||
}
|
}
|
||||||
|
|||||||
@ -25,9 +25,11 @@ class SwitchToken implements ControlStructure {
|
|||||||
return ( $output ?? "" ) . "case $arguments: ?>";
|
return ( $output ?? "" ) . "case $arguments: ?>";
|
||||||
|
|
||||||
case "endcase":
|
case "endcase":
|
||||||
|
case "/case":
|
||||||
return "<?php break; ?>";
|
return "<?php break; ?>";
|
||||||
|
|
||||||
case "endswitch":
|
case "endswitch":
|
||||||
|
case "/switch":
|
||||||
return "<?php endswitch; ?>";
|
return "<?php endswitch; ?>";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
25
src/ControlStructure/TryCatchToken.php
Normal file
25
src/ControlStructure/TryCatchToken.php
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Picea\ControlStructure;
|
||||||
|
|
||||||
|
class TryCatchToken implements ControlStructure {
|
||||||
|
|
||||||
|
public array $token = [ "try", "catch", "finally", "endtry", "/try" ];
|
||||||
|
|
||||||
|
public function parse(\Picea\Compiler\Context &$context, ?string $arguments, string $token, array $options = []) : string {
|
||||||
|
switch($token) {
|
||||||
|
case "try":
|
||||||
|
return "<?php try { ?>";
|
||||||
|
|
||||||
|
case "catch":
|
||||||
|
return "<?php } catch($arguments) { ?>";
|
||||||
|
|
||||||
|
case "finally":
|
||||||
|
return "<?php } finally { ?>";
|
||||||
|
|
||||||
|
case "endtry":
|
||||||
|
case "/try":
|
||||||
|
return "<?php } ?>";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -3,7 +3,7 @@
|
|||||||
namespace Picea\ControlStructure;
|
namespace Picea\ControlStructure;
|
||||||
|
|
||||||
class WhileToken extends AbstractLoop {
|
class WhileToken extends AbstractLoop {
|
||||||
public array $token = [ "do", "while", "endwhile", ];
|
public array $token = [ "do", "while", "endwhile", "/while" ];
|
||||||
|
|
||||||
public function parse(\Picea\Compiler\Context &$context, ?string $arguments, string $token, array $options = []) : string {
|
public function parse(\Picea\Compiler\Context &$context, ?string $arguments, string $token, array $options = []) : string {
|
||||||
switch($token) {
|
switch($token) {
|
||||||
@ -23,10 +23,13 @@ class WhileToken extends AbstractLoop {
|
|||||||
return "<?php } while($arguments); ?>";
|
return "<?php } while($arguments); ?>";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return $this->openLoop($context, $arguments, $token);
|
||||||
|
|
||||||
|
case "endwhile":
|
||||||
|
case "/while":
|
||||||
|
return $this->closeLoop($context, $arguments, $token);
|
||||||
}
|
}
|
||||||
|
|
||||||
return parent::parse($context, $arguments, $token);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@ -30,8 +30,8 @@ PATTERN;
|
|||||||
|
|
||||||
public array $tokens = [ "url" , "route", "asset", "slug" ];
|
public array $tokens = [ "url" , "route", "asset", "slug" ];
|
||||||
|
|
||||||
#[\Deprecated]
|
##[\Deprecated]
|
||||||
protected bool $enforceExistingArguments = true;
|
public bool $enforceExistingArguments = true;
|
||||||
|
|
||||||
public function __construct(string $urlBase = "", string $assetToken = "", array $appUrl = [], bool $forceSSL = false) {
|
public function __construct(string $urlBase = "", string $assetToken = "", array $appUrl = [], bool $forceSSL = false) {
|
||||||
$this->urlBase = trim($urlBase, "/");
|
$this->urlBase = trim($urlBase, "/");
|
||||||
@ -120,7 +120,7 @@ PATTERN;
|
|||||||
|
|
||||||
public function buildRouteUrl(string $name, array $parameters = [], bool $appendVersion = false) : string
|
public function buildRouteUrl(string $name, array $parameters = [], bool $appendVersion = false) : string
|
||||||
{
|
{
|
||||||
if ( false !== ( $route = $this->routes[$name] ?? false ) ) {
|
if ( false !== $route = $this->findRoute($name) ) {
|
||||||
return $this->buildUrl($this->prepareRoute($route, $parameters), $parameters, $appendVersion);
|
return $this->buildUrl($this->prepareRoute($route, $parameters), $parameters, $appendVersion);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -149,14 +149,28 @@ PATTERN;
|
|||||||
|
|
||||||
public function registerRoute(string $name, string $route, string $class, string $method, array $routeMethods) : void
|
public function registerRoute(string $name, string $route, string $class, string $method, array $routeMethods) : void
|
||||||
{
|
{
|
||||||
$this->routes[$name] = [
|
$this->routes[] = $array = [
|
||||||
|
'name' => $name,
|
||||||
'route' => $route,
|
'route' => $route,
|
||||||
'routeMethods' => $routeMethods,
|
'routeMethods' => array_map('strtoupper', $routeMethods),
|
||||||
'class' => $class,
|
'class' => $class,
|
||||||
'classMethod' => $method,
|
'classMethod' => $method,
|
||||||
];
|
];
|
||||||
|
|
||||||
$this->eventExecute(UrlRegisterRouteEvent::class, $name, $this->routes[$name]);
|
$this->eventExecute(UrlRegisterRouteEvent::class, $name, $array);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function findRoute(string $name, string $method = "*") : false|array
|
||||||
|
{
|
||||||
|
foreach($this->routes as $route) {
|
||||||
|
if ( $route['name'] === $name ) {
|
||||||
|
if ($method === '*' || in_array(strtoupper($method), $route['routeMethods']) ) {
|
||||||
|
return $route;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -275,7 +289,7 @@ PATTERN;
|
|||||||
if ($default ?? false) {
|
if ($default ?? false) {
|
||||||
$value = $default;
|
$value = $default;
|
||||||
}
|
}
|
||||||
elseif ( strpos($route, "[{$matches[0][0]}]") !== false && $this->enforceExistingArguments) {
|
elseif ( $this->enforceExistingArguments && ! preg_match(sprintf("/\[\/?%s]/i", $item[0]), $route) ) {
|
||||||
throw new \RuntimeException(sprintf("Error while preparing route %s : could not match variable '%s' into given arguments ( %s ) from %s::%s", $route, $variable, json_encode($arguments), $routeParam['class'], $routeParam['classMethod']));
|
throw new \RuntimeException(sprintf("Error while preparing route %s : could not match variable '%s' into given arguments ( %s ) from %s::%s", $route, $variable, json_encode($arguments), $routeParam['class'], $routeParam['classMethod']));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -32,6 +32,7 @@ class DefaultRegistrations implements LanguageRegistration
|
|||||||
|
|
||||||
public function registerControlStructure(Compiler $compiler) : void
|
public function registerControlStructure(Compiler $compiler) : void
|
||||||
{
|
{
|
||||||
|
$compiler->registerControlStructure(new \Picea\ControlStructure\TryCatchToken());
|
||||||
$compiler->registerControlStructure(new \Picea\ControlStructure\NamespaceToken());
|
$compiler->registerControlStructure(new \Picea\ControlStructure\NamespaceToken());
|
||||||
$compiler->registerControlStructure(new \Picea\ControlStructure\UseToken());
|
$compiler->registerControlStructure(new \Picea\ControlStructure\UseToken());
|
||||||
$compiler->registerControlStructure(new \Picea\ControlStructure\IfToken());
|
$compiler->registerControlStructure(new \Picea\ControlStructure\IfToken());
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user